// 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', steps:0, //正序 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, }); 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.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()); let steps = 0 sharList.forEach((item)=>{ if(item.steps){ steps = steps+item.steps } }) this.setData({ steps, }) this.getBackgroundColor() console.log('sharList',steps); }, //获取当前位置信息 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' }); } }); }, // 判断日期是否是今天 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(); }, //切换 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.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.include('user'); try { let P = await ActivityDataquery.find(); let todayList = P.map(item => item.toJSON()); // 创建一个对象来存储用户的总步数 const userStepsMap = {}; // 遍历数据,累加相同用户的步数 todayList.forEach(item => { const userId = item.user.objectId; const steps = item.steps; if (steps) { if (!userStepsMap[userId]) { userStepsMap[userId] = { ...item.user, // 包含用户信息 totalSteps: 0 // 初始化总步数 }; } userStepsMap[userId].totalSteps += steps; // 累加步数 } }); // 将对象转换为数组 const aggregatedList = Object.values(userStepsMap); // 按总步数降序排序 aggregatedList.sort((a, b) => b.totalSteps - a.totalSteps); // 添加排名 let currentRank = 1; // 当前排名 for (let i = 0; i < aggregatedList.length; i++) { if (i > 0 && aggregatedList[i].totalSteps === aggregatedList[i - 1].totalSteps) { // 如果步数相同,排名相同 aggregatedList[i].rank = aggregatedList[i - 1].rank; } else { // 否则,更新当前排名 aggregatedList[i].rank = currentRank; } currentRank++; } // 更新页面数据 this.setData({ todayList: aggregatedList, }); 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() { let percentage = (this.data.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); }, } })