store.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. <template>
  2. <view class="brand-page-container">
  3. <view style="background: linear-gradient(180deg, #EF530E 23%, #FAC894 43%, #fcfbf9 103%);">
  4. <view class="top-container">
  5. <view style="padding: 28upx 28upx 24upx;color: #ffffff;">
  6. 巨蜂本地生活
  7. </view>
  8. <view class="search-header">
  9. <BeeLocale event-name="sendChooseAddressSuccessMsg"></BeeLocale>
  10. <SearchBar prevent background="#fff" @click="$jump('/pages_category_page1/search/index/index')"></SearchBar>
  11. <CategoryIcon></CategoryIcon>
  12. </view>
  13. <view class="menus-wrapper">
  14. <BeeMenus :data="menusData" @click="handleTo"></BeeMenus>
  15. </view>
  16. <view style="display: flex;justify-content: space-between;padding: 0 28upx;">
  17. <view
  18. style="width: 130upx;height: 168upx;background: url('../../static/images/index/tab-png1.png') no-repeat center/contain;"
  19. @click="$jump('/pages_category_page1/integral/sign')"
  20. >
  21. <view style="padding: 20upx 0 0;font-weight: bold;font-size: 28upx;text-align: center;">签到赚钱</view>
  22. </view>
  23. <view
  24. style="width: 130upx;height: 168upx;background: url('../../static/images/index/tab-png2.png') no-repeat center/contain;"
  25. @click="$jump('/pages_category_page2/userModule/coupon')"
  26. >
  27. <view style="padding: 20upx 0 0;font-weight: bold;font-size: 28upx;text-align: center;">我的卡券</view>
  28. </view>
  29. <view
  30. style="width: 130upx;height: 168upx;background: url('../../static/images/index/tab-png3.png') no-repeat center/contain;"
  31. @click="$jump('/pages_category_page1/memberCenter/index')"
  32. >
  33. <view style="padding: 20upx 0 0;font-weight: bold;font-size: 28upx;text-align: center;">会员中心</view>
  34. </view>
  35. <view
  36. style="width: 130upx;height: 168upx;background: url('../../static/images/index/tab-png4.png') no-repeat center/contain;"
  37. @click="$jump('/pages_category_page1/integral/index')"
  38. >
  39. <view style="padding: 20upx 0 0;font-weight: bold;font-size: 28upx;text-align: center;">我的积分</view>
  40. </view>
  41. <view
  42. style="width: 130upx;height: 168upx;background: url('../../static/images/index/tab-png5.png') no-repeat center/contain;"
  43. @click="$jump('/pages_category_page1/distributionModule/index')"
  44. >
  45. <view style="padding: 20upx 0 0;font-weight: bold;font-size: 28upx;text-align: center;">分销中心</view>
  46. </view>
  47. </view>
  48. <view class="banner-wrapper" @click="$jump('/pages_category_page1/memberCenter/index')">
  49. <image src="../../static/images/index/banner2.png" mode="" />
  50. </view>
  51. </view>
  52. </view>
  53. <view style="width: 100%;">
  54. <view style="display: flex;justify-content: space-between;margin-top: 20upx;padding: 0 28upx;">
  55. <view style="width: 48%;position: relative;" @click="$switchTab('/pages/red-envelope/red-envelope')">
  56. <image style="width: 100%;" src="../../static/images/index/card-png1.png" mode="widthFix" />
  57. <view style="position: absolute;top: 5upx;left: 10upx;">
  58. <view style="font-size: 26upx;color: #ffffff;">地图红包</view>
  59. <view style="margin: 80upx 0 0 68upx;font-size: 38upx;color: #eb2006;font-weight: bold;">立抢红包 ></view>
  60. </view>
  61. </view>
  62. <view style="width: 48%;display: flex;flex-direction: column;justify-content: space-between;">
  63. <view @click="$jump('/pages_user/serve/tuanyou/service-oil')">
  64. <image style="width: 100%;" src="../../static/images/index/card-png2.png" mode="widthFix" />
  65. </view>
  66. <view style="position: relative;" @click="$jump('/pages_user/serve/red-envelope-distribution/index')">
  67. <image style="width: 100%;" src="../../static/images/index/card-png3.png" mode="widthFix" />
  68. <view style="position: absolute;top: 5upx;left: 26upx;">
  69. <view style="font-size: 26upx;color: #ffffff;">发红包</view>
  70. <view style="margin: 30upx 0 0 -12upx;font-size: 34upx;color: #0f0f0f;">红包推广宣传</view>
  71. </view>
  72. </view>
  73. </view>
  74. </view>
  75. <view
  76. style="position: relative;margin-top: 20upx;background-color: #ffedd9;"
  77. @click="$jump('/pages_category_page2/userModule/messageCenter')"
  78. >
  79. <image style="width: 100%;height: 245upx;" src="../../static/images/index/banner3.png" mode="" />
  80. <view style="position: absolute;top: 45upx;left: 106upx;">
  81. <view style="font-size: 36upx;font-weight: bold;">消息中心 ></view>
  82. <view style="margin-top: 10upx;font-size: 26upx;color: #959392;">订单、商品等通知提示</view>
  83. </view>
  84. </view>
  85. </view>
  86. <view class="brand">
  87. <BeeStoreFilter @confirm="handleConfirmType" @select-distance="handleSelectDistance"></BeeStoreFilter>
  88. <view class="brand-list-wrapper">
  89. <view v-if="$data._list && $data._list.length">
  90. <BeeBrandPane v-for="item in $data._list" :key="item.id" :is-positioning="isPositioning" :brand-info="item">
  91. </BeeBrandPane>
  92. </view>
  93. <!-- <view style="margin-top: 20upx;">
  94. <tui-waterfall :list-data="$data._list" :type="2">
  95. <template #left="{ entity }">
  96. <view style="width: 345upx;">
  97. <BeeBrandCard :brand="entity"></BeeBrandCard>
  98. </view>
  99. </template>
  100. <template #right="{ entity }">
  101. <view style="width: 345upx;">
  102. <BeeBrandCard :brand="entity"></BeeBrandCard>
  103. </view>
  104. </template>
  105. </tui-waterfall>
  106. </view> -->
  107. <view style="padding-bottom: 45upx;">
  108. <LoadMore
  109. :status="!$data._isEmpty && !$data._list.length
  110. ? 'loading' : !$data._isEmpty && $data._list.length && ($data._list.length >= $data._listTotal) ? 'no-more' : ''"
  111. >
  112. </LoadMore>
  113. <tui-no-data v-if="$data._isEmpty" :fixed="false" style="margin-top: 60upx;">暂无数据</tui-no-data>
  114. </view>
  115. </view>
  116. </view>
  117. </view>
  118. </template>
  119. <script>
  120. import { mapGetters } from 'vuex'
  121. import loadData from '../../mixins/loadData'
  122. import { menusData } from './data'
  123. import { getHomeBrandListApi, getCategoryListApi } from '../../api/user'
  124. import { getAdressDetailByLngLat } from '@/utils'
  125. // import { CHANGE_IS_IN_MINIPROGRAM } from '../../store/modules/type'
  126. export default {
  127. name: 'Store',
  128. data() {
  129. return {
  130. menusData: Object.freeze(menusData),
  131. isPositioning: true,
  132. // loopTimer: null,
  133. queryParam: {
  134. dressing: '',
  135. distance: ''
  136. }
  137. }
  138. },
  139. mixins: [
  140. loadData({
  141. api: getHomeBrandListApi,
  142. mapKey: {
  143. list: 'list',
  144. listTotal: 'total',
  145. pageSize: 'pageSize'
  146. },
  147. callingcb: true,
  148. dataFn(data) {
  149. const ignoreBrandList = ['佛山市顺德区修江缘美食餐饮店', '测试门店呀', '巨蜂自营']
  150. return data.filter((item) => !ignoreBrandList.includes(item.name))
  151. }
  152. })
  153. ],
  154. onLoad(options) {
  155. // if (options.miniProgram) {
  156. // // getApp().globalData.isInMiniprogram = true;
  157. // this.$store.commit(`app/${CHANGE_IS_IN_MINIPROGRAM}`, !!(options.miniProgram * 1))
  158. // }
  159. // // #ifdef H5
  160. // const script = document.createElement('script')
  161. // script.src = 'https://res.wx.qq.com/open/js/jweixin-1.4.0.js'
  162. // document.body.appendChild(script)
  163. // // #endif
  164. this.getBrandList()
  165. this.getCategoryList()
  166. uni.$on('sendStoreDetailMsg', (data) => {
  167. if (data.data.meaning === 'refreshCurrentData') {
  168. if (!this.isPositioning) {
  169. // uni.showLoading()
  170. getHomeBrandListApi({
  171. page: 1,
  172. pageSize: this.$data._query.page * this.$data._query.pageSize,
  173. ...this.queryParam,
  174. areaId: this.$store.state.location.locationInfo.adcode,
  175. longitude: this.$store.state.location.locationInfo.streetNumber.location.split(',')[0],
  176. latitude: this.$store.state.location.locationInfo.streetNumber.location.split(',')[1]
  177. })
  178. .then(({ data }) => {
  179. console.log(data)
  180. this.$data._list = data.list || []
  181. // uni.hideLoading()
  182. })
  183. .catch(() => {
  184. // uni.hideLoading()
  185. })
  186. }
  187. }
  188. })
  189. uni.$on('sendChooseAddressSuccessMsg', (data) => {
  190. this.getBrandList()
  191. })
  192. },
  193. onUnload() {
  194. // this.loopTimer && clearInterval(this.loopTimer)
  195. },
  196. computed: {
  197. ...mapGetters([ 'obtainLocationCount' ])
  198. },
  199. watch: {
  200. obtainLocationCount(val, oldVal) {
  201. const pages = getCurrentPages()
  202. if (pages[pages.length - 1].route === 'pages/store/store') this.getBrandList()
  203. }
  204. },
  205. methods: {
  206. getBrandList() {
  207. // let num = 0
  208. if (!this.$store.getters.obtainLocationCount) {
  209. const tempTime = Date.now()
  210. const queryLocation = { longitude: '', latitude: '' }
  211. uni.getLocation({
  212. type: 'gcj02',
  213. highAccuracyExpireTime: 1000,
  214. success: (result) => {
  215. queryLocation.longitude = result.longitude
  216. queryLocation.latitude = result.latitude
  217. console.log(result)
  218. getAdressDetailByLngLat(queryLocation.latitude, queryLocation.longitude)
  219. .then((res) => {
  220. if (res.status === '1') {
  221. this.$data._query = { ...this.$data._query, ...this.queryParam, ...queryLocation, areaId: typeof res.regeocode.addressComponent.adcode === 'object' ? '' : res.regeocode.addressComponent.adcode }
  222. if ((Date.now() - tempTime) >= 1000) {
  223. this._loadData(null, () => this.isPositioning = true)
  224. } else {
  225. this._loadData(null, () => this.isPositioning = false)
  226. }
  227. } else {
  228. this.$showToast('查询失败')
  229. }
  230. })
  231. .catch(() => {
  232. this.$showToast('查询失败')
  233. })
  234. },
  235. fail: () => {
  236. this.$data._query = {
  237. ...this.$data._query,
  238. ...this.queryParam,
  239. areaId: this.$store.state.location.locationInfo.adcode,
  240. longitude: this.$store.state.location.locationInfo.streetNumber.location.split(',')[0],
  241. latitude: this.$store.state.location.locationInfo.streetNumber.location.split(',')[1]
  242. }
  243. this._loadData()
  244. }
  245. })
  246. } else {
  247. this.$data._query = {
  248. ...this.$data._query,
  249. ...this.queryParam,
  250. areaId: this.$store.state.location.locationInfo.adcode,
  251. longitude: this.$store.state.location.locationInfo.streetNumber.location.split(',')[0],
  252. latitude: this.$store.state.location.locationInfo.streetNumber.location.split(',')[1]
  253. // areaId: 440606,
  254. // longitude: 113.293719,
  255. // latitude: 22.803751
  256. }
  257. this._loadData(null, () => this.isPositioning = false)
  258. }
  259. },
  260. // 获取首页分类数据
  261. async getCategoryList() {
  262. const { data } = await getCategoryListApi({ levelId: 1 })
  263. // this.menusData = data.slice(0, 8)
  264. this.menusData = data
  265. },
  266. handleTo(item) {
  267. console.log(item)
  268. if (item.storeName === '美食饮品') {
  269. this.$jump(`/pages/store/fine-food/fine-food?name=${item.storeName}&id=${item.id}`)
  270. } else {
  271. this.$jump(`/pages/store/fine-food/food-nearby/food-nearby?name=${item.storeName}&id=${item.id}`)
  272. }
  273. },
  274. handleConfirmType(e) {
  275. this.queryParam.dressing = e.id
  276. this.$data._query.page = 1
  277. this.$data._list = []
  278. this.$data.listTotal = 0
  279. this.$data._isEmpty = false
  280. this.getBrandList()
  281. },
  282. handleSelectDistance(e) {
  283. this.queryParam.distance = e
  284. this.$data._query.page = 1
  285. this.$data._list = []
  286. this.$data.listTotal = 0
  287. this.$data._isEmpty = false
  288. this.getBrandList()
  289. }
  290. },
  291. onPullDownRefresh() {
  292. this.$data._query.page = 1
  293. this.$data._list = []
  294. this.$data._listTotal = 0
  295. this.$data._isEmpty = false
  296. this._loadData()
  297. uni.stopPullDownRefresh()
  298. }
  299. }
  300. </script>
  301. <style lang="less" scoped>
  302. .brand-page-container {
  303. width: 100vw;
  304. min-height: 100vh;
  305. background: #f5f5f7;
  306. box-sizing: border-box;
  307. .top-container {
  308. width: 100%;
  309. // background: #f6f6f6;
  310. background: url('../../static/images/index/top-background.png') no-repeat center top/contain;
  311. // min-height: 826upx;
  312. // background: linear-gradient(
  313. // 0deg,
  314. // rgba(246, 246, 246, 0.87) -3%,
  315. // rgba(246, 246, 246, 0.87) 8%,
  316. // rgba(246, 246, 246, 0.87) 14%,
  317. // rgba(253, 164, 164, 0.87) 59%
  318. // );
  319. .search-header {
  320. display: flex;
  321. align-items: center;
  322. justify-content: space-between;
  323. padding: 44upx 28upx 20upx;
  324. /deep/ .search-bar-container {
  325. flex: 1;
  326. margin-right: 15upx;
  327. }
  328. }
  329. .menus-wrapper {
  330. padding: 0 28upx 20upx;
  331. box-sizing: border-box;
  332. /deep/ .menus-container {
  333. margin-top: 0;
  334. }
  335. }
  336. .banner-wrapper {
  337. margin-top: 20upx;
  338. padding: 0 28upx;
  339. box-sizing: border-box;
  340. image {
  341. width: 100%;
  342. height: 225upx;
  343. border-radius: 20upx;
  344. }
  345. }
  346. }
  347. .brand {
  348. position: relative;
  349. z-index: 1;
  350. margin-top: -40upx;
  351. .brand-list-wrapper {
  352. padding: 0 28upx;
  353. box-sizing: border-box;
  354. padding-bottom: 140upx;
  355. }
  356. }
  357. }
  358. </style>