// pages/experience/activityinfo/activityinfo.js var app = getApp(); var util = require("../../../utils/util.js"); Page({ data: { appAssetsUrl: app.appAssetsUrl, appAssetsUrl2: app.appAssetsUrl2, nodata: util.nodata(), timeList: [ { code: "", name: "时间排序", }, { code: 1, name: "最近三天", }, { code: 2, name: "最近七天", }, { code: 3, name: "最近一个月", }, ], timeListIndex: 0, statusList: [], statusListIndex: 0, noBgImg: "", params: { page: 1, limit: 10, }, total: { currPage: 0, totalPage: 0, }, noMore: false, cityListPickerData: [], cityListIndex: [0, 0], listData: [], statusBarHeight: 0, titleHeight: 0, conTop: 0, nameList: [{ itemname: "全部" }], nameListEle: [], nameIndex: 0, shaiHeight: 0, jwidth: 0, staHeight: 0, }, onLoad: function (options) { this.loadCity(); this.getNameList(); let button = wx.getMenuButtonBoundingClientRect(); let _this = this; wx.getSystemInfo({ success: function (res) { _this.setData({ scrollHeight: res.windowHeight, jwidth: button.width + 20 + "px", }); }, }); this.height(); let index = getApp().params.pePageToIndex; let nameIndex = this.data.nameIndex; console.log(nameIndex, "nameIndex"); this.setData({ nameIndex: 0, }); if (this.data.nameList.length == 1) { this.getLabelList(0); } else { this.scroll(0); } this.loadList(true); console.log("res", button); }, onShow() { // let index = getApp().params.pePageToIndex; // let nameIndex = this.data.nameIndex; // console.log(nameIndex,'nameIndex') // this.setData({ // nameIndex:0 // }) // if(this.data.nameList.length==1){ // this.getLabelList(0) // }else{ // this.scroll(0) // } }, nameHandler(e) { let nameIndex = e.currentTarget.dataset.index; getApp().params.pePageToIndex = nameIndex; this.setData({ nameIndex, }); console.log(e); this.scroll(nameIndex); this.loadList(true); }, getLabelList(index) { let that = this; app._post_form( "bizcatelog/apiSelectBizcatelog/act_title", "", null, function (res) { console.log(res, 1112222); if (res.code == 0) { that.setData({ nameList: [{ itemname: "全部" }, ...res.dictList], }); wx.nextTick(() => { let query = wx.createSelectorQuery(); query .selectAll(".nameitem") .boundingClientRect() .exec(function (res) { let nameListEle = []; for (let i in res[0]) { nameListEle.push(res[0][i].width * 1); } that.setData({ nameListEle, }); }); setTimeout(() => { that.scroll(index); }, 500); }); } } ); }, scroll(index) { let that = this; let leftNum = 0; if (index > 0) { for (let i in that.data.nameListEle) { if (i < index) { leftNum += that.data.nameListEle[i]; leftNum += (20 / 750) * wx.getSystemInfoSync().windowWidth; } } } that.setData({ navScrollWidth: leftNum, }); }, // 自定义高度处理 height() { let that = this; const { platform, statusBarHeight } = wx.getSystemInfoSync(); let height = statusBarHeight + 4; //ios 24px let mH = statusBarHeight + 4; if (platform.toLowerCase() == "android") { height += 4; //android 28px mH += 4; } height = height + 38; // 胶囊高度 32px 下边框6px height 状态栏高度 const ButtonBounding = wx.getMenuButtonBoundingClientRect(); wx.getSystemInfo({ success: (res) => { let navHeight = ButtonBounding.height + res.statusBarHeight + (ButtonBounding.top - res.statusBarHeight) * 2; that.setData({ statusBarHeight: ButtonBounding.height + res.statusBarHeight + (ButtonBounding.top - res.statusBarHeight) * 2 + "px", titleHeight: res.statusBarHeight + "px", conTop: 50 + 48 + "px", shaiHeight: navHeight + 48 + "px", staHeight: res.statusBarHeight, }); }, }); // let res = uni.getSystemInfoSync() // return ButtonBounding.height + (ButtonBounding.top - res.statusBarHeight) * 2 }, activeDetail: function (e) { if (e.currentTarget.dataset.id) { wx.navigateTo({ url: "/pages/home/index/activityDetail/activityDetail?id=" + e.currentTarget.dataset.id, }); } }, getNameList(index) { let that = this; app._post_form("home/activityStatus", "", null, function (res) { if (res.code == 0) { that.setData({ statusList: [{ itemname: "活动状态", itemcode: "" }, ...res.data], }); } }); }, // 活动 loadList(isRefresh) { let that = this; if (!isRefresh && this.data.noMore) { wx.showToast({ title: "没有更多了~", icon: "none", }); return false; } console.log(this.data.cityListPickerData); this.setData({ listData: isRefresh ? [] : this.data.listData, params: { ...this.data.params, page: isRefresh ? 1 : this.data.params.page + 1, city: this.data.cityListPickerData[0][this.data.cityListIndex[0]].id, // area: this.data.cityListPickerData[1][this.data.cityListIndex[1]].id, time: this.data.timeList[this.data.timeListIndex].code, status: this.data.statusList[this.data.statusListIndex].itemcode, titleCode: that.data.nameList[that.data.nameIndex].itemcode, }, noMore: isRefresh ? false : this.data.noMore, }); wx.showLoading({ title: "努力加载中...", }); app._post_form( "act/list", "", this.data.params, function (res) { if (res.code == 0) { if ( res.page.list.length > 0 && that.data.listData.length > 0 && res.page.list[0].id == that.data.listData[0].id ) { return; } res.page.list.map((v) => { (v.startTime = v.startTime.replace(/-/g, ".").split(" ")[0]), (v.endTime = v.endTime.replace(/-/g, ".").split(" ")[0]); }); let listData = that.data.listData; listData.push(...res.page.list); that.setData({ listData, currPage: res.page.currPage, totalPage: res.page.totalPage, noMore: res.page.totalPage == res.page.currPage, }); } }, function (res) { wx.hideLoading(); } ); }, dateForm(val) { // if(typeof val == String) { // } // return val.split(' ')[0] }, loadCity: function () { let _this = this; app._post_form("region/list", "", null, function (res) { if (res.data.length) { //设置城市下拉框数据 let cityListPickerData = [res.data]; let cityListIndex = [0, 0]; //nowCity是之前首页的城市选择下拉框的数据 let nowCity = wx.getStorageSync("CHOOSECITY"); if (nowCity) { a: for (let i = 0; i < res.data.length; i++) { let cityName = res.data[i].name; if (nowCity.cityName === cityName) { cityListIndex[0] = i; b: for ( let i2 = 0; i2 < res.data[i].childRegionList.length; i2++ ) { let areaName = res.data[i].childRegionList[i2].name; if (nowCity.areaName === areaName) { cityListIndex[1] = i2; cityListPickerData.push(res.data[i].childRegionList); } } } } } //设置城市下拉框数据 _this.setData({ cityList: res.data, cityListPickerData, cityListIndex, }); setTimeout(function () { _this.loadList(true); }, 300); } }); }, //重新选择城市 cityPickerChange(e) { let cityListIndex = e.detail.value; this.setData({ cityListIndex, }); this.loadList(true); }, cityPickerColumnChange(e) { if (e.detail.column == 0) { this.setData({ cityListPickerData: [ this.data.cityList, this.data.cityList[e.detail.value].childRegionList, ], }); } }, //选择时间排序 timePickerChange(e) { let timeListIndex = e.detail.value; this.setData({ timeListIndex, }); this.loadList(true); }, //选择报名状态 statusPickerChange(e) { let statusListIndex = e.detail.value; this.setData({ statusListIndex, }); this.loadList(true); }, /** * 生命周期函数--监听页面初次渲染完成 */ onReady: function () {}, /** * 生命周期函数--监听页面显示 */ /** * 生命周期函数--监听页面隐藏 */ onHide: function () {}, /** * 生命周期函数--监听页面卸载 */ onUnload: function () {}, /** * 页面相关事件处理函数--监听用户下拉动作 */ onPullDownRefresh: function () { var that = this; this.loadCity(); this.getNameList(); // 处理完成后,终止下拉刷新 wx.stopPullDownRefresh(); }, /** * 页面上拉触底事件的处理函数 */ onReachBottom: function () { this.loadList(); }, /** * 用户点击右上角分享 */ onShareAppMessage: function () {}, });