| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514 | 
							- // nova-werun/components/home/index.js
 
- const Parse = getApp().Parse;
 
- const company = getApp().globalData.company;
 
- Component({
 
-     /**
 
-      * 组件的属性列表
 
-      */
 
-     properties: {
 
-     },
 
-     /**
 
-      * 组件的初始数据
 
-      */
 
-     data: {
 
-         //屏幕高度
 
-         statusBarHeight: 0, // 状态栏高度
 
-         screenHeight: 0, // 屏幕高度
 
-         customHeight: 0, // 自定义导航栏高度(如小程序右上角胶囊按钮)
 
-         bottomNavHeight: 0, // 底部导航栏高度
 
-         contentHeight: 0, // 可用内容高度
 
-         contentpadding: 0, //顶部padding高度
 
-         navheight: 0,
 
-         percentage: 0,
 
-         //选择
 
-         rows: [{
 
-                 image: 'https://file-cloud.fmode.cn/qpFbRRSZrO/20241225/r5j1uc041211788.png',
 
-                 text: '签到打卡',
 
-                 url: '../../pages/home/signin/index'
 
-             },
 
-             {
 
-                 image: 'https://file-cloud.fmode.cn/qpFbRRSZrO/20241225/n1pin1040819673.png',
 
-                 text: '实时步行',
 
-                 url: '../../pages/home/sport/sport-home/index',
 
-             },
 
-             {
 
-                 image: 'https://file-cloud.fmode.cn/qpFbRRSZrO/20241225/9vfr1l040831635.png',
 
-                 text: '转发分享',
 
-                 url: '../../pages/home/share/index'
 
-             },
 
-             {
 
-                 image: 'https://file-cloud.fmode.cn/qpFbRRSZrO/20241225/it1rna040843179.png',
 
-                 text: '我的勋章',
 
-                 url: '../../pages/home/medal/index'
 
-             },
 
-             {
 
-                 image: 'https://file-cloud.fmode.cn/qpFbRRSZrO/20241225/r5193r040853498.png',
 
-                 text: '我的统计',
 
-                 url: '../../pages/home/statistics/index'
 
-             },
 
-             // {
 
-             //     image: 'https://file-cloud.fmode.cn/qpFbRRSZrO/20241102/v6p4fm041343296.png?imageView2/1/w/200/h/200',
 
-             //     text: '排行榜',
 
-             //     url: '../../pages/home/ranking/index'
 
-             // },
 
-             // {
 
-             //     image: 'https://file-cloud.fmode.cn/qpFbRRSZrO/20241102/71svpg041343669.png?imageView2/1/w/200/h/200',
 
-             //     text: '跑步',
 
-             //     url: '../../pages/home/sport/sport-home/index',
 
-             //     active: 1
 
-             // },
 
-             // {
 
-             //     image: 'https://file-cloud.fmode.cn/qpFbRRSZrO/20241104/k1q4no034958681.png?imageView2/1/w/200/h/200',
 
-             //     text: '积分',
 
-             //     url: '../../pages/home/integral/index'
 
-             // },
 
-         ],
 
-         target: 0,
 
-         sharList: [],
 
-         address: "",
 
-         //排行榜
 
-         todayList: [],
 
-         changetitle: 'today',
 
-         //正序
 
-         rank: 'up'
 
-     },
 
-     lifetimes: {
 
-         detached: function () {
 
-             // 在组件实例被从页面节点树移除时执行
 
-         },
 
-         attached: async function () {
 
-             // 在组件实例进入页面节点树时执行
 
-             // 计算
 
-             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 - bottomNavHeight - 50 - statusBarHeight - customHeight) * 750 / systemInfo.windowWidth;
 
-             const navheight = (statusBarHeight + customHeight) * 750 / systemInfo.windowWidth;
 
-             this.setData({
 
-                 statusBarHeight,
 
-                 screenHeight: (screenHeight - 50 - bottomNavHeight) * 750 / systemInfo.windowWidth,
 
-                 customHeight,
 
-                 bottomNavHeight,
 
-                 contentHeight,
 
-                 contentpadding,
 
-                 navheight,
 
-             });
 
-             console.log('123', contentpadding);
 
-             this.getWeRunData()
 
-             this.gettarget()
 
-             // this.order()
 
-             this.Getlocation()
 
-             this.gettoday()
 
-         },
 
-     },
 
-     /**
 
-      * 组件的方法列表
 
-      */
 
-     methods: {
 
-         //跳转
 
-         gourl(e) {
 
-             const url = e.currentTarget.dataset.url
 
-             const active = e.currentTarget.dataset.active
 
-             if (active) {
 
-                 wx.navigateTo({
 
-                     url: `${url}?id=` + active // 目标页面的路径
 
-                 });
 
-                 console.log(active);
 
-             } else {
 
-                 wx.navigateTo({
 
-                     url: `${url}` // 目标页面的路径
 
-                 });
 
-             }
 
-         },
 
-         //获取目标步数
 
-         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);
 
-             } else {
 
-                 const currentUser2 = Parse.User.current();
 
-                 let userquery2 = new Parse.Query('_User');
 
-                 userquery2.equalTo('company', company);
 
-                 userquery2.equalTo('objectId', currentUser2.id);
 
-                 userquery2.notEqualTo('isDeleted', true)
 
-                 let user2 = await userquery2.first();
 
-                 user2.set('num', 5000)
 
-                 try {
 
-                     let saveDate2 = await user2.save();
 
-                     console.log(saveDate2);
 
-                     this.setData({
 
-                         target: 5000
 
-                     })
 
-                     console.log("目标步数更改成功");
 
-                 } catch (error) {
 
-                     console.error("保存数据时出现错误:", error);
 
-                 }
 
-             }
 
