businessDetail.js 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. const pages = require('../../mixin/pages')
  2. const { getShopDetail } = require('../../api/common')
  3. let leftHeight = 0
  4. let rightHeight = 0
  5. let query = null
  6. Page({
  7. /**
  8. * 页面的初始数据
  9. */
  10. data: {
  11. ...pages.data(),
  12. listUrl: '/api/user/home/shop/product/list',
  13. searchForm: {
  14. shop_id: ''
  15. },
  16. background: ['demo-text-1', 'demo-text-2', 'demo-text-3'],
  17. nav: [
  18. {
  19. name: '详情',
  20. value: '1'
  21. },
  22. {
  23. name: '产品',
  24. value: '2'
  25. }
  26. ],
  27. active: '1',
  28. leftList: [],
  29. rightList: []
  30. },
  31. ...pages.methods,
  32. /**
  33. * 生命周期函数--监听页面加载
  34. */
  35. onLoad(options) {
  36. const { shop_id } = options
  37. this.setData({
  38. 'searchForm.shop_id': shop_id
  39. }, () => {
  40. this.fetchShopDetail()
  41. this.fetchOrderList()
  42. })
  43. },
  44. /**
  45. * 生命周期函数--监听页面初次渲染完成
  46. */
  47. onReady() {
  48. },
  49. /**
  50. * 生命周期函数--监听页面显示
  51. */
  52. onShow() {
  53. },
  54. /**
  55. * 生命周期函数--监听页面隐藏
  56. */
  57. onHide() {
  58. },
  59. /**
  60. * 生命周期函数--监听页面卸载
  61. */
  62. onUnload() {
  63. },
  64. /**
  65. * 页面相关事件处理函数--监听用户下拉动作
  66. */
  67. onPullDownRefresh() {
  68. if (this.data.freshing) {
  69. return
  70. }
  71. this.setData({
  72. freshing: true
  73. })
  74. this.fetchShopDetail()
  75. this.bindCallBack()
  76. },
  77. /**
  78. * 页面上拉触底事件的处理函数
  79. */
  80. onReachBottom() {
  81. this.fetchOrderList()
  82. },
  83. bindCallBack() {
  84. this.fetchShopDetail()
  85. this.refreshOrderList()
  86. },
  87. async fetchShopDetail() {
  88. try {
  89. const { status, data, msg } = await getShopDetail(this.data.searchForm.shop_id)
  90. if (status) {
  91. } else {
  92. wx.showToast({
  93. title: msg,
  94. icon: 'none'
  95. })
  96. }
  97. } catch (err) {}
  98. },
  99. async isLeft(list) {
  100. const {
  101. leftList,
  102. rightList
  103. } = this.data
  104. query = wx.createSelectorQuery()
  105. for (const item of list) {
  106. leftHeight <= rightHeight ? leftList.push(item) : rightList.push(item)
  107. await this.getBoxHeight(leftList, rightList)
  108. }
  109. },
  110. getBoxHeight(leftList, rightList) {
  111. return new Promise((resolve, reject) => {
  112. this.setData({
  113. leftList,
  114. rightList
  115. }, () => {
  116. query.select('.waterfall-left').boundingClientRect()
  117. query.select('.waterfall-right').boundingClientRect()
  118. query.exec((res) => {
  119. leftHeight = res[0].height
  120. rightHeight = res[1].height
  121. resolve()
  122. })
  123. })
  124. })
  125. },
  126. handleNav(e) {
  127. const { value } = e.detail
  128. this.setData({
  129. active: value
  130. })
  131. }
  132. })