s-coupon-block.js 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. "use strict";
  2. const common_vendor = require("../../../common/vendor.js");
  3. const sheep_index = require("../../index.js");
  4. const sheep_api_promotion_coupon = require("../../api/promotion/coupon.js");
  5. const sheep_util_const = require("../../util/const.js");
  6. const sheep_util_index = require("../../util/index.js");
  7. require("../../api/index.js");
  8. require("../../api/distri/score.js");
  9. require("../../request/index.js");
  10. require("../../config/index.js");
  11. require("../../store/index.js");
  12. require("../../store/app.js");
  13. require("../../api/promotion/diy.js");
  14. require("../../platform/index.js");
  15. require("../../platform/provider/wechat/index.js");
  16. require("../../platform/provider/wechat/miniProgram.js");
  17. require("../../api/member/auth.js");
  18. require("../../api/member/social.js");
  19. require("../../api/member/user.js");
  20. require("../../platform/provider/apple/index.js");
  21. require("../../platform/share.js");
  22. require("../../router/index.js");
  23. require("../../hooks/useModal.js");
  24. require("../../helper/index.js");
  25. require("../../helper/test.js");
  26. require("../../helper/digit.js");
  27. require("../../api/member/signin.js");
  28. require("../../helper/throttle.js");
  29. require("../../url/index.js");
  30. require("../../platform/pay.js");
  31. require("../../api/pay/order.js");
  32. require("../../store/user.js");
  33. require("../../store/cart.js");
  34. require("../../api/trade/cart.js");
  35. require("../../api/pay/wallet.js");
  36. require("../../api/trade/order.js");
  37. require("../../store/sys.js");
  38. require("../../store/modal.js");
  39. require("../../api/distri/share.js");
  40. require("../../api/distri/team.js");
  41. require("../../api/infra/file.js");
  42. require("../../api/member/address.js");
  43. require("../../api/member/point.js");
  44. require("../../api/migration/app.js");
  45. require("../../api/migration/chat.js");
  46. require("../../api/migration/index.js");
  47. require("../../api/migration/third.js");
  48. require("../../api/pay/channel.js");
  49. require("../../api/product/category.js");
  50. require("../../api/product/comment.js");
  51. require("../../api/product/favorite.js");
  52. require("../../api/product/history.js");
  53. require("../../api/product/spu.js");
  54. require("../../api/promotion/activity.js");
  55. require("../../api/promotion/article.js");
  56. require("../../api/promotion/bargain.js");
  57. require("../../api/promotion/combination.js");
  58. require("../../api/promotion/rewardActivity.js");
  59. require("../../api/promotion/seckill.js");
  60. require("../../api/system/area.js");
  61. require("../../api/system/voice.js");
  62. require("../../api/trade/afterSale.js");
  63. require("../../api/trade/brokerage.js");
  64. require("../../api/trade/config.js");
  65. require("../../api/trade/delivery.js");
  66. require("../../config/zIndex.js");
  67. if (!Array) {
  68. const _easycom_su_coupon2 = common_vendor.resolveComponent("su-coupon");
  69. _easycom_su_coupon2();
  70. }
  71. const _easycom_su_coupon = () => "../../ui/su-coupon/su-coupon.js";
  72. if (!Math) {
  73. _easycom_su_coupon();
  74. }
  75. const _sfc_main = {
  76. __name: "s-coupon-block",
  77. props: {
  78. data: {
  79. type: Object,
  80. default: () => ({})
  81. },
  82. styles: {
  83. type: Object,
  84. default: () => ({})
  85. }
  86. },
  87. setup(__props) {
  88. const props = __props;
  89. const { columns, button } = props.data;
  90. const SIZE_LIST = ["lg", "md", "xs"];
  91. const couponBg = {
  92. background: `url(${sheep_index.sheep.$url.cdn(props.data.bgImg)}) no-repeat top center / 100% 100%`
  93. };
  94. const btnStyles = {
  95. background: button.bgColor,
  96. color: button.color
  97. };
  98. const formatCouponDiscountType = (coupon) => {
  99. if (coupon.discountType === sheep_util_const.PromotionDiscountTypeEnum.PRICE.type) {
  100. return "reduce";
  101. }
  102. if (coupon.discountType === sheep_util_const.PromotionDiscountTypeEnum.PERCENT.type) {
  103. return "percent";
  104. }
  105. return `未知【${coupon.discountType}】`;
  106. };
  107. const formatCouponDiscountValue = (coupon) => {
  108. if (coupon.discountType === sheep_util_const.PromotionDiscountTypeEnum.PRICE.type) {
  109. return sheep_util_index.floatToFixed2(coupon.discountPrice);
  110. }
  111. if (coupon.discountType === sheep_util_const.PromotionDiscountTypeEnum.PERCENT.type) {
  112. return coupon.discountPercent;
  113. }
  114. return `未知【${coupon.discountType}】`;
  115. };
  116. const formatValidityType = (row) => {
  117. if (row.validityType === sheep_util_const.CouponTemplateValidityTypeEnum.DATE.type) {
  118. return `${sheep_util_index.formatDate(row.validStartTime)} 至 ${sheep_util_index.formatDate(row.validEndTime)}`;
  119. }
  120. if (row.validityType === sheep_util_const.CouponTemplateValidityTypeEnum.TERM.type) {
  121. return `领取后第 ${row.fixedStartTerm} - ${row.fixedEndTerm} 天内可用`;
  122. }
  123. return "未知【" + row.validityType + "】";
  124. };
  125. const couponList = common_vendor.ref([]);
  126. async function onGetCoupon(id) {
  127. const { error, msg } = await sheep_api_promotion_coupon.CouponApi.takeCoupon(id);
  128. if (error === 0) {
  129. common_vendor.index.showToast({
  130. title: msg,
  131. icon: "none"
  132. });
  133. return;
  134. }
  135. await getCouponTemplateList();
  136. }
  137. const getCouponTemplateList = async () => {
  138. const { data } = await sheep_api_promotion_coupon.CouponApi.getCouponTemplateListByIds(props.data.couponIds.join(","));
  139. couponList.value = data;
  140. };
  141. common_vendor.onMounted(() => {
  142. getCouponTemplateList();
  143. });
  144. return (_ctx, _cache) => {
  145. return {
  146. a: common_vendor.f(couponList.value, (item, index, i0) => {
  147. return common_vendor.e(common_vendor.unref(columns) === 2 ? {
  148. a: common_vendor.o(($event) => onGetCoupon(item.id), index),
  149. b: common_vendor.s(btnStyles)
  150. } : {
  151. c: common_vendor.s(btnStyles),
  152. d: common_vendor.o(($event) => onGetCoupon(item.id), index)
  153. }, {
  154. e: "6b61b8da-0-" + i0,
  155. f: common_vendor.p({
  156. size: SIZE_LIST[common_vendor.unref(columns) - 1],
  157. textColor: __props.data.textColor,
  158. background: "",
  159. couponId: item.id,
  160. title: item.name,
  161. type: formatCouponDiscountType(item),
  162. value: formatCouponDiscountValue(item),
  163. sellBy: formatValidityType(item)
  164. }),
  165. g: index
  166. });
  167. }),
  168. b: common_vendor.unref(columns) === 2,
  169. c: common_vendor.s(couponBg),
  170. d: common_vendor.s({
  171. marginLeft: `${__props.data.space}px`
  172. })
  173. };
  174. };
  175. }
  176. };
  177. const Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["__scopeId", "data-v-6b61b8da"], ["__file", "D:/zx/mall-front-app/sheep/components/s-coupon-block/s-coupon-block.vue"]]);
  178. wx.createComponent(Component);