@pisell/pisellos 2.1.130 → 2.1.131
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.
- package/dist/model/strategy/adapter/promotion/index.js +9 -0
- package/dist/modules/Order/index.d.ts +3 -6
- package/dist/modules/Order/index.js +119 -41
- package/dist/modules/Order/types.d.ts +23 -5
- package/dist/modules/Order/types.js +2 -0
- package/dist/modules/Order/utils.d.ts +66 -11
- package/dist/modules/Order/utils.js +281 -45
- package/dist/modules/SalesSummary/utils.js +33 -68
- package/dist/modules/ScanOrderLogger/providers/feishu.js +168 -60
- package/dist/modules/ScanOrderLogger/types.d.ts +6 -0
- package/dist/modules/Summary/utils.js +6 -21
- package/dist/solution/ScanOrder/index.d.ts +31 -6
- package/dist/solution/ScanOrder/index.js +1062 -498
- package/dist/solution/ScanOrder/types.d.ts +52 -2
- package/dist/solution/ScanOrder/types.js +16 -1
- package/dist/solution/ScanOrder/utils.d.ts +41 -5
- package/dist/solution/ScanOrder/utils.js +214 -33
- package/dist/solution/VenueBooking/index.d.ts +2 -5
- package/dist/solution/VenueBooking/index.js +35 -27
- package/lib/modules/Order/index.d.ts +3 -6
- package/lib/modules/Order/index.js +109 -30
- package/lib/modules/Order/types.d.ts +23 -5
- package/lib/modules/Order/utils.d.ts +66 -11
- package/lib/modules/Order/utils.js +181 -16
- package/lib/modules/SalesSummary/utils.js +13 -47
- package/lib/modules/ScanOrderLogger/providers/feishu.js +100 -34
- package/lib/modules/ScanOrderLogger/types.d.ts +6 -0
- package/lib/modules/Summary/utils.js +4 -18
- package/lib/solution/ScanOrder/index.d.ts +31 -6
- package/lib/solution/ScanOrder/index.js +315 -14
- package/lib/solution/ScanOrder/types.d.ts +52 -2
- package/lib/solution/ScanOrder/utils.d.ts +41 -5
- package/lib/solution/ScanOrder/utils.js +150 -20
- package/lib/solution/VenueBooking/index.d.ts +2 -5
- package/lib/solution/VenueBooking/index.js +13 -6
- package/package.json +1 -1
|
@@ -2,94 +2,202 @@ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" ==
|
|
|
2
2
|
function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
|
|
3
3
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
|
|
4
4
|
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
|
|
5
|
-
|
|
6
|
-
|
|
5
|
+
var DEFAULT_THROTTLE_MS = 3000;
|
|
6
|
+
var pendingQueue = [];
|
|
7
|
+
var flushTimer = null;
|
|
8
|
+
var cachedProviderConfig;
|
|
9
|
+
function safeStringify(value) {
|
|
10
|
+
if (value === undefined || value === null) return '';
|
|
11
|
+
if (typeof value === 'string') return value;
|
|
12
|
+
if (typeof value === 'number' || typeof value === 'boolean' || typeof value === 'bigint') {
|
|
13
|
+
return String(value);
|
|
14
|
+
}
|
|
7
15
|
try {
|
|
8
|
-
return JSON.stringify(
|
|
16
|
+
return JSON.stringify(value);
|
|
9
17
|
} catch (error) {
|
|
10
18
|
return "[unserializable: ".concat(String(error), "]");
|
|
11
19
|
}
|
|
12
20
|
}
|
|
13
|
-
function
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
21
|
+
function isWebhookUsable(webhook) {
|
|
22
|
+
if (!webhook) return false;
|
|
23
|
+
if (webhook.includes('REPLACE_ME')) return false;
|
|
24
|
+
return true;
|
|
25
|
+
}
|
|
26
|
+
function buildRecordSegments(record) {
|
|
27
|
+
var context = record.context || {};
|
|
28
|
+
return [[{
|
|
29
|
+
tag: 'text',
|
|
30
|
+
text: "[".concat(record.level, "] ").concat(record.timestamp, " ").concat(record.title, "\n")
|
|
31
|
+
}], [{
|
|
32
|
+
tag: 'text',
|
|
33
|
+
text: "\u7F13\u5B58\u6807\u8BC6: ".concat(safeStringify(context.cacheId), "\n")
|
|
34
|
+
}], [{
|
|
35
|
+
tag: 'text',
|
|
36
|
+
text: "\u65E5\u5FD7\u6765\u6E90: ".concat(safeStringify(context), "\n")
|
|
37
|
+
}], [{
|
|
38
|
+
tag: 'text',
|
|
39
|
+
text: "\u65E5\u5FD7\u5185\u5BB9: ".concat(safeStringify(record.payload), "\n")
|
|
40
|
+
}], [{
|
|
41
|
+
tag: 'text',
|
|
42
|
+
text: "\u6269\u5C55\u4FE1\u606F: ".concat(safeStringify(record.extra), "\n")
|
|
43
|
+
}], [{
|
|
44
|
+
tag: 'text',
|
|
45
|
+
text: '------\n'
|
|
46
|
+
}]];
|
|
47
|
+
}
|
|
48
|
+
function buildFeishuBody(records) {
|
|
49
|
+
var title = records.length === 1 ? records[0].title : "ScanOrder \u65E5\u5FD7\u6279\u91CF (".concat(records.length, " \u6761)");
|
|
50
|
+
var content = [];
|
|
51
|
+
records.forEach(function (record) {
|
|
52
|
+
buildRecordSegments(record).forEach(function (segment) {
|
|
53
|
+
return content.push(segment);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
return JSON.stringify({
|
|
57
|
+
msg_type: 'post',
|
|
58
|
+
content: JSON.stringify({
|
|
59
|
+
post: {
|
|
60
|
+
zh_cn: {
|
|
61
|
+
title: title,
|
|
62
|
+
content: content
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
})
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
function postToFeishu(_x, _x2) {
|
|
69
|
+
return _postToFeishu.apply(this, arguments);
|
|
70
|
+
}
|
|
71
|
+
function _postToFeishu() {
|
|
72
|
+
_postToFeishu = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(webhook, body) {
|
|
73
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
74
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
75
|
+
case 0:
|
|
76
|
+
_context2.next = 2;
|
|
77
|
+
return fetch(webhook, {
|
|
78
|
+
method: 'POST',
|
|
79
|
+
headers: {
|
|
80
|
+
'Content-Type': 'application/json'
|
|
81
|
+
},
|
|
82
|
+
body: body
|
|
83
|
+
});
|
|
84
|
+
case 2:
|
|
85
|
+
case "end":
|
|
86
|
+
return _context2.stop();
|
|
87
|
+
}
|
|
88
|
+
}, _callee2);
|
|
89
|
+
}));
|
|
90
|
+
return _postToFeishu.apply(this, arguments);
|
|
91
|
+
}
|
|
92
|
+
function flushQueue() {
|
|
93
|
+
return _flushQueue.apply(this, arguments);
|
|
94
|
+
}
|
|
95
|
+
function _flushQueue() {
|
|
96
|
+
_flushQueue = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3() {
|
|
97
|
+
var _cachedProviderConfig;
|
|
98
|
+
var records, webhook;
|
|
99
|
+
return _regeneratorRuntime().wrap(function _callee3$(_context3) {
|
|
100
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
101
|
+
case 0:
|
|
102
|
+
flushTimer = null;
|
|
103
|
+
if (pendingQueue.length) {
|
|
104
|
+
_context3.next = 3;
|
|
105
|
+
break;
|
|
106
|
+
}
|
|
107
|
+
return _context3.abrupt("return");
|
|
108
|
+
case 3:
|
|
109
|
+
records = pendingQueue.splice(0, pendingQueue.length);
|
|
110
|
+
webhook = (_cachedProviderConfig = cachedProviderConfig) === null || _cachedProviderConfig === void 0 || (_cachedProviderConfig = _cachedProviderConfig.feishu) === null || _cachedProviderConfig === void 0 ? void 0 : _cachedProviderConfig.webhook;
|
|
111
|
+
if (isWebhookUsable(webhook)) {
|
|
112
|
+
_context3.next = 7;
|
|
113
|
+
break;
|
|
114
|
+
}
|
|
115
|
+
return _context3.abrupt("return");
|
|
116
|
+
case 7:
|
|
117
|
+
if (!(typeof fetch !== 'function')) {
|
|
118
|
+
_context3.next = 10;
|
|
119
|
+
break;
|
|
120
|
+
}
|
|
121
|
+
console.warn('[ScanOrderLogger] 当前环境不支持 fetch,跳过 Feishu 日志批量上报');
|
|
122
|
+
return _context3.abrupt("return");
|
|
123
|
+
case 10:
|
|
124
|
+
_context3.prev = 10;
|
|
125
|
+
_context3.next = 13;
|
|
126
|
+
return postToFeishu(webhook, buildFeishuBody(records));
|
|
127
|
+
case 13:
|
|
128
|
+
_context3.next = 18;
|
|
129
|
+
break;
|
|
130
|
+
case 15:
|
|
131
|
+
_context3.prev = 15;
|
|
132
|
+
_context3.t0 = _context3["catch"](10);
|
|
133
|
+
console.warn('[ScanOrderLogger] Feishu 批量上报失败', _context3.t0);
|
|
134
|
+
case 18:
|
|
135
|
+
case "end":
|
|
136
|
+
return _context3.stop();
|
|
137
|
+
}
|
|
138
|
+
}, _callee3, null, [[10, 15]]);
|
|
22
139
|
}));
|
|
140
|
+
return _flushQueue.apply(this, arguments);
|
|
23
141
|
}
|
|
24
142
|
export var feishuLoggerProvider = {
|
|
25
143
|
send: function send(payload) {
|
|
26
144
|
return _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
|
|
27
|
-
var _payload$providerConf;
|
|
28
|
-
var webhook,
|
|
145
|
+
var _payload$providerConf, _payload$providerConf2, _payload$providerConf3;
|
|
146
|
+
var webhook, throttleMs;
|
|
29
147
|
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
30
148
|
while (1) switch (_context.prev = _context.next) {
|
|
31
149
|
case 0:
|
|
150
|
+
cachedProviderConfig = payload.providerConfig;
|
|
32
151
|
webhook = (_payload$providerConf = payload.providerConfig) === null || _payload$providerConf === void 0 || (_payload$providerConf = _payload$providerConf.feishu) === null || _payload$providerConf === void 0 ? void 0 : _payload$providerConf.webhook;
|
|
33
|
-
if (
|
|
34
|
-
_context.next =
|
|
152
|
+
if (webhook) {
|
|
153
|
+
_context.next = 5;
|
|
35
154
|
break;
|
|
36
155
|
}
|
|
156
|
+
console.warn('[ScanOrderLogger] Feishu webhook 未配置,跳过日志上报');
|
|
37
157
|
return _context.abrupt("return");
|
|
38
|
-
case
|
|
39
|
-
if (webhook) {
|
|
40
|
-
_context.next =
|
|
158
|
+
case 5:
|
|
159
|
+
if (isWebhookUsable(webhook)) {
|
|
160
|
+
_context.next = 7;
|
|
41
161
|
break;
|
|
42
162
|
}
|
|
43
|
-
console.warn('[ScanOrderLogger] Feishu webhook 未配置,跳过日志上报');
|
|
44
163
|
return _context.abrupt("return");
|
|
45
|
-
case
|
|
164
|
+
case 7:
|
|
46
165
|
if (!(typeof fetch !== 'function')) {
|
|
47
|
-
_context.next =
|
|
166
|
+
_context.next = 10;
|
|
48
167
|
break;
|
|
49
168
|
}
|
|
50
169
|
console.warn('[ScanOrderLogger] 当前环境不支持 fetch,跳过 Feishu 日志上报');
|
|
51
170
|
return _context.abrupt("return");
|
|
52
|
-
case
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
return fetch(webhook, {
|
|
79
|
-
headers: {
|
|
80
|
-
'Content-Type': 'application/json'
|
|
81
|
-
},
|
|
82
|
-
method: 'POST',
|
|
83
|
-
body: JSON.stringify({
|
|
84
|
-
msg_type: 'post',
|
|
85
|
-
content: "{\"post\":{\"zh_cn\":{\"title\":\"".concat(record.title, "\",\"content\":").concat(contentStr, "}}}")
|
|
86
|
-
})
|
|
87
|
-
});
|
|
88
|
-
case 14:
|
|
171
|
+
case 10:
|
|
172
|
+
throttleMs = (_payload$providerConf2 = (_payload$providerConf3 = payload.providerConfig) === null || _payload$providerConf3 === void 0 || (_payload$providerConf3 = _payload$providerConf3.feishu) === null || _payload$providerConf3 === void 0 ? void 0 : _payload$providerConf3.throttleMs) !== null && _payload$providerConf2 !== void 0 ? _payload$providerConf2 : DEFAULT_THROTTLE_MS;
|
|
173
|
+
if (!(throttleMs <= 0)) {
|
|
174
|
+
_context.next = 21;
|
|
175
|
+
break;
|
|
176
|
+
}
|
|
177
|
+
_context.prev = 12;
|
|
178
|
+
_context.next = 15;
|
|
179
|
+
return postToFeishu(webhook, buildFeishuBody([payload.record]));
|
|
180
|
+
case 15:
|
|
181
|
+
_context.next = 20;
|
|
182
|
+
break;
|
|
183
|
+
case 17:
|
|
184
|
+
_context.prev = 17;
|
|
185
|
+
_context.t0 = _context["catch"](12);
|
|
186
|
+
console.warn('[ScanOrderLogger] Feishu 日志上报失败', _context.t0);
|
|
187
|
+
case 20:
|
|
188
|
+
return _context.abrupt("return");
|
|
189
|
+
case 21:
|
|
190
|
+
pendingQueue.push(payload.record);
|
|
191
|
+
if (!flushTimer) {
|
|
192
|
+
flushTimer = setTimeout(function () {
|
|
193
|
+
void flushQueue();
|
|
194
|
+
}, throttleMs);
|
|
195
|
+
}
|
|
196
|
+
case 23:
|
|
89
197
|
case "end":
|
|
90
198
|
return _context.stop();
|
|
91
199
|
}
|
|
92
|
-
}, _callee);
|
|
200
|
+
}, _callee, null, [[12, 17]]);
|
|
93
201
|
}))();
|
|
94
202
|
}
|
|
95
203
|
};
|
|
@@ -2,6 +2,12 @@ export type ScanOrderLogLevel = 'info' | 'warning' | 'error' | 'debug';
|
|
|
2
2
|
export type ScanOrderLoggerProviderType = 'feishu' | 'grafana';
|
|
3
3
|
export interface ScanOrderLoggerProviderFeishuConfig {
|
|
4
4
|
webhook?: string;
|
|
5
|
+
/**
|
|
6
|
+
* 节流窗口毫秒数,默认 3000ms
|
|
7
|
+
* - >0:首条日志进入队列并启动定时器,窗口结束后合并成一条 Feishu post 统一发送
|
|
8
|
+
* - <=0:关闭节流,保持每条日志立即单独发送
|
|
9
|
+
*/
|
|
10
|
+
throttleMs?: number;
|
|
5
11
|
}
|
|
6
12
|
export interface ScanOrderLoggerProviderGrafanaConfig {
|
|
7
13
|
endpoint?: string;
|
|
@@ -685,31 +685,16 @@ var getBundleItemIsDiscountPrice = function getBundleItemIsDiscountPrice(item) {
|
|
|
685
685
|
var getBundleItemIsMarkupOrDiscountPrice = function getBundleItemIsMarkupOrDiscountPrice(item) {
|
|
686
686
|
return getBundleItemIsMarkupPrice(item) || getBundleItemIsDiscountPrice(item);
|
|
687
687
|
};
|
|
688
|
-
var getDiscountAmount = function getDiscountAmount(discounts) {
|
|
689
|
-
return (discounts || []).reduce(function (total, discount) {
|
|
690
|
-
return total.add(new Decimal(discount.amount || 0));
|
|
691
|
-
}, new Decimal(0)).toNumber();
|
|
692
|
-
};
|
|
693
688
|
|
|
694
689
|
/**
|
|
695
690
|
* 获取主商品加价减价后的总价 (主商品价格 + 子商品加价减价)
|
|
696
691
|
*/
|
|
697
692
|
var getMainProductTotal = function getMainProductTotal(item) {
|
|
698
|
-
var _ref8, _ref9, _item$main_product_se, _item$metadata, _item$
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
})) || [];
|
|
704
|
-
var mainProductDiscountAmount = getDiscountAmount(discount);
|
|
705
|
-
total = total.minus(mainProductDiscountAmount);
|
|
706
|
-
|
|
707
|
-
// 单规格
|
|
708
|
-
if (item !== null && item !== void 0 && item.option && Array.isArray(item === null || item === void 0 ? void 0 : item.option)) {
|
|
709
|
-
total = total.add(item === null || item === void 0 ? void 0 : item.option.reduce(function (t, option) {
|
|
710
|
-
return t.add(new Decimal(option.price || 0).mul(option.num || 1));
|
|
711
|
-
}, new Decimal(0)));
|
|
712
|
-
}
|
|
693
|
+
var _ref8, _ref9, _item$main_product_se, _item$metadata, _item$metadata2;
|
|
694
|
+
// 新语义 v2 下 `main_product_selling_price` / `metadata.main_product_selling_price`
|
|
695
|
+
// 已经是"含 option、含主商品折扣"的主价,直接作为主商品基准,无需再减折扣或加 option。
|
|
696
|
+
// 仅需叠加 markup / markdown 类 bundle(原价 bundle 的税费单独处理)。
|
|
697
|
+
var total = new Decimal((_ref8 = (_ref9 = (_item$main_product_se = item === null || item === void 0 ? void 0 : item.main_product_selling_price) !== null && _item$main_product_se !== void 0 ? _item$main_product_se : item === null || item === void 0 || (_item$metadata = item.metadata) === null || _item$metadata === void 0 ? void 0 : _item$metadata.main_product_selling_price) !== null && _ref9 !== void 0 ? _ref9 : item === null || item === void 0 || (_item$metadata2 = item.metadata) === null || _item$metadata2 === void 0 ? void 0 : _item$metadata2.main_product_original_price) !== null && _ref8 !== void 0 ? _ref8 : 0);
|
|
713
698
|
var _iterator4 = _createForOfIteratorHelper((item === null || item === void 0 ? void 0 : item.bundle) || []),
|
|
714
699
|
_step4;
|
|
715
700
|
try {
|
|
@@ -717,7 +702,7 @@ var getMainProductTotal = function getMainProductTotal(item) {
|
|
|
717
702
|
var bundleItem = _step4.value;
|
|
718
703
|
if (getBundleItemIsMarkupOrDiscountPrice(bundleItem)) {
|
|
719
704
|
var _ref10, _bundleItem$bundle_se2;
|
|
720
|
-
// IMPORTANT: 套餐子商品如果应用了 discount,bundle_selling_price和 price 其实都已经是折后价格了,不需要单独再减一次
|
|
705
|
+
// IMPORTANT: 套餐子商品如果应用了 discount,bundle_selling_price 和 price 其实都已经是折后价格了,不需要单独再减一次
|
|
721
706
|
var bundleItemTotal = new Decimal((_ref10 = (_bundleItem$bundle_se2 = bundleItem.bundle_selling_price) !== null && _bundleItem$bundle_se2 !== void 0 ? _bundleItem$bundle_se2 : bundleItem.price) !== null && _ref10 !== void 0 ? _ref10 : 0);
|
|
722
707
|
total = total.add(bundleItemTotal);
|
|
723
708
|
}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { Module, ModuleOptions, PisellCore } from '../../types';
|
|
2
2
|
import { BaseModule } from '../../modules/BaseModule';
|
|
3
|
-
import { ScanOrderAddLogParams, ScanOrderAvailabilityInfo, ScanOrderOrderProduct, ScanOrderOrderProductIdentity } from './types';
|
|
3
|
+
import { ScanOrderAddLogParams, ScanOrderAvailabilityInfo, ScanOrderOrderProduct, ScanOrderOrderProductIdentity, ScanOrderScanCodeResult } from './types';
|
|
4
|
+
import type { UpdateProductInOrderParams } from '../../modules/Order/types';
|
|
5
|
+
import type { Discount } from '../../modules/Discount/types';
|
|
4
6
|
import { type CartItemSummary, type PaxInfo, type QuantityCheckResult, type QuantityLimitResult } from '../../model/strategy/adapter/itemRule';
|
|
5
7
|
import type { StrategyConfig } from '../../model/strategy/type';
|
|
6
8
|
export * from './types';
|
|
@@ -29,6 +31,10 @@ export declare class ScanOrderImpl extends BaseModule implements Module {
|
|
|
29
31
|
private itemRuleRuntimeConfig;
|
|
30
32
|
/** 最近一次 checkResourceAvailable 从预约规则 link 拉取的商品快照 */
|
|
31
33
|
private enabledReservationRuleProducts;
|
|
34
|
+
private loginEffectDisposers;
|
|
35
|
+
private customerLoginRefreshInFlight;
|
|
36
|
+
private customerLoginRefreshIdInFlight;
|
|
37
|
+
private static readonly PISELL1_LOGIN_SUCCESS;
|
|
32
38
|
private getScanOrderLoggerContext;
|
|
33
39
|
private serializeError;
|
|
34
40
|
private addScanOrderLog;
|
|
@@ -36,7 +42,16 @@ export declare class ScanOrderImpl extends BaseModule implements Module {
|
|
|
36
42
|
private logMethodSuccess;
|
|
37
43
|
private logMethodError;
|
|
38
44
|
addLog(params: ScanOrderAddLogParams): Promise<void>;
|
|
45
|
+
private normalizeCustomerId;
|
|
46
|
+
private resolveCustomerIdFromLoginPayload;
|
|
47
|
+
private clearLoginEffectListeners;
|
|
48
|
+
private registerLoginEffect;
|
|
49
|
+
private registerCustomerLoginListeners;
|
|
50
|
+
private refreshOrderMarketingAfterLogin;
|
|
39
51
|
constructor(name?: string, version?: string);
|
|
52
|
+
/** 与 `otherParams.cacheId` 一致,供宿主在 URL 变化时判断是否需要重新注册模块 */
|
|
53
|
+
getCacheId(): string | undefined;
|
|
54
|
+
private destroyRegisteredChildModules;
|
|
40
55
|
initialize(core: PisellCore, options?: ModuleOptions): Promise<void>;
|
|
41
56
|
destroy(): Promise<void>;
|
|
42
57
|
retryInit(): Promise<void>;
|
|
@@ -62,14 +77,24 @@ export declare class ScanOrderImpl extends BaseModule implements Module {
|
|
|
62
77
|
restoreOrder(): Promise<import("./types").ScanOrderTempOrder>;
|
|
63
78
|
getOrderProducts(): ScanOrderOrderProduct[];
|
|
64
79
|
getSummary(): Promise<import("./types").ScanOrderSummary>;
|
|
80
|
+
getDiscountList(): Discount[];
|
|
81
|
+
scanCode(code: string, customerId?: number): Promise<ScanOrderScanCodeResult>;
|
|
82
|
+
setDiscountSelected(params: {
|
|
83
|
+
discountId: number;
|
|
84
|
+
isSelected: boolean;
|
|
85
|
+
}): Promise<void>;
|
|
86
|
+
onCustomerLogin(params: {
|
|
87
|
+
customerId: number;
|
|
88
|
+
}): Promise<void>;
|
|
65
89
|
private buildSubmitPayloadEnhancer;
|
|
66
90
|
submitScanOrder<T = any>(): Promise<T>;
|
|
67
91
|
addProductToOrder(product: Partial<ScanOrderOrderProduct> & ScanOrderOrderProductIdentity): Promise<ScanOrderOrderProduct[]>;
|
|
68
|
-
updateProductInOrder(params:
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
92
|
+
updateProductInOrder(params: UpdateProductInOrderParams): Promise<ScanOrderOrderProduct[]>;
|
|
93
|
+
/**
|
|
94
|
+
* 设置单行商品备注(与整单 `updateTempOrderNote` 区分)。
|
|
95
|
+
* 多行同 SKU 时必须传入与删除/更新一致的 identity(如 `identity_key`)。
|
|
96
|
+
*/
|
|
97
|
+
setOrderProductLineNote(identity: ScanOrderOrderProductIdentity, note: string): Promise<ScanOrderOrderProduct[]>;
|
|
73
98
|
removeProductFromOrder(identity: ScanOrderOrderProductIdentity): Promise<ScanOrderOrderProduct[]>;
|
|
74
99
|
private loadRuntimeConfigs;
|
|
75
100
|
private syncItemRuleConfigsFromDineInConfig;
|