index.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393
  1. // pages/experience/activityinfo/activityinfo.js
  2. var app = getApp();
  3. var util = require("../../../utils/util.js");
  4. Page({
  5. data: {
  6. appAssetsUrl: app.appAssetsUrl,
  7. appAssetsUrl2: app.appAssetsUrl2,
  8. appAssetsUrl3: app.appAssetsUrl3,
  9. nodata: util.nodata(),
  10. timeList: [
  11. {
  12. code: "",
  13. name: "时间排序",
  14. },
  15. {
  16. code: 1,
  17. name: "最近三天",
  18. },
  19. {
  20. code: 2,
  21. name: "最近七天",
  22. },
  23. {
  24. code: 3,
  25. name: "最近一个月",
  26. },
  27. ],
  28. timeListIndex: 0,
  29. statusList: [],
  30. statusListIndex: 0,
  31. noBgImg:
  32. "",
  33. params: {
  34. page: 1,
  35. limit: 10,
  36. },
  37. total: {
  38. currPage: 0,
  39. totalPage: 0,
  40. },
  41. noMore: false,
  42. cityListPickerData: [],
  43. cityListIndex: [0, 0],
  44. listData: [],
  45. statusBarHeight: 0,
  46. titleHeight: 0,
  47. conTop: 0,
  48. nameList: [{ itemname: "全部" }],
  49. nameListEle: [],
  50. nameIndex: 0,
  51. shaiHeight: 0,
  52. jwidth: 0,
  53. staHeight: 0,
  54. },
  55. onLoad: function (options) {
  56. this.loadCity();
  57. this.getNameList();
  58. let button = wx.getMenuButtonBoundingClientRect();
  59. let _this = this;
  60. wx.getSystemInfo({
  61. success: function (res) {
  62. _this.setData({
  63. scrollHeight: res.windowHeight,
  64. jwidth: button.width + 20 + "px",
  65. });
  66. },
  67. });
  68. this.height();
  69. let index = getApp().params.pePageToIndex;
  70. let nameIndex = this.data.nameIndex;
  71. console.log(nameIndex, "nameIndex");
  72. this.setData({
  73. nameIndex: 0,
  74. });
  75. if (this.data.nameList.length == 1) {
  76. this.getLabelList(0);
  77. } else {
  78. this.scroll(0);
  79. }
  80. this.loadList(true);
  81. console.log("res", button);
  82. },
  83. onShow() {
  84. // let index = getApp().params.pePageToIndex;
  85. // let nameIndex = this.data.nameIndex;
  86. // console.log(nameIndex,'nameIndex')
  87. // this.setData({
  88. // nameIndex:0
  89. // })
  90. // if(this.data.nameList.length==1){
  91. // this.getLabelList(0)
  92. // }else{
  93. // this.scroll(0)
  94. // }
  95. },
  96. nameHandler(e) {
  97. let nameIndex = e.currentTarget.dataset.index;
  98. getApp().params.pePageToIndex = nameIndex;
  99. this.setData({
  100. nameIndex,
  101. });
  102. console.log(e);
  103. this.scroll(nameIndex);
  104. this.loadList(true);
  105. },
  106. getLabelList(index) {
  107. let that = this;
  108. app._post_form(
  109. "bizcatelog/apiSelectBizcatelog/act_title",
  110. "",
  111. null,
  112. function (res) {
  113. console.log(res, 1112222);
  114. if (res.code == 0) {
  115. that.setData({
  116. nameList: [{ itemname: "全部" }, ...res.dictList],
  117. });
  118. wx.nextTick(() => {
  119. let query = wx.createSelectorQuery();
  120. query
  121. .selectAll(".nameitem")
  122. .boundingClientRect()
  123. .exec(function (res) {
  124. let nameListEle = [];
  125. for (let i in res[0]) {
  126. nameListEle.push(res[0][i].width * 1);
  127. }
  128. that.setData({
  129. nameListEle,
  130. });
  131. });
  132. setTimeout(() => {
  133. that.scroll(index);
  134. }, 500);
  135. });
  136. }
  137. }
  138. );
  139. },
  140. scroll(index) {
  141. let that = this;
  142. let leftNum = 0;
  143. if (index > 0) {
  144. for (let i in that.data.nameListEle) {
  145. if (i < index) {
  146. leftNum += that.data.nameListEle[i];
  147. leftNum += (20 / 750) * wx.getSystemInfoSync().windowWidth;
  148. }
  149. }
  150. }
  151. that.setData({
  152. navScrollWidth: leftNum,
  153. });
  154. },
  155. // 自定义高度处理
  156. height() {
  157. let that = this;
  158. const { platform, statusBarHeight } = wx.getSystemInfoSync();
  159. let height = statusBarHeight + 4; //ios 24px
  160. let mH = statusBarHeight + 4;
  161. if (platform.toLowerCase() == "android") {
  162. height += 4; //android 28px
  163. mH += 4;
  164. }
  165. height = height + 38;
  166. // 胶囊高度 32px 下边框6px height 状态栏高度
  167. const ButtonBounding = wx.getMenuButtonBoundingClientRect();
  168. wx.getSystemInfo({
  169. success: (res) => {
  170. let navHeight =
  171. ButtonBounding.height +
  172. res.statusBarHeight +
  173. (ButtonBounding.top - res.statusBarHeight) * 2;
  174. that.setData({
  175. statusBarHeight:
  176. ButtonBounding.height +
  177. res.statusBarHeight +
  178. (ButtonBounding.top - res.statusBarHeight) * 2 +
  179. "px",
  180. titleHeight: res.statusBarHeight + "px",
  181. conTop: 40 + "px",
  182. shaiHeight: navHeight + 48 + "px",
  183. staHeight: res.statusBarHeight,
  184. });
  185. },
  186. });
  187. // let res = uni.getSystemInfoSync()
  188. // return ButtonBounding.height + (ButtonBounding.top - res.statusBarHeight) * 2
  189. },
  190. activeDetail: function (e) {
  191. if (e.currentTarget.dataset.id) {
  192. wx.navigateTo({
  193. url:
  194. "/pages/home/index/activityDetail/activityDetail?id=" +
  195. e.currentTarget.dataset.id,
  196. });
  197. }
  198. },
  199. getNameList(index) {
  200. let that = this;
  201. app._post_form("home/activityStatus", "", null, function (res) {
  202. if (res.code == 0) {
  203. that.setData({
  204. statusList: [{ itemname: "活动状态", itemcode: "" }, ...res.data],
  205. });
  206. }
  207. });
  208. },
  209. // 活动
  210. loadList(isRefresh) {
  211. let that = this;
  212. if (!isRefresh && this.data.noMore) {
  213. wx.showToast({
  214. title: "没有更多了~",
  215. icon: "none",
  216. });
  217. return false;
  218. }
  219. // console.log(this.data.cityListPickerData);
  220. // console.log(this.data.statusList, this.data.statusListIndex);
  221. this.setData({
  222. listData: isRefresh ? [] : this.data.listData,
  223. params: {
  224. ...this.data.params,
  225. page: isRefresh ? 1 : this.data.params.page + 1,
  226. city: this.data.cityListPickerData.length ? this.data.cityListPickerData[0][this.data.cityListIndex[0]].id : '',
  227. // area: this.data.cityListPickerData[1][this.data.cityListIndex[1]].id,
  228. time: this.data.timeList.length ? this.data.timeList[this.data.timeListIndex].code : '',
  229. status: this.data.statusList.length ? this.data.statusList[this.data.statusListIndex].itemcode : '',
  230. titleCode: that.data.nameList.length ? that.data.nameList[that.data.nameIndex].itemcode : '',
  231. },
  232. noMore: isRefresh ? false : this.data.noMore,
  233. });
  234. wx.showLoading({
  235. title: "努力加载中...",
  236. });
  237. app._post_form(
  238. "act/list",
  239. "",
  240. this.data.params,
  241. function (res) {
  242. if (res.code == 0) {
  243. if (
  244. res.page.list.length > 0 &&
  245. that.data.listData.length > 0 &&
  246. res.page.list[0].id == that.data.listData[0].id
  247. ) {
  248. return;
  249. }
  250. res.page.list.map((v) => {
  251. (v.startTime = v.startTime.replace(/-/g, ".").split(" ")[0]),
  252. (v.endTime = v.endTime.replace(/-/g, ".").split(" ")[0]);
  253. });
  254. let listData = that.data.listData;
  255. listData.push(...res.page.list);
  256. that.setData({
  257. listData,
  258. currPage: res.page.currPage,
  259. totalPage: res.page.totalPage,
  260. noMore: res.page.totalPage == res.page.currPage,
  261. });
  262. }
  263. },
  264. function (res) {
  265. wx.hideLoading();
  266. }
  267. );
  268. },
  269. dateForm(val) {
  270. // if(typeof val == String) {
  271. // }
  272. // return val.split(' ')[0]
  273. },
  274. loadCity: function () {
  275. let _this = this;
  276. app._post_form("region/list", "", null, function (res) {
  277. if (res.data.length) {
  278. //设置城市下拉框数据
  279. let cityListPickerData = [res.data];
  280. let cityListIndex = [0, 0];
  281. //nowCity是之前首页的城市选择下拉框的数据
  282. let nowCity = wx.getStorageSync("CHOOSECITY");
  283. if (nowCity) {
  284. a: for (let i = 0; i < res.data.length; i++) {
  285. let cityName = res.data[i].name;
  286. if (nowCity.cityName === cityName) {
  287. cityListIndex[0] = i;
  288. b: for (
  289. let i2 = 0;
  290. i2 < res.data[i].childRegionList.length;
  291. i2++
  292. ) {
  293. let areaName = res.data[i].childRegionList[i2].name;
  294. if (nowCity.areaName === areaName) {
  295. cityListIndex[1] = i2;
  296. cityListPickerData.push(res.data[i].childRegionList);
  297. }
  298. }
  299. }
  300. }
  301. }
  302. //设置城市下拉框数据
  303. _this.setData({
  304. cityList: res.data,
  305. cityListPickerData,
  306. cityListIndex,
  307. });
  308. setTimeout(function () {
  309. _this.loadList(true);
  310. }, 300);
  311. }
  312. });
  313. },
  314. //重新选择城市
  315. cityPickerChange(e) {
  316. let cityListIndex = e.detail.value;
  317. this.setData({
  318. cityListIndex,
  319. });
  320. this.loadList(true);
  321. },
  322. cityPickerColumnChange(e) {
  323. if (e.detail.column == 0) {
  324. this.setData({
  325. cityListPickerData: [
  326. this.data.cityList,
  327. this.data.cityList[e.detail.value].childRegionList,
  328. ],
  329. });
  330. }
  331. },
  332. //选择时间排序
  333. timePickerChange(e) {
  334. let timeListIndex = e.detail.value;
  335. this.setData({
  336. timeListIndex,
  337. });
  338. this.loadList(true);
  339. },
  340. //选择报名状态
  341. statusPickerChange(e) {
  342. let statusListIndex = e.detail.value;
  343. this.setData({
  344. statusListIndex,
  345. });
  346. this.loadList(true);
  347. },
  348. /**
  349. * 生命周期函数--监听页面初次渲染完成
  350. */
  351. onReady: function () {},
  352. /**
  353. * 生命周期函数--监听页面显示
  354. */
  355. /**
  356. * 生命周期函数--监听页面隐藏
  357. */
  358. onHide: function () {},
  359. /**
  360. * 生命周期函数--监听页面卸载
  361. */
  362. onUnload: function () {},
  363. /**
  364. * 页面相关事件处理函数--监听用户下拉动作
  365. */
  366. onPullDownRefresh: function () {
  367. var that = this;
  368. this.loadCity();
  369. this.getNameList();
  370. // 处理完成后,终止下拉刷新
  371. wx.stopPullDownRefresh();
  372. },
  373. /**
  374. * 页面上拉触底事件的处理函数
  375. */
  376. onReachBottom: function () {
  377. this.loadList();
  378. },
  379. /**
  380. * 用户点击右上角分享
  381. */
  382. onShareAppMessage: function () {},
  383. });