-         },
 
-         //获取当天运动数据
 
-         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); // 今天的结束时间
 
-             // 在查询条件中添加对 createdAt 的限制
 
-             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);
 
-         },
 
-         //获取当前位置信息
 
-         Getlocation() {
 
-             // 获取当前位置信息
 
-             wx.getLocation({
 
-                 type: 'wgs84',
 
-                 success: (res) => {
 
-                     const {
 
-                         latitude,
 
-                         longitude
 
-                     } = res;
 
-                     //调用api解析地址
 
-                     wx.request({
 
-                         url: 'https://api.map.baidu.com/reverse_geocoding/v3/?ak=sHZTomd7grslfP7sPKB8tRgT49FK9TEu&output=json&coordtype=gcj02&location=' + latitude + ',' + longitude,
 
-                         data: {},
 
-                         header: {
 
-                             'Content-Type': 'application/json'
 
-                         },
 
-                         success: (ops) => { // 使用箭头函数
 
-                             console.log(ops);
 
-                             // const address = ops.data.result.formatted_address;//详细地址
 
-                             const address = ops.data.result.addressComponent.city; //市
 
-                             this.setData({
 
-                                 address: address,
 
-                             });
 
-                             console.log(this.data.address);
 
-                         },
 
-                         fail: function (resq) {
 
-                             wx.showModal({
 
-                                 title: '信息提示',
 
-                                 content: '请求失败',
 
-                                 showCancel: false,
 
-                                 confirmColor: '#f37938'
 
-                             });
 
-                         },
 
-                         complete: function () {}
 
-                     })
 
-                 },
 
-                 fail: (err) => {
 
-                     console.error(err);
 
-                     wx.showToast({
 
-                         title: '获取位置失败',
 
-                         icon: 'none'
 
-                     });
 
-                 }
 
-             });
 
-         },
 
-         //获取微信步数
 
-         getWeRunData() {
 
-             wx.getWeRunData({
 
-                 success: (res) => {
 
-                     // 获取到的加密数据
 
-                     const encryptedData = res.encryptedData;
 
-                     const iv = res.iv;
 
-                     console.log('encryptedData', encryptedData);
 
-                     console.log('iv', iv);
 
-                     const userInfo = wx.getStorageSync('userInfo');
 
-                     const session_key = userInfo.session_key
 
-                     console.log('session_key', session_key);
 
-                     // 这里需要调用你的后端接口进行解密
 
-                     // 假设你有一个解密函数 decryptData
 
-                     this.decryptData(encryptedData, iv, session_key).then(steps => {
 
-                         this.setData({
 
-                             steps: steps
 
-                         });
 
-                         console.log('用户步数:', this.data.steps);
 
-                         this.updatetoday(steps)
 
-                     }).catch(err => {
 
-                         console.error('解密失败:', err);
 
-                     });   
 
-                 },
 
-                 fail: (err) => {
 
-                     console.error('获取运动数据失败:', err);
 
-                 }
 
-             });
 
-         },
 
