@pisell/pisellos 3.0.61 → 3.0.63

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -12,6 +12,7 @@ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol"
12
12
  function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
13
13
  import Decimal from 'decimal.js';
14
14
  import { isNormalProduct } from "../../Product/utils";
15
+ import { getDiscountAmount } from "../../../solution/ShopDiscount/utils";
15
16
 
16
17
  /**
17
18
  * @title 处理组合商品
@@ -192,8 +193,14 @@ export var getProductTotalPrice = function getProductTotalPrice(params) {
192
193
  // 不是商品券则代表折扣卡,计算打折后的价格
193
194
  // 一个商品折扣卡只能存在于一张
194
195
  if (currentValue.type !== 'good_pass') {
195
- var discountPrice = new Decimal(100).minus(currentValue.discount.percent || 0).div(100).mul(new Decimal(price || 0)).toFixed(2);
196
- price = Number(discountPrice);
196
+ var _currentValue$discoun;
197
+ price = getDiscountAmount({
198
+ tag: currentValue.type,
199
+ par_value: currentValue.discount.percent,
200
+ metadata: {
201
+ discount_card_type: currentValue === null || currentValue === void 0 || (_currentValue$discoun = currentValue.discount) === null || _currentValue$discoun === void 0 ? void 0 : _currentValue$discoun.discount_card_type
202
+ }
203
+ }, price, price);
197
204
  }
198
205
  });
199
206
  }
@@ -70,6 +70,9 @@ export interface Discount {
70
70
  limited_relation_product_data: Limitedrelationproductdata;
71
71
  balance: string;
72
72
  format_title: Formattitle;
73
+ metadata?: {
74
+ discount_card_type?: 'fixed_amount' | 'percent';
75
+ };
73
76
  product: Product;
74
77
  type: "product" | 'good_pass';
75
78
  resource_id?: number;
@@ -25,7 +25,7 @@ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol"
25
25
  function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
26
26
  import { BaseModule } from "../BaseModule";
27
27
  import { RulesHooks } from "./types";
28
- import { uniqueById } from "../../solution/ShopDiscount/utils";
28
+ import { uniqueById, getDiscountAmount } from "../../solution/ShopDiscount/utils";
29
29
  import { getProductOriginTotalPrice, getProductTotalPrice } from "../Cart/utils";
30
30
  import Decimal from 'decimal.js';
31
31
  export var RulesModule = /*#__PURE__*/function (_BaseModule) {
@@ -188,8 +188,12 @@ export var RulesModule = /*#__PURE__*/function (_BaseModule) {
188
188
  });
189
189
 
190
190
  // 优惠力度排序,传进来的数据里可能有商品券,也可能有优惠券
