123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404 |
- import * as echarts from "../../../components/ec-canvas/echarts.min"
- const Parse = getApp().Parse;
- const company = getApp().globalData.company;
- 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: null
- },
- resultList: [],
- stepsData: [],
- xAxis: [],
- percentage: '',
- percent: '',
- },
-
- onLoad: async 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
- });
- await this.gettarget()
- await this.order()
- this.allorder()
- await this.getweekday()
- this.echartsComponnet = this.selectComponent('#mychart')
- await this.initChart()
- },
-
- initChart() {
- if (this.chart) {
- this.chart.clear();
- }
- this.echartsComponnet.init((canvas, width, height, dpr) => {
-
- this.chart = echarts.init(canvas, null, {
- width: width,
- height: height,
- devicePixelRatio: dpr
- });
- this.chart.setOption(this.getOption())
- return this.chart;
- });
- },
- getOption() {
- var option = {
- xAxis: {
- type: 'category',
- data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日'],
- axisLabel: {
- formatter: (value, index) => this.formatter(value, index)
- }
- },
- yAxis: {
- type: 'value',
- max: 20000,
- axisLabel: {
- formatter: function (value) {
- if (value >= 10000) {
- return (value / 1000) + 'k';
- }
- return value;
- }
- }
- },
- series: [{
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- data: this.data.stepsData,
- type: 'bar',
- barWidth: '10',
- itemStyle: {
- borderRadius: 15,
- }
- }],
- };
- return option;
- },
-
- formatter(value, index) {
- let daylist = this.data.resultList.map(item => {
- const day = new Date(item.createdAt);
- const dayOfMonth = day.getDate();
- return dayOfMonth
- })
- daylist.reverse()
- const dayindex = daylist.length-1
- if (daylist.length < 7) {
- for (let i = daylist.length; i < 7; i++) {
- const lastDay = daylist[daylist.length - 1];
- daylist.push(lastDay + (i - daylist.length + 1));
- }
- }
- const dates = daylist.map(item=>{
- return `${item}号`
- })
- console.log('dates',dates);
- return index === dayindex ? '今天' : value + '\n' + '\n' + dates[index];
- },
-
- onReady: function () {
- },
-
- onShow: function () {
- },
-
- onHide: function () {
- },
-
- onUnload: function () {
- },
-
- onPullDownRefresh: function () {
- },
-
- onReachBottom: function () {
- },
-
- onShareAppMessage: function () {
- },
-
- onChange(event) {
- this.setData({
- active: event.detail
- });
- this.echartsComponnet = this.selectComponent('#mychart')
- this.initChart()
- },
-
- 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
- });
- 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;
- console.log('目标', percent);
- if (percent > 100) {
- percent = 100;
- }
-
- percent = parseFloat(percent.toFixed(2));
- this.setData({
- percent,
- percentage: `conic-gradient(from 0deg, #015EEA ${percent}%, white 0%)`,
- })
- console.log('百分比', this.data.percentage);
- },
-
- async getweekday() {
- 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(b.createdAt) - new Date(a.createdAt));
-
- const today = new Date();
- const dayOfWeek = today.getDay();
-
- let numItemsToTake;
- if (dayOfWeek === 0) {
- numItemsToTake = 7;
- } else {
- numItemsToTake = dayOfWeek;
- }
-
- const resultList = allList.slice(0, numItemsToTake);
- const stepsData = resultList.map((item, index) => {
- if (index === 0) {
-
- return {
- value: item.steps,
- itemStyle: {
- color: '#a90000',
- }
- };
- } else {
-
- return item.steps;
- }
- });
- this.setData({
- resultList,
- stepsData
- })
- console.log('resultList', resultList);
- },
- })
|