-         //  解密
 
-         decryptData(encryptedData, iv, session_key) {
 
-             return new Promise((resolve, reject) => {
 
-                 // 发送请求到后端进行解密
 
-                 wx.request({
 
-                     url: 'https://server.fmode.cn/api/wxapp/decrypt_phone', // 替换为你的后端解密接口
 
-                     method: 'get',
 
-                     data: {
 
-                         encryptedData: encryptedData,
 
-                         iv: iv,
 
-                         appId: 'wxe6ecc0193c09696c',
 
-                         sessionKey: session_key
 
-                     },
 
-                     success: (res) => {
 
-                         // if (res.data && res.data.steps) {
 
-                         //     console.log(res.data.steps);
 
-                         //     // resolve(res.data.steps); // 返回步数
 
-                         //     // const steps = 123456
 
-                         //     resolve(steps);
 
-                         // } else {
 
-                         //     reject('解密返回数据格式错误');
 
-                         // }
 
-                         if (res.data.data) {
 
-                             const stepInfoList = res.data.data.stepInfoList
 
-                             console.log(stepInfoList);
 
-                             const todaylist = stepInfoList.filter(item => {
 
-                                 console.log(this.isToday(item));
 
-                                 return this.isToday(item); // 使用 isToday 函数判断是否是今天
 
-                             });
 
-                             const steps = todaylist[0].step;
 
-                             resolve(steps);
 
-                             console.log('今日步数', steps);
 
-                         } else {
 
-                             reject('解密返回数据格式错误');
 
-                         }
 
-                     },
 
-                     fail: (err) => {
 
-                         reject(err);
 
-                     }
 
-                 });
 
-             });
 
-         },
 
-         // 判断日期是否是今天
 
-         isToday(item) {
 
-             const today = new Date();
 
-             const date = new Date(item.timestamp * 1000); // 假设时间戳是以秒为单位
 
-             // 比较年、月、日
 
-             return date.getFullYear() === today.getFullYear() &&
 
-                 date.getMonth() === today.getMonth() &&
 
-                 date.getDate() === today.getDate();
 
-         },
 
-         //更新今日步数
 
-         async updatetoday(steps) {
 
-             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); // 今天的结束时间
 
-             // 在查询条件中添加对 createdAt 的限制
 
-             ActivityDataquery.greaterThanOrEqualTo('createdAt', todayStart);
 
-             ActivityDataquery.lessThanOrEqualTo('createdAt', todayEnd);
 
-             let r = await ActivityDataquery.first();
 
-             if (r) {
 
-                 r.set('steps', steps)
 
-                 try {
 
-                     let saveDate = await r.save();
 
-                     this.order()
 
-                     this.gettoday()
 
-                     console.log("步数修改成功");
 
-                 } catch (error) {
 
-                     console.error("保存数据时出现错误:", error);
 
-                 }
 
-             } else {
 
-                 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.first();
 
-                 let companyPointer = Parse.Object.extend('Company').createWithoutData(company);
 
-                 let Comment = new Parse.Object('ActivityData');
 
-                 Comment.set('company', companyPointer);
 
-                 Comment.set('type', 'today');
 
-                 Comment.set('user', user.toPointer());
 
-                 Comment.set('steps', steps);
 
-                 try {
 
-                     let saveDate2 = await Comment.save();
 
-                     this.order()
 
-                     this.gettoday()
 
-                     // console.log(saveDate2);
 
-                     console.log("步数保存成功");
 
-                 } catch (error) {
 
-                     console.error("保存数据时出现错误:", error);
 
-                 }
 
-             }
 
-         },
 
-         //切换
 
