s-coupon-block.js 5.4 KB

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