index.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. <template>
  2. <!-- 优惠券 -->
  3. <view class="couponBox">
  4. <view class="acea-row row-around navCoupon" :class="navShow ? 'headerfixed' : ''" :style="{ top: statusBarHeight+44 + 'px' }">
  5. <template>
  6. <view v-for="(item,index) in navList" :key="index"
  7. :class="['acea-row', 'row-middle', type === item.type ? 'on' : '']">
  8. <text @click="setType(item.type)">{{item.name}}</text>
  9. </view>
  10. </template>
  11. </view>
  12. <view v-if="couponsList.length" class="coupon coupon-list">
  13. <view v-for="(item,index) in couponsList" :key="index" class="item">
  14. <!-- :class="{gary:item.isUse}" -->
  15. <view class="left main_bg">
  16. <view class="money">
  17. <text>¥{{ item.money }}</text>
  18. <view class="pic-num" v-if="parseFloat(item.minPrice)>0">
  19. 满{{ item.minPrice?Number(item.minPrice):'' }}可用</view>
  20. </view>
  21. </view>
  22. <view class="right">
  23. <view class="name line2">
  24. <text>{{item.category===1?'商家券':'商品券'}}</text>
  25. {{ item.name }}
  26. </view>
  27. <view class="time-wrap" style="justify-content: space-between;">
  28. <block v-if="item.isFixedTime">
  29. <view class="time">
  30. {{ item.useStartTimeStr | dateFormat }}-{{ item.useEndTimeStr | dateFormat }}
  31. </view>
  32. </block>
  33. <block v-else>
  34. <view>{{'领取后'+ item.day+ '天内可用'}}</view>
  35. </block>
  36. <block v-if="item.isUse">
  37. <view class='getgray iconfont icon-yilingqu1'></view>
  38. </block>
  39. <block v-else>
  40. <view class="button" @click="receiveCoupon(item)">领取</view>
  41. </block>
  42. </view>
  43. </view>
  44. </view>
  45. </view>
  46. <view class='loadingicon acea-row row-center-wrapper'>
  47. <text class='loading iconfont icon-jiazai'
  48. :hidden='loadingcoupon==false'></text>{{couponsList.length?loadTitle:''}}
  49. </view>
  50. <emptyPage v-if="couponsList.length == 0 && !loadingcoupon" title="暂无可用优惠券~"
  51. :imgSrc="urlDomain+'crmebimage/presets/noCoupon.png'"></emptyPage>
  52. </view>
  53. </template>
  54. <script>
  55. import {
  56. getCoupons,
  57. setCouponReceive,
  58. } from '@/api/api.js';
  59. var statusBarHeight = uni.getSystemInfoSync().statusBarHeight;
  60. export default {
  61. data() {
  62. return {
  63. merid: 0,
  64. couponsList: [],
  65. navList: [{
  66. type: 1,
  67. name: '商家券',
  68. count: 0
  69. },
  70. {
  71. type: 2,
  72. name: '商品券',
  73. count: 0
  74. }
  75. ],
  76. urlDomain: this.$Cache.get("imgHost"),
  77. loadendcoupon: false,
  78. loadingcoupon: false,
  79. page: 1,
  80. limit: 10,
  81. type: 1,
  82. statusBarHeight: 0,
  83. navShow: false,
  84. }
  85. },
  86. onShow() {
  87. // #ifdef MP || APP-PLUS
  88. this.statusBarHeight = statusBarHeight;
  89. // #endif
  90. // #ifdef H5
  91. this.statusBarHeight = 20;
  92. // #endif
  93. },
  94. onLoad(options) {
  95. this.merid = parseInt(options.merid)
  96. },
  97. mounted() {
  98. this.getCoupon()
  99. },
  100. methods: {
  101. // 领取优惠券
  102. receiveCoupon(item) {
  103. let that = this;
  104. if (that.isLogin === false) {
  105. toLogin();
  106. } else {
  107. uni.showLoading({
  108. title: '加载中...'
  109. });
  110. setCouponReceive(item.id).then(res => {
  111. uni.showToast({
  112. title: '领取成功',
  113. icon: 'none'
  114. })
  115. uni.hideLoading();
  116. item.isUse = !item.isUse
  117. }).catch(err => {
  118. uni.showToast({
  119. title: err,
  120. icon: 'none'
  121. })
  122. uni.hideLoading();
  123. })
  124. }
  125. },
  126. setType: function(type) {
  127. if (this.type !== type) {
  128. this.type = type;
  129. this.couponsList = [];
  130. this.page = 1;
  131. this.loadendcoupon = false;
  132. this.getCoupon();
  133. }
  134. },
  135. // 获取商铺优惠券
  136. getCoupon: function() {
  137. let that = this
  138. if (that.loadendcoupon) return false;
  139. if (that.loadingcoupon) return false;
  140. that.loadingcoupon = true;
  141. getCoupons({
  142. page: that.page,
  143. limit: that.limit,
  144. category: this.type,
  145. merId: this.merid
  146. }).then(res => {
  147. let list = res.data.list,
  148. loadend = list.length < that.limit;
  149. let couponsList = that.$util.SplitArray(list, that.couponsList);
  150. that.$set(that, 'couponsList', couponsList);
  151. that.loadendcoupon = loadend;
  152. that.loadTitle = loadend ? '我也是有底线的' : '显示更多';
  153. that.page = that.page + 1;
  154. that.loadingcoupon = false;
  155. that.isShow = true;
  156. }).catch(err => {
  157. that.loadingcoupon = false;
  158. that.loadTitle = '显示更多';
  159. });
  160. },
  161. }
  162. }
  163. </script>
  164. <style lang="scss" scoped>
  165. .coupon-list {
  166. margin-top: 0;
  167. .right {
  168. position: relative;
  169. overflow: hidden;
  170. }
  171. }
  172. .couponBox {
  173. /deep/.empty-box {
  174. padding-top: 200rpx;
  175. margin-top: 0 !important;
  176. }
  177. }
  178. .navCoupon {
  179. width: 100%;
  180. height: 80rpx;
  181. color: #999999;
  182. background-color: #fff;
  183. }
  184. .navCoupon .acea-row {
  185. border-top: 5rpx solid transparent;
  186. border-bottom: 5rpx solid transparent;
  187. cursor: pointer;
  188. }
  189. .navCoupon .acea-row.on {
  190. @include tab_border_bottom(theme);
  191. @include main_color(theme);
  192. }
  193. .coupon {
  194. padding: 24rpx;
  195. background-color: #F5F5F5;
  196. .item {
  197. display: flex;
  198. margin-bottom: 16rpx;
  199. .left {
  200. display: flex;
  201. flex-direction: column;
  202. justify-content: center;
  203. align-items: center;
  204. width: 240rpx;
  205. font-weight: 500;
  206. font-size: 24rpx;
  207. line-height: 1;
  208. color: #FFFFFF;
  209. &.gary {
  210. background-image: url('');
  211. }
  212. .money {
  213. text {
  214. margin-left: 10rpx;
  215. font-size: 60rpx;
  216. }
  217. }
  218. }
  219. .right {
  220. flex: 1;
  221. min-width: 0;
  222. padding: 0 20rpx;
  223. background-color: #FFFFFF;
  224. .name {
  225. border-bottom: 1rpx solid #F0F0F0;
  226. font-weight: 500;
  227. height: 115rpx;
  228. font-size: 30;
  229. line-height: 46rpx;
  230. color: #282828;
  231. padding: 15rpx 0;
  232. text {
  233. display: inline-block;
  234. // width: 84rpx;
  235. // height: 28rpx;
  236. padding: 0 10rpx;
  237. border-radius: 14rpx;
  238. margin-right: 15rpx;
  239. background-color: #FFF4F3;
  240. font-weight: 500;
  241. font-size: 20rpx;
  242. line-height: 26rpx;
  243. text-align: center;
  244. @include main_color(theme);
  245. @include coupons_border_color(theme);
  246. &.gary {
  247. border-color: #BBB;
  248. color: #bbb;
  249. background-color: #F5F5F5;
  250. }
  251. }
  252. }
  253. .time-wrap {
  254. display: flex;
  255. align-items: center;
  256. padding-top: 16rpx;
  257. padding-bottom: 16rpx;
  258. font-weight: 500;
  259. font-size: 20rpx;
  260. color: #999999;
  261. .time {
  262. flex: 1;
  263. min-width: 0;
  264. }
  265. .button {
  266. width: 136rpx;
  267. height: 44rpx;
  268. border-radius: 22rpx;
  269. @include main_bg_color(theme);
  270. font-weight: 500;
  271. font-size: 22rpx;
  272. line-height: 44rpx;
  273. text-align: center;
  274. color: #FFFFFF;
  275. &.gary {
  276. background-color: #999;
  277. }
  278. }
  279. }
  280. }
  281. }
  282. .disabled {
  283. .left {
  284. background-image: url(../static/images/coupon2.png);
  285. }
  286. .right {
  287. .name {
  288. text {
  289. border-color: #C1C1C1;
  290. color: #C1C1C1;
  291. }
  292. }
  293. .time-wrap {
  294. .button {
  295. background-color: #CCCCCC;
  296. color: #FFFFFF;
  297. }
  298. }
  299. }
  300. }
  301. }
  302. </style>