index.vue 33 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051
  1. <template>
  2. <page :nav="false" ref="pageRef" custom-class="paddingB10 relative" @click="clickPage">
  3. <view
  4. class="pagae-nav"
  5. :style="{ paddingTop: statusBarHeight + 'px', background: headerBg }"
  6. >
  7. <view class="flex-column-align-center nav-title">宝箱</view>
  8. </view>
  9. <view class="boxPage" :style="{ backgroundImage: 'url(' + ossurl.box.headbj + ')' }">
  10. <view class="seizeSeet" :style="{ paddingTop: statusBarHeight + 40 + 'px' }"></view>
  11. <view class="p30">
  12. <view class="headerBox" :style="{ backgroundImage: 'url(' + ossurl.box.headInfo + ')' }">
  13. <view class="userBox">
  14. <view class="avatar">
  15. <image
  16. class="avatarImg"
  17. :src="user ? user.avatar : ossurl.common.noavatar"
  18. />
  19. </view>
  20. <view class="userName" v-if="user">
  21. {{ user.nickname }}
  22. </view>
  23. <view class="numList" v-if="user">
  24. <view
  25. class="item"
  26. @click="showView({ url: '/pages/magic/index', login: true })"
  27. >
  28. <view class="numBox">
  29. {{ showNumber('magicBalance') }}
  30. </view>
  31. <view class="numTitle">源石</view>
  32. </view>
  33. <view
  34. class="item"
  35. @click="showView({ url: '/pages/coupon/index', login: true })"
  36. >
  37. <view class="numBox">
  38. {{ showNumber('couponCount') }}
  39. </view>
  40. <view class="numTitle">优惠券</view>
  41. </view>
  42. <view
  43. class="item"
  44. @click="showView({ url: '/pages/store/index', login: true })"
  45. >
  46. <view class="numBox">
  47. {{ showNumber('inventoryCount') }}
  48. </view>
  49. <view class="numTitle">仓库</view>
  50. </view>
  51. </view>
  52. </view>
  53. <view class="searchBox">
  54. <view class="searchInput">
  55. <input
  56. type="text"
  57. confirm-type="search"
  58. placeholder="搜索你感兴趣的~"
  59. v-model.trim="keyword"
  60. placeholder-style="color:#A27400;font-size:12px;"
  61. @confirm="getData()"
  62. />
  63. <text class="cuIcon-search" @click="getData()"></text>
  64. </view>
  65. <view class="rule fx-c-c" @click="showView({ url: '/pages/message/index', login: false })">
  66. <text>i</text><text>规则</text>
  67. </view>
  68. </view>
  69. </view>
  70. <!-- 广告 -->
  71. <view>
  72. <view class="flex-align-center flex-center marginB10"></view>
  73. <view>
  74. <view class="marginT10">
  75. <barrage ref="barrage1" />
  76. </view>
  77. <view class="marginT5">
  78. <barrage :left="50" ref="barrage2" />
  79. </view>
  80. </view>
  81. </view>
  82. </view>
  83. <view class="listSection">
  84. <view class="tabList" :style="{ backgroundImage: 'url(' + ossurl.box.tabBg + ')' }">
  85. <view class="tab">
  86. <view class="item fx-c" @click="changeTab('')" :style="tabValue == '' ? 'background: url(' + ossurl.box.tabIndexbj + ')no-repeat' : 'background: #F3F3F3' ">
  87. <view class="img">
  88. <image :src="ossurl.box.tabIndex1" mode="widthFix" />
  89. </view>
  90. <text>全部</text>
  91. </view>
  92. <view class="item fx-c" @click="changeTab('UNLIMITED')" :style="tabValue == 'UNLIMITED' ? 'background: url(' + ossurl.box.tabIndexbj + ')no-repeat' : 'background: #F3F3F3' ">
  93. <view class="img">
  94. <image :src="ossurl.box.tabIndex2" mode="widthFix" />
  95. </view>
  96. <text>超级赏</text>
  97. </view>
  98. <view class="item fx-c" @click="changeTab('YFS_PRO')" :style="tabValue == 'YFS_PRO' ? 'background: url(' + ossurl.box.tabIndexbj + ')no-repeat' : 'background: #F3F3F3' ">
  99. <view class="img">
  100. <image :src="ossurl.box.tabIndex3" mode="widthFix" />
  101. </view>
  102. <text>一番赏</text>
  103. </view>
  104. </view>
  105. </view>
  106. <view
  107. v-for="item in list"
  108. :key="item.id"
  109. class="item2 flex-column-center"
  110. @click="showDetail(item)"
  111. >
  112. <view class="relative itemBox">
  113. <div class="itemTag">
  114. <image v-if="item.mode === 'UNLIMITED'" :src="ossurl.box.cj" mode="widthFix"></image>
  115. <image v-else-if="item.mode === 'YFS_PRO'" :src="ossurl.box.yf" mode="widthFix"></image>
  116. </div>
  117. <image class="itemImage" mode="aspectFill" :src="item.cover"></image>
  118. <view class="itemText">
  119. {{ item.name }}
  120. <view class="itemPrice">
  121. <span class="unit">¥</span>
  122. &nbsp;{{ item.price }}
  123. </view>
  124. </view>
  125. </view>
  126. </view>
  127. </view>
  128. </view>
  129. <coupon-com ref="couponRef" @success="refresh" />
  130. <poster ref="posterRef" />
  131. <activity ref="activityRef" @success="getIndex" />
  132. <view
  133. v-if="filterMoneyVisible"
  134. class="filter-list-wrapper"
  135. :style="{ left: filterMoneyStyle.left, top: filterMoneyStyle.top }"
  136. >
  137. <view
  138. v-for="item in filterMoneys"
  139. :key="item.label"
  140. @click.stop="chooseMoneyFilter(item)"
  141. class="cell flex-align-center"
  142. >
  143. {{ item.label }}
  144. </view>
  145. </view>
  146. <view
  147. v-if="filterTypeVisible"
  148. class="filter-list-wrapper"
  149. :style="{ left: filterTypeStyle.left, top: filterTypeStyle.top }"
  150. >
  151. <view
  152. v-for="item in filterTypes"
  153. :key="item.label"
  154. @click.stop="chooseTypeFilter(item)"
  155. class="cell flex-align-center"
  156. >
  157. {{ item.label }}
  158. </view>
  159. </view>
  160. <popularize-com ref="popularizeRef" />
  161. <view v-if="floorstatus" class="goTop" @click="goTop">
  162. <image :src="ossurl.common.topBtn" class="goTopImg" />
  163. </view>
  164. <activity-list ref="activityListRef" />
  165. <image
  166. class="receiveBenefits"
  167. :src="ossurl.box.receiveBenefits"
  168. @click="gotoWeb()"
  169. mode="widthFix"
  170. />
  171. </view>
  172. <view v-if="adList && adList.length > 0">
  173. <adDialog v-for="(item, index) of adList" :adInfo="item" :key="index"></adDialog>
  174. </view>
  175. </page>
  176. </template>
  177. <script>
  178. import barrage from './barrage'
  179. import loginMixin from '@/mixin/login'
  180. import store from '@/store'
  181. import { SET_PID } from '@/store/mutation-types'
  182. import couponCom from './coupon'
  183. import top from './top'
  184. import poster from './poster'
  185. import activity from './activity'
  186. import banner from './banner'
  187. import activityList from './activity_tab'
  188. import popularizeCom from './../center/poster.vue'
  189. import { SET_SHARE_USERID } from '@/store/mutation-types'
  190. import ossurl from '@/utils/ossurl'
  191. import adDialog from './adDialog.vue'
  192. const FILTER_MONEY = [
  193. { label: '全部价格' },
  194. { label: '¥0 ~ ¥9.9', priceMin: '0', priceMax: '9.9' },
  195. { label: '¥10 ~ ¥19.9', priceMin: '9.9', priceMax: '19.9' },
  196. { label: '大于 ¥19.9', priceMin: '19.9' }
  197. ]
  198. const FILTER_TYPE = [
  199. { label: '全部模式' },
  200. { label: '无限', value: 'UNLIMITED' },
  201. { label: '一番赏Pro', value: 'YFS_PRO' }
  202. ]
  203. export default {
  204. components: {
  205. barrage,
  206. couponCom,
  207. top,
  208. poster,
  209. activity,
  210. banner,
  211. popularizeCom,
  212. activityList,
  213. adDialog
  214. },
  215. data() {
  216. return {
  217. keyword: '',
  218. ossurl,
  219. list: [],
  220. horse1: [],
  221. horse2: [],
  222. requestTime: null,
  223. requestActivityTime: false,
  224. indexData: null,
  225. notice: null,
  226. tabValue: '',
  227. filterMoneys: FILTER_MONEY,
  228. filterMoney: FILTER_MONEY[0],
  229. filterMoneyStyle: {},
  230. filterMoneyVisible: false,
  231. filterTypes: FILTER_TYPE,
  232. filterType: FILTER_TYPE[0],
  233. filterTypeStyle: {},
  234. filterTypeVisible: false,
  235. floorstatus: false,
  236. scrollTop: 0
  237. }
  238. },
  239. computed: {
  240. user() {
  241. return this.$store.state.userInfo
  242. },
  243. headerBg() {
  244. return this.scrollTop > 0 ? '#fff' : 'transparent'
  245. },
  246. statusBarHeight() {
  247. if (this.$store.state.systemInfo) {
  248. return this.$store.state.systemInfo.statusBarHeight
  249. }
  250. return 20
  251. },
  252. hide() {
  253. return !this.$store.state.hide
  254. },
  255. tabList() {
  256. return this.$store.state.pageConfig['index_icon'].components[0].elements
  257. },
  258. adList() {
  259. return this.$store.state.pageConfig['super_ad']?this.$store.state.pageConfig['super_ad'].components[0].elements:[]
  260. },
  261. boxBanner() {
  262. return this.$store.state.pageConfig['box_banner']?this.$store.state.pageConfig['box_banner'].components[0].elements:[]
  263. },
  264. banners() {
  265. if (!this.$store.state.pageConfig || !this.$store.state.pageConfig['magic_luck']) {
  266. return null
  267. }
  268. let components = this.$store.state.pageConfig['magic_luck'].components
  269. if (!components || components.length === 0) return null
  270. let data = null
  271. for (let i = 0; i < components.length; i++) {
  272. if (components[i].type === 'capsule') {
  273. data = components[i].elements
  274. }
  275. }
  276. return data
  277. }
  278. },
  279. onLoad(options) {
  280. if (options.scene) {
  281. var param = options.scene.split('%3A')
  282. store.commit(SET_SHARE_USERID, param[1])
  283. // this.$store.state.shareUserId
  284. }
  285. this.appShow()
  286. this.$event.on(this.$event.key.APP_SHOW, this.appShow)
  287. this.$event.on(this.$event.key.LOGIN, this.afterLogin)
  288. this.$event.on(this.$event.key.AWARD_REFRESH, this.refresh)
  289. },
  290. onUnload() {
  291. this.$event.off(this.$event.key.APP_SHOW)
  292. this.$event.off(this.$event.key.LOGIN)
  293. this.$event.off(this.$event.key.AWARD_REFRESH)
  294. },
  295. mounted() {},
  296. onReady() {
  297. // setTimeout(() => {
  298. // this.initFilterPosition()
  299. // }, 500)
  300. // console.log(this.$refs)
  301. },
  302. onShow() {
  303. this.init(true)
  304. // if (this.userInfo && this.userInfo.userId) {
  305. // this.getInfo()
  306. // // this.getTurntable()
  307. // }
  308. },
  309. onPullDownRefresh() {
  310. this.init(true)
  311. },
  312. onShareAppMessage(res) {
  313. return {
  314. title: '燚火漫域 次元聚集地,潮玩新势力',
  315. path: '/pages/award/index'
  316. }
  317. },
  318. onShareTimeline() {
  319. return {
  320. title: '燚火漫域 次元聚集地,潮玩新势力',
  321. imageUrl: this.list[0].cover
  322. }
  323. },
  324. // 获取滚动条当前位置
  325. onPageScroll(e) {
  326. let isTop = e.scrollTop > 100
  327. this.floorstatus = isTop ? true : false
  328. this.scrollTop = e.scrollTop
  329. },
  330. methods: {
  331. gotoRoute(item) {
  332. this.visible = false
  333. this.$common.showNext(item)
  334. },
  335. initFilterPosition() {
  336. this.initFilterPositionItem('filterMoney', 'filterMoneyStyle')
  337. this.initFilterPositionItem('filterType', 'filterTypeStyle')
  338. },
  339. initFilterPositionItem(className, key) {
  340. const el1 = uni.createSelectorQuery().in(this)
  341. el1.select(`.${className}`)
  342. .boundingClientRect((el) => {
  343. this[key] = {
  344. left: el.left - (132 - el.width) / 2 + 'px',
  345. top: el.top + el.height + 1 + 'px'
  346. }
  347. })
  348. .exec()
  349. },
  350. async appShow() {
  351. await this.initNewPeople()
  352. this.showPopularize()
  353. this.initCoupon()
  354. // const res = this.$cache.get(this.$cache.key.POSTER)
  355. // if (!res || res < 3) {
  356. // setTimeout(() => {
  357. // this.$refs.posterRef && this.$refs.posterRef.show()
  358. // }, 600)
  359. // this.$cache.set(this.$cache.key.POSTER, res ? res + 1 : 1)
  360. // }
  361. },
  362. async initNewPeople() {
  363. let now = new Date().getTime()
  364. if (this.requestActivityTime && now - this.requestActivityTime < 2 * 60 * 1000) {
  365. return false
  366. }
  367. let NEW_PEOPLE = this.$cache.get(this.$cache.key.NEW_PEOPLE)
  368. if (!NEW_PEOPLE) {
  369. const res = await this.$service.weal.activity()
  370. if (res) {
  371. this.$cache.set(this.$cache.key.NEW_PEOPLE, true)
  372. this.$refs.activityRef.show(res)
  373. }
  374. }
  375. return true
  376. },
  377. showPopularize() {
  378. let num = this.$cache.get(this.$cache.key.POPULARIZE)
  379. let flag =
  380. this.banners &&
  381. this.banners.some((item) => {
  382. return (
  383. item.path && item.path.params && item.path.params.url === 'popularize'
  384. )
  385. })
  386. if (!num && flag) {
  387. this.$refs.popularizeRef.show()
  388. this.$cache.set(this.$cache.key.POPULARIZE, (num || 0) + 1)
  389. }
  390. },
  391. gotoWeb() {
  392. const url =
  393. 'https://mp.weixin.qq.com/s?__biz=MzkzMTU2ODM4MQ==&mid=2247483786&idx=1&sn=b8fb65d562c3778881101d0e194bd5aa&chksm=c2684e18f51fc70ea3140fa1145adabed0d7203928d0b36431e425f9360fd66d4ed173f60870#rd'
  394. this.$router.web(url, '领福利')
  395. },
  396. async initCoupon() {
  397. const res = await this.$service.wallet.targetCoupon('LUCK', null, false)
  398. if (res && res.length > 0) {
  399. this.$refs.couponRef.show(res)
  400. }
  401. },
  402. changeTab(value) {
  403. this.tabValue = value
  404. this.refresh()
  405. },
  406. afterLogin() {
  407. this.refresh()
  408. if (this.$refs.couponRef && this.$refs.couponRef.refresh) {
  409. this.$refs.couponRef.refresh()
  410. }
  411. },
  412. refresh() {
  413. this.init(true)
  414. },
  415. init(flag = false) {
  416. this.getIndex()
  417. let now = new Date().getTime()
  418. if (!flag && this.requestTime && now - this.requestTime < 10 * 60 * 1000) {
  419. uni.stopPullDownRefresh()
  420. return
  421. }
  422. this.requestTime = now
  423. this.getData()
  424. this.getHorse()
  425. this.getNotice()
  426. },
  427. async getData(loading = false) {
  428. const res = await this.$service.award.list(
  429. { mode: this.tabValue, keyword: this.keyword },
  430. null,
  431. null,
  432. loading
  433. )
  434. uni.stopPullDownRefresh()
  435. this.list = res
  436. },
  437. async getHorse() {
  438. const res = await this.$service.award.horse()
  439. if (res && res.length > 0) {
  440. let middle = parseInt(res.length / 2 + 0.5)
  441. this.horse1 = res.slice(0, res.length)
  442. this.horse2 = res.slice(middle)
  443. this.$refs.barrage1 && this.$refs.barrage1.start(this.horse1)
  444. this.$refs.barrage2 && this.$refs.barrage2.start(this.horse2)
  445. }
  446. },
  447. async getIndex() {
  448. if (!this.$common.isLogin()) {
  449. this.indexData = null
  450. return
  451. }
  452. const res = await this.$service.award.magicIndex()
  453. this.indexData = res
  454. },
  455. async getNotice() {
  456. const res = await this.$service.base.message(1, 3, 'NOTICE')
  457. this.notice = res
  458. },
  459. showDetail(item) {
  460. if (item.status !== 1) return
  461. if (item.mode === 'UNLIMITED') {
  462. this.$router.push('award_detail', {
  463. poolId: item.id
  464. })
  465. } else if (item.mode === 'YFS_PRO') {
  466. this.$router.push('award_detail_yfs', {
  467. poolId: item.id
  468. })
  469. }
  470. },
  471. showKefu() {
  472. console.log(1)
  473. this.$common.showKefu()
  474. },
  475. back() {
  476. this.$router.back()
  477. },
  478. showNumber(key) {
  479. if (!this.indexData) return '-'
  480. if (typeof this.indexData[key] === 'undefined') return '-'
  481. const val = this.bigNumberTransform(this.indexData[key])
  482. return val
  483. },
  484. bigNumberTransform(value) {
  485. const newValue = ['', '', '']
  486. let fr = 1000
  487. let num = 3
  488. let text1 = ''
  489. let fm = 1
  490. while (value / fr >= 1) {
  491. fr *= 10
  492. num += 1
  493. // console.log('数字', value / fr, 'num:', num)
  494. }
  495. if (num <= 4) {
  496. // 千
  497. newValue[0] = parseInt(value / 1000) + ''
  498. newValue[1] = '千'
  499. } else if (num <= 8) {
  500. // 万
  501. text1 = parseInt(num - 4) / 3 > 1 ? '千万' : '万'
  502. // tslint:disable-next-line:no-shadowed-variable
  503. fm = text1 === '万' ? 10000 : 10000000
  504. if (value % fm === 0) {
  505. newValue[0] = parseInt(value / fm) + ''
  506. } else {
  507. newValue[0] = Math.floor(parseFloat(value / fm) * 10) / 10 + ''
  508. }
  509. newValue[1] = text1
  510. } else if (num <= 16) {
  511. // 亿
  512. text1 = (num - 8) / 3 > 1 ? '千亿' : '亿'
  513. text1 = (num - 8) / 4 > 1 ? '万亿' : text1
  514. text1 = (num - 8) / 7 > 1 ? '千万亿' : text1
  515. // tslint:disable-next-line:no-shadowed-variable
  516. fm = 1
  517. if (text1 === '亿') {
  518. fm = 100000000
  519. } else if (text1 === '千亿') {
  520. fm = 100000000000
  521. } else if (text1 === '万亿') {
  522. fm = 1000000000000
  523. } else if (text1 === '千万亿') {
  524. fm = 1000000000000000
  525. }
  526. if (value % fm === 0) {
  527. newValue[0] = parseInt(value / fm) + ''
  528. } else {
  529. newValue[0] = Math.floor(parseFloat(value / fm) * 10) / 10 + ''
  530. }
  531. newValue[1] = text1
  532. }
  533. if (value < 1000) {
  534. newValue[0] = value + ''
  535. newValue[1] = ''
  536. }
  537. return newValue.join('')
  538. },
  539. showMoneyVisible() {
  540. if (this.filterMoneyVisible) {
  541. this.filterMoneyVisible = false
  542. return
  543. }
  544. if (this.filterMoneyStyle && this.filterMoneyStyle.top) {
  545. this.filterMoneyVisible = true
  546. this.filterTypeVisible = false
  547. }
  548. },
  549. showTypeVisible() {
  550. if (this.filterTypeVisible) {
  551. this.filterTypeVisible = false
  552. return
  553. }
  554. if (this.filterTypeStyle && this.filterTypeStyle.top) {
  555. this.filterTypeVisible = true
  556. this.filterMoneyVisible = false
  557. }
  558. },
  559. chooseMoneyFilter(item) {
  560. this.filterMoney = item
  561. this.filterMoneyVisible = false
  562. this.getData(true)
  563. },
  564. chooseTypeFilter(item) {
  565. this.filterType = item
  566. this.filterTypeVisible = false
  567. this.getData(true)
  568. },
  569. clickPage() {
  570. this.filterMoneyVisible = false
  571. this.filterTypeVisible = false
  572. },
  573. //回到顶部
  574. goTop: function (e) {
  575. // 一键回到顶部
  576. if (wx.pageScrollTo) {
  577. wx.pageScrollTo({
  578. scrollTop: 0
  579. })
  580. } else {
  581. wx.showModal({
  582. title: '提示',
  583. content: '当前微信版本过低,无法使用该功能,请升级到最新微信版本后重试。'
  584. })
  585. }
  586. },
  587. onActivity() {
  588. this.$refs.activityListRef.show()
  589. }
  590. }
  591. }
  592. </script>
  593. <style></style>
  594. <style lang="scss" scoped>
  595. .listSection{
  596. background: #fff;
  597. padding-top: 30rpx;
  598. border-radius: 30rpx 30rpx 0 0;
  599. margin-top: 30rpx;
  600. }
  601. .boxPage {
  602. background-size: 100% auto;
  603. background-repeat: no-repeat;
  604. }
  605. .headerBox {
  606. background-size: 100% auto;
  607. background-repeat: no-repeat;
  608. padding: 70rpx 56rpx 24rpx 6rpx;
  609. box-sizing: border-box;
  610. .searchBox {
  611. display: flex;
  612. align-items: center;
  613. }
  614. .searchInput {
  615. height: 64rpx;
  616. background: rgba(255, 255, 255, 0.5);
  617. border-radius: 64rpx;
  618. color: #000;
  619. display: flex;
  620. flex: 1;
  621. align-items: center;
  622. padding: 0 24rpx;
  623. margin-right: 30rpx;
  624. margin-left: 40rpx;
  625. .cuIcon-search {
  626. color: #333;
  627. }
  628. input {
  629. flex: 1;
  630. }
  631. }
  632. .rule {
  633. width: 112rpx;
  634. height: 64rpx;
  635. background: #464646;
  636. border-radius: 12rpx;
  637. text {
  638. color: #FFE957;
  639. margin-left: 5rpx;
  640. font-weight: bold;
  641. font-size: 28rpx;
  642. }
  643. }
  644. .userBox {
  645. width: 680rpx;
  646. height: 162rpx;
  647. background-size: 680rpx 162rpx;
  648. margin-top: 20rpx;
  649. display: flex;
  650. align-items: center;
  651. padding-left: 40rpx;
  652. .avatar {
  653. .avatarImg {
  654. width: 82rpx;
  655. height: 82rpx;
  656. opacity: 1;
  657. border: 6rpx solid #fec433;
  658. border-radius: 50%;
  659. }
  660. }
  661. .userName {
  662. font-size: 28rpx;
  663. font-family: Source Han Sans, Source Han Sans;
  664. font-weight: bold;
  665. color: #000000;
  666. line-height: 44rpx;
  667. padding: 0 28rpx;
  668. border-right: 2rpx solid #f1c845;
  669. }
  670. .numList {
  671. display: flex;
  672. flex: 1;
  673. padding-left: 28rpx;
  674. text-align: center;
  675. .item {
  676. flex: 1;
  677. }
  678. .numBox {
  679. font-size: 32rpx;
  680. font-family: Rousseau Deco, Rousseau Deco;
  681. font-weight: bold;
  682. color: #000000;
  683. line-height: 44rpx;
  684. }
  685. .numTitle {
  686. font-size: 24rpx;
  687. font-family: Source Han Sans, Source Han Sans;
  688. font-weight: 350;
  689. color: #999;
  690. }
  691. }
  692. }
  693. }
  694. .bg {
  695. position: fixed;
  696. z-index: -1;
  697. left: 0;
  698. right: 0;
  699. top: 0;
  700. width: 100%;
  701. height: 100%;
  702. }
  703. .pagae-nav {
  704. width: 100%;
  705. position: fixed;
  706. top: 0;
  707. z-index: 100;
  708. transition: 0.2s;
  709. }
  710. .nav-title {
  711. height: 80rpx;
  712. font-size: 32rpx;
  713. font-family: Source Han Sans, Source Han Sans;
  714. font-weight: bold;
  715. color: #000000;
  716. }
  717. .tabList {
  718. padding: 20rpx 22rpx;
  719. .tab {
  720. display: flex;
  721. justify-content: space-between;
  722. .item {
  723. width: 220rpx;
  724. height: 68rpx;
  725. background: #F3F3F3;
  726. border-radius: 40rpx;
  727. padding: 0 14rpx;
  728. background-size: 100% 100%;
  729. image {
  730. margin-right: 16rpx;
  731. }
  732. text {
  733. font-size: 32rpx;
  734. font-weight: bold;
  735. }
  736. .img{
  737. width: 48rpx;
  738. height: 48rpx;
  739. overflow: hidden;
  740. image{
  741. width: 48rpx;
  742. }
  743. }
  744. }
  745. .item1 {
  746. display: flex;
  747. width: 200rpx;
  748. height: 78rpx;
  749. background: url('https://file.supermarts.cn/file/yi_huo_man_yu/images/award/a3.png') no-repeat;
  750. background-size: 100% 100%;
  751. align-items: initial;
  752. image {
  753. margin-top: 16rpx;
  754. }
  755. text {
  756. margin-top: 16rpx;
  757. }
  758. }
  759. }
  760. .tabItem {
  761. margin-right: 24rpx;
  762. height: 150rpx;
  763. &:last-child {
  764. margin: 0;
  765. }
  766. }
  767. }
  768. .item1 {
  769. height: 240rpx;
  770. width: 100%;
  771. border-radius: 20rpx;
  772. overflow: hidden;
  773. position: relative;
  774. padding: 1rpx;
  775. // .frame {
  776. // position: absolute;
  777. // left: 1rpx;
  778. // right: 1rpx;
  779. // top: 1rpx;
  780. // height: 238rpx;
  781. // }
  782. image {
  783. width: 100%;
  784. height: 100%;
  785. border-radius: 20rpx;
  786. }
  787. }
  788. .itemList {
  789. padding: 0rpx 4rpx 80rpx 4rpx;
  790. }
  791. .item2 {
  792. width: 50%;
  793. position: relative;
  794. margin: auto;
  795. display: inline-block;
  796. padding: 16rpx;
  797. .itemBox {
  798. font-size: 0;
  799. width: 100%;
  800. margin-bottom: 5rpx;
  801. .itemImage {
  802. border-radius: 14rpx;
  803. width: 338rpx;
  804. height: 402rpx;
  805. }
  806. .itemTag {
  807. position: absolute;
  808. z-index: 1;
  809. top: 0rpx;
  810. left: 0rpx;
  811. image {
  812. width: 152rpx;
  813. }
  814. }
  815. .itemText {
  816. font-size: 28rpx;
  817. font-family: Source Han Sans, Source Han Sans;
  818. font-weight: 350;
  819. color: rgba(0, 0, 0, 0.85);
  820. padding: 20rpx;
  821. }
  822. .itemPrice {
  823. color: #ff0000;
  824. font-size: 24rpx;
  825. font-family: Rousseau Deco, Rousseau Deco;
  826. font-weight: 400;
  827. margin-top: 10rpx;
  828. .unit {
  829. font-size: 24rpx;
  830. margin-right: 4rpx;
  831. }
  832. }
  833. }
  834. .frame {
  835. position: absolute;
  836. left: 0;
  837. top: 0;
  838. height: 600rpx;
  839. width: 100%;
  840. }
  841. .image {
  842. width: 100%;
  843. height: 360rpx;
  844. border-radius: 20rpx;
  845. }
  846. .image-flag {
  847. position: absolute;
  848. left: 0;
  849. bottom: 20rpx;
  850. width: 218rpx;
  851. height: 20rpx;
  852. }
  853. .content {
  854. position: absolute;
  855. left: 2rpx;
  856. right: 2rpx;
  857. bottom: 20rpx;
  858. padding: 0 20rpx;
  859. .btn {
  860. margin-left: 20rpx;
  861. padding: 0 28rpx;
  862. height: 60rpx;
  863. line-height: 60rpx;
  864. // background: #fff;
  865. color: #fff;
  866. font-size: 32rpx;
  867. text-align: center;
  868. font-weight: bold;
  869. &.disable {
  870. background: #ccc;
  871. }
  872. }
  873. }
  874. .status {
  875. width: 110rpx;
  876. height: 110rpx;
  877. position: absolute;
  878. right: 0;
  879. top: 0;
  880. z-index: 100;
  881. }
  882. .mode {
  883. position: absolute;
  884. left: 0;
  885. top: 0;
  886. padding: 0 20rpx;
  887. height: 52rpx;
  888. line-height: 52rpx;
  889. text-align: center;
  890. background: #49ffff;
  891. border-radius: 8px 0px 8px 0px;
  892. }
  893. .mask {
  894. position: absolute;
  895. left: 0;
  896. top: 0;
  897. right: 0;
  898. bottom: 0;
  899. background: rgba(0, 0, 0, 0.6);
  900. }
  901. }
  902. .filter-wrapper {
  903. width: 226rpx;
  904. height: 72rpx;
  905. position: relative;
  906. overflow: hidden;
  907. .image {
  908. position: absolute;
  909. left: 0;
  910. top: 0;
  911. width: 226rpx;
  912. height: 72rpx;
  913. }
  914. .text {
  915. color: #e0f2ff;
  916. font-size: 24rpx;
  917. position: relative;
  918. }
  919. .group-btn {
  920. // position: absolute;
  921. left: 0;
  922. top: 0;
  923. right: 0;
  924. bottom: 0;
  925. opacity: 0;
  926. }
  927. .arrow {
  928. width: 12rpx;
  929. height: 6rpx;
  930. margin-left: 6px;
  931. // position: absolute;
  932. // right: 30rpx;
  933. }
  934. }
  935. .filter-list-wrapper {
  936. position: absolute;
  937. width: 132px;
  938. background: rgba(0, 0, 0, 0.8);
  939. box-shadow: 0px 0px 8rpx 0px rgba(73, 255, 255, 0.5);
  940. border-radius: 12rpx;
  941. border: 1px solid rgba(174, 231, 255, 0.5);
  942. z-index: 1500;
  943. padding: 8px 0;
  944. .cell {
  945. height: 27px;
  946. text-align: center;
  947. color: #e0f2ff;
  948. font-size: 24rpx;
  949. }
  950. }
  951. .goTop {
  952. position: fixed;
  953. bottom: 120rpx;
  954. right: 9rpx;
  955. height: 98rpx;
  956. width: 68rpx;
  957. z-index: 1000;
  958. .goTopImg {
  959. height: 98rpx;
  960. width: 68rpx;
  961. }
  962. }
  963. .receiveBenefits {
  964. position: fixed;
  965. bottom: 240rpx;
  966. right: 0;
  967. width: 152rpx;
  968. height: 156rpx;
  969. z-index: 1000;
  970. }
  971. .active_list {
  972. position: fixed;
  973. right: 10rpx;
  974. bottom: 480rpx;
  975. width: 100rpx;
  976. height: 100rpx;
  977. }
  978. .group_gift {
  979. position: fixed;
  980. right: 14rpx;
  981. bottom: 210rpx;
  982. width: 100rpx;
  983. height: 130rpx;
  984. overflow: hidden;
  985. .group-btn {
  986. position: absolute;
  987. left: 0;
  988. top: 0;
  989. right: 0;
  990. bottom: 0;
  991. opacity: 0;
  992. }
  993. }
  994. .rule {
  995. width: 520rpx;
  996. // animation: scroll 3s linear infinite; /* 关键帧动画 */
  997. .rule-text {
  998. // overflow: hidden;
  999. overflow: hidden;
  1000. white-space: nowrap; /* 防止文字换行 */
  1001. text-overflow: ellipsis; /* 超出显示省略号 */
  1002. white-space: nowrap; /* 防止文字换行 */
  1003. // animation: scroll 15s linear infinite; /* 关键帧动画 */
  1004. }
  1005. @keyframes scroll {
  1006. from {
  1007. -webkit-transform: translateX(100%);
  1008. transform: translateX(100%);
  1009. }
  1010. to {
  1011. -webkit-transform: translateX(-300%);
  1012. transform: translateX(-300%);
  1013. }
  1014. }
  1015. }
  1016. .bannerSwiper {
  1017. width: 650rpx;
  1018. height: 220rpx;
  1019. padding: 20rpx 0;
  1020. .bannerBox {
  1021. border-radius: 14rpx;
  1022. overflow: hidden;
  1023. line-height: 0;
  1024. font-size: 0;
  1025. .image {
  1026. width: 650rpx;
  1027. height: 180rpx;
  1028. }
  1029. }
  1030. }
  1031. </style>