@pisell/pisellos 3.0.61 → 3.0.62

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,7 @@ 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,
304
330
  resource_id: discount.id,
305
331
  title: discount.format_title,
306
332
  original_amount: product.origin_total,
@@ -427,7 +453,7 @@ export var RulesModule = /*#__PURE__*/function (_BaseModule) {
427
453
  }));
428
454
  }
429
455
  for (var _i = 0; _i < splitCount; _i++) {
430
- var _product$discount_lis11, _originProduct$_produ;
456
+ var _product$discount_lis11, _originProduct$_produ, _selectedDiscount$met;
431
457
  // 如果用过折扣卡,也就不存在拆分的情况了,这里直接使用上面计算出来的折扣卡
432
458
  var _selectedDiscount = selectedDiscountCard || applicableDiscounts[_i];
433
459
  // 标记优惠券为已使用
@@ -448,11 +474,12 @@ export var RulesModule = /*#__PURE__*/function (_BaseModule) {
448
474
  }
449
475
 
450
476
  // 计算使用折扣卡/商品券以后,单个商品的总 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();
477
+ var targetProductTotal = getDiscountAmount(_selectedDiscount, productOriginTotal, product.price);
452
478
  var discountDetail = {
453
479
  amount: new Decimal(productOriginTotal).minus(new Decimal(targetProductTotal)).toNumber(),
454
480
  type: _selectedDiscount.tag === 'product_discount_card' ? 'discount_card' : _selectedDiscount.tag,
455
481
  discount: {
482
+ discount_card_type: _selectedDiscount === null || _selectedDiscount === void 0 || (_selectedDiscount$met = _selectedDiscount.metadata) === null || _selectedDiscount$met === void 0 ? void 0 : _selectedDiscount$met.discount_card_type,
456
483
  resource_id: _selectedDiscount.id,
457
484
  title: _selectedDiscount.format_title,
458
485
  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,7 @@ 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,
196
213
  resource_id: discount.id,
197
214
  title: discount.format_title,
198
215
  original_amount: product.origin_total,
@@ -207,7 +224,7 @@ var RulesModule = class extends import_BaseModule.BaseModule {
207
224
  });
208
225
  console.log(sortedProductList, "sortedProductListsortedProductList");
209
226
  sortedProductList.forEach((originProduct, i) => {
210
- var _a, _b, _c, _d, _e, _f, _g, _h;
227
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i;
211
228
  const product = this.hooks.getProduct(originProduct);
212
229
  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
230
  processedProductsMap.set(product._id, [originProduct]);
@@ -308,11 +325,12 @@ var RulesModule = class extends import_BaseModule.BaseModule {
308
325
  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
326
  productOriginTotal = product.total;
310
327
  }
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();
328
+ const targetProductTotal = (0, import_utils.getDiscountAmount)(selectedDiscount2, productOriginTotal, product.price);
312
329
  const discountDetail = {
313
330
  amount: new import_decimal.default(productOriginTotal).minus(new import_decimal.default(targetProductTotal)).toNumber(),
314
331
  type: selectedDiscount2.tag === "product_discount_card" ? "discount_card" : selectedDiscount2.tag,
315
332
  discount: {
333
+ discount_card_type: (_i = selectedDiscount2 == null ? void 0 : selectedDiscount2.metadata) == null ? void 0 : _i.discount_card_type,
316
334
  resource_id: selectedDiscount2.id,
317
335
  title: selectedDiscount2.format_title,
318
336
  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.62",
5
5
  "description": "一个可扩展的前端模块化SDK框架,支持插件系统",
6
6
  "main": "dist/index.js",
7
7
  "types": "dist/index.d.ts",