-         change() {
 
-             // 使用数组来简化切换逻辑
 
-             const titles = ['today', 'weekdday', 'month'];
 
-             const currentIndex = titles.indexOf(this.data.changetitle); //获取index
 
-             const nextIndex = (currentIndex + 1) % titles.length; // 循环切换
 
-             this.setData({
 
-                 changetitle: titles[nextIndex]
 
-             });
 
-             if (this.data.changetitle == 'today') {
 
-                 this.setData({
 
-                     rank: 'up'
 
-                 })
 
-                 this.gettoday()
 
-             }
 
-             if (this.data.changetitle == 'weekdday') {
 
-                 this.setData({
 
-                     rank: 'up'
 
-                 })
 
-                 console.log('weekdday');
 
-             }
 
-             if (this.data.changetitle == 'month') {
 
-                 this.setData({
 
-                     rank: 'up'
 
-                 })
 
-                 console.log('month');
 
-             }
 
-         },
 
-         // 获取本日排行
 
-         async gettoday() {
 
-             const currentUser = Parse.User.current();
 
-             let ActivityDataquery = new Parse.Query('ActivityData');
 
-             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); // 今天的结束时间
 
-             console.log(todayStart, todayEnd);
 
-             // 在查询条件中添加对 createdAt 的限制
 
-             ActivityDataquery.greaterThanOrEqualTo('createdAt', todayStart);
 
-             ActivityDataquery.lessThanOrEqualTo('createdAt', todayEnd);
 
-             // 根据 steps 字段进行降序排序
 
-             ActivityDataquery.descending('steps');
 
-             ActivityDataquery.include('user');
 
-             try {
 
-                 let P = await ActivityDataquery.find();
 
-                 let todayList = P.map(item => item.toJSON());
 
-                 // // 初始化 myList
 
-                 // let myList = [];
 
-                 // // 找到当前用户的数据并计算排名
 
-                 // todayList.forEach((item, index) => {
 
-                 //     if (item.user.objectId === currentUser.id) {
 
-                 //         myList.push({
 
-                 //             ...item, // 包含用户数据
 
-                 //             rank: index + 1 // 计算排名(index 从 0 开始,所以加 1)
 
-                 //         });
 
-                 //     }
 
-                 // });
 
-                 // 更新页面数据
 
-                 this.setData({
 
-                     todayList,
 
-                 });
 
-                 console.log(this.data.todayList);
 
-             } catch (error) {
 
-                 console.error('Error fetching today\'s data:', error);
 
-             }
 
-         },
 
-         //正序逆序
 
-         changeup() {
 
-             if (this.data.rank == 'up') {
 
-                 this.setData({
 
-                     rank: 'down'
 
-                 })
 
-                 if (this.data.changetitle == 'today') {
 
-                     this.setData({
 
-                         todayList: this.data.todayList.reverse(),
 
-                     })
 
-                     console.log('逆序');
 
-                 }
 
-                 if (this.data.changetitle == 'weekdday') {
 
-                     console.log('weekdday逆序');
 
-                 }
 
-                 if (this.data.changetitle == 'month') {
 
-                     console.log('month逆序');
 
-                 }
 
-             } else {
 
-                 this.setData({
 
-                     rank: 'up'
 
-                 })
 
-                 if (this.data.changetitle == 'today') {
 
-                     this.setData({
 
-                         todayList: this.data.todayList.reverse(),
 
-                     })
 
-                     console.log('顺序');
 
-                 }
 
-                 if (this.data.changetitle == 'weekdday') {
 
-                     console.log('weekdday顺序');
 
-                 }
 
-                 if (this.data.changetitle == 'month') {
 
-                     console.log('month顺序');
 
-                 }
 
-             }
 
-         },
 
-         //修改进度条
 
-         getBackgroundColor() {
 
-             const steps = this.data.sharList[0].steps || 0;
 
-             let percentage = (steps / this.data.target) * 100;
 
-             if (percentage > 100) {
 
-                 percentage = 100;
 
-             }
 
-             this.setData({
 
-                 percentage: `conic-gradient(from 0deg, #015EEA ${percentage}%, white 0%)`,
 
-             })
 
-             console.log('百分比', this.data.percentage);
 
-         },
 
-     }
 
- })
 
 
  |