@fctc/interface-logic 1.0.1 → 1.0.3
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/base-model-type-DvO53Lwi.d.mts +7 -0
- package/dist/base-model-type-DvO53Lwi.d.ts +7 -0
- package/dist/config.d.mts +16 -0
- package/dist/config.d.ts +16 -0
- package/dist/config.js +2355 -0
- package/dist/config.mjs +2318 -0
- package/dist/constants.d.mts +128 -0
- package/dist/constants.d.ts +128 -0
- package/dist/constants.js +202 -0
- package/dist/constants.mjs +163 -0
- package/dist/context-type-D5XefoL-.d.mts +8 -0
- package/dist/context-type-D5XefoL-.d.ts +8 -0
- package/dist/environment.d.mts +41 -0
- package/dist/environment.d.ts +41 -0
- package/dist/environment.js +3061 -0
- package/dist/environment.mjs +3021 -0
- package/dist/hook.d.mts +292 -0
- package/dist/hook.d.ts +292 -0
- package/dist/hook.js +5683 -0
- package/dist/hook.mjs +5587 -0
- package/dist/index-C_nK1Mii.d.mts +19 -0
- package/dist/index-C_nK1Mii.d.ts +19 -0
- package/dist/index.d.mts +1 -1389
- package/dist/index.d.ts +1 -1389
- package/dist/index.js +0 -6856
- package/dist/index.mjs +0 -6629
- package/dist/model.d.mts +35 -0
- package/dist/model.d.ts +35 -0
- package/dist/model.js +3320 -0
- package/dist/model.mjs +3281 -0
- package/dist/provider.d.mts +15 -0
- package/dist/provider.d.ts +15 -0
- package/dist/provider.js +6566 -0
- package/dist/provider.mjs +6550 -0
- package/dist/services.d.mts +224 -0
- package/dist/services.d.ts +224 -0
- package/dist/services.js +4477 -0
- package/dist/services.mjs +4432 -0
- package/dist/session-storage-CxkkEmQh.d.mts +15 -0
- package/dist/session-storage-CxkkEmQh.d.ts +15 -0
- package/dist/store.d.mts +643 -0
- package/dist/store.d.ts +643 -0
- package/dist/store.js +814 -0
- package/dist/store.mjs +709 -0
- package/dist/types.d.mts +12 -0
- package/dist/types.d.ts +12 -0
- package/dist/types.js +18 -0
- package/dist/types.mjs +0 -0
- package/dist/use-get-selection-QZu1jKqa.d.mts +15 -0
- package/dist/use-get-selection-QZu1jKqa.d.ts +15 -0
- package/dist/utils.d.mts +87 -0
- package/dist/utils.d.ts +87 -0
- package/dist/utils.js +2947 -0
- package/dist/utils.mjs +2881 -0
- package/dist/view-type-y6vtF3wg.d.mts +106 -0
- package/dist/view-type-y6vtF3wg.d.ts +106 -0
- package/package.json +55 -13
package/dist/config.js
ADDED
@@ -0,0 +1,2355 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __create = Object.create;
|
3
|
+
var __defProp = Object.defineProperty;
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
8
|
+
var __export = (target, all) => {
|
9
|
+
for (var name in all)
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
11
|
+
};
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
14
|
+
for (let key of __getOwnPropNames(from))
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
17
|
+
}
|
18
|
+
return to;
|
19
|
+
};
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
26
|
+
mod
|
27
|
+
));
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
29
|
+
|
30
|
+
// src/config.ts
|
31
|
+
var config_exports = {};
|
32
|
+
__export(config_exports, {
|
33
|
+
axiosClient: () => axiosClient
|
34
|
+
});
|
35
|
+
module.exports = __toCommonJS(config_exports);
|
36
|
+
|
37
|
+
// src/configs/axios-client.ts
|
38
|
+
var import_axios = __toESM(require("axios"));
|
39
|
+
|
40
|
+
// src/utils/format.ts
|
41
|
+
var import_moment = __toESM(require("moment"));
|
42
|
+
|
43
|
+
// src/utils/domain/py_tokenizer.ts
|
44
|
+
var TokenizerError = class extends Error {
|
45
|
+
};
|
46
|
+
var directMap = {
|
47
|
+
"\\": "\\",
|
48
|
+
'"': '"',
|
49
|
+
"'": "'",
|
50
|
+
a: "\x07",
|
51
|
+
b: "\b",
|
52
|
+
f: "\f",
|
53
|
+
n: "\n",
|
54
|
+
r: "\r",
|
55
|
+
t: " ",
|
56
|
+
v: "\v"
|
57
|
+
};
|
58
|
+
function decodeStringLiteral(str, unicode) {
|
59
|
+
const out = [];
|
60
|
+
let code;
|
61
|
+
for (let i = 0; i < str.length; ++i) {
|
62
|
+
if (str[i] !== "\\") {
|
63
|
+
out.push(str[i]);
|
64
|
+
continue;
|
65
|
+
}
|
66
|
+
const escape = str[i + 1];
|
67
|
+
if (escape in directMap) {
|
68
|
+
out.push(directMap[escape]);
|
69
|
+
++i;
|
70
|
+
continue;
|
71
|
+
}
|
72
|
+
switch (escape) {
|
73
|
+
case "\n":
|
74
|
+
++i;
|
75
|
+
continue;
|
76
|
+
case "N":
|
77
|
+
if (!unicode) {
|
78
|
+
break;
|
79
|
+
}
|
80
|
+
throw new TokenizerError("SyntaxError: \\N{} escape not implemented");
|
81
|
+
case "u":
|
82
|
+
if (!unicode) {
|
83
|
+
break;
|
84
|
+
}
|
85
|
+
const uni = str.slice(i + 2, i + 6);
|
86
|
+
if (!/[0-9a-f]{4}/i.test(uni)) {
|
87
|
+
throw new TokenizerError(
|
88
|
+
[
|
89
|
+
"SyntaxError: (unicode error) 'unicodeescape' codec",
|
90
|
+
" can't decode bytes in position ",
|
91
|
+
i,
|
92
|
+
"-",
|
93
|
+
i + 4,
|
94
|
+
": truncated \\uXXXX escape"
|
95
|
+
].join("")
|
96
|
+
);
|
97
|
+
}
|
98
|
+
code = parseInt(uni, 16);
|
99
|
+
out.push(String.fromCharCode(code));
|
100
|
+
i += 5;
|
101
|
+
continue;
|
102
|
+
case "U":
|
103
|
+
if (!unicode) {
|
104
|
+
break;
|
105
|
+
}
|
106
|
+
throw new TokenizerError("SyntaxError: \\U escape not implemented");
|
107
|
+
case "x":
|
108
|
+
const hex = str.slice(i + 2, i + 4);
|
109
|
+
if (!/[0-9a-f]{2}/i.test(hex)) {
|
110
|
+
if (!unicode) {
|
111
|
+
throw new TokenizerError("ValueError: invalid \\x escape");
|
112
|
+
}
|
113
|
+
throw new TokenizerError(
|
114
|
+
[
|
115
|
+
"SyntaxError: (unicode error) 'unicodeescape'",
|
116
|
+
" codec can't decode bytes in position ",
|
117
|
+
i,
|
118
|
+
"-",
|
119
|
+
i + 2,
|
120
|
+
": truncated \\xXX escape"
|
121
|
+
].join("")
|
122
|
+
);
|
123
|
+
}
|
124
|
+
code = parseInt(hex, 16);
|
125
|
+
out.push(String.fromCharCode(code));
|
126
|
+
i += 3;
|
127
|
+
continue;
|
128
|
+
default:
|
129
|
+
if (!/[0-8]/.test(escape)) {
|
130
|
+
break;
|
131
|
+
}
|
132
|
+
const r = /[0-8]{1,3}/g;
|
133
|
+
r.lastIndex = i + 1;
|
134
|
+
const m = r.exec(str);
|
135
|
+
if (!m) break;
|
136
|
+
const oct = m[0];
|
137
|
+
code = parseInt(oct, 8);
|
138
|
+
out.push(String.fromCharCode(code));
|
139
|
+
i += oct.length;
|
140
|
+
continue;
|
141
|
+
}
|
142
|
+
out.push("\\");
|
143
|
+
}
|
144
|
+
return out.join("");
|
145
|
+
}
|
146
|
+
var constants = /* @__PURE__ */ new Set(["None", "False", "True"]);
|
147
|
+
var comparators = [
|
148
|
+
"in",
|
149
|
+
"not",
|
150
|
+
"not in",
|
151
|
+
"is",
|
152
|
+
"is not",
|
153
|
+
"<",
|
154
|
+
"<=",
|
155
|
+
">",
|
156
|
+
">=",
|
157
|
+
"<>",
|
158
|
+
"!=",
|
159
|
+
"=="
|
160
|
+
];
|
161
|
+
var binaryOperators = [
|
162
|
+
"or",
|
163
|
+
"and",
|
164
|
+
"|",
|
165
|
+
"^",
|
166
|
+
"&",
|
167
|
+
"<<",
|
168
|
+
">>",
|
169
|
+
"+",
|
170
|
+
"-",
|
171
|
+
"*",
|
172
|
+
"/",
|
173
|
+
"//",
|
174
|
+
"%",
|
175
|
+
"~",
|
176
|
+
"**",
|
177
|
+
"."
|
178
|
+
];
|
179
|
+
var unaryOperators = ["-"];
|
180
|
+
var symbols = /* @__PURE__ */ new Set([
|
181
|
+
...["(", ")", "[", "]", "{", "}", ":", ","],
|
182
|
+
...["if", "else", "lambda", "="],
|
183
|
+
...comparators,
|
184
|
+
...binaryOperators,
|
185
|
+
...unaryOperators
|
186
|
+
]);
|
187
|
+
function group(...args) {
|
188
|
+
return "(" + args.join("|") + ")";
|
189
|
+
}
|
190
|
+
var Name = "[a-zA-Z_]\\w*";
|
191
|
+
var Whitespace = "[ \\f\\t]*";
|
192
|
+
var DecNumber = "\\d+(L|l)?";
|
193
|
+
var IntNumber = DecNumber;
|
194
|
+
var Exponent = "[eE][+-]?\\d+";
|
195
|
+
var PointFloat = group(`\\d+\\.\\d*(${Exponent})?`, `\\.\\d+(${Exponent})?`);
|
196
|
+
var FloatNumber = group(PointFloat, `\\d+${Exponent}`);
|
197
|
+
var Number2 = group(FloatNumber, IntNumber);
|
198
|
+
var Operator = group(
|
199
|
+
"\\*\\*=?",
|
200
|
+
">>=?",
|
201
|
+
"<<=?",
|
202
|
+
"<>",
|
203
|
+
"!=",
|
204
|
+
"//=?",
|
205
|
+
"[+\\-*/%&|^=<>]=?",
|
206
|
+
"~"
|
207
|
+
);
|
208
|
+
var Bracket = "[\\[\\]\\(\\)\\{\\}]";
|
209
|
+
var Special = "[:;.,`@]";
|
210
|
+
var Funny = group(Operator, Bracket, Special);
|
211
|
+
var ContStr = group(
|
212
|
+
"([uU])?'([^\\n'\\\\]*(?:\\\\.[^\\n'\\\\]*)*)'",
|
213
|
+
'([uU])?"([^\\n"\\\\]*(?:\\\\.[^\\n"\\\\]*)*)"'
|
214
|
+
);
|
215
|
+
var PseudoToken = Whitespace + group(Number2, Funny, ContStr, Name);
|
216
|
+
var NumberPattern = new RegExp("^" + Number2 + "$");
|
217
|
+
var StringPattern = new RegExp("^" + ContStr + "$");
|
218
|
+
var NamePattern = new RegExp("^" + Name + "$");
|
219
|
+
var strip = new RegExp("^" + Whitespace);
|
220
|
+
function tokenize(str) {
|
221
|
+
const tokens = [];
|
222
|
+
const max = str.length;
|
223
|
+
let start = 0;
|
224
|
+
let end = 0;
|
225
|
+
const pseudoprog = new RegExp(PseudoToken, "g");
|
226
|
+
while (pseudoprog.lastIndex < max) {
|
227
|
+
const pseudomatch = pseudoprog.exec(str);
|
228
|
+
if (!pseudomatch) {
|
229
|
+
if (/^\s+$/.test(str.slice(end))) {
|
230
|
+
break;
|
231
|
+
}
|
232
|
+
throw new TokenizerError(
|
233
|
+
"Failed to tokenize <<" + str + ">> at index " + (end || 0) + "; parsed so far: " + tokens
|
234
|
+
);
|
235
|
+
}
|
236
|
+
if (pseudomatch.index > end) {
|
237
|
+
if (str.slice(end, pseudomatch.index).trim()) {
|
238
|
+
throw new TokenizerError("Invalid expression");
|
239
|
+
}
|
240
|
+
}
|
241
|
+
start = pseudomatch.index;
|
242
|
+
end = pseudoprog.lastIndex;
|
243
|
+
let token = str.slice(start, end).replace(strip, "");
|
244
|
+
if (NumberPattern.test(token)) {
|
245
|
+
tokens.push({
|
246
|
+
type: 0,
|
247
|
+
value: parseFloat(token)
|
248
|
+
});
|
249
|
+
} else if (StringPattern.test(token)) {
|
250
|
+
const m = StringPattern.exec(token);
|
251
|
+
if (!m) throw new TokenizerError("Invalid string match");
|
252
|
+
tokens.push({
|
253
|
+
type: 1,
|
254
|
+
value: decodeStringLiteral(
|
255
|
+
m[3] !== void 0 ? m[3] : m[5],
|
256
|
+
!!(m[2] || m[4])
|
257
|
+
)
|
258
|
+
});
|
259
|
+
} else if (symbols.has(token)) {
|
260
|
+
if (token === "in" && tokens.length > 0 && tokens[tokens.length - 1].value === "not") {
|
261
|
+
token = "not in";
|
262
|
+
tokens.pop();
|
263
|
+
} else if (token === "not" && tokens.length > 0 && tokens[tokens.length - 1].value === "is") {
|
264
|
+
token = "is not";
|
265
|
+
tokens.pop();
|
266
|
+
}
|
267
|
+
tokens.push({
|
268
|
+
type: 2,
|
269
|
+
value: token
|
270
|
+
});
|
271
|
+
} else if (constants.has(token)) {
|
272
|
+
tokens.push({
|
273
|
+
type: 4,
|
274
|
+
value: token
|
275
|
+
});
|
276
|
+
} else if (NamePattern.test(token)) {
|
277
|
+
tokens.push({
|
278
|
+
type: 3,
|
279
|
+
value: token
|
280
|
+
});
|
281
|
+
} else {
|
282
|
+
throw new TokenizerError("Invalid expression");
|
283
|
+
}
|
284
|
+
}
|
285
|
+
return tokens;
|
286
|
+
}
|
287
|
+
|
288
|
+
// src/utils/domain/py_parser.ts
|
289
|
+
var ParserError = class extends Error {
|
290
|
+
};
|
291
|
+
var chainedOperators = new Set(comparators);
|
292
|
+
var infixOperators = /* @__PURE__ */ new Set([...binaryOperators, ...comparators]);
|
293
|
+
function bp(symbol) {
|
294
|
+
switch (symbol) {
|
295
|
+
case "=":
|
296
|
+
return 10;
|
297
|
+
case "if":
|
298
|
+
return 20;
|
299
|
+
case "in":
|
300
|
+
case "not in":
|
301
|
+
case "is":
|
302
|
+
case "is not":
|
303
|
+
case "<":
|
304
|
+
case "<=":
|
305
|
+
case ">":
|
306
|
+
case ">=":
|
307
|
+
case "<>":
|
308
|
+
case "==":
|
309
|
+
case "!=":
|
310
|
+
return 60;
|
311
|
+
case "or":
|
312
|
+
return 30;
|
313
|
+
case "and":
|
314
|
+
return 40;
|
315
|
+
case "not":
|
316
|
+
return 50;
|
317
|
+
case "|":
|
318
|
+
return 70;
|
319
|
+
case "^":
|
320
|
+
return 80;
|
321
|
+
case "&":
|
322
|
+
return 90;
|
323
|
+
case "<<":
|
324
|
+
case ">>":
|
325
|
+
return 100;
|
326
|
+
case "+":
|
327
|
+
case "-":
|
328
|
+
return 110;
|
329
|
+
case "*":
|
330
|
+
case "/":
|
331
|
+
case "//":
|
332
|
+
case "%":
|
333
|
+
return 120;
|
334
|
+
case "**":
|
335
|
+
return 140;
|
336
|
+
case ".":
|
337
|
+
case "(":
|
338
|
+
case "[":
|
339
|
+
return 150;
|
340
|
+
default:
|
341
|
+
return 0;
|
342
|
+
}
|
343
|
+
}
|
344
|
+
function bindingPower(token) {
|
345
|
+
return token.type === 2 ? bp(token.value) : 0;
|
346
|
+
}
|
347
|
+
function isSymbol(token, value) {
|
348
|
+
return token.type === 2 && token.value === value;
|
349
|
+
}
|
350
|
+
function parsePrefix(current, tokens) {
|
351
|
+
switch (current.type) {
|
352
|
+
case 0:
|
353
|
+
return { type: 0, value: current.value };
|
354
|
+
case 1:
|
355
|
+
return { type: 1, value: current.value };
|
356
|
+
case 4:
|
357
|
+
if (current.value === "None") {
|
358
|
+
return {
|
359
|
+
type: 3
|
360
|
+
/* None */
|
361
|
+
};
|
362
|
+
} else {
|
363
|
+
return { type: 2, value: current.value === "True" };
|
364
|
+
}
|
365
|
+
case 3:
|
366
|
+
return { type: 5, value: current.value };
|
367
|
+
case 2:
|
368
|
+
switch (current.value) {
|
369
|
+
case "-":
|
370
|
+
case "+":
|
371
|
+
case "~":
|
372
|
+
return {
|
373
|
+
type: 6,
|
374
|
+
op: current.value,
|
375
|
+
right: _parse(tokens, 130)
|
376
|
+
};
|
377
|
+
case "not":
|
378
|
+
return {
|
379
|
+
type: 6,
|
380
|
+
op: current.value,
|
381
|
+
right: _parse(tokens, 50)
|
382
|
+
};
|
383
|
+
case "(":
|
384
|
+
const content = [];
|
385
|
+
let isTuple = false;
|
386
|
+
while (tokens[0] && !isSymbol(tokens[0], ")")) {
|
387
|
+
content.push(_parse(tokens, 0));
|
388
|
+
if (tokens[0]) {
|
389
|
+
if (tokens[0] && isSymbol(tokens[0], ",")) {
|
390
|
+
isTuple = true;
|
391
|
+
tokens.shift();
|
392
|
+
} else if (!isSymbol(tokens[0], ")")) {
|
393
|
+
throw new ParserError("parsing error");
|
394
|
+
}
|
395
|
+
} else {
|
396
|
+
throw new ParserError("parsing error");
|
397
|
+
}
|
398
|
+
}
|
399
|
+
if (!tokens[0] || !isSymbol(tokens[0], ")")) {
|
400
|
+
throw new ParserError("parsing error");
|
401
|
+
}
|
402
|
+
tokens.shift();
|
403
|
+
isTuple = isTuple || content.length === 0;
|
404
|
+
return isTuple ? { type: 10, value: content } : content[0];
|
405
|
+
case "[":
|
406
|
+
const value = [];
|
407
|
+
while (tokens[0] && !isSymbol(tokens[0], "]")) {
|
408
|
+
value.push(_parse(tokens, 0));
|
409
|
+
if (tokens[0]) {
|
410
|
+
if (isSymbol(tokens[0], ",")) {
|
411
|
+
tokens.shift();
|
412
|
+
} else if (!isSymbol(tokens[0], "]")) {
|
413
|
+
throw new ParserError("parsing error");
|
414
|
+
}
|
415
|
+
}
|
416
|
+
}
|
417
|
+
if (!tokens[0] || !isSymbol(tokens[0], "]")) {
|
418
|
+
throw new ParserError("parsing error");
|
419
|
+
}
|
420
|
+
tokens.shift();
|
421
|
+
return { type: 4, value };
|
422
|
+
case "{":
|
423
|
+
const dict = {};
|
424
|
+
while (tokens[0] && !isSymbol(tokens[0], "}")) {
|
425
|
+
const key = _parse(tokens, 0);
|
426
|
+
if (key.type !== 1 && key.type !== 0 || !tokens[0] || !isSymbol(tokens[0], ":")) {
|
427
|
+
throw new ParserError("parsing error");
|
428
|
+
}
|
429
|
+
tokens.shift();
|
430
|
+
const val = _parse(tokens, 0);
|
431
|
+
dict[key.value] = val;
|
432
|
+
if (isSymbol(tokens[0], ",")) {
|
433
|
+
tokens.shift();
|
434
|
+
}
|
435
|
+
}
|
436
|
+
if (!tokens.shift()) {
|
437
|
+
throw new ParserError("parsing error");
|
438
|
+
}
|
439
|
+
return { type: 11, value: dict };
|
440
|
+
default:
|
441
|
+
throw new ParserError("Token cannot be parsed");
|
442
|
+
}
|
443
|
+
default:
|
444
|
+
throw new ParserError("Token cannot be parsed");
|
445
|
+
}
|
446
|
+
}
|
447
|
+
function parseInfix(left, current, tokens) {
|
448
|
+
switch (current.type) {
|
449
|
+
case 2:
|
450
|
+
if (infixOperators.has(current.value)) {
|
451
|
+
let right = _parse(tokens, bindingPower(current));
|
452
|
+
if (current.value === "and" || current.value === "or") {
|
453
|
+
return {
|
454
|
+
type: 14,
|
455
|
+
op: current.value,
|
456
|
+
left,
|
457
|
+
right
|
458
|
+
};
|
459
|
+
} else if (current.value === ".") {
|
460
|
+
if (right.type === 5) {
|
461
|
+
return {
|
462
|
+
type: 15,
|
463
|
+
obj: left,
|
464
|
+
key: right.value
|
465
|
+
};
|
466
|
+
} else {
|
467
|
+
throw new ParserError("invalid obj lookup");
|
468
|
+
}
|
469
|
+
}
|
470
|
+
let op = {
|
471
|
+
type: 7,
|
472
|
+
op: current.value,
|
473
|
+
left,
|
474
|
+
right
|
475
|
+
};
|
476
|
+
while (chainedOperators.has(current.value) && tokens[0] && tokens[0].type === 2 && chainedOperators.has(tokens[0].value)) {
|
477
|
+
const nextToken = tokens.shift();
|
478
|
+
op = {
|
479
|
+
type: 14,
|
480
|
+
op: "and",
|
481
|
+
left: op,
|
482
|
+
right: {
|
483
|
+
type: 7,
|
484
|
+
op: nextToken.value,
|
485
|
+
left: right,
|
486
|
+
right: _parse(tokens, bindingPower(nextToken))
|
487
|
+
}
|
488
|
+
};
|
489
|
+
right = op.right;
|
490
|
+
}
|
491
|
+
return op;
|
492
|
+
}
|
493
|
+
switch (current.value) {
|
494
|
+
case "(":
|
495
|
+
const args = [];
|
496
|
+
const kwargs = {};
|
497
|
+
while (tokens[0] && !isSymbol(tokens[0], ")")) {
|
498
|
+
const arg = _parse(tokens, 0);
|
499
|
+
if (arg.type === 9) {
|
500
|
+
kwargs[arg.name.value] = arg.value;
|
501
|
+
} else {
|
502
|
+
args.push(arg);
|
503
|
+
}
|
504
|
+
if (tokens[0] && isSymbol(tokens[0], ",")) {
|
505
|
+
tokens.shift();
|
506
|
+
}
|
507
|
+
}
|
508
|
+
if (!tokens[0] || !isSymbol(tokens[0], ")")) {
|
509
|
+
throw new ParserError("parsing error");
|
510
|
+
}
|
511
|
+
tokens.shift();
|
512
|
+
return { type: 8, fn: left, args, kwargs };
|
513
|
+
case "=":
|
514
|
+
if (left.type === 5) {
|
515
|
+
return {
|
516
|
+
type: 9,
|
517
|
+
name: left,
|
518
|
+
value: _parse(tokens, 10)
|
519
|
+
};
|
520
|
+
}
|
521
|
+
break;
|
522
|
+
case "[":
|
523
|
+
const key = _parse(tokens);
|
524
|
+
if (!tokens[0] || !isSymbol(tokens[0], "]")) {
|
525
|
+
throw new ParserError("parsing error");
|
526
|
+
}
|
527
|
+
tokens.shift();
|
528
|
+
return {
|
529
|
+
type: 12,
|
530
|
+
target: left,
|
531
|
+
key
|
532
|
+
};
|
533
|
+
case "if":
|
534
|
+
const condition = _parse(tokens);
|
535
|
+
if (!tokens[0] || !isSymbol(tokens[0], "else")) {
|
536
|
+
throw new ParserError("parsing error");
|
537
|
+
}
|
538
|
+
tokens.shift();
|
539
|
+
const ifFalse = _parse(tokens);
|
540
|
+
return {
|
541
|
+
type: 13,
|
542
|
+
condition,
|
543
|
+
ifTrue: left,
|
544
|
+
ifFalse
|
545
|
+
};
|
546
|
+
default:
|
547
|
+
break;
|
548
|
+
}
|
549
|
+
}
|
550
|
+
throw new ParserError("Token cannot be parsed");
|
551
|
+
}
|
552
|
+
function _parse(tokens, bp2 = 0) {
|
553
|
+
const token = tokens.shift();
|
554
|
+
if (!token) {
|
555
|
+
throw new ParserError("Unexpected end of input");
|
556
|
+
}
|
557
|
+
let expr = parsePrefix(token, tokens);
|
558
|
+
while (tokens[0] && bindingPower(tokens[0]) > bp2) {
|
559
|
+
expr = parseInfix(expr, tokens.shift(), tokens);
|
560
|
+
}
|
561
|
+
return expr;
|
562
|
+
}
|
563
|
+
function parse(tokens) {
|
564
|
+
if (tokens.length) {
|
565
|
+
return _parse(tokens, 0);
|
566
|
+
}
|
567
|
+
throw new ParserError("Missing token");
|
568
|
+
}
|
569
|
+
function parseArgs(args, spec) {
|
570
|
+
const last = args[args.length - 1];
|
571
|
+
const unnamedArgs = typeof last === "object" ? args.slice(0, -1) : args;
|
572
|
+
const kwargs = typeof last === "object" ? last : {};
|
573
|
+
for (const [index, val] of unnamedArgs.entries()) {
|
574
|
+
kwargs[spec[index]] = val;
|
575
|
+
}
|
576
|
+
return kwargs;
|
577
|
+
}
|
578
|
+
|
579
|
+
// src/utils/domain/py_date.ts
|
580
|
+
var AssertionError = class extends Error {
|
581
|
+
};
|
582
|
+
var ValueError = class extends Error {
|
583
|
+
};
|
584
|
+
var NotSupportedError = class extends Error {
|
585
|
+
};
|
586
|
+
function fmt2(n) {
|
587
|
+
return String(n).padStart(2, "0");
|
588
|
+
}
|
589
|
+
function fmt4(n) {
|
590
|
+
return String(n).padStart(4, "0");
|
591
|
+
}
|
592
|
+
function divmod(a, b, fn) {
|
593
|
+
let mod = a % b;
|
594
|
+
if (mod > 0 && b < 0 || mod < 0 && b > 0) {
|
595
|
+
mod += b;
|
596
|
+
}
|
597
|
+
return fn(Math.floor(a / b), mod);
|
598
|
+
}
|
599
|
+
function assert(bool, message = "AssertionError") {
|
600
|
+
if (!bool) {
|
601
|
+
throw new AssertionError(message);
|
602
|
+
}
|
603
|
+
}
|
604
|
+
var DAYS_IN_MONTH = [
|
605
|
+
null,
|
606
|
+
31,
|
607
|
+
28,
|
608
|
+
31,
|
609
|
+
30,
|
610
|
+
31,
|
611
|
+
30,
|
612
|
+
31,
|
613
|
+
31,
|
614
|
+
30,
|
615
|
+
31,
|
616
|
+
30,
|
617
|
+
31
|
618
|
+
];
|
619
|
+
var DAYS_BEFORE_MONTH = [null];
|
620
|
+
for (let dbm = 0, i = 1; i < DAYS_IN_MONTH.length; ++i) {
|
621
|
+
DAYS_BEFORE_MONTH.push(dbm);
|
622
|
+
dbm += DAYS_IN_MONTH[i];
|
623
|
+
}
|
624
|
+
function daysInMonth(year, month) {
|
625
|
+
if (month === 2 && isLeap(year)) {
|
626
|
+
return 29;
|
627
|
+
}
|
628
|
+
return DAYS_IN_MONTH[month];
|
629
|
+
}
|
630
|
+
function isLeap(year) {
|
631
|
+
return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
|
632
|
+
}
|
633
|
+
function daysBeforeYear(year) {
|
634
|
+
const y = year - 1;
|
635
|
+
return y * 365 + Math.floor(y / 4) - Math.floor(y / 100) + Math.floor(y / 400);
|
636
|
+
}
|
637
|
+
function daysBeforeMonth(year, month) {
|
638
|
+
const postLeapFeb = month > 2 && isLeap(year);
|
639
|
+
return DAYS_BEFORE_MONTH[month] + (postLeapFeb ? 1 : 0);
|
640
|
+
}
|
641
|
+
function ymd2ord(year, month, day) {
|
642
|
+
const dim = daysInMonth(year, month);
|
643
|
+
if (!(1 <= day && day <= dim)) {
|
644
|
+
throw new ValueError(`day must be in 1..${dim}`);
|
645
|
+
}
|
646
|
+
return daysBeforeYear(year) + daysBeforeMonth(year, month) + day;
|
647
|
+
}
|
648
|
+
var DI400Y = daysBeforeYear(401);
|
649
|
+
var DI100Y = daysBeforeYear(101);
|
650
|
+
var DI4Y = daysBeforeYear(5);
|
651
|
+
function ord2ymd(n) {
|
652
|
+
--n;
|
653
|
+
let n400 = 0, n100 = 0, n4 = 0, n1 = 0, n0 = 0;
|
654
|
+
divmod(n, DI400Y, (_n400, n2) => {
|
655
|
+
n400 = _n400;
|
656
|
+
divmod(n2, DI100Y, (_n100, n3) => {
|
657
|
+
n100 = _n100;
|
658
|
+
divmod(n3, DI4Y, (_n4, n5) => {
|
659
|
+
n4 = _n4;
|
660
|
+
divmod(n5, 365, (_n1, n6) => {
|
661
|
+
n1 = _n1;
|
662
|
+
n0 = n6;
|
663
|
+
});
|
664
|
+
});
|
665
|
+
});
|
666
|
+
});
|
667
|
+
n = n0;
|
668
|
+
const year = n400 * 400 + 1 + n100 * 100 + n4 * 4 + n1;
|
669
|
+
if (n1 === 4 || n100 === 100) {
|
670
|
+
assert(n0 === 0);
|
671
|
+
return {
|
672
|
+
year: year - 1,
|
673
|
+
month: 12,
|
674
|
+
day: 31
|
675
|
+
};
|
676
|
+
}
|
677
|
+
const leapyear = n1 === 3 && (n4 !== 24 || n100 === 3);
|
678
|
+
assert(leapyear === isLeap(year));
|
679
|
+
let month = n + 50 >> 5;
|
680
|
+
let preceding = DAYS_BEFORE_MONTH[month] + (month > 2 && leapyear ? 1 : 0);
|
681
|
+
if (preceding > n) {
|
682
|
+
--month;
|
683
|
+
preceding -= DAYS_IN_MONTH[month] + (month === 2 && leapyear ? 1 : 0);
|
684
|
+
}
|
685
|
+
n -= preceding;
|
686
|
+
return {
|
687
|
+
year,
|
688
|
+
month,
|
689
|
+
day: n + 1
|
690
|
+
};
|
691
|
+
}
|
692
|
+
function tmxxx(year, month, day, hour, minute, second, microsecond) {
|
693
|
+
hour = hour || 0;
|
694
|
+
minute = minute || 0;
|
695
|
+
second = second || 0;
|
696
|
+
microsecond = microsecond || 0;
|
697
|
+
if (microsecond < 0 || microsecond > 999999) {
|
698
|
+
divmod(microsecond, 1e6, (carry, ms) => {
|
699
|
+
microsecond = ms;
|
700
|
+
second += carry;
|
701
|
+
});
|
702
|
+
}
|
703
|
+
if (second < 0 || second > 59) {
|
704
|
+
divmod(second, 60, (carry, s) => {
|
705
|
+
second = s;
|
706
|
+
minute += carry;
|
707
|
+
});
|
708
|
+
}
|
709
|
+
if (minute < 0 || minute > 59) {
|
710
|
+
divmod(minute, 60, (carry, m) => {
|
711
|
+
minute = m;
|
712
|
+
hour += carry;
|
713
|
+
});
|
714
|
+
}
|
715
|
+
if (hour < 0 || hour > 23) {
|
716
|
+
divmod(hour, 24, (carry, h) => {
|
717
|
+
hour = h;
|
718
|
+
day += carry;
|
719
|
+
});
|
720
|
+
}
|
721
|
+
if (month < 1 || month > 12) {
|
722
|
+
divmod(month - 1, 12, (carry, m) => {
|
723
|
+
month = m + 1;
|
724
|
+
year += carry;
|
725
|
+
});
|
726
|
+
}
|
727
|
+
const dim = daysInMonth(year, month);
|
728
|
+
if (day < 1 || day > dim) {
|
729
|
+
if (day === 0) {
|
730
|
+
--month;
|
731
|
+
if (month > 0) {
|
732
|
+
day = daysInMonth(year, month);
|
733
|
+
} else {
|
734
|
+
--year;
|
735
|
+
month = 12;
|
736
|
+
day = 31;
|
737
|
+
}
|
738
|
+
} else if (day === dim + 1) {
|
739
|
+
++month;
|
740
|
+
day = 1;
|
741
|
+
if (month > 12) {
|
742
|
+
month = 1;
|
743
|
+
++year;
|
744
|
+
}
|
745
|
+
} else {
|
746
|
+
const r = ord2ymd(ymd2ord(year, month, 1) + (day - 1));
|
747
|
+
year = r.year;
|
748
|
+
month = r.month;
|
749
|
+
day = r.day;
|
750
|
+
}
|
751
|
+
}
|
752
|
+
return {
|
753
|
+
year,
|
754
|
+
month,
|
755
|
+
day,
|
756
|
+
hour,
|
757
|
+
minute,
|
758
|
+
second,
|
759
|
+
microsecond
|
760
|
+
};
|
761
|
+
}
|
762
|
+
var PyDate = class _PyDate {
|
763
|
+
constructor(year, month, day) {
|
764
|
+
this.year = year;
|
765
|
+
this.month = month;
|
766
|
+
this.day = day;
|
767
|
+
}
|
768
|
+
static today() {
|
769
|
+
return this.convertDate(/* @__PURE__ */ new Date());
|
770
|
+
}
|
771
|
+
static convertDate(date) {
|
772
|
+
const year = date.getFullYear();
|
773
|
+
const month = date.getMonth() + 1;
|
774
|
+
const day = date.getDate();
|
775
|
+
return new _PyDate(year, month, day);
|
776
|
+
}
|
777
|
+
static create(...args) {
|
778
|
+
const { year, month, day } = parseArgs(args, ["year", "month", "day"]);
|
779
|
+
return new _PyDate(year, month, day);
|
780
|
+
}
|
781
|
+
add(timedelta) {
|
782
|
+
const s = tmxxx(this.year, this.month, this.day + timedelta.days, 0, 0, 0);
|
783
|
+
return new _PyDate(s.year, s.month, s.day);
|
784
|
+
}
|
785
|
+
isEqual(other) {
|
786
|
+
if (!(other instanceof _PyDate)) {
|
787
|
+
return false;
|
788
|
+
}
|
789
|
+
return this.year === other.year && this.month === other.month && this.day === other.day;
|
790
|
+
}
|
791
|
+
strftime(format) {
|
792
|
+
return format.replace(/%([A-Za-z])/g, (m, c) => {
|
793
|
+
switch (c) {
|
794
|
+
case "Y":
|
795
|
+
return fmt4(this.year);
|
796
|
+
case "m":
|
797
|
+
return fmt2(this.month);
|
798
|
+
case "d":
|
799
|
+
return fmt2(this.day);
|
800
|
+
default:
|
801
|
+
throw new ValueError(`No known conversion for ${m}`);
|
802
|
+
}
|
803
|
+
});
|
804
|
+
}
|
805
|
+
substract(other) {
|
806
|
+
if (other instanceof PyTimeDelta) {
|
807
|
+
return this.add(other.negate());
|
808
|
+
}
|
809
|
+
if (other instanceof _PyDate) {
|
810
|
+
return PyTimeDelta.create(this.toordinal() - other.toordinal());
|
811
|
+
}
|
812
|
+
throw new NotSupportedError();
|
813
|
+
}
|
814
|
+
toJSON() {
|
815
|
+
return this.strftime("%Y-%m-%d");
|
816
|
+
}
|
817
|
+
toordinal() {
|
818
|
+
return ymd2ord(this.year, this.month, this.day);
|
819
|
+
}
|
820
|
+
};
|
821
|
+
var PyDateTime = class _PyDateTime {
|
822
|
+
constructor(year, month, day, hour, minute, second, microsecond) {
|
823
|
+
this.year = year;
|
824
|
+
this.month = month;
|
825
|
+
this.day = day;
|
826
|
+
this.hour = hour;
|
827
|
+
this.minute = minute;
|
828
|
+
this.second = second;
|
829
|
+
this.microsecond = microsecond;
|
830
|
+
}
|
831
|
+
static now() {
|
832
|
+
return this.convertDate(/* @__PURE__ */ new Date());
|
833
|
+
}
|
834
|
+
static convertDate(date) {
|
835
|
+
const year = date.getFullYear();
|
836
|
+
const month = date.getMonth() + 1;
|
837
|
+
const day = date.getDate();
|
838
|
+
const hour = date.getHours();
|
839
|
+
const minute = date.getMinutes();
|
840
|
+
const second = date.getSeconds();
|
841
|
+
return new _PyDateTime(year, month, day, hour, minute, second, 0);
|
842
|
+
}
|
843
|
+
static create(...args) {
|
844
|
+
const namedArgs = parseArgs(args, [
|
845
|
+
"year",
|
846
|
+
"month",
|
847
|
+
"day",
|
848
|
+
"hour",
|
849
|
+
"minute",
|
850
|
+
"second",
|
851
|
+
"microsecond"
|
852
|
+
]);
|
853
|
+
const year = namedArgs.year;
|
854
|
+
const month = namedArgs.month;
|
855
|
+
const day = namedArgs.day;
|
856
|
+
const hour = namedArgs.hour || 0;
|
857
|
+
const minute = namedArgs.minute || 0;
|
858
|
+
const second = namedArgs.second || 0;
|
859
|
+
const ms = namedArgs.microsecond / 1e3 || 0;
|
860
|
+
return new _PyDateTime(year, month, day, hour, minute, second, ms);
|
861
|
+
}
|
862
|
+
static combine(...args) {
|
863
|
+
const { date, time } = parseArgs(args, ["date", "time"]);
|
864
|
+
return _PyDateTime.create(
|
865
|
+
date.year,
|
866
|
+
date.month,
|
867
|
+
date.day,
|
868
|
+
time.hour,
|
869
|
+
time.minute,
|
870
|
+
time.second
|
871
|
+
);
|
872
|
+
}
|
873
|
+
add(timedelta) {
|
874
|
+
const s = tmxxx(
|
875
|
+
this.year,
|
876
|
+
this.month,
|
877
|
+
this.day + timedelta.days,
|
878
|
+
this.hour,
|
879
|
+
this.minute,
|
880
|
+
this.second + timedelta.seconds,
|
881
|
+
this.microsecond + timedelta.microseconds
|
882
|
+
);
|
883
|
+
return new _PyDateTime(
|
884
|
+
s.year,
|
885
|
+
s.month,
|
886
|
+
s.day,
|
887
|
+
s.hour,
|
888
|
+
s.minute,
|
889
|
+
s.second,
|
890
|
+
s.microsecond
|
891
|
+
);
|
892
|
+
}
|
893
|
+
isEqual(other) {
|
894
|
+
if (!(other instanceof _PyDateTime)) {
|
895
|
+
return false;
|
896
|
+
}
|
897
|
+
return this.year === other.year && this.month === other.month && this.day === other.day && this.hour === other.hour && this.minute === other.minute && this.second === other.second && this.microsecond === other.microsecond;
|
898
|
+
}
|
899
|
+
strftime(format) {
|
900
|
+
return format.replace(/%([A-Za-z])/g, (m, c) => {
|
901
|
+
switch (c) {
|
902
|
+
case "Y":
|
903
|
+
return fmt4(this.year);
|
904
|
+
case "m":
|
905
|
+
return fmt2(this.month);
|
906
|
+
case "d":
|
907
|
+
return fmt2(this.day);
|
908
|
+
case "H":
|
909
|
+
return fmt2(this.hour);
|
910
|
+
case "M":
|
911
|
+
return fmt2(this.minute);
|
912
|
+
case "S":
|
913
|
+
return fmt2(this.second);
|
914
|
+
default:
|
915
|
+
throw new ValueError(`No known conversion for ${m}`);
|
916
|
+
}
|
917
|
+
});
|
918
|
+
}
|
919
|
+
substract(timedelta) {
|
920
|
+
return this.add(timedelta.negate());
|
921
|
+
}
|
922
|
+
toJSON() {
|
923
|
+
return this.strftime("%Y-%m-%d %H:%M:%S");
|
924
|
+
}
|
925
|
+
to_utc() {
|
926
|
+
const d = new Date(
|
927
|
+
this.year,
|
928
|
+
this.month - 1,
|
929
|
+
this.day,
|
930
|
+
this.hour,
|
931
|
+
this.minute,
|
932
|
+
this.second
|
933
|
+
);
|
934
|
+
const timedelta = PyTimeDelta.create({ minutes: d.getTimezoneOffset() });
|
935
|
+
return this.add(timedelta);
|
936
|
+
}
|
937
|
+
};
|
938
|
+
var PyTime = class _PyTime extends PyDate {
|
939
|
+
constructor(hour, minute, second) {
|
940
|
+
const now = /* @__PURE__ */ new Date();
|
941
|
+
const year = now.getFullYear();
|
942
|
+
const month = now.getMonth() + 1;
|
943
|
+
const day = now.getDate();
|
944
|
+
super(year, month, day);
|
945
|
+
this.hour = hour;
|
946
|
+
this.minute = minute;
|
947
|
+
this.second = second;
|
948
|
+
this.hour = hour;
|
949
|
+
this.minute = minute;
|
950
|
+
this.second = second;
|
951
|
+
}
|
952
|
+
static create(...args) {
|
953
|
+
const namedArgs = parseArgs(args, ["hour", "minute", "second"]);
|
954
|
+
const hour = namedArgs.hour || 0;
|
955
|
+
const minute = namedArgs.minute || 0;
|
956
|
+
const second = namedArgs.second || 0;
|
957
|
+
return new _PyTime(hour, minute, second);
|
958
|
+
}
|
959
|
+
strftime(format) {
|
960
|
+
return format.replace(/%([A-Za-z])/g, (m, c) => {
|
961
|
+
switch (c) {
|
962
|
+
case "Y":
|
963
|
+
return fmt4(this.year);
|
964
|
+
case "m":
|
965
|
+
return fmt2(this.month);
|
966
|
+
case "d":
|
967
|
+
return fmt2(this.day);
|
968
|
+
case "H":
|
969
|
+
return fmt2(this.hour);
|
970
|
+
case "M":
|
971
|
+
return fmt2(this.minute);
|
972
|
+
case "S":
|
973
|
+
return fmt2(this.second);
|
974
|
+
default:
|
975
|
+
throw new ValueError(`No known conversion for ${m}`);
|
976
|
+
}
|
977
|
+
});
|
978
|
+
}
|
979
|
+
toJSON() {
|
980
|
+
return this.strftime("%H:%M:%S");
|
981
|
+
}
|
982
|
+
};
|
983
|
+
var DAYS_IN_YEAR = [
|
984
|
+
31,
|
985
|
+
59,
|
986
|
+
90,
|
987
|
+
120,
|
988
|
+
151,
|
989
|
+
181,
|
990
|
+
212,
|
991
|
+
243,
|
992
|
+
273,
|
993
|
+
304,
|
994
|
+
334,
|
995
|
+
366
|
996
|
+
];
|
997
|
+
var TIME_PERIODS = ["hour", "minute", "second"];
|
998
|
+
var PERIODS = ["year", "month", "day", ...TIME_PERIODS];
|
999
|
+
var RELATIVE_KEYS = "years months weeks days hours minutes seconds microseconds leapdays".split(
|
1000
|
+
" "
|
1001
|
+
);
|
1002
|
+
var ABSOLUTE_KEYS = "year month day hour minute second microsecond weekday nlyearday yearday".split(
|
1003
|
+
" "
|
1004
|
+
);
|
1005
|
+
var argsSpec = ["dt1", "dt2"];
|
1006
|
+
var PyRelativeDelta = class _PyRelativeDelta {
|
1007
|
+
static create(...args) {
|
1008
|
+
const params = parseArgs(args, argsSpec);
|
1009
|
+
if ("dt1" in params) {
|
1010
|
+
throw new Error("relativedelta(dt1, dt2) is not supported for now");
|
1011
|
+
}
|
1012
|
+
for (const period of PERIODS) {
|
1013
|
+
if (period in params) {
|
1014
|
+
const val = params[period];
|
1015
|
+
assert(val >= 0, `${period} ${val} is out of range`);
|
1016
|
+
}
|
1017
|
+
}
|
1018
|
+
for (const key of RELATIVE_KEYS) {
|
1019
|
+
params[key] = params[key] || 0;
|
1020
|
+
}
|
1021
|
+
for (const key of ABSOLUTE_KEYS) {
|
1022
|
+
params[key] = key in params ? params[key] : null;
|
1023
|
+
}
|
1024
|
+
params.days += 7 * params.weeks;
|
1025
|
+
let yearDay = 0;
|
1026
|
+
if (params.nlyearday) {
|
1027
|
+
yearDay = params.nlyearday;
|
1028
|
+
} else if (params.yearday) {
|
1029
|
+
yearDay = params.yearday;
|
1030
|
+
if (yearDay > 59) {
|
1031
|
+
params.leapDays = -1;
|
1032
|
+
}
|
1033
|
+
}
|
1034
|
+
if (yearDay) {
|
1035
|
+
for (let monthIndex = 0; monthIndex < DAYS_IN_YEAR.length; monthIndex++) {
|
1036
|
+
if (yearDay <= DAYS_IN_YEAR[monthIndex]) {
|
1037
|
+
params.month = monthIndex + 1;
|
1038
|
+
if (monthIndex === 0) {
|
1039
|
+
params.day = yearDay;
|
1040
|
+
} else {
|
1041
|
+
params.day = yearDay - DAYS_IN_YEAR[monthIndex - 1];
|
1042
|
+
}
|
1043
|
+
break;
|
1044
|
+
}
|
1045
|
+
}
|
1046
|
+
}
|
1047
|
+
return new _PyRelativeDelta(params);
|
1048
|
+
}
|
1049
|
+
static add(date, delta) {
|
1050
|
+
if (!(date instanceof PyDate || date instanceof PyDateTime)) {
|
1051
|
+
throw new NotSupportedError();
|
1052
|
+
}
|
1053
|
+
const s = tmxxx(
|
1054
|
+
(delta.year || date.year) + delta.years,
|
1055
|
+
(delta.month || date.month) + delta.months,
|
1056
|
+
delta.day || date.day,
|
1057
|
+
delta.hour || (date instanceof PyDateTime ? date.hour : 0),
|
1058
|
+
delta.minute || (date instanceof PyDateTime ? date.minute : 0),
|
1059
|
+
delta.second || (date instanceof PyDateTime ? date.second : 0),
|
1060
|
+
delta.microseconds || (date instanceof PyDateTime ? date.microsecond : 0)
|
1061
|
+
);
|
1062
|
+
const newDateTime = new PyDateTime(
|
1063
|
+
s.year,
|
1064
|
+
s.month,
|
1065
|
+
s.day,
|
1066
|
+
s.hour,
|
1067
|
+
s.minute,
|
1068
|
+
s.second,
|
1069
|
+
s.microsecond
|
1070
|
+
);
|
1071
|
+
let leapDays = 0;
|
1072
|
+
if (delta.leapDays && newDateTime.month > 2 && isLeap(newDateTime.year)) {
|
1073
|
+
leapDays = delta.leapDays;
|
1074
|
+
}
|
1075
|
+
const temp = newDateTime.add(
|
1076
|
+
PyTimeDelta.create({
|
1077
|
+
days: delta.days + leapDays,
|
1078
|
+
hours: delta.hours,
|
1079
|
+
minutes: delta.minutes,
|
1080
|
+
seconds: delta.seconds,
|
1081
|
+
microseconds: delta.microseconds
|
1082
|
+
})
|
1083
|
+
);
|
1084
|
+
const hasTime = Boolean(
|
1085
|
+
temp.hour || temp.minute || temp.second || temp.microsecond
|
1086
|
+
);
|
1087
|
+
const returnDate = !hasTime && date instanceof PyDate ? new PyDate(temp.year, temp.month, temp.day) : temp;
|
1088
|
+
if (delta.weekday !== null) {
|
1089
|
+
const wantedDow = delta.weekday + 1;
|
1090
|
+
const _date = new Date(
|
1091
|
+
returnDate.year,
|
1092
|
+
returnDate.month - 1,
|
1093
|
+
returnDate.day
|
1094
|
+
);
|
1095
|
+
const days = (7 - _date.getDay() + wantedDow) % 7;
|
1096
|
+
return returnDate.add(new PyTimeDelta(days, 0, 0));
|
1097
|
+
}
|
1098
|
+
return returnDate;
|
1099
|
+
}
|
1100
|
+
static substract(date, delta) {
|
1101
|
+
return _PyRelativeDelta.add(date, delta.negate());
|
1102
|
+
}
|
1103
|
+
constructor(params = {}, sign = 1) {
|
1104
|
+
this.years = sign * params.years;
|
1105
|
+
this.months = sign * params.months;
|
1106
|
+
this.days = sign * params.days;
|
1107
|
+
this.hours = sign * params.hours;
|
1108
|
+
this.minutes = sign * params.minutes;
|
1109
|
+
this.seconds = sign * params.seconds;
|
1110
|
+
this.microseconds = sign * params.microseconds;
|
1111
|
+
this.leapDays = params.leapDays;
|
1112
|
+
this.year = params.year;
|
1113
|
+
this.month = params.month;
|
1114
|
+
this.day = params.day;
|
1115
|
+
this.hour = params.hour;
|
1116
|
+
this.minute = params.minute;
|
1117
|
+
this.second = params.second;
|
1118
|
+
this.microsecond = params.microsecond;
|
1119
|
+
this.weekday = params.weekday;
|
1120
|
+
}
|
1121
|
+
years;
|
1122
|
+
months;
|
1123
|
+
days;
|
1124
|
+
hours;
|
1125
|
+
minutes;
|
1126
|
+
seconds;
|
1127
|
+
microseconds;
|
1128
|
+
leapDays;
|
1129
|
+
year;
|
1130
|
+
month;
|
1131
|
+
day;
|
1132
|
+
hour;
|
1133
|
+
minute;
|
1134
|
+
second;
|
1135
|
+
microsecond;
|
1136
|
+
weekday;
|
1137
|
+
negate() {
|
1138
|
+
return new _PyRelativeDelta(this, -1);
|
1139
|
+
}
|
1140
|
+
isEqual() {
|
1141
|
+
throw new NotSupportedError();
|
1142
|
+
}
|
1143
|
+
};
|
1144
|
+
var TIME_DELTA_KEYS = "weeks days hours minutes seconds milliseconds microseconds".split(" ");
|
1145
|
+
function modf(x) {
|
1146
|
+
const mod = x % 1;
|
1147
|
+
return [mod < 0 ? mod + 1 : mod, Math.floor(x)];
|
1148
|
+
}
|
1149
|
+
var PyTimeDelta = class _PyTimeDelta {
|
1150
|
+
constructor(days, seconds, microseconds) {
|
1151
|
+
this.days = days;
|
1152
|
+
this.seconds = seconds;
|
1153
|
+
this.microseconds = microseconds;
|
1154
|
+
}
|
1155
|
+
static create(...args) {
|
1156
|
+
const namedArgs = parseArgs(args, ["days", "seconds", "microseconds"]);
|
1157
|
+
for (const key of TIME_DELTA_KEYS) {
|
1158
|
+
namedArgs[key] = namedArgs[key] || 0;
|
1159
|
+
}
|
1160
|
+
let d = 0;
|
1161
|
+
let s = 0;
|
1162
|
+
let us = 0;
|
1163
|
+
const days = namedArgs.days + namedArgs.weeks * 7;
|
1164
|
+
let seconds = namedArgs.seconds + 60 * namedArgs.minutes + 3600 * namedArgs.hours;
|
1165
|
+
let microseconds = namedArgs.microseconds + 1e3 * namedArgs.milliseconds;
|
1166
|
+
const [dFrac, dInt] = modf(days);
|
1167
|
+
d = dInt;
|
1168
|
+
let daysecondsfrac = 0;
|
1169
|
+
if (dFrac) {
|
1170
|
+
const [dsFrac, dsInt] = modf(dFrac * 24 * 3600);
|
1171
|
+
s = dsInt;
|
1172
|
+
daysecondsfrac = dsFrac;
|
1173
|
+
}
|
1174
|
+
const [sFrac, sInt] = modf(seconds);
|
1175
|
+
seconds = sInt;
|
1176
|
+
const secondsfrac = sFrac + daysecondsfrac;
|
1177
|
+
divmod(seconds, 24 * 3600, (days2, seconds2) => {
|
1178
|
+
d += days2;
|
1179
|
+
s += seconds2;
|
1180
|
+
});
|
1181
|
+
microseconds += secondsfrac * 1e6;
|
1182
|
+
divmod(microseconds, 1e6, (seconds2, microseconds2) => {
|
1183
|
+
divmod(seconds2, 24 * 3600, (days2, seconds3) => {
|
1184
|
+
d += days2;
|
1185
|
+
s += seconds3;
|
1186
|
+
us += Math.round(microseconds2);
|
1187
|
+
});
|
1188
|
+
});
|
1189
|
+
return new _PyTimeDelta(d, s, us);
|
1190
|
+
}
|
1191
|
+
add(other) {
|
1192
|
+
return _PyTimeDelta.create({
|
1193
|
+
days: this.days + other.days,
|
1194
|
+
seconds: this.seconds + other.seconds,
|
1195
|
+
microseconds: this.microseconds + other.microseconds
|
1196
|
+
});
|
1197
|
+
}
|
1198
|
+
divide(n) {
|
1199
|
+
const us = (this.days * 24 * 3600 + this.seconds) * 1e6 + this.microseconds;
|
1200
|
+
return _PyTimeDelta.create({ microseconds: Math.floor(us / n) });
|
1201
|
+
}
|
1202
|
+
isEqual(other) {
|
1203
|
+
if (!(other instanceof _PyTimeDelta)) {
|
1204
|
+
return false;
|
1205
|
+
}
|
1206
|
+
return this.days === other.days && this.seconds === other.seconds && this.microseconds === other.microseconds;
|
1207
|
+
}
|
1208
|
+
isTrue() {
|
1209
|
+
return this.days !== 0 || this.seconds !== 0 || this.microseconds !== 0;
|
1210
|
+
}
|
1211
|
+
multiply(n) {
|
1212
|
+
return _PyTimeDelta.create({
|
1213
|
+
days: n * this.days,
|
1214
|
+
seconds: n * this.seconds,
|
1215
|
+
microseconds: n * this.microseconds
|
1216
|
+
});
|
1217
|
+
}
|
1218
|
+
negate() {
|
1219
|
+
return _PyTimeDelta.create({
|
1220
|
+
days: -this.days,
|
1221
|
+
seconds: -this.seconds,
|
1222
|
+
microseconds: -this.microseconds
|
1223
|
+
});
|
1224
|
+
}
|
1225
|
+
substract(other) {
|
1226
|
+
return _PyTimeDelta.create({
|
1227
|
+
days: this.days - other.days,
|
1228
|
+
seconds: this.seconds - other.seconds,
|
1229
|
+
microseconds: this.microseconds - other.microseconds
|
1230
|
+
});
|
1231
|
+
}
|
1232
|
+
total_seconds() {
|
1233
|
+
return this.days * 86400 + this.seconds + this.microseconds / 1e6;
|
1234
|
+
}
|
1235
|
+
};
|
1236
|
+
|
1237
|
+
// src/utils/domain/py_builtin.ts
|
1238
|
+
var EvaluationError = class extends Error {
|
1239
|
+
constructor(message) {
|
1240
|
+
super(message);
|
1241
|
+
this.name = "EvaluationError";
|
1242
|
+
}
|
1243
|
+
};
|
1244
|
+
function execOnIterable(iterable, func) {
|
1245
|
+
if (iterable === null) {
|
1246
|
+
throw new EvaluationError("value not iterable");
|
1247
|
+
}
|
1248
|
+
if (typeof iterable === "object" && !Array.isArray(iterable) && !(iterable instanceof Set)) {
|
1249
|
+
iterable = Object.keys(iterable);
|
1250
|
+
}
|
1251
|
+
if (typeof iterable?.[Symbol.iterator] !== "function") {
|
1252
|
+
throw new EvaluationError("value not iterable");
|
1253
|
+
}
|
1254
|
+
return func(iterable);
|
1255
|
+
}
|
1256
|
+
var BUILTINS = {
|
1257
|
+
/**
|
1258
|
+
* @param {any} value
|
1259
|
+
* @returns {boolean}
|
1260
|
+
*/
|
1261
|
+
bool(value) {
|
1262
|
+
switch (typeof value) {
|
1263
|
+
case "number":
|
1264
|
+
return value !== 0;
|
1265
|
+
case "string":
|
1266
|
+
return value !== "";
|
1267
|
+
case "boolean":
|
1268
|
+
return value;
|
1269
|
+
case "object":
|
1270
|
+
if (value === null || value === void 0) {
|
1271
|
+
return false;
|
1272
|
+
}
|
1273
|
+
if ("isTrue" in value && typeof value.isTrue === "function") {
|
1274
|
+
return value.isTrue();
|
1275
|
+
}
|
1276
|
+
if (value instanceof Array) {
|
1277
|
+
return !!value.length;
|
1278
|
+
}
|
1279
|
+
if (value instanceof Set) {
|
1280
|
+
return !!value.size;
|
1281
|
+
}
|
1282
|
+
return Object.keys(value).length !== 0;
|
1283
|
+
default:
|
1284
|
+
return true;
|
1285
|
+
}
|
1286
|
+
},
|
1287
|
+
set(iterable) {
|
1288
|
+
if (arguments.length > 2) {
|
1289
|
+
throw new EvaluationError(
|
1290
|
+
`set expected at most 1 argument, got (${arguments.length - 1})`
|
1291
|
+
);
|
1292
|
+
}
|
1293
|
+
return execOnIterable(
|
1294
|
+
iterable,
|
1295
|
+
(iterable2) => new Set(iterable2)
|
1296
|
+
);
|
1297
|
+
},
|
1298
|
+
time: {
|
1299
|
+
strftime(format) {
|
1300
|
+
return PyDateTime.now().strftime(format);
|
1301
|
+
}
|
1302
|
+
},
|
1303
|
+
context_today() {
|
1304
|
+
return PyDate.today();
|
1305
|
+
},
|
1306
|
+
get current_date() {
|
1307
|
+
return this.today;
|
1308
|
+
},
|
1309
|
+
get today() {
|
1310
|
+
return PyDate.today().strftime("%Y-%m-%d");
|
1311
|
+
},
|
1312
|
+
get now() {
|
1313
|
+
return PyDateTime.now().strftime("%Y-%m-%d %H:%M:%S");
|
1314
|
+
},
|
1315
|
+
datetime: {
|
1316
|
+
time: PyTime,
|
1317
|
+
timedelta: PyTimeDelta,
|
1318
|
+
datetime: PyDateTime,
|
1319
|
+
date: PyDate
|
1320
|
+
},
|
1321
|
+
relativedelta: PyRelativeDelta,
|
1322
|
+
true: true,
|
1323
|
+
false: false
|
1324
|
+
};
|
1325
|
+
|
1326
|
+
// src/utils/domain/py_utils.ts
|
1327
|
+
function toPyValue(value) {
|
1328
|
+
switch (typeof value) {
|
1329
|
+
case "string":
|
1330
|
+
return { type: 1, value };
|
1331
|
+
case "number":
|
1332
|
+
return { type: 0, value };
|
1333
|
+
case "boolean":
|
1334
|
+
return { type: 2, value };
|
1335
|
+
case "object":
|
1336
|
+
if (Array.isArray(value)) {
|
1337
|
+
return { type: 4, value: value.map(toPyValue) };
|
1338
|
+
} else if (value === null) {
|
1339
|
+
return {
|
1340
|
+
type: 3
|
1341
|
+
/* None */
|
1342
|
+
};
|
1343
|
+
} else if (value instanceof Date) {
|
1344
|
+
return {
|
1345
|
+
type: 1,
|
1346
|
+
value: String(PyDateTime.convertDate(value))
|
1347
|
+
};
|
1348
|
+
} else if (value instanceof PyDate || value instanceof PyDateTime) {
|
1349
|
+
return { type: 1, value };
|
1350
|
+
} else {
|
1351
|
+
const content = {};
|
1352
|
+
for (const key in value) {
|
1353
|
+
content[key] = toPyValue(value[key]);
|
1354
|
+
}
|
1355
|
+
return { type: 11, value: content };
|
1356
|
+
}
|
1357
|
+
default:
|
1358
|
+
throw new Error("Invalid type");
|
1359
|
+
}
|
1360
|
+
}
|
1361
|
+
function formatAST(ast, lbp = 0) {
|
1362
|
+
switch (ast.type) {
|
1363
|
+
case 3:
|
1364
|
+
return "None";
|
1365
|
+
case 1:
|
1366
|
+
return JSON.stringify(ast.value);
|
1367
|
+
case 0:
|
1368
|
+
return String(ast.value);
|
1369
|
+
case 2:
|
1370
|
+
return ast.value ? "True" : "False";
|
1371
|
+
case 4:
|
1372
|
+
return `[${ast.value.map(formatAST).join(", ")}]`;
|
1373
|
+
case 6:
|
1374
|
+
if (ast.op === "not") {
|
1375
|
+
return `not ${formatAST(ast.right, 50)}`;
|
1376
|
+
}
|
1377
|
+
return `${ast.op}${formatAST(ast.right, 130)}`;
|
1378
|
+
case 7:
|
1379
|
+
const abp = bp(ast.op);
|
1380
|
+
const binaryStr = `${formatAST(ast.left, abp)} ${ast.op} ${formatAST(ast.right, abp)}`;
|
1381
|
+
return abp < lbp ? `(${binaryStr})` : binaryStr;
|
1382
|
+
case 11:
|
1383
|
+
const pairs = [];
|
1384
|
+
for (const k in ast.value) {
|
1385
|
+
pairs.push(`"${k}": ${formatAST(ast.value[k])}`);
|
1386
|
+
}
|
1387
|
+
return `{${pairs.join(", ")}}`;
|
1388
|
+
case 10:
|
1389
|
+
return `(${ast.value.map(formatAST).join(", ")})`;
|
1390
|
+
case 5:
|
1391
|
+
return ast.value;
|
1392
|
+
case 12:
|
1393
|
+
return `${formatAST(ast.target)}[${formatAST(ast.key)}]`;
|
1394
|
+
case 13:
|
1395
|
+
const { ifTrue, condition, ifFalse } = ast;
|
1396
|
+
return `${formatAST(ifTrue)} if ${formatAST(condition)} else ${formatAST(ifFalse)}`;
|
1397
|
+
case 14:
|
1398
|
+
const boolAbp = bp(ast.op);
|
1399
|
+
const boolStr = `${formatAST(ast.left, boolAbp)} ${ast.op} ${formatAST(ast.right, boolAbp)}`;
|
1400
|
+
return boolAbp < lbp ? `(${boolStr})` : boolStr;
|
1401
|
+
case 15:
|
1402
|
+
return `${formatAST(ast.obj, 150)}.${ast.key}`;
|
1403
|
+
case 8:
|
1404
|
+
const args = ast.args.map(formatAST);
|
1405
|
+
const kwargs = [];
|
1406
|
+
for (const kwarg in ast.kwargs) {
|
1407
|
+
kwargs.push(`${kwarg} = ${formatAST(ast.kwargs[kwarg])}`);
|
1408
|
+
}
|
1409
|
+
const argStr = args.concat(kwargs).join(", ");
|
1410
|
+
return `${formatAST(ast.fn)}(${argStr})`;
|
1411
|
+
default:
|
1412
|
+
throw new Error("invalid expression: " + JSON.stringify(ast));
|
1413
|
+
}
|
1414
|
+
}
|
1415
|
+
var PY_DICT = /* @__PURE__ */ Object.create(null);
|
1416
|
+
function toPyDict(obj) {
|
1417
|
+
return new Proxy(obj, {
|
1418
|
+
getPrototypeOf() {
|
1419
|
+
return PY_DICT;
|
1420
|
+
}
|
1421
|
+
});
|
1422
|
+
}
|
1423
|
+
|
1424
|
+
// src/utils/domain/py_interpreter.ts
|
1425
|
+
var isTrue = BUILTINS.bool;
|
1426
|
+
function applyUnaryOp(ast, context) {
|
1427
|
+
const value = evaluate(ast.right, context);
|
1428
|
+
switch (ast.op) {
|
1429
|
+
case "-":
|
1430
|
+
if (value instanceof Object && "negate" in value) {
|
1431
|
+
return value.negate();
|
1432
|
+
}
|
1433
|
+
return -value;
|
1434
|
+
case "+":
|
1435
|
+
return value;
|
1436
|
+
case "not":
|
1437
|
+
return !isTrue(value);
|
1438
|
+
default:
|
1439
|
+
throw new EvaluationError(`Unknown unary operator: ${ast.op}`);
|
1440
|
+
}
|
1441
|
+
}
|
1442
|
+
function pytypeIndex(val) {
|
1443
|
+
switch (typeof val) {
|
1444
|
+
case "object":
|
1445
|
+
return val === null ? 1 : Array.isArray(val) ? 5 : 3;
|
1446
|
+
case "number":
|
1447
|
+
return 2;
|
1448
|
+
case "string":
|
1449
|
+
return 4;
|
1450
|
+
default:
|
1451
|
+
throw new EvaluationError(`Unknown type: ${typeof val}`);
|
1452
|
+
}
|
1453
|
+
}
|
1454
|
+
function isLess(left, right) {
|
1455
|
+
if (typeof left === "number" && typeof right === "number") {
|
1456
|
+
return left < right;
|
1457
|
+
}
|
1458
|
+
if (typeof left === "boolean") {
|
1459
|
+
left = left ? 1 : 0;
|
1460
|
+
}
|
1461
|
+
if (typeof right === "boolean") {
|
1462
|
+
right = right ? 1 : 0;
|
1463
|
+
}
|
1464
|
+
const leftIndex = pytypeIndex(left);
|
1465
|
+
const rightIndex = pytypeIndex(right);
|
1466
|
+
if (leftIndex === rightIndex) {
|
1467
|
+
return left < right;
|
1468
|
+
}
|
1469
|
+
return leftIndex < rightIndex;
|
1470
|
+
}
|
1471
|
+
function isEqual(left, right) {
|
1472
|
+
if (typeof left !== typeof right) {
|
1473
|
+
if (typeof left === "boolean" && typeof right === "number") {
|
1474
|
+
return right === (left ? 1 : 0);
|
1475
|
+
}
|
1476
|
+
if (typeof left === "number" && typeof right === "boolean") {
|
1477
|
+
return left === (right ? 1 : 0);
|
1478
|
+
}
|
1479
|
+
return false;
|
1480
|
+
}
|
1481
|
+
if (left instanceof Object && "isEqual" in left) {
|
1482
|
+
return left.isEqual(right);
|
1483
|
+
}
|
1484
|
+
return left === right;
|
1485
|
+
}
|
1486
|
+
function isIn(left, right) {
|
1487
|
+
if (Array.isArray(right)) {
|
1488
|
+
return right.includes(left);
|
1489
|
+
}
|
1490
|
+
if (typeof right === "string" && typeof left === "string") {
|
1491
|
+
return right.includes(left);
|
1492
|
+
}
|
1493
|
+
if (typeof right === "object") {
|
1494
|
+
return left in right;
|
1495
|
+
}
|
1496
|
+
return false;
|
1497
|
+
}
|
1498
|
+
function applyBinaryOp(ast, context) {
|
1499
|
+
const left = evaluate(ast.left, context);
|
1500
|
+
const right = evaluate(ast.right, context);
|
1501
|
+
switch (ast.op) {
|
1502
|
+
case "+": {
|
1503
|
+
const relativeDeltaOnLeft = left instanceof PyRelativeDelta;
|
1504
|
+
const relativeDeltaOnRight = right instanceof PyRelativeDelta;
|
1505
|
+
if (relativeDeltaOnLeft || relativeDeltaOnRight) {
|
1506
|
+
const date = relativeDeltaOnLeft ? right : left;
|
1507
|
+
const delta = relativeDeltaOnLeft ? left : right;
|
1508
|
+
return PyRelativeDelta.add(date, delta);
|
1509
|
+
}
|
1510
|
+
const timeDeltaOnLeft = left instanceof PyTimeDelta;
|
1511
|
+
const timeDeltaOnRight = right instanceof PyTimeDelta;
|
1512
|
+
if (timeDeltaOnLeft && timeDeltaOnRight) {
|
1513
|
+
return left.add(right);
|
1514
|
+
}
|
1515
|
+
if (timeDeltaOnLeft) {
|
1516
|
+
if (right instanceof PyDate || right instanceof PyDateTime) {
|
1517
|
+
return right.add(left);
|
1518
|
+
} else {
|
1519
|
+
throw new NotSupportedError();
|
1520
|
+
}
|
1521
|
+
}
|
1522
|
+
if (timeDeltaOnRight) {
|
1523
|
+
if (left instanceof PyDate || left instanceof PyDateTime) {
|
1524
|
+
return left.add(right);
|
1525
|
+
} else {
|
1526
|
+
throw new NotSupportedError();
|
1527
|
+
}
|
1528
|
+
}
|
1529
|
+
if (left instanceof Array && right instanceof Array) {
|
1530
|
+
return [...left, ...right];
|
1531
|
+
}
|
1532
|
+
return left + right;
|
1533
|
+
}
|
1534
|
+
case "-": {
|
1535
|
+
const isRightDelta = right instanceof PyRelativeDelta;
|
1536
|
+
if (isRightDelta) {
|
1537
|
+
return PyRelativeDelta.substract(left, right);
|
1538
|
+
}
|
1539
|
+
const timeDeltaOnRight = right instanceof PyTimeDelta;
|
1540
|
+
if (timeDeltaOnRight) {
|
1541
|
+
if (left instanceof PyTimeDelta) {
|
1542
|
+
return left.substract(right);
|
1543
|
+
} else if (left instanceof PyDate || left instanceof PyDateTime) {
|
1544
|
+
return left.substract(right);
|
1545
|
+
} else {
|
1546
|
+
throw new NotSupportedError();
|
1547
|
+
}
|
1548
|
+
}
|
1549
|
+
if (left instanceof PyDate) {
|
1550
|
+
return left.substract(right);
|
1551
|
+
}
|
1552
|
+
return left - right;
|
1553
|
+
}
|
1554
|
+
case "*": {
|
1555
|
+
const timeDeltaOnLeft = left instanceof PyTimeDelta;
|
1556
|
+
const timeDeltaOnRight = right instanceof PyTimeDelta;
|
1557
|
+
if (timeDeltaOnLeft || timeDeltaOnRight) {
|
1558
|
+
const number = timeDeltaOnLeft ? right : left;
|
1559
|
+
const delta = timeDeltaOnLeft ? left : right;
|
1560
|
+
return delta.multiply(number);
|
1561
|
+
}
|
1562
|
+
return left * right;
|
1563
|
+
}
|
1564
|
+
case "/":
|
1565
|
+
return left / right;
|
1566
|
+
case "%":
|
1567
|
+
return left % right;
|
1568
|
+
case "//":
|
1569
|
+
if (left instanceof PyTimeDelta) {
|
1570
|
+
return left.divide(right);
|
1571
|
+
}
|
1572
|
+
return Math.floor(left / right);
|
1573
|
+
case "**":
|
1574
|
+
return left ** right;
|
1575
|
+
case "==":
|
1576
|
+
return isEqual(left, right);
|
1577
|
+
case "<>":
|
1578
|
+
case "!=":
|
1579
|
+
return !isEqual(left, right);
|
1580
|
+
case "<":
|
1581
|
+
return isLess(left, right);
|
1582
|
+
case ">":
|
1583
|
+
return isLess(right, left);
|
1584
|
+
case ">=":
|
1585
|
+
return isEqual(left, right) || isLess(right, left);
|
1586
|
+
case "<=":
|
1587
|
+
return isEqual(left, right) || isLess(left, right);
|
1588
|
+
case "in":
|
1589
|
+
return isIn(left, right);
|
1590
|
+
case "not in":
|
1591
|
+
return !isIn(left, right);
|
1592
|
+
default:
|
1593
|
+
throw new EvaluationError(`Unknown binary operator: ${ast.op}`);
|
1594
|
+
}
|
1595
|
+
}
|
1596
|
+
var DICT = {
|
1597
|
+
get(...args) {
|
1598
|
+
const { key, defValue } = parseArgs(args, ["key", "defValue"]);
|
1599
|
+
const self = this;
|
1600
|
+
if (key in self) {
|
1601
|
+
return self[key];
|
1602
|
+
} else if (defValue !== void 0) {
|
1603
|
+
return defValue;
|
1604
|
+
}
|
1605
|
+
return null;
|
1606
|
+
}
|
1607
|
+
};
|
1608
|
+
var STRING = {
|
1609
|
+
lower() {
|
1610
|
+
return this.toLowerCase();
|
1611
|
+
},
|
1612
|
+
upper() {
|
1613
|
+
return this.toUpperCase();
|
1614
|
+
}
|
1615
|
+
};
|
1616
|
+
function applyFunc(key, func, set, ...args) {
|
1617
|
+
if (args.length === 1) {
|
1618
|
+
return new Set(set);
|
1619
|
+
}
|
1620
|
+
if (args.length > 2) {
|
1621
|
+
throw new EvaluationError(
|
1622
|
+
`${key}: py_js supports at most 1 argument, got (${args.length - 1})`
|
1623
|
+
);
|
1624
|
+
}
|
1625
|
+
return execOnIterable(args[0], func);
|
1626
|
+
}
|
1627
|
+
var SET = {
|
1628
|
+
intersection(...args) {
|
1629
|
+
return applyFunc(
|
1630
|
+
"intersection",
|
1631
|
+
(iterable) => {
|
1632
|
+
const intersection = /* @__PURE__ */ new Set();
|
1633
|
+
for (const i of iterable) {
|
1634
|
+
if (this.has(i)) {
|
1635
|
+
intersection.add(i);
|
1636
|
+
}
|
1637
|
+
}
|
1638
|
+
return intersection;
|
1639
|
+
},
|
1640
|
+
this,
|
1641
|
+
...args
|
1642
|
+
);
|
1643
|
+
},
|
1644
|
+
difference(...args) {
|
1645
|
+
return applyFunc(
|
1646
|
+
"difference",
|
1647
|
+
(iterable) => {
|
1648
|
+
iterable = new Set(iterable);
|
1649
|
+
const difference = /* @__PURE__ */ new Set();
|
1650
|
+
for (const e of this) {
|
1651
|
+
if (!iterable.has(e)) {
|
1652
|
+
difference.add(e);
|
1653
|
+
}
|
1654
|
+
}
|
1655
|
+
return difference;
|
1656
|
+
},
|
1657
|
+
this,
|
1658
|
+
...args
|
1659
|
+
);
|
1660
|
+
},
|
1661
|
+
union(...args) {
|
1662
|
+
return applyFunc(
|
1663
|
+
"union",
|
1664
|
+
(iterable) => {
|
1665
|
+
return /* @__PURE__ */ new Set([...this, ...iterable]);
|
1666
|
+
},
|
1667
|
+
this,
|
1668
|
+
...args
|
1669
|
+
);
|
1670
|
+
}
|
1671
|
+
};
|
1672
|
+
function methods(_class) {
|
1673
|
+
return Object.getOwnPropertyNames(_class.prototype).map(
|
1674
|
+
(prop) => _class.prototype[prop]
|
1675
|
+
);
|
1676
|
+
}
|
1677
|
+
var allowedFns = /* @__PURE__ */ new Set([
|
1678
|
+
BUILTINS.time.strftime,
|
1679
|
+
BUILTINS.set,
|
1680
|
+
BUILTINS.bool,
|
1681
|
+
BUILTINS.context_today,
|
1682
|
+
BUILTINS.datetime.datetime.now,
|
1683
|
+
BUILTINS.datetime.datetime.combine,
|
1684
|
+
BUILTINS.datetime.date.today,
|
1685
|
+
...methods(BUILTINS.relativedelta),
|
1686
|
+
...Object.values(BUILTINS.datetime).flatMap((obj) => methods(obj)),
|
1687
|
+
...Object.values(SET),
|
1688
|
+
...Object.values(DICT),
|
1689
|
+
...Object.values(STRING)
|
1690
|
+
]);
|
1691
|
+
var unboundFn = Symbol("unbound function");
|
1692
|
+
function evaluate(ast, context = {}) {
|
1693
|
+
const dicts = /* @__PURE__ */ new Set();
|
1694
|
+
let pyContext;
|
1695
|
+
const evalContext = Object.create(context);
|
1696
|
+
if (!evalContext?.context) {
|
1697
|
+
Object.defineProperty(evalContext, "context", {
|
1698
|
+
get() {
|
1699
|
+
if (!pyContext) {
|
1700
|
+
pyContext = toPyDict(context);
|
1701
|
+
}
|
1702
|
+
return pyContext;
|
1703
|
+
}
|
1704
|
+
});
|
1705
|
+
}
|
1706
|
+
function _innerEvaluate(ast2) {
|
1707
|
+
switch (ast2?.type) {
|
1708
|
+
case 0:
|
1709
|
+
// Number
|
1710
|
+
case 1:
|
1711
|
+
return ast2.value;
|
1712
|
+
case 5:
|
1713
|
+
if (ast2.value in evalContext) {
|
1714
|
+
if (typeof evalContext[ast2.value] === "object" && evalContext[ast2.value]?.id) {
|
1715
|
+
return evalContext[ast2.value]?.id;
|
1716
|
+
}
|
1717
|
+
return evalContext[ast2.value] ?? false;
|
1718
|
+
} else if (ast2.value in BUILTINS) {
|
1719
|
+
return BUILTINS[ast2.value];
|
1720
|
+
} else {
|
1721
|
+
return false;
|
1722
|
+
}
|
1723
|
+
case 3:
|
1724
|
+
return null;
|
1725
|
+
case 2:
|
1726
|
+
return ast2.value;
|
1727
|
+
case 6:
|
1728
|
+
return applyUnaryOp(ast2, evalContext);
|
1729
|
+
case 7:
|
1730
|
+
return applyBinaryOp(ast2, evalContext);
|
1731
|
+
case 14:
|
1732
|
+
const left = _evaluate(ast2.left);
|
1733
|
+
if (ast2.op === "and") {
|
1734
|
+
return isTrue(left) ? _evaluate(ast2.right) : left;
|
1735
|
+
} else {
|
1736
|
+
return isTrue(left) ? left : _evaluate(ast2.right);
|
1737
|
+
}
|
1738
|
+
case 4:
|
1739
|
+
// List
|
1740
|
+
case 10:
|
1741
|
+
return ast2.value.map(_evaluate);
|
1742
|
+
case 11:
|
1743
|
+
const dict = {};
|
1744
|
+
for (const key2 in ast2.value) {
|
1745
|
+
dict[key2] = _evaluate(ast2.value[key2]);
|
1746
|
+
}
|
1747
|
+
dicts.add(dict);
|
1748
|
+
return dict;
|
1749
|
+
case 8:
|
1750
|
+
const fnValue = _evaluate(ast2.fn);
|
1751
|
+
const args = ast2.args.map(_evaluate);
|
1752
|
+
const kwargs = {};
|
1753
|
+
for (const kwarg in ast2.kwargs) {
|
1754
|
+
kwargs[kwarg] = _evaluate(ast2?.kwargs[kwarg]);
|
1755
|
+
}
|
1756
|
+
if (fnValue === PyDate || fnValue === PyDateTime || fnValue === PyTime || fnValue === PyRelativeDelta || fnValue === PyTimeDelta) {
|
1757
|
+
return fnValue.create(...args, kwargs);
|
1758
|
+
}
|
1759
|
+
return fnValue(...args, kwargs);
|
1760
|
+
case 12:
|
1761
|
+
const dictVal = _evaluate(ast2.target);
|
1762
|
+
const key = _evaluate(ast2.key);
|
1763
|
+
return dictVal[key];
|
1764
|
+
case 13:
|
1765
|
+
if (isTrue(_evaluate(ast2.condition))) {
|
1766
|
+
return _evaluate(ast2.ifTrue);
|
1767
|
+
} else {
|
1768
|
+
return _evaluate(ast2.ifFalse);
|
1769
|
+
}
|
1770
|
+
case 15:
|
1771
|
+
let leftVal = _evaluate(ast2.obj);
|
1772
|
+
let result;
|
1773
|
+
if (dicts.has(leftVal) || Object.isPrototypeOf.call(PY_DICT, leftVal)) {
|
1774
|
+
result = DICT[ast2.key];
|
1775
|
+
} else if (typeof leftVal === "string") {
|
1776
|
+
result = STRING[ast2.key];
|
1777
|
+
} else if (leftVal instanceof Set) {
|
1778
|
+
result = SET[ast2.key];
|
1779
|
+
} else if (ast2.key === "get" && typeof leftVal === "object") {
|
1780
|
+
result = DICT[ast2.key];
|
1781
|
+
leftVal = toPyDict(leftVal);
|
1782
|
+
} else {
|
1783
|
+
result = leftVal[ast2.key];
|
1784
|
+
}
|
1785
|
+
if (typeof result === "function") {
|
1786
|
+
const bound = result.bind(leftVal);
|
1787
|
+
bound[unboundFn] = result;
|
1788
|
+
return bound;
|
1789
|
+
}
|
1790
|
+
return result;
|
1791
|
+
default:
|
1792
|
+
throw new EvaluationError(`AST of type ${ast2.type} cannot be evaluated`);
|
1793
|
+
}
|
1794
|
+
}
|
1795
|
+
function _evaluate(ast2) {
|
1796
|
+
const val = _innerEvaluate(ast2);
|
1797
|
+
if (typeof val === "function" && !allowedFns.has(val) && !allowedFns.has(val[unboundFn])) {
|
1798
|
+
throw new Error("Invalid Function Call");
|
1799
|
+
}
|
1800
|
+
return val;
|
1801
|
+
}
|
1802
|
+
return _evaluate(ast);
|
1803
|
+
}
|
1804
|
+
|
1805
|
+
// src/utils/domain/py.ts
|
1806
|
+
function parseExpr(expr) {
|
1807
|
+
const tokens = tokenize(expr);
|
1808
|
+
return parse(tokens);
|
1809
|
+
}
|
1810
|
+
|
1811
|
+
// src/utils/domain/objects.ts
|
1812
|
+
function shallowEqual(obj1, obj2, comparisonFn = (a, b) => a === b) {
|
1813
|
+
if (!obj1 || !obj2 || typeof obj1 !== "object" || typeof obj2 !== "object") {
|
1814
|
+
return obj1 === obj2;
|
1815
|
+
}
|
1816
|
+
const obj1Keys = Object.keys(obj1);
|
1817
|
+
return obj1Keys.length === Object.keys(obj2).length && obj1Keys.every((key) => comparisonFn(obj1[key], obj2[key]));
|
1818
|
+
}
|
1819
|
+
|
1820
|
+
// src/utils/domain/arrays.ts
|
1821
|
+
var shallowEqual2 = shallowEqual;
|
1822
|
+
|
1823
|
+
// src/utils/domain/strings.ts
|
1824
|
+
var escapeMethod = Symbol("html");
|
1825
|
+
function escapeRegExp(str) {
|
1826
|
+
return str.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
1827
|
+
}
|
1828
|
+
|
1829
|
+
// src/utils/domain/domain.ts
|
1830
|
+
var InvalidDomainError = class extends Error {
|
1831
|
+
};
|
1832
|
+
var Domain = class _Domain {
|
1833
|
+
ast = { type: -1, value: null };
|
1834
|
+
static TRUE;
|
1835
|
+
static FALSE;
|
1836
|
+
static combine(domains, operator) {
|
1837
|
+
if (domains.length === 0) {
|
1838
|
+
return new _Domain([]);
|
1839
|
+
}
|
1840
|
+
const domain1 = domains[0] instanceof _Domain ? domains[0] : new _Domain(domains[0]);
|
1841
|
+
if (domains.length === 1) {
|
1842
|
+
return domain1;
|
1843
|
+
}
|
1844
|
+
const domain2 = _Domain.combine(domains.slice(1), operator);
|
1845
|
+
const result = new _Domain([]);
|
1846
|
+
const astValues1 = domain1.ast.value;
|
1847
|
+
const astValues2 = domain2.ast.value;
|
1848
|
+
const op = operator === "AND" ? "&" : "|";
|
1849
|
+
const combinedAST = {
|
1850
|
+
type: 4,
|
1851
|
+
value: astValues1.concat(astValues2)
|
1852
|
+
};
|
1853
|
+
result.ast = normalizeDomainAST(combinedAST, op);
|
1854
|
+
return result;
|
1855
|
+
}
|
1856
|
+
static and(domains) {
|
1857
|
+
return _Domain.combine(domains, "AND");
|
1858
|
+
}
|
1859
|
+
static or(domains) {
|
1860
|
+
return _Domain.combine(domains, "OR");
|
1861
|
+
}
|
1862
|
+
static not(domain) {
|
1863
|
+
const result = new _Domain(domain);
|
1864
|
+
result.ast.value.unshift({ type: 1, value: "!" });
|
1865
|
+
return result;
|
1866
|
+
}
|
1867
|
+
static removeDomainLeaves(domain, keysToRemove) {
|
1868
|
+
function processLeaf(elements, idx, operatorCtx, newDomain2) {
|
1869
|
+
const leaf = elements[idx];
|
1870
|
+
if (leaf.type === 10) {
|
1871
|
+
if (keysToRemove.includes(leaf.value[0].value)) {
|
1872
|
+
if (operatorCtx === "&") {
|
1873
|
+
newDomain2.ast.value.push(..._Domain.TRUE.ast.value);
|
1874
|
+
} else if (operatorCtx === "|") {
|
1875
|
+
newDomain2.ast.value.push(..._Domain.FALSE.ast.value);
|
1876
|
+
}
|
1877
|
+
} else {
|
1878
|
+
newDomain2.ast.value.push(leaf);
|
1879
|
+
}
|
1880
|
+
return 1;
|
1881
|
+
} else if (leaf.type === 1) {
|
1882
|
+
if (leaf.value === "|" && elements[idx + 1].type === 10 && elements[idx + 2].type === 10 && keysToRemove.includes(elements[idx + 1].value[0].value) && keysToRemove.includes(elements[idx + 2].value[0].value)) {
|
1883
|
+
newDomain2.ast.value.push(..._Domain.TRUE.ast.value);
|
1884
|
+
return 3;
|
1885
|
+
}
|
1886
|
+
newDomain2.ast.value.push(leaf);
|
1887
|
+
if (leaf.value === "!") {
|
1888
|
+
return 1 + processLeaf(elements, idx + 1, "&", newDomain2);
|
1889
|
+
}
|
1890
|
+
const firstLeafSkip = processLeaf(
|
1891
|
+
elements,
|
1892
|
+
idx + 1,
|
1893
|
+
leaf.value,
|
1894
|
+
newDomain2
|
1895
|
+
);
|
1896
|
+
const secondLeafSkip = processLeaf(
|
1897
|
+
elements,
|
1898
|
+
idx + 1 + firstLeafSkip,
|
1899
|
+
leaf.value,
|
1900
|
+
newDomain2
|
1901
|
+
);
|
1902
|
+
return 1 + firstLeafSkip + secondLeafSkip;
|
1903
|
+
}
|
1904
|
+
return 0;
|
1905
|
+
}
|
1906
|
+
const d = new _Domain(domain);
|
1907
|
+
if (d.ast.value.length === 0) {
|
1908
|
+
return d;
|
1909
|
+
}
|
1910
|
+
const newDomain = new _Domain([]);
|
1911
|
+
processLeaf(d.ast.value, 0, "&", newDomain);
|
1912
|
+
return newDomain;
|
1913
|
+
}
|
1914
|
+
constructor(descr = []) {
|
1915
|
+
if (descr instanceof _Domain) {
|
1916
|
+
return new _Domain(descr.toString());
|
1917
|
+
} else {
|
1918
|
+
let rawAST;
|
1919
|
+
try {
|
1920
|
+
rawAST = typeof descr === "string" ? parseExpr(descr) : toAST(descr);
|
1921
|
+
} catch (error) {
|
1922
|
+
throw new InvalidDomainError(
|
1923
|
+
`Invalid domain representation: ${descr}`,
|
1924
|
+
{
|
1925
|
+
cause: error
|
1926
|
+
}
|
1927
|
+
);
|
1928
|
+
}
|
1929
|
+
this.ast = normalizeDomainAST(rawAST);
|
1930
|
+
}
|
1931
|
+
}
|
1932
|
+
contains(record) {
|
1933
|
+
const expr = evaluate(this.ast, record);
|
1934
|
+
return matchDomain(record, expr);
|
1935
|
+
}
|
1936
|
+
toString() {
|
1937
|
+
return formatAST(this.ast);
|
1938
|
+
}
|
1939
|
+
toList(context) {
|
1940
|
+
return evaluate(this.ast, context);
|
1941
|
+
}
|
1942
|
+
toJson() {
|
1943
|
+
try {
|
1944
|
+
const evaluatedAsList = this.toList({});
|
1945
|
+
const evaluatedDomain = new _Domain(evaluatedAsList);
|
1946
|
+
if (evaluatedDomain.toString() === this.toString()) {
|
1947
|
+
return evaluatedAsList;
|
1948
|
+
}
|
1949
|
+
return this.toString();
|
1950
|
+
} catch {
|
1951
|
+
return this.toString();
|
1952
|
+
}
|
1953
|
+
}
|
1954
|
+
};
|
1955
|
+
var TRUE_LEAF = [1, "=", 1];
|
1956
|
+
var FALSE_LEAF = [0, "=", 1];
|
1957
|
+
var TRUE_DOMAIN = new Domain([TRUE_LEAF]);
|
1958
|
+
var FALSE_DOMAIN = new Domain([FALSE_LEAF]);
|
1959
|
+
Domain.TRUE = TRUE_DOMAIN;
|
1960
|
+
Domain.FALSE = FALSE_DOMAIN;
|
1961
|
+
function toAST(domain) {
|
1962
|
+
const elems = domain.map((elem) => {
|
1963
|
+
switch (elem) {
|
1964
|
+
case "!":
|
1965
|
+
case "&":
|
1966
|
+
case "|":
|
1967
|
+
return { type: 1, value: elem };
|
1968
|
+
default:
|
1969
|
+
return {
|
1970
|
+
type: 10,
|
1971
|
+
value: elem.map(toPyValue)
|
1972
|
+
};
|
1973
|
+
}
|
1974
|
+
});
|
1975
|
+
return { type: 4, value: elems };
|
1976
|
+
}
|
1977
|
+
function normalizeDomainAST(domain, op = "&") {
|
1978
|
+
if (domain.type !== 4) {
|
1979
|
+
if (domain.type === 10) {
|
1980
|
+
const value = domain.value;
|
1981
|
+
if (value.findIndex((e) => e.type === 10) === -1 || !value.every((e) => e.type === 10 || e.type === 1)) {
|
1982
|
+
throw new InvalidDomainError("Invalid domain AST");
|
1983
|
+
}
|
1984
|
+
} else {
|
1985
|
+
throw new InvalidDomainError("Invalid domain AST");
|
1986
|
+
}
|
1987
|
+
}
|
1988
|
+
if (domain.value.length === 0) {
|
1989
|
+
return domain;
|
1990
|
+
}
|
1991
|
+
let expected = 1;
|
1992
|
+
for (const child of domain.value) {
|
1993
|
+
switch (child.type) {
|
1994
|
+
case 1:
|
1995
|
+
if (child.value === "&" || child.value === "|") {
|
1996
|
+
expected++;
|
1997
|
+
} else if (child.value !== "!") {
|
1998
|
+
throw new InvalidDomainError("Invalid domain AST");
|
1999
|
+
}
|
2000
|
+
break;
|
2001
|
+
case 4:
|
2002
|
+
/* list */
|
2003
|
+
case 10:
|
2004
|
+
if (child.value.length === 3) {
|
2005
|
+
expected--;
|
2006
|
+
break;
|
2007
|
+
}
|
2008
|
+
throw new InvalidDomainError("Invalid domain AST");
|
2009
|
+
default:
|
2010
|
+
throw new InvalidDomainError("Invalid domain AST");
|
2011
|
+
}
|
2012
|
+
}
|
2013
|
+
const values = domain.value.slice();
|
2014
|
+
while (expected < 0) {
|
2015
|
+
expected++;
|
2016
|
+
values.unshift({ type: 1, value: op });
|
2017
|
+
}
|
2018
|
+
if (expected > 0) {
|
2019
|
+
throw new InvalidDomainError(
|
2020
|
+
`invalid domain ${formatAST(domain)} (missing ${expected} segment(s))`
|
2021
|
+
);
|
2022
|
+
}
|
2023
|
+
return { type: 4, value: values };
|
2024
|
+
}
|
2025
|
+
function matchCondition(record, condition) {
|
2026
|
+
if (typeof condition === "boolean") {
|
2027
|
+
return condition;
|
2028
|
+
}
|
2029
|
+
const [field, operator, value] = condition;
|
2030
|
+
if (typeof field === "string") {
|
2031
|
+
const names = field.split(".");
|
2032
|
+
if (names.length >= 2) {
|
2033
|
+
return matchCondition(record[names[0]], [
|
2034
|
+
names.slice(1).join("."),
|
2035
|
+
operator,
|
2036
|
+
value
|
2037
|
+
]);
|
2038
|
+
}
|
2039
|
+
}
|
2040
|
+
let likeRegexp, ilikeRegexp;
|
2041
|
+
if (["like", "not like", "ilike", "not ilike"].includes(operator)) {
|
2042
|
+
likeRegexp = new RegExp(
|
2043
|
+
`(.*)${escapeRegExp(value).replaceAll("%", "(.*)")}(.*)`,
|
2044
|
+
"g"
|
2045
|
+
);
|
2046
|
+
ilikeRegexp = new RegExp(
|
2047
|
+
`(.*)${escapeRegExp(value).replaceAll("%", "(.*)")}(.*)`,
|
2048
|
+
"gi"
|
2049
|
+
);
|
2050
|
+
}
|
2051
|
+
const fieldValue = typeof field === "number" ? field : record[field];
|
2052
|
+
switch (operator) {
|
2053
|
+
case "=?":
|
2054
|
+
if ([false, null].includes(value)) {
|
2055
|
+
return true;
|
2056
|
+
}
|
2057
|
+
// eslint-disable-next-line no-fallthrough
|
2058
|
+
case "=":
|
2059
|
+
case "==":
|
2060
|
+
if (Array.isArray(fieldValue) && Array.isArray(value)) {
|
2061
|
+
return shallowEqual2(fieldValue, value);
|
2062
|
+
}
|
2063
|
+
return fieldValue === value;
|
2064
|
+
case "!=":
|
2065
|
+
case "<>":
|
2066
|
+
return !matchCondition(record, [field, "==", value]);
|
2067
|
+
case "<":
|
2068
|
+
return fieldValue < value;
|
2069
|
+
case "<=":
|
2070
|
+
return fieldValue <= value;
|
2071
|
+
case ">":
|
2072
|
+
return fieldValue > value;
|
2073
|
+
case ">=":
|
2074
|
+
return fieldValue >= value;
|
2075
|
+
case "in": {
|
2076
|
+
const val = Array.isArray(value) ? value : [value];
|
2077
|
+
const fieldVal = Array.isArray(fieldValue) ? fieldValue : [fieldValue];
|
2078
|
+
return fieldVal.some((fv) => val.includes(fv));
|
2079
|
+
}
|
2080
|
+
case "not in": {
|
2081
|
+
const val = Array.isArray(value) ? value : [value];
|
2082
|
+
const fieldVal = Array.isArray(fieldValue) ? fieldValue : [fieldValue];
|
2083
|
+
return !fieldVal.some((fv) => val.includes(fv));
|
2084
|
+
}
|
2085
|
+
case "like":
|
2086
|
+
if (fieldValue === false) {
|
2087
|
+
return false;
|
2088
|
+
}
|
2089
|
+
return Boolean(fieldValue.match(likeRegexp));
|
2090
|
+
case "not like":
|
2091
|
+
if (fieldValue === false) {
|
2092
|
+
return false;
|
2093
|
+
}
|
2094
|
+
return Boolean(!fieldValue.match(likeRegexp));
|
2095
|
+
case "=like":
|
2096
|
+
if (fieldValue === false) {
|
2097
|
+
return false;
|
2098
|
+
}
|
2099
|
+
return new RegExp(escapeRegExp(value).replace(/%/g, ".*")).test(
|
2100
|
+
fieldValue
|
2101
|
+
);
|
2102
|
+
case "ilike":
|
2103
|
+
if (fieldValue === false) {
|
2104
|
+
return false;
|
2105
|
+
}
|
2106
|
+
return Boolean(fieldValue.match(ilikeRegexp));
|
2107
|
+
case "not ilike":
|
2108
|
+
if (fieldValue === false) {
|
2109
|
+
return false;
|
2110
|
+
}
|
2111
|
+
return Boolean(!fieldValue.match(ilikeRegexp));
|
2112
|
+
case "=ilike":
|
2113
|
+
if (fieldValue === false) {
|
2114
|
+
return false;
|
2115
|
+
}
|
2116
|
+
return new RegExp(escapeRegExp(value).replace(/%/g, ".*"), "i").test(
|
2117
|
+
fieldValue
|
2118
|
+
);
|
2119
|
+
}
|
2120
|
+
throw new InvalidDomainError("could not match domain");
|
2121
|
+
}
|
2122
|
+
function makeOperators(record) {
|
2123
|
+
const match = matchCondition.bind(null, record);
|
2124
|
+
return {
|
2125
|
+
"!": (x) => !match(x),
|
2126
|
+
"&": (a, b) => match(a) && match(b),
|
2127
|
+
"|": (a, b) => match(a) || match(b)
|
2128
|
+
};
|
2129
|
+
}
|
2130
|
+
function matchDomain(record, domain) {
|
2131
|
+
if (domain.length === 0) {
|
2132
|
+
return true;
|
2133
|
+
}
|
2134
|
+
const operators = makeOperators(record);
|
2135
|
+
const reversedDomain = Array.from(domain).reverse();
|
2136
|
+
const condStack = [];
|
2137
|
+
for (const item of reversedDomain) {
|
2138
|
+
const operator = typeof item === "string" && operators[item];
|
2139
|
+
if (operator) {
|
2140
|
+
const operands = condStack.splice(-operator.length);
|
2141
|
+
condStack.push(operator(...operands));
|
2142
|
+
} else {
|
2143
|
+
condStack.push(item);
|
2144
|
+
}
|
2145
|
+
}
|
2146
|
+
return matchCondition(record, condStack.pop());
|
2147
|
+
}
|
2148
|
+
|
2149
|
+
// src/utils/storage/local-storage.ts
|
2150
|
+
var localStorageUtils = () => {
|
2151
|
+
const setToken = async (access_token) => {
|
2152
|
+
localStorage.setItem("accessToken", access_token);
|
2153
|
+
};
|
2154
|
+
const setRefreshToken = async (refresh_token) => {
|
2155
|
+
localStorage.setItem("refreshToken", refresh_token);
|
2156
|
+
};
|
2157
|
+
const getAccessToken = async () => {
|
2158
|
+
return localStorage.getItem("accessToken");
|
2159
|
+
};
|
2160
|
+
const getRefreshToken = async () => {
|
2161
|
+
return localStorage.getItem("refreshToken");
|
2162
|
+
};
|
2163
|
+
const clearToken = async () => {
|
2164
|
+
localStorage.removeItem("accessToken");
|
2165
|
+
localStorage.removeItem("refreshToken");
|
2166
|
+
};
|
2167
|
+
return {
|
2168
|
+
setToken,
|
2169
|
+
setRefreshToken,
|
2170
|
+
getAccessToken,
|
2171
|
+
getRefreshToken,
|
2172
|
+
clearToken
|
2173
|
+
};
|
2174
|
+
};
|
2175
|
+
|
2176
|
+
// src/utils/storage/session-storage.ts
|
2177
|
+
var sessionStorageUtils = () => {
|
2178
|
+
const getBrowserSession = async () => {
|
2179
|
+
return sessionStorage.getItem("browserSession");
|
2180
|
+
};
|
2181
|
+
return {
|
2182
|
+
getBrowserSession
|
2183
|
+
};
|
2184
|
+
};
|
2185
|
+
|
2186
|
+
// src/configs/axios-client.ts
|
2187
|
+
var axiosClient = {
|
2188
|
+
init(config) {
|
2189
|
+
const localStorage2 = config.localStorageUtils ?? localStorageUtils();
|
2190
|
+
const sessionStorage2 = config.sessionStorageUtils ?? sessionStorageUtils();
|
2191
|
+
const db = config.db;
|
2192
|
+
let isRefreshing = false;
|
2193
|
+
let failedQueue = [];
|
2194
|
+
const processQueue = (error, token = null) => {
|
2195
|
+
failedQueue?.forEach((prom) => {
|
2196
|
+
if (error) {
|
2197
|
+
prom.reject(error);
|
2198
|
+
} else {
|
2199
|
+
prom.resolve(token);
|
2200
|
+
}
|
2201
|
+
});
|
2202
|
+
failedQueue = [];
|
2203
|
+
};
|
2204
|
+
const instance = import_axios.default.create({
|
2205
|
+
adapter: import_axios.default.defaults.adapter,
|
2206
|
+
baseURL: config.baseUrl,
|
2207
|
+
timeout: 5e4,
|
2208
|
+
paramsSerializer: (params) => new URLSearchParams(params).toString()
|
2209
|
+
});
|
2210
|
+
instance.interceptors.request.use(
|
2211
|
+
async (config2) => {
|
2212
|
+
const token = await localStorage2.getAccessToken();
|
2213
|
+
if (token) {
|
2214
|
+
config2.headers["Authorization"] = "Bearer " + token;
|
2215
|
+
}
|
2216
|
+
return config2;
|
2217
|
+
},
|
2218
|
+
(error) => {
|
2219
|
+
Promise.reject(error);
|
2220
|
+
}
|
2221
|
+
);
|
2222
|
+
instance.interceptors.response.use(
|
2223
|
+
(response) => {
|
2224
|
+
return handleResponse(response);
|
2225
|
+
},
|
2226
|
+
async (error) => {
|
2227
|
+
const handleError3 = async (error2) => {
|
2228
|
+
if (!error2.response) {
|
2229
|
+
return error2;
|
2230
|
+
}
|
2231
|
+
const { data } = error2.response;
|
2232
|
+
if (data && data.code === 400 && ["invalid_grant"].includes(data.data?.error)) {
|
2233
|
+
await clearAuthToken();
|
2234
|
+
}
|
2235
|
+
return data;
|
2236
|
+
};
|
2237
|
+
const originalRequest = error.config;
|
2238
|
+
if ((error.response?.status === 403 || error.response?.status === 401 || error.response?.status === 404) && ["TOKEN_EXPIRED", "AUTHEN_FAIL", 401].includes(
|
2239
|
+
error.response.data.code
|
2240
|
+
)) {
|
2241
|
+
if (isRefreshing) {
|
2242
|
+
return new Promise(function(resolve, reject) {
|
2243
|
+
failedQueue.push({ resolve, reject });
|
2244
|
+
}).then((token) => {
|
2245
|
+
originalRequest.headers["Authorization"] = "Bearer " + token;
|
2246
|
+
return instance.request(originalRequest);
|
2247
|
+
}).catch(async (err) => {
|
2248
|
+
if ((err.response?.status === 400 || err.response?.status === 401) && ["invalid_grant"].includes(err.response.data.error)) {
|
2249
|
+
await clearAuthToken();
|
2250
|
+
}
|
2251
|
+
});
|
2252
|
+
}
|
2253
|
+
const browserSession = await sessionStorage2.getBrowserSession();
|
2254
|
+
const refreshToken = await localStorage2.getRefreshToken();
|
2255
|
+
const accessTokenExp = await localStorage2.getAccessToken();
|
2256
|
+
isRefreshing = true;
|
2257
|
+
if (!refreshToken && (!browserSession || browserSession == "unActive")) {
|
2258
|
+
await clearAuthToken();
|
2259
|
+
} else {
|
2260
|
+
const payload = Object.fromEntries(
|
2261
|
+
Object.entries({
|
2262
|
+
refresh_token: refreshToken,
|
2263
|
+
grant_type: "refresh_token",
|
2264
|
+
client_id: config.config.clientId,
|
2265
|
+
client_secret: config.config.clientSecret
|
2266
|
+
}).filter(([_, value]) => !!value)
|
2267
|
+
);
|
2268
|
+
return new Promise(function(resolve) {
|
2269
|
+
import_axios.default.post(
|
2270
|
+
`${config.baseUrl}${"/authentication/oauth2/token" /* AUTH_TOKEN_PATH */}`,
|
2271
|
+
payload,
|
2272
|
+
{
|
2273
|
+
headers: {
|
2274
|
+
"Content-Type": "multipart/form-data",
|
2275
|
+
Authorization: `Bearer ${accessTokenExp}`
|
2276
|
+
}
|
2277
|
+
}
|
2278
|
+
).then(async (res) => {
|
2279
|
+
const data = res.data;
|
2280
|
+
await localStorage2.setToken(data.access_token);
|
2281
|
+
await localStorage2.setRefreshToken(data.refresh_token);
|
2282
|
+
import_axios.default.defaults.headers.common["Authorization"] = "Bearer " + data.access_token;
|
2283
|
+
originalRequest.headers["Authorization"] = "Bearer " + data.access_token;
|
2284
|
+
processQueue(null, data.access_token);
|
2285
|
+
resolve(instance.request(originalRequest));
|
2286
|
+
}).catch(async (err) => {
|
2287
|
+
if (err && (err?.error_code === "AUTHEN_FAIL" || err?.error_code === "TOKEN_EXPIRED" || err?.error_code === "TOKEN_INCORRECT" || err?.code === "ERR_BAD_REQUEST")) {
|
2288
|
+
await clearAuthToken();
|
2289
|
+
}
|
2290
|
+
if (err && err.response) {
|
2291
|
+
const { error_code } = err.response?.data || {};
|
2292
|
+
if (error_code === "AUTHEN_FAIL") {
|
2293
|
+
await clearAuthToken();
|
2294
|
+
}
|
2295
|
+
}
|
2296
|
+
processQueue(err, null);
|
2297
|
+
}).finally(() => {
|
2298
|
+
isRefreshing = false;
|
2299
|
+
});
|
2300
|
+
});
|
2301
|
+
}
|
2302
|
+
}
|
2303
|
+
return Promise.reject(await handleError3(error));
|
2304
|
+
}
|
2305
|
+
);
|
2306
|
+
const handleResponse = (res) => {
|
2307
|
+
if (res && res.data) {
|
2308
|
+
return res.data;
|
2309
|
+
}
|
2310
|
+
return res;
|
2311
|
+
};
|
2312
|
+
const handleError2 = (error) => {
|
2313
|
+
if (error.isAxiosError && error.code === "ECONNABORTED") {
|
2314
|
+
console.error("Request Timeout Error:", error);
|
2315
|
+
return "Request Timeout Error";
|
2316
|
+
} else if (error.isAxiosError && !error.response) {
|
2317
|
+
console.error("Network Error:", error);
|
2318
|
+
return "Network Error";
|
2319
|
+
} else {
|
2320
|
+
console.error("Other Error:", error?.response);
|
2321
|
+
const errorMessage = error?.response?.data?.message || "An error occurred";
|
2322
|
+
return { message: errorMessage, status: error?.response?.status };
|
2323
|
+
}
|
2324
|
+
};
|
2325
|
+
const clearAuthToken = async () => {
|
2326
|
+
await localStorage2.clearToken();
|
2327
|
+
if (typeof window !== "undefined") {
|
2328
|
+
window.location.href = `/login`;
|
2329
|
+
}
|
2330
|
+
};
|
2331
|
+
function formatUrl(url, db2) {
|
2332
|
+
return url + (db2 ? "?db=" + db2 : "");
|
2333
|
+
}
|
2334
|
+
const responseBody = (response) => response;
|
2335
|
+
const requests = {
|
2336
|
+
get: (url, headers) => instance.get(formatUrl(url, db), headers).then(responseBody),
|
2337
|
+
post: (url, body, headers) => instance.post(formatUrl(url, db), body, { headers }).then(responseBody),
|
2338
|
+
post_excel: (url, body, headers) => instance.post(formatUrl(url, db), body, {
|
2339
|
+
responseType: "arraybuffer",
|
2340
|
+
headers: {
|
2341
|
+
"Content-Type": typeof window !== "undefined" ? "application/json" : "application/javascript",
|
2342
|
+
Accept: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
|
2343
|
+
}
|
2344
|
+
}).then(responseBody),
|
2345
|
+
put: (url, body, headers) => instance.put(formatUrl(url, db), body, headers).then(responseBody),
|
2346
|
+
patch: (url, body) => instance.patch(formatUrl(url, db), body).then(responseBody),
|
2347
|
+
delete: (url, body) => instance.delete(formatUrl(url, db), body).then(responseBody)
|
2348
|
+
};
|
2349
|
+
return requests;
|
2350
|
+
}
|
2351
|
+
};
|
2352
|
+
// Annotate the CommonJS export names for ESM import in node:
|
2353
|
+
0 && (module.exports = {
|
2354
|
+
axiosClient
|
2355
|
+
});
|