amis-formula 2.0.0-beta.1 → 2.0.0-beta.2

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.
@@ -0,0 +1,1043 @@
1
+ /**
2
+ * @file 公式内置函数
3
+ */
4
+ import { EvaluatorOptions, FilterMap, FunctionMap } from './types';
5
+ export declare class Evaluator {
6
+ readonly options: EvaluatorOptions;
7
+ readonly filters: FilterMap;
8
+ readonly functions: FunctionMap;
9
+ readonly context: {
10
+ [propName: string]: any;
11
+ };
12
+ contextStack: Array<(varname: string) => any>;
13
+ static defaultFilters: FilterMap;
14
+ static setDefaultFilters(filters: FilterMap): void;
15
+ constructor(context: {
16
+ [propName: string]: any;
17
+ }, options?: EvaluatorOptions);
18
+ evalute(ast: any): any;
19
+ document(ast: {
20
+ type: 'document';
21
+ body: Array<any>;
22
+ }): any;
23
+ filter(ast: {
24
+ type: 'filter';
25
+ input: any;
26
+ filters: Array<{
27
+ name: string;
28
+ args: Array<any>;
29
+ }>;
30
+ }): any;
31
+ raw(ast: {
32
+ type: 'raw';
33
+ value: string;
34
+ }): string;
35
+ script(ast: {
36
+ type: 'script';
37
+ body: any;
38
+ }): any;
39
+ expressionList(ast: {
40
+ type: 'expression-list';
41
+ body: Array<any>;
42
+ }): any;
43
+ template(ast: {
44
+ type: 'template';
45
+ body: Array<any>;
46
+ }): string;
47
+ templateRaw(ast: {
48
+ type: 'template_raw';
49
+ value: any;
50
+ }): any;
51
+ getter(ast: {
52
+ host: any;
53
+ key: any;
54
+ }): any;
55
+ unary(ast: {
56
+ op: '+' | '-' | '~' | '!';
57
+ value: any;
58
+ }): number | boolean;
59
+ formatNumber(value: any, int?: boolean): any;
60
+ power(ast: {
61
+ left: any;
62
+ right: any;
63
+ }): number;
64
+ multiply(ast: {
65
+ left: any;
66
+ right: any;
67
+ }): number;
68
+ divide(ast: {
69
+ left: any;
70
+ right: any;
71
+ }): number;
72
+ remainder(ast: {
73
+ left: any;
74
+ right: any;
75
+ }): number;
76
+ add(ast: {
77
+ left: any;
78
+ right: any;
79
+ }): number;
80
+ minus(ast: {
81
+ left: any;
82
+ right: any;
83
+ }): number;
84
+ shift(ast: {
85
+ op: '<<' | '>>' | '>>>';
86
+ left: any;
87
+ right: any;
88
+ }): number;
89
+ lt(ast: {
90
+ left: any;
91
+ right: any;
92
+ }): boolean;
93
+ gt(ast: {
94
+ left: any;
95
+ right: any;
96
+ }): boolean;
97
+ le(ast: {
98
+ left: any;
99
+ right: any;
100
+ }): boolean;
101
+ ge(ast: {
102
+ left: any;
103
+ right: any;
104
+ }): boolean;
105
+ eq(ast: {
106
+ left: any;
107
+ right: any;
108
+ }): boolean;
109
+ ne(ast: {
110
+ left: any;
111
+ right: any;
112
+ }): boolean;
113
+ streq(ast: {
114
+ left: any;
115
+ right: any;
116
+ }): boolean;
117
+ strneq(ast: {
118
+ left: any;
119
+ right: any;
120
+ }): boolean;
121
+ binary(ast: {
122
+ op: '&' | '^' | '|';
123
+ left: any;
124
+ right: any;
125
+ }): number;
126
+ and(ast: {
127
+ left: any;
128
+ right: any;
129
+ }): any;
130
+ or(ast: {
131
+ left: any;
132
+ right: any;
133
+ }): any;
134
+ number(ast: {
135
+ value: any;
136
+ raw: string;
137
+ }): any;
138
+ nsVariable(ast: {
139
+ namespace: string;
140
+ body: any;
141
+ }): any;
142
+ variable(ast: {
143
+ name: string;
144
+ }): any;
145
+ identifier(ast: {
146
+ name: string;
147
+ }): string;
148
+ array(ast: {
149
+ type: 'array';
150
+ members: Array<any>;
151
+ }): any[];
152
+ literal(ast: {
153
+ type: 'literal';
154
+ value: any;
155
+ }): any;
156
+ string(ast: {
157
+ type: 'string';
158
+ value: string;
159
+ }): string;
160
+ object(ast: {
161
+ members: Array<{
162
+ key: string;
163
+ value: any;
164
+ }>;
165
+ }): any;
166
+ conditional(ast: {
167
+ type: 'conditional';
168
+ test: any;
169
+ consequent: any;
170
+ alternate: any;
171
+ }): any;
172
+ funcCall(this: any, ast: {
173
+ identifier: string;
174
+ args: Array<any>;
175
+ }): any;
176
+ anonymousFunction(ast: any): any;
177
+ callAnonymousFunction(ast: {
178
+ args: any[];
179
+ return: any;
180
+ }, args: Array<any>): any;
181
+ /**
182
+ * 示例:IF(A, B, C)
183
+ *
184
+ * 如果满足条件A,则返回B,否则返回C,支持多层嵌套IF函数。
185
+ *
186
+ * 也可以用表达式如:A ? B : C
187
+ *
188
+ * @example IF(condition, consequent, alternate)
189
+ * @param {expression} condition - 条件表达式.
190
+ * @param {any} consequent 条件判断通过的返回结果
191
+ * @param {any} alternate 条件判断不通过的返回结果
192
+ * @namespace 逻辑函数
193
+ *
194
+ * @returns {any} 根据条件返回不同的结果
195
+ */
196
+ fnIF(condition: () => any, trueValue: () => any, falseValue: () => any): any;
197
+ /**
198
+ * 条件全部符合,返回 true,否则返回 false
199
+ *
200
+ * 示例:AND(语文成绩>80, 数学成绩>80)
201
+ *
202
+ * 语文成绩和数学成绩都大于 80,则返回 true,否则返回 false
203
+ *
204
+ * 也可以直接用表达式如:语文成绩>80 && 数学成绩>80
205
+ *
206
+ * @example AND(expression1, expression2, ...expressionN)
207
+ * @param {...expression} conditions - 条件表达式.
208
+ * @namespace 逻辑函数
209
+ *
210
+ * @returns {boolean}
211
+ */
212
+ fnAND(...condtions: Array<() => any>): boolean;
213
+ /**
214
+ * 条件任意一个满足条件,返回 true,否则返回 false
215
+ *
216
+ * 示例:OR(语文成绩>80, 数学成绩>80)
217
+ *
218
+ * 语文成绩和数学成绩任意一个大于 80,则返回 true,否则返回 false
219
+ *
220
+ * 也可以直接用表达式如:语文成绩>80 || 数学成绩>80
221
+ *
222
+ * @example OR(expression1, expression2, ...expressionN)
223
+ * @param {...expression} conditions - 条件表达式.
224
+ * @namespace 逻辑函数
225
+ *
226
+ * @returns {boolean}
227
+ */
228
+ fnOR(...condtions: Array<() => any>): boolean;
229
+ /**
230
+ * 异或处理,两个表达式同时为「真」,或者同时为「假」,则结果返回为「真」
231
+ *
232
+ * @example XOR(condition1, condition2)
233
+ * @param {expression} condition1 - 条件表达式1
234
+ * @param {expression} condition2 - 条件表达式2
235
+ * @namespace 逻辑函数
236
+ *
237
+ * @returns {boolean}
238
+ */
239
+ fnXOR(c1: () => any, c2: () => any): boolean;
240
+ /**
241
+ * 判断函数集合,相当于多个 else if 合并成一个。
242
+ *
243
+ * 示例:IFS(语文成绩 > 80, "优秀", 语文成绩 > 60, "良", "继续努力")
244
+ *
245
+ * 如果语文成绩大于 80,则返回优秀,否则判断大于 60 分,则返回良,否则返回继续努力。
246
+ *
247
+ * @example IFS(condition1, result1, condition2, result2,...conditionN, resultN)
248
+ * @param {...any} args - 条件,返回值集合
249
+ * @namespace 逻辑函数
250
+ * @returns {any} 第一个满足条件的结果,没有命中的返回 false。
251
+ */
252
+ fnIFS(...args: Array<() => any>): any;
253
+ /**
254
+ * 返回传入数字的绝对值
255
+ *
256
+ * @example ABS(num)
257
+ * @param {number} num - 数值
258
+ * @namespace 数学函数
259
+ *
260
+ * @returns {number} 传入数值的绝对值
261
+ */
262
+ fnABS(a: number): number;
263
+ /**
264
+ * 获取最大值,如果只有一个参数且是数组,则计算这个数组内的值
265
+ *
266
+ * @example MAX(num1, num2, ...numN)
267
+ * @param {...number} num - 数值
268
+ * @namespace 数学函数
269
+ *
270
+ * @returns {number} 所有传入值中最大的那个
271
+ */
272
+ fnMAX(...args: Array<any>): any;
273
+ /**
274
+ * 获取最小值,如果只有一个参数且是数组,则计算这个数组内的值
275
+ *
276
+ * @example MIN(num1, num2, ...numN)
277
+ * @param {...number} num - 数值
278
+ * @namespace 数学函数
279
+ *
280
+ * @returns {number} 所有传入值中最小的那个
281
+ */
282
+ fnMIN(...args: Array<number>): any;
283
+ /**
284
+ * 求和,如果只有一个参数且是数组,则计算这个数组内的值
285
+ *
286
+ * @example SUM(num1, num2, ...numN)
287
+ * @param {...number} num - 数值
288
+ * @namespace 数学函数
289
+ *
290
+ * @returns {number} 所有传入数值的总和
291
+ */
292
+ fnSUM(...args: Array<number>): any;
293
+ /**
294
+ * 将数值向下取整为最接近的整数
295
+ *
296
+ * @example INT(num)
297
+ * @param {number} num - 数值
298
+ * @namespace 数学函数
299
+ *
300
+ * @returns {number} 数值对应的整形
301
+ */
302
+ fnINT(n: number): number;
303
+ /**
304
+ * 返回两数相除的余数,参数 number 是被除数,divisor 是除数
305
+ *
306
+ * @example MOD(num, divisor)
307
+ * @param {number} num - 被除数
308
+ * @param {number} divisor - 除数
309
+ * @namespace 数学函数
310
+ *
311
+ * @returns {number} 两数相除的余数
312
+ */
313
+ fnMOD(a: number, b: number): number;
314
+ /**
315
+ * 圆周率 3.1415...
316
+ *
317
+ * @example PI()
318
+ * @namespace 数学函数
319
+ *
320
+ * @returns {number} 圆周率数值
321
+ */
322
+ fnPI(): number;
323
+ /**
324
+ * 将数字四舍五入到指定的位数,可以设置小数位。
325
+ *
326
+ * @example ROUND(num[, numDigits = 2])
327
+ * @param {number} num - 要处理的数字
328
+ * @param {number} numDigits - 小数位数
329
+ * @namespace 数学函数
330
+ *
331
+ * @returns {number} 传入数值四舍五入后的结果
332
+ */
333
+ fnROUND(a: number, b: number): number;
334
+ /**
335
+ * 将数字向下取整到指定的位数,可以设置小数位。
336
+ *
337
+ * @example FLOOR(num[, numDigits=2])
338
+ * @param {number} num - 要处理的数字
339
+ * @param {number} numDigits - 小数位数
340
+ * @namespace 数学函数
341
+ *
342
+ * @returns {number} 传入数值向下取整后的结果
343
+ */
344
+ fnFLOOR(a: number, b: number): number;
345
+ /**
346
+ * 将数字向上取整到指定的位数,可以设置小数位。
347
+ *
348
+ * @example CEIL(num[, numDigits=2])
349
+ * @param {number} num - 要处理的数字
350
+ * @param {number} numDigits - 小数位数
351
+ * @namespace 数学函数
352
+ *
353
+ * @returns {number} 传入数值向上取整后的结果
354
+ */
355
+ fnCEIL(a: number, b: number): number;
356
+ /**
357
+ * 开平方,参数 number 为非负数
358
+ *
359
+ * @example SQRT(num)
360
+ * @param {number} num - 要处理的数字
361
+ * @namespace 数学函数
362
+ *
363
+ * @returns {number} 开平方的结果
364
+ */
365
+ fnSQRT(n: number): number;
366
+ /**
367
+ * 返回所有参数的平均值,如果只有一个参数且是数组,则计算这个数组内的值
368
+ *
369
+ * @example AVG(num1, num2, ...numN)
370
+ * @param {...number} num - 要处理的数字
371
+ * @namespace 数学函数
372
+ *
373
+ * @returns {number} 所有数值的平均值
374
+ */
375
+ fnAVG(...args: Array<any>): number;
376
+ /**
377
+ * 返回数据点与数据均值点之差(数据偏差)的平方和,如果只有一个参数且是数组,则计算这个数组内的值
378
+ *
379
+ * @example DEVSQ(num1, num2, ...numN)
380
+ * @param {...number} num - 要处理的数字
381
+ * @namespace 数学函数
382
+ *
383
+ * @returns {number} 所有数值的平均值
384
+ */
385
+ fnDEVSQ(...args: Array<any>): number | null;
386
+ /**
387
+ * 数据点到其算术平均值的绝对偏差的平均值
388
+ *
389
+ * @example AVEDEV(num1, num2, ...numN)
390
+ * @param {...number} num - 要处理的数字
391
+ * @namespace 数学函数
392
+ *
393
+ * @returns {number} 所有数值的平均值
394
+ */
395
+ fnAVEDEV(...args: Array<any>): number | null;
396
+ /**
397
+ * 数据点的调和平均值,如果只有一个参数且是数组,则计算这个数组内的值
398
+ *
399
+ * @example HARMEAN(num1, num2, ...numN)
400
+ * @param {...number} num - 要处理的数字
401
+ * @namespace 数学函数
402
+ *
403
+ * @returns {number} 所有数值的平均值
404
+ */
405
+ fnHARMEAN(...args: Array<any>): number | null;
406
+ /**
407
+ * 数据集中第 k 个最大值
408
+ *
409
+ * @example LARGE(array, k)
410
+ * @param {array} nums - 要处理的数字
411
+ * @param {number} k - 第几大
412
+ * @namespace 数学函数
413
+ *
414
+ * @returns {number} 所有数值的平均值
415
+ */
416
+ fnLARGE(nums: Array<any>, k: number): any;
417
+ /**
418
+ * 将数值转为中文大写金额
419
+ *
420
+ * @example UPPERMONEY(num)
421
+ * @param {number} num - 要处理的数字
422
+ * @namespace 数学函数
423
+ *
424
+ * @returns {string} 数值中文大写字符
425
+ */
426
+ fnUPPERMONEY(n: number): string;
427
+ /**
428
+ * 返回大于等于 0 且小于 1 的均匀分布随机实数。每一次触发计算都会变化。
429
+ *
430
+ * 示例:`RAND()*100`
431
+ *
432
+ * 返回 0-100 之间的随机数
433
+ *
434
+ * @example RAND()
435
+ * @namespace 数学函数
436
+ *
437
+ * @returns {number} 随机数
438
+ */
439
+ fnRAND(): number;
440
+ /**
441
+ * 取数据最后一个
442
+ *
443
+ * @example LAST(array)
444
+ * @param {...number} arr - 要处理的数组
445
+ * @namespace 数学函数
446
+ *
447
+ * @returns {any} 最后一个值
448
+ */
449
+ fnLAST(arr: Array<any>): any;
450
+ normalizeText(raw: any): string;
451
+ /**
452
+ * 返回传入文本左侧的指定长度字符串。
453
+ *
454
+ * @example LEFT(text, len)
455
+ * @param {string} text - 要处理的文本
456
+ * @param {number} len - 要处理的长度
457
+ * @namespace 文本函数
458
+ *
459
+ * @returns {string} 对应字符串
460
+ */
461
+ fnLEFT(text: string, len: number): string;
462
+ /**
463
+ * 返回传入文本右侧的指定长度字符串。
464
+ *
465
+ * @example RIGHT(text, len)
466
+ * @param {string} text - 要处理的文本
467
+ * @param {number} len - 要处理的长度
468
+ * @namespace 文本函数
469
+ *
470
+ * @returns {string} 对应字符串
471
+ */
472
+ fnRIGHT(text: string, len: number): string;
473
+ /**
474
+ * 计算文本的长度
475
+ *
476
+ * @example LEN(text)
477
+ * @param {string} text - 要处理的文本
478
+ * @namespace 文本函数
479
+ *
480
+ * @returns {number} 长度
481
+ */
482
+ fnLEN(text: string): number;
483
+ /**
484
+ * 计算文本集合中所有文本的长度
485
+ *
486
+ * @example LENGTH(textArr)
487
+ * @param {string[]} textArr - 要处理的文本集合
488
+ * @namespace 文本函数
489
+ *
490
+ * @returns {number[]} 长度集合
491
+ */
492
+ fnLENGTH(...args: any[]): any;
493
+ /**
494
+ * 判断文本是否为空
495
+ *
496
+ * @example ISEMPTY(text)
497
+ * @param {string} text - 要处理的文本
498
+ * @namespace 文本函数
499
+ *
500
+ * @returns {boolean} 判断结果
501
+ */
502
+ fnISEMPTY(text: string): boolean;
503
+ /**
504
+ * 将多个传入值连接成文本
505
+ *
506
+ * @example CONCATENATE(text1, text2, ...textN)
507
+ * @param {...string} text - 文本集合
508
+ * @namespace 文本函数
509
+ *
510
+ * @returns {string} 连接后的文本
511
+ */
512
+ fnCONCATENATE(...args: Array<any>): string;
513
+ /**
514
+ * 返回计算机字符集的数字代码所对应的字符。
515
+ *
516
+ * `CHAR(97)` 等价于 "a"
517
+ *
518
+ * @example CHAR(code)
519
+ * @param {number} code - 编码值
520
+ * @namespace 文本函数
521
+ *
522
+ * @returns {string} 指定位置的字符
523
+ */
524
+ fnCHAR(code: number): string;
525
+ /**
526
+ * 将传入文本转成小写
527
+ *
528
+ * @example LOWER(text)
529
+ * @param {string} text - 文本
530
+ * @namespace 文本函数
531
+ *
532
+ * @returns {string} 结果文本
533
+ */
534
+ fnLOWER(text: string): string;
535
+ /**
536
+ * 将传入文本转成大写
537
+ *
538
+ * @example UPPER(text)
539
+ * @param {string} text - 文本
540
+ * @namespace 文本函数
541
+ *
542
+ * @returns {string} 结果文本
543
+ */
544
+ fnUPPER(text: string): string;
545
+ /**
546
+ * 将传入文本首字母转成大写
547
+ *
548
+ * @example UPPERFIRST(text)
549
+ * @param {string} text - 文本
550
+ * @namespace 文本函数
551
+ *
552
+ * @returns {string} 结果文本
553
+ */
554
+ fnUPPERFIRST(text: string): string;
555
+ /**
556
+ * 向前补齐文本长度
557
+ *
558
+ * 示例 `PADSTART("6", 2, "0")`
559
+ *
560
+ * 返回 `06`
561
+ *
562
+ * @example PADSTART(text)
563
+ * @param {string} text - 文本
564
+ * @param {number} num - 目标长度
565
+ * @param {string} pad - 用于补齐的文本
566
+ * @namespace 文本函数
567
+ *
568
+ * @returns {string} 结果文本
569
+ */
570
+ fnPADSTART(text: string, num: number, pad: string): string;
571
+ /**
572
+ * 将文本转成标题
573
+ *
574
+ * 示例 `CAPITALIZE("star")`
575
+ *
576
+ * 返回 `Star`
577
+ *
578
+ * @example CAPITALIZE(text)
579
+ * @param {string} text - 文本
580
+ * @namespace 文本函数
581
+ *
582
+ * @returns {string} 结果文本
583
+ */
584
+ fnCAPITALIZE(text: string): string;
585
+ /**
586
+ * 对文本进行 HTML 转义
587
+ *
588
+ * 示例 `ESCAPE("star")`
589
+ *
590
+ * 返回 `Star`
591
+ *
592
+ * @example ESCAPE(text)
593
+ * @param {string} text - 文本
594
+ * @namespace 文本函数
595
+ *
596
+ * @returns {string} 结果文本
597
+ */
598
+ fnESCAPE(text: string): string;
599
+ /**
600
+ * 对文本长度进行截断
601
+ *
602
+ * 示例 `TRUNCATE("amis.baidu.com", 6)`
603
+ *
604
+ * 返回 `amis...`
605
+ *
606
+ * @example TRUNCATE(text, 6)
607
+ * @param {string} text - 文本
608
+ * @param {number} text - 最长长度
609
+ * @namespace 文本函数
610
+ *
611
+ * @returns {string} 结果文本
612
+ */
613
+ fnTRUNCATE(text: string, length: number): string;
614
+ /**
615
+ * 取在某个分隔符之前的所有字符串
616
+ *
617
+ * @example BEFORELAST(text, '.')
618
+ * @param {string} text - 文本
619
+ * @param {string} delimiter - 结束文本
620
+ * @namespace 文本函数
621
+ *
622
+ * @returns {string} 判断结果
623
+ */
624
+ fnBEFORELAST(text: string, delimiter?: string): string;
625
+ /**
626
+ * 将文本根据指定片段分割成数组
627
+ *
628
+ * 示例:`SPLIT("a,b,c", ",")`
629
+ *
630
+ * 返回 `["a", "b", "c"]`
631
+ *
632
+ * @example SPLIT(text, ',')
633
+ * @param {string} text - 文本
634
+ * @param {string} delimiter - 文本片段
635
+ * @namespace 文本函数
636
+ *
637
+ * @returns {Array<string>} 文本集
638
+ */
639
+ fnSPLIT(text: string, sep?: string): string[];
640
+ /**
641
+ * 将文本去除前后空格
642
+ *
643
+ * @example TRIM(text)
644
+ * @param {string} text - 文本
645
+ * @namespace 文本函数
646
+ *
647
+ * @returns {string} 处理后的文本
648
+ */
649
+ fnTRIM(text: string): string;
650
+ /**
651
+ * 去除文本中的 HTML 标签
652
+ *
653
+ * 示例:`STRIPTAG("<b>amis</b>")`
654
+ *
655
+ * 返回:`amis`
656
+ *
657
+ * @example STRIPTAG(text)
658
+ * @param {string} text - 文本
659
+ * @namespace 文本函数
660
+ *
661
+ * @returns {string} 处理后的文本
662
+ */
663
+ fnSTRIPTAG(text: string): string;
664
+ /**
665
+ * 将字符串中的换行转成 HTML `<br>`,用于简单换行的场景
666
+ *
667
+ * 示例:`LINEBREAK("\n")`
668
+ *
669
+ * 返回:`<br/>`
670
+ *
671
+ * @example LINEBREAK(text)
672
+ * @param {string} text - 文本
673
+ * @namespace 文本函数
674
+ *
675
+ * @returns {string} 处理后的文本
676
+ */
677
+ fnLINEBREAK(text: string): string;
678
+ /**
679
+ * 判断字符串(text)是否以特定字符串(startString)开始,是则返回 True,否则返回 False
680
+ *
681
+ * @example STARTSWITH(text, '片段')
682
+ * @param {string} text - 文本
683
+ * @param {string} startString - 起始文本
684
+ * @namespace 文本函数
685
+ *
686
+ * @returns {string} 判断结果
687
+ */
688
+ fnSTARTSWITH(text: string, search: string): boolean;
689
+ /**
690
+ * 判断字符串(text)是否以特定字符串(endString)结束,是则返回 True,否则返回 False
691
+ *
692
+ * @example ENDSWITH(text, '片段')
693
+ * @param {string} text - 文本
694
+ * @param {string} endString - 结束文本
695
+ * @namespace 文本函数
696
+ *
697
+ * @returns {string} 判断结果
698
+ */
699
+ fnENDSWITH(text: string, search: string): boolean;
700
+ /**
701
+ * 判断参数 1 中的文本是否包含参数 2 中的文本。
702
+ *
703
+ * @example CONTAINS(text, searchText)
704
+ * @param {string} text - 文本
705
+ * @param {string} searchText - 搜索文本
706
+ * @namespace 文本函数
707
+ *
708
+ * @returns {string} 判断结果
709
+ */
710
+ fnCONTAINS(text: string, search: string): boolean;
711
+ /**
712
+ * 对文本进行全量替换。
713
+ *
714
+ * @example REPLACE(text, search, replace)
715
+ * @param {string} text - 要处理的文本
716
+ * @param {string} search - 要被替换的文本
717
+ * @param {string} replace - 要替换的文本
718
+ * @namespace 文本函数
719
+ *
720
+ * @returns {string} 处理结果
721
+ */
722
+ fnREPLACE(text: string, search: string, replace: string): string;
723
+ /**
724
+ * 对文本进行搜索,返回命中的位置
725
+ *
726
+ * @example SEARCH(text, search, 0)
727
+ * @param {string} text - 要处理的文本
728
+ * @param {string} search - 用来搜索的文本
729
+ * @param {number} start - 起始位置
730
+ * @namespace 文本函数
731
+ *
732
+ * @returns {number} 命中的位置
733
+ */
734
+ fnSEARCH(text: string, search: string, start?: number): number;
735
+ /**
736
+ * 返回文本字符串中从指定位置开始的特定数目的字符
737
+ *
738
+ * @example MID(text, from, len)
739
+ * @param {string} text - 要处理的文本
740
+ * @param {number} from - 起始位置
741
+ * @param {number} len - 处理长度
742
+ * @namespace 文本函数
743
+ *
744
+ * @returns {number} 命中的位置
745
+ */
746
+ fnMID(text: string, from: number, len: number): string;
747
+ /**
748
+ * 返回路径中的文件名
749
+ *
750
+ * 示例:`/home/amis/a.json`
751
+ *
752
+ * 返回:a.json`
753
+ *
754
+ * @example BASENAME(text)
755
+ * @param {string} text - 要处理的文本
756
+ * @namespace 文本函数
757
+ *
758
+ * @returns {string} 文件名
759
+ */
760
+ fnBASENAME(text: string): string | undefined;
761
+ /**
762
+ * 创建日期对象,可以通过特定格式的字符串,或者数值。
763
+ *
764
+ * 需要注意的是,其中月份的数值是从0开始的,也就是说,
765
+ * 如果是12月份,你应该传入数值11。
766
+ *
767
+ * @example DATE(2021, 11, 6, 8, 20, 0)
768
+ * @example DATE('2021-12-06 08:20:00')
769
+ * @namespace 日期函数
770
+ *
771
+ * @returns {Date} 日期对象
772
+ */
773
+ fnDATE(year: number, month: number, day: number, hour: number, minute: number, second: number): Date;
774
+ /**
775
+ * 返回时间的时间戳
776
+ *
777
+ * @example TIMESTAMP(date[, format = "X"])
778
+ * @namespace 日期函数
779
+ * @param {date} date 日期对象
780
+ * @param {string} format 时间戳格式,带毫秒传入 'x'。默认为 'X' 不带毫秒的。
781
+ *
782
+ * @returns {number} 时间戳
783
+ */
784
+ fnTIMESTAMP(date: Date, format?: 'x' | 'X'): number;
785
+ /**
786
+ * 返回今天的日期
787
+ *
788
+ * @example TODAY()
789
+ * @namespace 日期函数
790
+ *
791
+ * @returns {number} 日期
792
+ */
793
+ fnTODAY(): Date;
794
+ /**
795
+ * 返回现在的日期
796
+ *
797
+ * @example NOW()
798
+ * @namespace 日期函数
799
+ *
800
+ * @returns {number} 日期
801
+ */
802
+ fnNOW(): Date;
803
+ /**
804
+ * 将日期转成日期字符串
805
+ *
806
+ * @example DATETOSTR(date[, format="YYYY-MM-DD HH:mm:ss"])
807
+ * @namespace 日期函数
808
+ * @param {date} date 日期对象
809
+ * @param {string} format 日期格式,默认为 "YYYY-MM-DD HH:mm:ss"
810
+ *
811
+ * @returns {number} 日期字符串
812
+ */
813
+ fnDATETOSTR(date: Date, format?: string): string;
814
+ /**
815
+ * 返回日期的指定范围的开端
816
+ *
817
+ * @namespace 日期函数
818
+ * @example STARTOF(date[unit = "day"])
819
+ * @param {date} date 日期对象
820
+ * @param {string} unit 比如可以传入 'day'、'month'、'year' 或者 `week` 等等
821
+ * @returns {date} 新的日期对象
822
+ */
823
+ fnSTARTOF(date: Date, unit?: any): Date;
824
+ /**
825
+ * 返回日期的指定范围的末尾
826
+ * @namespace 日期函数
827
+ * @example ENDOF(date[unit = "day"])
828
+ * @param {date} date 日期对象
829
+ * @param {string} unit 比如可以传入 'day'、'month'、'year' 或者 `week` 等等
830
+ * @returns {date} 新的日期对象
831
+ */
832
+ fnENDOF(date: Date, unit?: any): Date;
833
+ normalizeDate(raw: any): Date;
834
+ /**
835
+ * 返回日期的年份
836
+ * @namespace 日期函数
837
+ * @example YEAR(date)
838
+ * @param {date} date 日期对象
839
+ * @returns {number} 数值
840
+ */
841
+ fnYEAR(date: Date): number;
842
+ /**
843
+ * 返回日期的月份,这里就是自然月份。
844
+ *
845
+ * @namespace 日期函数
846
+ * @example MONTH(date)
847
+ * @param {date} date 日期对象
848
+ * @returns {number} 数值
849
+ */
850
+ fnMONTH(date: Date): number;
851
+ /**
852
+ * 返回日期的天
853
+ * @namespace 日期函数
854
+ * @example DAY(date)
855
+ * @param {date} date 日期对象
856
+ * @returns {number} 数值
857
+ */
858
+ fnDAY(date: Date): number;
859
+ /**
860
+ * 返回日期的小时
861
+ * @param {date} date 日期对象
862
+ * @namespace 日期函数
863
+ * @example HOUR(date)
864
+ * @returns {number} 数值
865
+ */
866
+ fnHOUR(date: Date): number;
867
+ /**
868
+ * 返回日期的分
869
+ * @param {date} date 日期对象
870
+ * @namespace 日期函数
871
+ * @example MINUTE(date)
872
+ * @returns {number} 数值
873
+ */
874
+ fnMINUTE(date: Date): number;
875
+ /**
876
+ * 返回日期的秒
877
+ * @param {date} date 日期对象
878
+ * @namespace 日期函数
879
+ * @example SECOND(date)
880
+ * @returns {number} 数值
881
+ */
882
+ fnSECOND(date: Date): number;
883
+ /**
884
+ * 返回两个日期相差多少年
885
+ * @param {date} endDate 日期对象
886
+ * @param {date} startDate 日期对象
887
+ * @namespace 日期函数
888
+ * @example YEARS(endDate, startDate)
889
+ * @returns {number} 数值
890
+ */
891
+ fnYEARS(endDate: Date, startDate: Date): number;
892
+ /**
893
+ * 返回两个日期相差多少分钟
894
+ * @param {date} endDate 日期对象
895
+ * @param {date} startDate 日期对象
896
+ * @namespace 日期函数
897
+ * @example MINUTES(endDate, startDate)
898
+ * @returns {number} 数值
899
+ */
900
+ fnMINUTES(endDate: Date, startDate: Date): number;
901
+ /**
902
+ * 返回两个日期相差多少天
903
+ * @param {date} endDate 日期对象
904
+ * @param {date} startDate 日期对象
905
+ * @namespace 日期函数
906
+ * @example DAYS(endDate, startDate)
907
+ * @returns {number} 数值
908
+ */
909
+ fnDAYS(endDate: Date, startDate: Date): number;
910
+ /**
911
+ * 返回两个日期相差多少小时
912
+ * @param {date} endDate 日期对象
913
+ * @param {date} startDate 日期对象
914
+ * @namespace 日期函数
915
+ * @example HOURS(endDate, startDate)
916
+ * @returns {number} 数值
917
+ */
918
+ fnHOURS(endDate: Date, startDate: Date): number;
919
+ /**
920
+ * 修改日期,对日期进行加减天、月份、年等操作
921
+ *
922
+ * 示例:
923
+ *
924
+ * DATEMODIFY(A, -2, 'month')
925
+ *
926
+ * 对日期 A 进行往前减2月的操作。
927
+ *
928
+ * @param {date} date 日期对象
929
+ * @param {number} num 数值
930
+ * @param {string} unit 单位:支持年、月、天等等
931
+ * @namespace 日期函数
932
+ * @example DATEMODIFY(date, 2, 'days')
933
+ * @returns {date} 日期对象
934
+ */
935
+ fnDATEMODIFY(date: Date, num: number, format: any): Date;
936
+ /**
937
+ * 将字符日期转成日期对象,可以指定日期格式。
938
+ *
939
+ * 示例:STRTODATE('2021/12/6', 'YYYY/MM/DD')
940
+ *
941
+ * @param {string} value 日期字符
942
+ * @param {string} format 日期格式
943
+ * @namespace 日期函数
944
+ * @example STRTODATE(value[, format=""])
945
+ * @returns {date} 日期对象
946
+ */
947
+ fnSTRTODATE(value: any, format?: string): Date;
948
+ /**
949
+ * 判断两个日期,是否第一个日期在第二个日期的前面
950
+ *
951
+ * @param {date} a 第一个日期
952
+ * @param {date} b 第二个日期
953
+ * @param {string} unit 单位,默认是 'day', 即之比较到天
954
+ * @namespace 日期函数
955
+ * @example ISBEFORE(a, b)
956
+ * @returns {boolean} 判断结果
957
+ */
958
+ fnISBEFORE(a: Date, b: Date, unit?: any): boolean;
959
+ /**
960
+ * 判断两个日期,是否第一个日期在第二个日期的后面
961
+ *
962
+ * @param {date} a 第一个日期
963
+ * @param {date} b 第二个日期
964
+ * @param {string} unit 单位,默认是 'day', 即之比较到天
965
+ * @namespace 日期函数
966
+ * @example ISAFTER(a, b)
967
+ * @returns {boolean} 判断结果
968
+ */
969
+ fnISAFTER(a: Date, b: Date, unit?: any): boolean;
970
+ /**
971
+ * 判断两个日期,是否第一个日期在第二个日期的前面或者相等
972
+ *
973
+ * @param {date} a 第一个日期
974
+ * @param {date} b 第二个日期
975
+ * @param {string} unit 单位,默认是 'day', 即之比较到天
976
+ * @namespace 日期函数
977
+ * @example ISSAMEORBEFORE(a, b)
978
+ * @returns {boolean} 判断结果
979
+ */
980
+ fnISSAMEORBEFORE(a: Date, b: Date, unit?: any): boolean;
981
+ /**
982
+ * 判断两个日期,是否第一个日期在第二个日期的后面或者相等
983
+ *
984
+ * @param {date} a 第一个日期
985
+ * @param {date} b 第二个日期
986
+ * @param {string} unit 单位,默认是 'day', 即之比较到天
987
+ * @namespace 日期函数
988
+ * @example ISSAMEORAFTER(a, b)
989
+ * @returns {boolean} 判断结果
990
+ */
991
+ fnISSAMEORAFTER(a: Date, b: Date, unit?: any): boolean;
992
+ /**
993
+ * 返回数组的长度
994
+ *
995
+ * @param {Array<any>} arr 数组
996
+ * @namespace 数组
997
+ * @example COUNT(arr)
998
+ * @returns {boolean} 结果
999
+ */
1000
+ fnCOUNT(value: any): number;
1001
+ /**
1002
+ * 数组做数据转换,需要搭配箭头函数一起使用,注意箭头函数只支持单表达式用法。
1003
+ *
1004
+ * @param {Array<any>} arr 数组
1005
+ * @param {Function<any>} iterator 箭头函数
1006
+ * @namespace 数组
1007
+ * @example ARRAYMAP(arr, item => item)
1008
+ * @returns {boolean} 结果
1009
+ */
1010
+ fnARRAYMAP(value: any, iterator: any): any[];
1011
+ /**
1012
+ * 数组过滤掉 false、null、0 和 ""
1013
+ *
1014
+ * 示例:
1015
+ *
1016
+ * COMPACT([0, 1, false, 2, '', 3]) 得到 [1, 2, 3]
1017
+ *
1018
+ * @param {Array<any>} arr 数组
1019
+ * @namespace 数组
1020
+ * @example COMPACT(arr)
1021
+ * @returns {Array<any>} 结果
1022
+ */
1023
+ fnCOMPACT(arr: any[]): any[];
1024
+ /**
1025
+ * 数组转成字符串
1026
+ *
1027
+ * 示例:
1028
+ *
1029
+ * JOIN(['a', 'b', 'c'], '~') 得到 'a~b~c'
1030
+ *
1031
+ * @param {Array<any>} arr 数组
1032
+ * @param { String} separator 分隔符
1033
+ * @namespace 数组
1034
+ * @example JOIN(arr, string)
1035
+ * @returns {String} 结果
1036
+ */
1037
+ fnJOIN(arr: any[], separator?: string): string;
1038
+ }
1039
+ export declare function createObject(superProps?: {
1040
+ [propName: string]: any;
1041
+ }, props?: {
1042
+ [propName: string]: any;
1043
+ }, properties?: any): object;