123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310 |
- import * as echarts from "../../../components/ec-canvas/echarts.min"
- const Parse = getApp().Parse;
- const company = getApp().globalData.company;
- function initChart(canvas, width, height, dpr) {
- const chart = echarts.init(canvas, null, {
- width: width,
- height: height,
- devicePixelRatio: dpr
- });
- canvas.setChart(chart);
- var option = {
- xAxis: {
- type: 'category',
- data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日'],
- axisLabel: {
- formatter: function(value, index) {
- const dates = ['1号', '2号', '3号', '4号', '5号', '6号', '7号'];
- return index === 1 ? '今天' : value + '\n'+'\n' + dates[index];
- }
- }
- },
- yAxis: {
- type: 'value',
- max: 20000,
- axisLabel: {
- formatter: function(value) {
- if (value >= 10000) {
- return (value / 10000) + 'k';
- }
- return value;
- }
- }
- },
- series: [
- {
- data: [
- 12000,
- {
- value: 12000,
- itemStyle: {
- color: '#a90000',
- }
- },
- 12000,
- 12000,
- 12000,
- 12000,
- 12000
- ],
- type: 'bar',
- barWidth:'10',
- itemStyle: {
- borderRadius:15,
- }
- }
- ],
- };
- chart.setOption(option);
- return chart;
- }
- Page({
-
- data: {
-
- statusBarHeight: 0,
- screenHeight: 0,
- customHeight: 0,
- bottomNavHeight: 0,
- contentHeight: 0,
- contentHeight2: 0,
- contentpadding: 0,
- active: 0,
-
- day: '7',
- target: '',
- sharList: [],
-
- stardate: '',
- daysDifference: "",
- totalSteps: 0,
- totalDistance: 0,
- totalBurnCalories: 0,
- totalsportDate: 0,
- ec: {
- onInit: initChart
- },
- percentage:'',
- percent:'',
- },
-
- onLoad: function (options) {
-
- const systemInfo = wx.getSystemInfoSync();
- const statusBarHeight = systemInfo.statusBarHeight || 0;
- const screenHeight = systemInfo.screenHeight || 0;
- const custom = wx.getMenuButtonBoundingClientRect();
- const customHeight = custom.height + 10 + 2 || 0;
- const bottomNavHeight = systemInfo.screenHeight - systemInfo.safeArea.bottom || 0;
- const contentpadding = (statusBarHeight + customHeight) * 750 / systemInfo.windowWidth;
- const contentHeight = (screenHeight - 50 - bottomNavHeight - statusBarHeight - customHeight) * 750 / systemInfo.windowWidth;
- this.setData({
- statusBarHeight,
- screenHeight,
- customHeight,
- bottomNavHeight,
- contentpadding,
- contentHeight
- });
- this.gettarget()
- this.order()
- this.allorder()
- },
-
- onReady: function () {
- },
-
- onShow: function () {
- },
-
- onHide: function () {
- },
-
- onUnload: function () {
- },
-
- onPullDownRefresh: function () {
- },
-
- onReachBottom: function () {
- },
-
- onShareAppMessage: function () {
- },
- onChange(event) {
- this.setData({
- active: event.detail
- });
- },
- changeday() {
- if (this.data.day == '7') {
- this.setData({
- day: '30'
- })
- } else {
- this.setData({
- day: '7'
- })
- }
- },
- async gettarget() {
- const currentUser = Parse.User.current();
- let userquery = new Parse.Query('_User');
- userquery.equalTo('company', company);
- userquery.equalTo('objectId', currentUser.id);
- userquery.notEqualTo('isDeleted', true)
- let user = await userquery.find();
- let num = user.map(item => item.toJSON());
- if (num[0].num) {
- this.setData({
- target: num[0].num
- })
- console.log('当前步数', this.data.target);
- }
- },
-
- async order() {
- const currentUser = Parse.User.current();
- let ActivityDataquery = new Parse.Query('ActivityData');
- ActivityDataquery.equalTo('user', currentUser.id);
- ActivityDataquery.equalTo('company', company);
- ActivityDataquery.equalTo('type', 'today');
- ActivityDataquery.notEqualTo('isDeleted', true);
-
- const today = new Date();
- const todayStart = new Date(today.getFullYear(), today.getMonth(), today.getDate());
- const todayEnd = new Date(todayStart);
- todayEnd.setHours(23, 59, 59, 999);
-
- ActivityDataquery.greaterThanOrEqualTo('createdAt', todayStart);
- ActivityDataquery.lessThanOrEqualTo('createdAt', todayEnd);
- ActivityDataquery.include('user');
- let r = await ActivityDataquery.find();
- let sharList = r.map(item => item.toJSON());
- this.setData({
- sharList
- });
- await this.getBackgroundColor()
- console.log(this.data.sharList);
- },
-
- async allorder() {
- const currentUser = Parse.User.current();
- let ActivityDataquery = new Parse.Query('ActivityData');
- ActivityDataquery.equalTo('user', currentUser.id);
- ActivityDataquery.equalTo('company', company);
- ActivityDataquery.equalTo('type', 'today');
- ActivityDataquery.notEqualTo('isDeleted', true);
- let r = await ActivityDataquery.find();
- let allList = r.map(item => item.toJSON());
-
- allList.sort((a, b) => new Date(a.createdAt) - new Date(b.createdAt));
-
- const earliestDate = new Date(allList[0].createdAt);
-
- const formattedDate = `${earliestDate.getFullYear()}年${String(earliestDate.getMonth() + 1).padStart(2, '0')}月${String(earliestDate.getDate()).padStart(2, '0')}日`;
-
- const today = new Date();
-
- earliestDate.setHours(0, 0, 0, 0);
- today.setHours(0, 0, 0, 0);
-
- const timeDifference = today - earliestDate;
- const daysDifference = Math.floor(timeDifference / (1000 * 60 * 60 * 24));
-
- let totalSteps = 0;
- let totalDistance = 0;
- let totalBurnCalories = 0;
- let totalsportDate = 0;
- allList.forEach(item => {
- totalSteps += Number(item.steps) || 0;
- totalDistance += Number(item.distance) || 0;
- totalBurnCalories += Number(item.burnCalories) || 0;
- totalsportDate += Number(item.sportDate) || 0;
- });
-
- const days = Math.floor(totalsportDate / (60 * 24));
- const hours = Math.floor((totalsportDate % (60 * 24)) / 60);
- const minutes = totalsportDate % 60;
-
- this.setData({
- stardate: formattedDate,
- daysDifference: daysDifference,
- totalSteps,
- totalDistance,
- totalBurnCalories,
- totalsportDate: `${days}天 ${hours}小时 ${minutes}分钟`
- });
- console.log(allList, this.data.totalsportDate);
- },
- getBackgroundColor() {
- const steps = this.data.sharList[0].steps || 0;
- let percent = (steps / this.data.target) * 100;
- if (percent > 100) {
- percent = 100;
- }
- this.setData({
- percent,
- percentage:`conic-gradient(from 0deg, #015EEA ${percent}%, white 0%)`,
- })
- console.log('百分比',this.data.percentage);
- }
- })
|