191
- // 商品券(n.tag=good_pass)视为最优惠(免费),折扣券(n.tag=product_discount_card)按照n.par_value排序
192
- // 如果最后拍出来商品券有多个,或者说没有商品券,但是有多个相同折扣的折扣券(比如 6 折券有 3张),则按照过期时间(n.expire_time)排序
191
+ // 1. 商品券(n.tag=good_pass)视为最优惠(免费)
192
+ // 2. 折扣券(n.tag=product_discount_card)按照新的优先级排序:
193
+ // - 固定金额优先于百分比(固定金额 > 百分比)
194
+ // - 固定金额内部:金额越大越优先
195
+ // - 百分比内部:折扣越大越优先(par_value越小越优先)
196
+ // 3. 相同类型和金额的情况下,按照过期时间(n.expire_time)排序
193
197
  var sortedDiscountList = _toConsumableArray(filteredDiscountList).sort(function (a, b) {
194
198
  // 1. 商品券优先级最高
195
199
  if (a.tag === 'good_pass' && b.tag !== 'good_pass') return -1;
@@ -200,13 +204,34 @@ export var RulesModule = /*#__PURE__*/function (_BaseModule) {
200
204
  // 都是商品券,按照过期时间排序
201
205
  return compareByExpireTime(a, b);
202
206
  } else if (a.tag === 'product_discount_card' && b.tag === 'product_discount_card') {
203
- // 都是折扣券,按照par_value排序(折扣越大越优先,即par_value越小越优先)
204
- if (a.par_value !== b.par_value) {
205
- var valueA = new Decimal(100).minus(a.par_value || 0);
206
- var valueB = new Decimal(100).minus(b.par_value || 0);
207
- return valueA.minus(valueB).toNumber();
207
+ var _a$metadata, _b$metadata;
208
+ // 都是折扣券,按照新的优先级排序:固定金额优先于百分比
209
+ var typeA = ((_a$metadata = a.metadata) === null || _a$metadata === void 0 ? void 0 : _a$metadata.discount_card_type) || 'percent'; // 默认为百分比
210
+ var typeB = ((_b$metadata = b.metadata) === null || _b$metadata === void 0 ? void 0 : _b$metadata.discount_card_type) || 'percent'; // 默认为百分比
211
+
212
+ // 1. 固定金额优先于百分比
213
+ if (typeA === 'fixed_amount' && typeB === 'percent') return -1;
214
+ if (typeA === 'percent' && typeB === 'fixed_amount') return 1;
215
+
216
+ // 2. 都是固定金额时,金额越大越优先
217
+ if (typeA === 'fixed_amount' && typeB === 'fixed_amount') {
218
+ if (a.par_value !== b.par_value) {
219
+ var valueA = new Decimal(a.par_value || 0);
220
+ var valueB = new Decimal(b.par_value || 0);
221
+ return valueB.minus(valueA).toNumber(); // 金额大的在前
222
+ }
208
223
  }
209
- // 相同折扣的情况下,按照过期时间排序
224
+
225
+ // 3. 都是百分比时,折扣越大越优先(par_value越小越优先)
226
+ if (typeA === 'percent' && typeB === 'percent') {
227
+ if (a.par_value !== b.par_value) {
228
+ var _valueA = new Decimal(100).minus(a.par_value || 0);
229
+ var _valueB = new Decimal(100).minus(b.par_value || 0);
230
+ return _valueB.minus(_valueA).toNumber(); // 折扣大的在前
231
+ }
232
+ }
233
+
234
+ // 相同类型和金额的情况下,按照过期时间排序
210
235
  return compareByExpireTime(a, b);
211
236
  }
212
237
 
@@ -290,7 +315,7 @@ export var RulesModule = /*#__PURE__*/function (_BaseModule) {
290
315
 
291
316
  // 判断优惠券是否适用于该商品
292
317
  if (isAvailableProduct && isLimitedProduct) {
293
- var _discountApplicabilit;
318
+ var _discountApplicabilit, _discount$metadata;
294
319
  // 记录此优惠券适用的商品
295
320
  (_discountApplicabilit = discountApplicability.get(discount.id)) === null || _discountApplicabilit === void 0 || _discountApplicabilit.push(product.id);
296
321
 
@@ -301,6 +326,8 @@ export var RulesModule = /*#__PURE__*/function (_BaseModule) {
301
326
  type: discount.tag || discount.type,
302
327
  tag: discount.tag || discount.type,
303
328
  discount: {
329
+ discount_card_type: discount === null || discount === void 0 || (_discount$metadata = discount.metadata) === null || _discount$metadata === void 0 ? void 0 : _discount$metadata.discount_card_type,
330
+ fixed_amount: product.price,
304
331
  resource_id: discount.id,
305
332
  title: discount.format_title,
306
333
  original_amount: product.origin_total,
@@ -427,7 +454,7 @@ export var RulesModule = /*#__PURE__*/function (_BaseModule) {
427
454
  }));
428
455
  }
429
456
  for (var _i = 0; _i < splitCount; _i++) {
430
- var _product$discount_lis11, _originProduct$_produ;
457
+ var _product$discount_lis11, _originProduct$_produ, _selectedDiscount$met;
431
458
  // 如果用过折扣卡,也就不存在拆分的情况了,这里直接使用上面计算出来的折扣卡
432
459
  var _selectedDiscount = selectedDiscountCard || applicableDiscounts[_i];
433
460
  // 标记优惠券为已使用
@@ -448,11 +475,13 @@ export var RulesModule = /*#__PURE__*/function (_BaseModule) {
448
475
  }
449
476
 
450
477
  // 计算使用折扣卡/商品券以后,单个商品的总 total
451
- var targetProductTotal = _selectedDiscount.tag === 'good_pass' ? new Decimal(productOriginTotal).minus(new Decimal(product.price || 0)).toNumber() : new Decimal(100).minus(_selectedDiscount.par_value || 0).div(100).mul(new Decimal(productOriginTotal)).toNumber();
478
+ var targetProductTotal = getDiscountAmount(_selectedDiscount, productOriginTotal, product.price);
452
479
  var discountDetail = {
453
480
  amount: new Decimal(productOriginTotal).minus(new Decimal(targetProductTotal)).toNumber(),
454
481
  type: _selectedDiscount.tag === 'product_discount_card' ? 'discount_card' : _selectedDiscount.tag,
455
482
  discount: {
483
+ discount_card_type: _selectedDiscount === null || _selectedDiscount === void 0 || (_selectedDiscount$met = _selectedDiscount.metadata) === null || _selectedDiscount$met === void 0 ? void 0 : _selectedDiscount$met.discount_card_type,
484
+ fixed_amount: new Decimal(productOriginTotal).minus(new Decimal(targetProductTotal)).toNumber(),
456
485
  resource_id: _selectedDiscount.id,
457
486
  title: _selectedDiscount.format_title,
458
487
  original_amount: productOriginTotal,
@@ -1 +1,12 @@
1
+ import { Discount } from "../../modules/Discount/types";
1
2
  export declare const uniqueById: <T>(arr: T[], key?: string) => T[];
3
+ /**
4
+ * 获取折扣金额 基于折扣卡类型计算
5
+ * 商品券:直接返回商品价格
6
+ * 折扣卡:根据折扣卡类型计算 固定金额:直接返回折扣卡金额 百分比:根据折扣卡金额计算
7
+ * @param discount
8
+ * @param total
9
+ * @param price
10
+ * @returns
11
+ */
12
+ export declare const getDiscountAmount: (discount: Discount, total: number, price: number) => number;
@@ -1,7 +1,36 @@
1
+ import Decimal from "decimal.js";
1
2
  export var uniqueById = function uniqueById(arr) {
2
3
  var key = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'id';
3
4
  var seen = new Set();
4
5
  return arr.filter(function (item) {
5
6
  return !seen.has(item[key]) && seen.add(item[key]);
6
7
  });
8
+ };
9
+
10
+ /**
11
+ * 获取折扣金额 基于折扣卡类型计算
12
+ * 商品券:直接返回商品价格
13
+ * 折扣卡:根据折扣卡类型计算 固定金额:直接返回折扣卡金额 百分比:根据折扣卡金额计算
14
+ * @param discount
15
+ * @param total
16
+ * @param price
17
+ * @returns
18
+ */
19
+ export var getDiscountAmount = function getDiscountAmount(discount, total, price) {
20
+ var _discount$metadata;
21
+ // 商品券
22
+ if (discount.tag === 'good_pass') {
23
+ return new Decimal(total).minus(new Decimal(price || 0)).toNumber();
24
+ }
25
+
26
+ // 判断是否是固定金额
27
+ var isFixedAmount = (discount === null || discount === void 0 || (_discount$metadata = discount.metadata) === null || _discount$metadata === void 0 ? void 0 : _discount$metadata.discount_card_type) === 'fixed_amount';
28
+
29
+ // 固定金额 小于0时返回0
30
+ if (isFixedAmount) {
31
+ return Math.max(new Decimal(total).minus(new Decimal(discount.par_value || 0)).toNumber(), 0);
32
+ }
33
+
34
+ // 百分比:根据折扣卡金额计算
35
+ return new Decimal(100).minus(discount.par_value || 0).div(100).mul(new Decimal(total)).toNumber();
7
36
  };
@@ -44,6 +44,7 @@ __export(cartProduct_exports, {
44
44
  module.exports = __toCommonJS(cartProduct_exports);
45
45
  var import_decimal = __toESM(require("decimal.js"));
46
46
  var import_utils = require("../../Product/utils");
47
+ var import_utils2 = require("../../../solution/ShopDiscount/utils");
47
48
  var handleVariantProduct = (product) => {
48
49
  var _a;
49
50
  if (product == null ? void 0 : product.product_variant_id) {
@@ -183,9 +184,15 @@ var getProductTotalPrice = (params) => {
183
184
  }
184
185
  if (discounts == null ? void 0 : discounts.length) {
185
186
  discounts.forEach((currentValue) => {
187
+ var _a;
186
188
  if (currentValue.type !== "good_pass") {
187
- const discountPrice = new import_decimal.default(100).minus(currentValue.discount.percent || 0).div(100).mul(new import_decimal.default(price || 0)).toFixed(2);
188
- price = Number(discountPrice);
189
+ price = (0, import_utils2.getDiscountAmount)({
190
+ tag: currentValue.type,
191
+ par_value: currentValue.discount.percent,
192
+ metadata: {
193
+ discount_card_type: (_a = currentValue == null ? void 0 : currentValue.discount) == null ? void 0 : _a.discount_card_type
194
+ }
195
+ }, price, price);
189
196
  }
190
197
  });
191
198
  }
@@ -70,6 +70,9 @@ export interface Discount {
70
70
  limited_relation_product_data: Limitedrelationproductdata;
71
71
  balance: string;
72
72
  format_title: Formattitle;
73
+ metadata?: {
74
+ discount_card_type?: 'fixed_amount' | 'percent';
75
+ };
73
76
  product: Product;
74
77
  type: "product" | 'good_pass';
75
78
  resource_id?: number;
@@ -131,6 +131,7 @@ var RulesModule = class extends import_BaseModule.BaseModule {
131
131
  return !discount.isManualSelect;
132
132
  });
133
133
  const sortedDiscountList = [...filteredDiscountList].sort((a, b) => {
134
+ var _a, _b;
134
135
  if (a.tag === "good_pass" && b.tag !== "good_pass")
135
136
  return -1;
136
137
  if (b.tag === "good_pass" && a.tag !== "good_pass")
@@ -138,10 +139,25 @@ var RulesModule = class extends import_BaseModule.BaseModule {
138
139
  if (a.tag === "good_pass" && b.tag === "good_pass") {
139
140
  return compareByExpireTime(a, b);
140
141
  } else if (a.tag === "product_discount_card" && b.tag === "product_discount_card") {
141
- if (a.par_value !== b.par_value) {
142
- const valueA = new import_decimal.default(100).minus(a.par_value || 0);
143
- const valueB = new import_decimal.default(100).minus(b.par_value || 0);
144
- return valueA.minus(valueB).toNumber();
142
+ const typeA = ((_a = a.metadata) == null ? void 0 : _a.discount_card_type) || "percent";
143
+ const typeB = ((_b = b.metadata) == null ? void 0 : _b.discount_card_type) || "percent";
144
+ if (typeA === "fixed_amount" && typeB === "percent")
145
+ return -1;
146
+ if (typeA === "percent" && typeB === "fixed_amount")
147
+ return 1;
148
+ if (typeA === "fixed_amount" && typeB === "fixed_amount") {
149
+ if (a.par_value !== b.par_value) {
150
+ const valueA = new import_decimal.default(a.par_value || 0);
151
+ const valueB = new import_decimal.default(b.par_value || 0);
152
+ return valueB.minus(valueA).toNumber();
153
+ }
154
+ }
155
+ if (typeA === "percent" && typeB === "percent") {
156
+ if (a.par_value !== b.par_value) {
157
+ const valueA = new import_decimal.default(100).minus(a.par_value || 0);
158
+ const valueB = new import_decimal.default(100).minus(b.par_value || 0);
159
+ return valueB.minus(valueA).toNumber();
160
+ }
145
161
  }
146
162
  return compareByExpireTime(a, b);
147
163
  }
@@ -181,7 +197,7 @@ var RulesModule = class extends import_BaseModule.BaseModule {
181
197
  sortedProductList.forEach((originProduct) => {
182
198
  const product = this.hooks.getProduct(originProduct);
183
199
  addModeDiscount.forEach((discount) => {
184
- var _a, _b, _c;
200
+ var _a, _b, _c, _d;
185
201
  const limitedData = discount == null ? void 0 : discount.limited_relation_product_data;
186
202
  const isLimitedProduct = limitedData.type === "product_all" || limitedData.product_ids && limitedData.product_ids.includes(product.id);
187
203
  const isAvailableProduct = !((product == null ? void 0 : product.booking_id) && ((_a = product == null ? void 0 : product.discount_list) == null ? void 0 : _a.length) && ((_b = product == null ? void 0 : product.discount_list) == null ? void 0 : _b.every((discount2) => discount2.id && ["good_pass", "discount_card", "product_discount_card"].includes(discount2.tag || discount2.type))));
@@ -193,6 +209,8 @@ var RulesModule = class extends import_BaseModule.BaseModule {
193
209
  type: discount.tag || discount.type,
194
210
  tag: discount.tag || discount.type,
195
211
  discount: {
212
+ discount_card_type: (_d = discount == null ? void 0 : discount.metadata) == null ? void 0 : _d.discount_card_type,
213
+ fixed_amount: product.price,
196
214
  resource_id: discount.id,
197
215
  title: discount.format_title,
198
216
  original_amount: product.origin_total,
@@ -207,7 +225,7 @@ var RulesModule = class extends import_BaseModule.BaseModule {
207
225
  });
208
226
  console.log(sortedProductList, "sortedProductListsortedProductList");
209
227
  sortedProductList.forEach((originProduct, i) => {
210
- var _a, _b, _c, _d, _e, _f, _g, _h;
228
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i;
211
229
  const product = this.hooks.getProduct(originProduct);
212
230
  if ((product == null ? void 0 : product.booking_id) && ((_a = product.discount_list) == null ? void 0 : _a.length) && ((_b = product == null ? void 0 : product.discount_list) == null ? void 0 : _b.every((discount) => discount.id && ["good_pass", "discount_card", "product_discount_card"].includes(discount.tag || discount.type)))) {
213
231
  processedProductsMap.set(product._id, [originProduct]);
@@ -308,11 +326,13 @@ var RulesModule = class extends import_BaseModule.BaseModule {
308
326
  if (Number(((_h = originProduct == null ? void 0 : originProduct._productInit) == null ? void 0 : _h.original_price) || 0) > 0 && product.origin_total && product.total && product.origin_total !== product.total) {
309
327
  productOriginTotal = product.total;
310
328
  }
311
- const targetProductTotal = selectedDiscount2.tag === "good_pass" ? new import_decimal.default(productOriginTotal).minus(new import_decimal.default(product.price || 0)).toNumber() : new import_decimal.default(100).minus(selectedDiscount2.par_value || 0).div(100).mul(new import_decimal.default(productOriginTotal)).toNumber();
329
+ const targetProductTotal = (0, import_utils.getDiscountAmount)(selectedDiscount2, productOriginTotal, product.price);
312
330
  const discountDetail = {
313
331
  amount: new import_decimal.default(productOriginTotal).minus(new import_decimal.default(targetProductTotal)).toNumber(),
314
332
  type: selectedDiscount2.tag === "product_discount_card" ? "discount_card" : selectedDiscount2.tag,
315
333
  discount: {
334
+ discount_card_type: (_i = selectedDiscount2 == null ? void 0 : selectedDiscount2.metadata) == null ? void 0 : _i.discount_card_type,
335
+ fixed_amount: new import_decimal.default(productOriginTotal).minus(new import_decimal.default(targetProductTotal)).toNumber(),
316
336
  resource_id: selectedDiscount2.id,
317
337
  title: selectedDiscount2.format_title,
318
338
  original_amount: productOriginTotal,
@@ -1 +1,12 @@
1
+ import { Discount } from "../../modules/Discount/types";
1
2
  export declare const uniqueById: <T>(arr: T[], key?: string) => T[];
3
+ /**
4
+ * 获取折扣金额 基于折扣卡类型计算
5
+ * 商品券:直接返回商品价格
6
+ * 折扣卡:根据折扣卡类型计算 固定金额:直接返回折扣卡金额 百分比:根据折扣卡金额计算
7
+ * @param discount
8
+ * @param total
9
+ * @param price
10
+ * @returns
11
+ */
12
+ export declare const getDiscountAmount: (discount: Discount, total: number, price: number) => number;
@@ -1,6 +1,8 @@
1
+ var __create = Object.create;
1
2
  var __defProp = Object.defineProperty;
2
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
4
6
  var __hasOwnProp = Object.prototype.hasOwnProperty;
5
7
  var __export = (target, all) => {
6
8
  for (var name in all)
@@ -14,19 +16,41 @@ var __copyProps = (to, from, except, desc) => {
14
16
  }
15
17
  return to;
16
18
  };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
17
27
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
28
 
19
29
  // src/solution/ShopDiscount/utils.ts
20
30
  var utils_exports = {};
21
31
  __export(utils_exports, {
32
+ getDiscountAmount: () => getDiscountAmount,
22
33
  uniqueById: () => uniqueById
23
34
  });
24
35
  module.exports = __toCommonJS(utils_exports);
36
+ var import_decimal = __toESM(require("decimal.js"));
25
37
  var uniqueById = (arr, key = "id") => {
26
38
  const seen = /* @__PURE__ */ new Set();
27
39
  return arr.filter((item) => !seen.has(item[key]) && seen.add(item[key]));
28
40
  };
41
+ var getDiscountAmount = (discount, total, price) => {
42
+ var _a;
43
+ if (discount.tag === "good_pass") {
44
+ return new import_decimal.default(total).minus(new import_decimal.default(price || 0)).toNumber();
45
+ }
46
+ const isFixedAmount = ((_a = discount == null ? void 0 : discount.metadata) == null ? void 0 : _a.discount_card_type) === "fixed_amount";
47
+ if (isFixedAmount) {
48
+ return Math.max(new import_decimal.default(total).minus(new import_decimal.default(discount.par_value || 0)).toNumber(), 0);
49
+ }
50
+ return new import_decimal.default(100).minus(discount.par_value || 0).div(100).mul(new import_decimal.default(total)).toNumber();
51
+ };
29
52
  // Annotate the CommonJS export names for ESM import in node:
30
53
  0 && (module.exports = {
54
+ getDiscountAmount,
31
55
  uniqueById
32
56
  });
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "private": false,
3
3
  "name": "@pisell/pisellos",
4
- "version": "3.0.61",
4
+ "version": "3.0.63",
5
5
  "description": "一个可扩展的前端模块化SDK框架,支持插件系统",
6
6
  "main": "dist/index.js",
7
7
  "types": "dist/index.d.ts",