@bestime/utils_base 1.0.5 → 1.0.7

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/README.md CHANGED
@@ -1,15 +1,15 @@
1
- ### 不同git项目,使用不同用户名和邮箱
2
-
3
- 修改配置文件 ~/.gitconfig
4
-
5
- ```cmd
6
- [core]
7
- autocrlf = false
8
- [includeIf "gitdir:D:/bestime/git/"]
9
- path = D:/bestime/config/.gitconfig
10
- [includeIf "gitdir:D:/work-qssoft/git/qs-t/"]
11
- path = D:/bestime/config/qssoft.gitconfig
12
- [includeIf "gitdir:D:/work-qssoft/git/rdc-cq/"]
13
- path = D:/bestime/config/sitian.gitconfig
14
-
1
+ ### 不同git项目,使用不同用户名和邮箱
2
+
3
+ 修改配置文件 ~/.gitconfig
4
+
5
+ ```cmd
6
+ [core]
7
+ autocrlf = false
8
+ [includeIf "gitdir:D:/bestime/git/"]
9
+ path = D:/bestime/config/.gitconfig
10
+ [includeIf "gitdir:D:/work-qssoft/git/qs-t/"]
11
+ path = D:/bestime/config/qssoft.gitconfig
12
+ [includeIf "gitdir:D:/work-qssoft/git/rdc-cq/"]
13
+ path = D:/bestime/config/sitian.gitconfig
14
+
15
15
  ```
@@ -20,15 +20,6 @@ declare function getType(data: any): string;
20
20
  */
21
21
  declare function isArray(arg: any): arg is any[];
22
22
 
23
- /**
24
- * 判断数据是否为对象
25
- * @param data - 判断的值
26
- * @returns 真假值
27
- */
28
- declare function isKvPair(data: any): boolean;
29
-
30
- declare function isString(data: any): data is string;
31
-
32
23
  /**
33
24
  * 递归将所有属性改为可选
34
25
  */
@@ -38,7 +29,17 @@ type BTDeepPartial<T = any> = {
38
29
  /**
39
30
  * 键值对格式的数据
40
31
  * */
41
- type IKvPair = Record<string, any>;
32
+ type TKvPair = Record<string | number | symbol, any>;
33
+ type TValueOf<T> = T[keyof T];
34
+
35
+ /**
36
+ * 判断数据是否为对象
37
+ * @param data - 判断的值
38
+ * @returns 真假值
39
+ */
40
+ declare function isKvPair(arg: any): arg is TKvPair;
41
+
42
+ declare function isString(data: any): data is string;
42
43
 
43
44
  /**
44
45
  * 强制转换数据为键值对数据,如果是json字符串,会尝试解析,如果失败,则返回一个空Map
@@ -57,7 +58,7 @@ type IKvPair = Record<string, any>;
57
58
  * const data3 = _KvPair({name: 'a'})
58
59
  * ```
59
60
  */
60
- declare function _KvPair(data: any): IKvPair;
61
+ declare function _KvPair(data: any): TKvPair;
61
62
 
62
63
  /**
63
64
  * 判断是否为空[null, undefined, '']
@@ -78,37 +79,48 @@ declare function isFunction(data: any): boolean;
78
79
  * @param data - 需要转化的数据
79
80
  * @returns 转换后的字符串
80
81
  */
81
- declare function param(data: Record<string | number, any>): string;
82
+ declare function param(data: TKvPair): string;
82
83
 
83
84
  /**
84
85
  * 为url链接拼接参数
85
- * @param url - url地址
86
+ * @param url - url地址。可带查询参数由 ”{{包裹}}”
86
87
  * @param searchString - 查询参数
87
- * @returns 拼接后的url地址
88
+ * @returns string 拼接后的url地址
89
+ * @example
90
+ * ```js
91
+ * urlToGet('/parent_{{ pid }}/info/{{ uid }}/detail?c=5&', {
92
+ * name: '张三',
93
+ * skill: [1, 2, 3, 4, 5]
94
+ * })
95
+ * urlToGet('1111111111', 'a=0&b=2')
96
+ * urlToGet('2222222222', 'a=0&b=2')
97
+ * urlToGet('333333333?c=5&', 'a=0&b=2')
98
+ * ```
99
+ *
88
100
  */
89
- declare function urlToGet(url: string, searchString: string | Record<string, any>): string;
101
+ declare function urlToGet(url: string, data: string | TKvPair): string;
90
102
 
91
103
  /**
92
- * 移除空字符串
104
+ * 移除空字符串。不清空 "\u200e"
93
105
  * @param data - 需要处理的数据
94
106
  * @param pos - 移除位置。默认:两侧,1:左侧,-1右侧,* 所有
95
107
  * @returns 字符串
96
108
  */
97
109
  declare function trim(data: any, pos?: 1 | -1 | '*'): string;
98
110
 
99
- declare function clean<
100
- T extends
101
- | any[]
102
- | {
103
- [key: string]: any;
104
- [key: number]: any;
105
- }
106
- >(data: T, removeEmptyStr?: boolean, removeEmptyObject?: boolean): T;
107
-
108
111
  type TargetData = Record<string, any> | any[];
109
112
  interface Options {
113
+ /**
114
+ * 是否移除空字符串。默认true
115
+ */
110
116
  string?: Boolean;
117
+ /**
118
+ * 是否移除空数组。默认true
119
+ */
111
120
  array?: Boolean;
121
+ /**
122
+ * 是否移除空键值对。默认true
123
+ */
112
124
  kvPair?: Boolean;
113
125
  }
114
126
  /**
@@ -180,7 +192,29 @@ declare function deepFindTreePath(
180
192
  */
181
193
  declare function _Number(data: any): number;
182
194
 
183
- declare function isNull(data: any): boolean;
195
+ type TNull = undefined | null | '';
196
+ declare function isNull(data: any): data is TNull;
197
+
198
+ /**
199
+ *
200
+ * @param value 看起来是否像一个数字
201
+ * @example
202
+ * ```
203
+ * isLickNumber(1) => true
204
+ * isLickNumber('2.36884') => true
205
+ * isLickNumber(1/0) => false
206
+ * isLickNumber(0/0) => false
207
+ * isLickNumber('') => false
208
+ * isLickNumber() => false
209
+ * isLickNumber(null) => false
210
+ * isLickNumber(true) => false
211
+ * isLickNumber(false) => false
212
+ * isLickNumber([]) => false
213
+ * isLickNumber(function () {}) => false
214
+ * ```
215
+ * @returns
216
+ */
217
+ declare function isLikeNumber(value: any): boolean;
184
218
 
185
219
  /**
186
220
  * 默认值处理函数
@@ -354,10 +388,10 @@ declare function cloneEasy<T extends [] | Record<any, any> | Function>(data: T):
354
388
  * @param childKeyFrom - 原始数据的孩子键
355
389
  * @returns 转变后的新数据
356
390
  */
357
- declare function main<T extends IKvPair, K extends IKvPair, C extends keyof T>(
391
+ declare function main<T extends TKvPair, K extends TKvPair, C extends keyof T>(
358
392
  data: K[],
359
393
  childKeyTo: C,
360
- handle: (data: K) => Omit<T, C>,
394
+ handle: (data: K) => Omit<T, C> | undefined,
361
395
  childKeyFrom?: keyof K
362
396
  ): T[];
363
397
 
@@ -404,9 +438,9 @@ declare function defineEventBus<T extends EventHander>(
404
438
  * @param handle - 迭代方法。这里不用返回子节点
405
439
  * @param childKey - 子节点字段。默认值:children
406
440
  */
407
- declare function forEachTree<T extends IKvPair>(
441
+ declare function forEachTree<T extends TKvPair>(
408
442
  data: T[],
409
- handle: (data: T) => void,
443
+ handle: (data: T, parents: T[]) => void,
410
444
  childKey?: keyof T
411
445
  ): void;
412
446
 
@@ -422,26 +456,9 @@ declare function randomColor(): string;
422
456
 
423
457
  type VoidFunc = () => void;
424
458
  interface PollingOption {
425
- /**
426
- * 多少毫秒一次
427
- */
428
459
  interval: number;
429
- /**
430
- * 过期时间。不填则永不过期
431
- */
432
- timeout?: number;
433
- /**
434
- *
435
- * @param remainTime 剩余时间回调(需要设置了timeout大于0)
436
- * @returns
437
- */
460
+ timeout: number;
438
461
  onMessage?: (remainTime: number) => void;
439
- /**
440
- *
441
- * @param next 继续轮询
442
- * @param done 完成并停止
443
- * @returns
444
- */
445
462
  handler: (next: VoidFunc, done: VoidFunc) => void;
446
463
  }
447
464
  /**
@@ -474,14 +491,13 @@ declare class Polling {
474
491
  private _timer;
475
492
  private _timer_info;
476
493
  private _stamp;
477
- private _isMount;
478
494
  private _passStamp;
479
495
  private _option;
480
496
  constructor(setting: Partial<PollingOption>);
481
497
  private _next;
482
498
  private _doOnce;
483
499
  /** 开始 */
484
- start(): this | undefined;
500
+ start(): this;
485
501
  /** 完成 */
486
502
  done(): this;
487
503
  /** 销毁 */
@@ -509,39 +525,379 @@ declare function dataPage<T>(
509
525
 
510
526
  /**
511
527
  * 解析序列化字符参数为Map格式数据
512
- * @param str - url 查询参数。默认为window.location.href
528
+ * @param str - url 查询参数
513
529
  * @returns 键值对
514
530
  */
515
- declare function parseQuery(str?: string): IKvPair;
531
+ declare function parseQuery(str?: string): TKvPair;
532
+
533
+ declare const fieldCheck: {
534
+ /**
535
+ * 验证传入的数据是否是数字
536
+ * @param title - 标题
537
+ * @param value - 值
538
+ * @param required - 是否必填
539
+ * @returns
540
+ */
541
+ number(title: string, value: any, required?: boolean): number;
542
+ /**
543
+ * 验证传入的数据是否是字符串
544
+ * @param title - 标题
545
+ * @param value - 值
546
+ * @param required - 是否必填
547
+ * @returns
548
+ */
549
+ string(title: string, value: any, required?: boolean): string;
550
+ };
551
+
552
+ interface ISummary {
553
+ /** 值 */
554
+ value: number;
555
+ /** 增长率 */
556
+ riseRatio?: number;
557
+ /** 比重 */
558
+ proportion: number;
559
+ }
560
+ interface IARTResultItem<T> {
561
+ name: string;
562
+ value: T;
563
+ data: Record<string, T[]>;
564
+ summary: Record<string, ISummary>;
565
+ }
566
+ type TArrayRowToColumnColumnSort = (a: string, b: string) => number;
567
+ /**
568
+ * 数字中某个字段由 行转列
569
+ * @param originData - 原始数组
570
+ * @param options - 配置项
571
+ * @returns 转换后的数据
572
+ */
573
+ declare function arrayRowToColumn<T extends Record<string, any>>(
574
+ originData: T[],
575
+ options: {
576
+ /** 唯一行的ID生成器 */
577
+ uniqueRowId: Array<keyof T>;
578
+ /** 将此字段转为列 */
579
+ colField: keyof T;
580
+ /** 列的排序方法 */
581
+ colSort?: TArrayRowToColumnColumnSort;
582
+ /** 生成列信息 */
583
+ colCreate: (key: string) => {
584
+ label: string;
585
+ field: string;
586
+ };
587
+ summaryConfig?: IConfig;
588
+ }
589
+ ): {
590
+ columns: {
591
+ value: string;
592
+ label: string;
593
+ field: string;
594
+ }[];
595
+ data: IARTResultItem<T>[];
596
+ colSummary: Record<string, Record<string, ISummary>>;
597
+ getExtRow: <T_1 extends keyof ISummary>(
598
+ groupName: string,
599
+ field: T_1,
600
+ formatter: (data: ISummary[T_1]) => string
601
+ ) => Record<string, string>;
602
+ };
603
+ type TArrayRowToColumnCalculateRow = {
604
+ proportionBaseField?: string;
605
+ count: {
606
+ field: string;
607
+ mode: 'length' | 'uniqLength' | 'notZeroValue';
608
+ };
609
+ value: {
610
+ field: string;
611
+ mode: 'sum' | 'uniqLength' | 'avg';
612
+ };
613
+ };
614
+ interface IConfig {
615
+ averageField: string;
616
+ row?: Record<string, TArrayRowToColumnCalculateRow>;
617
+ column?: TColSumaryConfig;
618
+ }
619
+ type TColSumaryConfig = Record<
620
+ string,
621
+ {
622
+ field: string;
623
+ mode: 'uniqLength' | 'avg' | 'notZeroLength' | 'sum';
624
+ }
625
+ >;
626
+
627
+ type ISpanTableItem<T extends TKvPair> = T & {
628
+ $rowSpan: Record<string, number>;
629
+ $colSpan: Record<number, number>;
630
+ $colField: Record<string | number, number>;
631
+ };
632
+ /**
633
+ * 合并单元格。不改变原数组
634
+ * @param data - 一维数组
635
+ * @param fields - 合并的字段
636
+ * @returns 合并后的数据。会在每一项中添加两个字段 "$rowSpan" "$colSpan" "$colField"
637
+ */
638
+ declare function spanTable<T extends TKvPair>(data: T[], fields: string[]): ISpanTableItem<T>[];
639
+
640
+ /**
641
+ * 正则千分位转换,支持小数(任意字符串按位数相隔)
642
+ *
643
+ * @param data 需要转换的字符
644
+ * @param len 按多少位分隔一次,默认3
645
+ * @param symbol 千分位替换符号,默认逗号
646
+ */
647
+ declare function thousands(data: number | string, len?: number, symbol?: string): string;
648
+
649
+ /**
650
+ * 键值对的map实现方法
651
+ * @param data - 元数据
652
+ * @param handler - 自定义处理函数
653
+ * @returns
654
+ */
655
+ declare function mapKvPair<T extends TKvPair, U>(
656
+ data: T,
657
+ handler: (data: TValueOf<T>, key: string) => U
658
+ ): Record<string | number | symbol, U>;
659
+
660
+ /**
661
+ * 模糊搜索,例如 a4 可匹配 a3645
662
+ * @param search - 输入的值,如果为空,则表示无筛选条件,直接返回true
663
+ * @param data - 源数据的值
664
+ * @param regFlags - 与 RegExp 第二个参数相同,指定是否全局、区分大小写等
665
+ * @return
666
+ */
667
+ declare function isFuzzyMatch(search: string, data: string, regFlags?: string): boolean;
668
+
669
+ /**
670
+ * 向字符串中添加零宽字符。(暂时用于排除同名表格单元格合并)
671
+ * @param data - 需要处理的数据
672
+ * @returns
673
+ */
674
+ declare function mixInZeroWidthUnicode(data: string): string;
675
+
676
+ /**
677
+ * 键值对的forEach实现方法
678
+ * @param data - 元数据
679
+ * @param handler - 自定义处理函数
680
+ * @returns
681
+ */
682
+ declare function forEachKvPair<T extends TKvPair, U>(
683
+ data: T,
684
+ handler: (data: TValueOf<T>, key: string, index: number) => U
685
+ ): Record<string | number | symbol, U>;
686
+
687
+ /**
688
+ * 获取排序后的索引列表。如 [2,1,3] 排序为 [1,2,3] 索引为 [1,0,2]
689
+ *
690
+ * @param data - 原始数据
691
+ * @param sortHandler 排序处理函数,与原生排序使用方式一致
692
+ * @returns 索引列表
693
+ *
694
+ */
695
+ declare function getSortIndex<T>(data: T[], sortHandler: (a: T, b: T) => number): number[];
696
+
697
+ /**
698
+ * 按索引顺序对数组进行排序
699
+ * @param data 需要排序的数据
700
+ * @param index 索引列表
701
+ * @returns 新数据
702
+ */
703
+ declare function sortWithIndex<T>(data: T[], index: ReturnType<typeof getSortIndex>): T[];
704
+
705
+ type TListGroupKey<T extends TKvPair> = {
706
+ field: string | string[];
707
+ sort?: (a: TInnerGroupListItem<T>, b: TInnerGroupListItem<T>) => number;
708
+ };
709
+ type TGetValueField = string;
710
+ interface ICellSummary {
711
+ denominator?: [string, 'length' | 'uniqLength'];
712
+ /**
713
+ * sum 求和
714
+ * length 长度
715
+ * uniqLength 去重长度
716
+ */
717
+ numerator: [string, 'sum' | 'length' | 'uniqLength'];
718
+ }
719
+ type TColCustomWay = {
720
+ /** 计算方式 */
721
+ 0: 'sum' | 'max' | 'diff';
722
+ /** 参与计算的列(就是被转为列的那些值) */
723
+ 1: string[] | '*';
724
+ /** 获取值的方式 */
725
+ 2?: 'value' | 'length' | 'uniqLength';
726
+ /** 原始数据中的字段 */
727
+ 3?: string;
728
+ };
729
+ interface IListGroupOption<T extends TKvPair> {
730
+ /**
731
+ * 按字段值组装树形结构数据
732
+ */
733
+ path: TListGroupKey<T>[];
734
+ /**
735
+ * 将此字段转为列,并做一些基础统计
736
+ */
737
+ colField?: keyof T;
738
+ /**
739
+ * 组装后数据的计算方法
740
+ */
741
+ cellSummary?: ICellSummary;
742
+ /**
743
+ * 自定义列。分子➗分母
744
+ */
745
+ colCustom?: Record<
746
+ string,
747
+ {
748
+ numerator: TColCustomWay;
749
+ denominator?: TColCustomWay;
750
+ riseRatio?: boolean;
751
+ }
752
+ >;
753
+ }
754
+ interface TInnerColumnsSummaryItem<T> extends TKvPair {
755
+ data: T[];
756
+ summary: number | undefined;
757
+ _collect: any[];
758
+ }
759
+ type TInnerGroupListItem<T extends TKvPair> = {
760
+ uid: string;
761
+ uidPath: string[];
762
+ data: T[];
763
+ _columns: Record<string, TInnerColumnsSummaryItem<T>>;
764
+ _columnRiseRatio: Record<string, number | undefined>;
765
+ _columnTotal: Record<string, number>;
766
+ _columnProportion: Record<string, number>;
767
+ isLeaf: boolean;
768
+ children: TInnerGroupListItem<T>[];
769
+ };
770
+ declare function listGroup<T extends TKvPair>(
771
+ data: T[],
772
+ options: IListGroupOption<T>
773
+ ): {
774
+ /** 树形分组数据 */
775
+ data: TInnerGroupListItem<T>[];
776
+ /** 获取单元格:值 */
777
+ getCellValue: (
778
+ uidPath: string[],
779
+ field: TGetValueField,
780
+ formatter: (value: number, list: T[]) => string,
781
+ defaultData?: string
782
+ ) => string;
783
+ /** 获取单元格:纵向增长率 */
784
+ getCellVerticalRiseRatio: (
785
+ uidPath: string[],
786
+ field: TGetValueField,
787
+ formatter: (value: number) => string,
788
+ defaultData?: string
789
+ ) => string;
790
+ /** 获取单元格:纵向累计 */
791
+ getCellVerticalTotal: (
792
+ uidPath: string[] | '*',
793
+ field: TGetValueField,
794
+ formatter: (value: number) => string,
795
+ defaultData?: string
796
+ ) => string;
797
+ /** 获取单元格:纵向比重 */
798
+ getCellVerticalProportion: (
799
+ uidPath: string[],
800
+ field: TGetValueField,
801
+ formatter: (value: number) => string,
802
+ defaultData?: string
803
+ ) => string;
804
+ /** 获取一行:值 */
805
+ getRowCellValue: (
806
+ uidPath: string[],
807
+ fieldList: {
808
+ id: string;
809
+ field: TGetValueField;
810
+ }[],
811
+ formatter: (value: number) => string,
812
+ defaultData?: string
813
+ ) => Record<string, string>;
814
+ /** 获取一行:纵向比重 */
815
+ getRowVerticalProportion: (
816
+ uidPath: string[],
817
+ fieldList: {
818
+ id: string;
819
+ field: TGetValueField;
820
+ }[],
821
+ formatter: (value: number) => string,
822
+ defaultData?: string
823
+ ) => Record<string, string>;
824
+ /** 获取一个分组的所有原始数据,用于使用者自行计算 */
825
+ getOriginGroupData: (uidPath: string[], field: TGetValueField) => T[];
826
+ getOriginAllData: () => T[];
827
+ };
828
+
829
+ declare function union<T extends TKvPair>(...args: T[]): T[];
830
+
831
+ declare function getRatio(value: number | undefined, base: number | undefined): number;
832
+
833
+ /**
834
+ * 筛选并从原始数组移除符合条件的数据
835
+ * @param data - 原始数据
836
+ * @param predicate - 迭代回调
837
+ * @returns 筛选的结果
838
+ */
839
+ declare function filterWithMove<T, S extends T>(
840
+ data: T[],
841
+ predicate: (value: T, index: number, array: T[]) => value is S
842
+ ): S[];
843
+
844
+ type TUnits = [number, string];
845
+ /**
846
+ * 数字格式化为简称
847
+ * @param data - 数字
848
+ * @param formatter - 格式化数字(不包括单位)
849
+ * @param units - 格式化规则,可自定义
850
+ * @returns 数字简写
851
+ */
852
+ declare function export_default(
853
+ data: number,
854
+ formatter: (data: number) => string,
855
+ units?: TUnits[]
856
+ ): {
857
+ value: number;
858
+ fmtValue: string;
859
+ unit: string;
860
+ };
516
861
 
517
862
  export {
518
863
  Polling,
864
+ TArrayRowToColumnCalculateRow,
519
865
  _Array,
520
866
  _Boolean,
521
867
  _KvPair,
522
868
  _Number,
523
869
  _String,
870
+ arrayRowToColumn,
524
871
  changeIndex,
525
- clean,
526
872
  cloneEasy,
527
873
  dataPage,
528
874
  deepFindItem,
529
875
  deepFindTreePath,
530
876
  defaultValue,
531
877
  defineEventBus,
878
+ fieldCheck,
879
+ filterWithMove,
532
880
  flatTree,
533
881
  floorFixed,
534
882
  forEach,
883
+ forEachKvPair,
535
884
  forEachTree,
536
885
  getRandom,
886
+ getRatio,
887
+ getSortIndex,
537
888
  getType,
538
889
  isArray,
539
890
  isEmpty,
540
891
  isFunction,
892
+ isFuzzyMatch,
541
893
  isKvPair,
894
+ isLikeNumber,
542
895
  isNull,
543
896
  isString,
897
+ listGroup,
898
+ mapKvPair,
544
899
  main as mapTree,
900
+ mixInZeroWidthUnicode,
545
901
  padEnd,
546
902
  padStart,
547
903
  param,
@@ -550,9 +906,14 @@ export {
550
906
  repeatString,
551
907
  roundFixed,
552
908
  shake,
909
+ export_default as shortNumber,
910
+ sortWithIndex,
911
+ spanTable,
553
912
  split,
913
+ thousands,
554
914
  flatArrayToTree as tree,
555
915
  trim,
916
+ union,
556
917
  urlToGet,
557
918
  uuid,
558
919
  variableHasValue
@@ -0,0 +1,5 @@
1
+ /**
2
+ * 纯JS工具库 => jUtilsBase
3
+ * @update 2024-06-12 15:01:25
4
+ */
5
+ var $letters=["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"],$ArrayTypeNameBig="Array",$FunctionTypeNameBig="Function",$ObjectTypeNameBig="Object",$stringTypeNameBig="String",$numberTypeNameBig="Number",$undefinedValue=void 0,$zeroString="0",$falseString="false",$trueString="true",$ObjectTypeNameBigPrototypeToString=Object.prototype.toString,$encodeURI=encodeURI,$decodeURIComponent=decodeURIComponent,$regSpaceStr="\\s\\uFEFF\\xA0",$zeroWidthCode="‎";function isNull(e){return null===e||e===$undefinedValue}function _String(e){return isNull(e)?"":String(e)}function getType(e){return $ObjectTypeNameBigPrototypeToString.call(e).slice(8,-1)}function isArray(e){return getType(e)===$ArrayTypeNameBig}function isKvPair(e){return getType(e)===$ObjectTypeNameBig}function isString(e){return getType(e)===$stringTypeNameBig}function hpJsonParse(e,n){var r;try{r=JSON.parse(e)}catch(t){r=n}return r}function _KvPair(e){return e=isKvPair(e)||isKvPair(e=hpJsonParse(e))?e:{}}function isEmpty(e){return isNull(e)||""===e}function isFunction(e){return"function"==typeof e}function param(e){var r=[];function a(e,n){null!=e&&""!==e&&(n=null==(n=isFunction(n)?n():n)?"":n,r[r.length]=$encodeURI(e)+"="+$encodeURI(n))}return function i(e,n){var r,t;if(e)switch(getType(n)){case $ArrayTypeNameBig:for(r=0;r<n.length;r++)i(e+"["+("object"==typeof n[r]&&n[r]?r:"")+"]",n[r]);break;case $ObjectTypeNameBig:for(t in n)i(e+"["+t+"]",n[t]);break;default:a(e,n)}else switch(getType(n)){case $stringTypeNameBig:case $ObjectTypeNameBig:for(t in n)i(t,n[t]);break;case $ArrayTypeNameBig:for(r=0;r<n.length;r++)a(n[r].name,n[r].value)}}("",e),r.join("&")}function _Array(e){return e=isArray(e)||isArray(e=hpJsonParse(e))?e:[]}function _Number(e){return e=Number(e),Math.abs(e)===Math.abs(Infinity)||isNaN(e)?0:e}function hpTryToParseStringToBasicType(e){return null==e?$undefinedValue:$falseString!==e&&($trueString===e||hpJsonParse(e,e))}var defaultSplitArr=[$undefinedValue,$undefinedValue];function handleDeepKey(e,n,r){var n=splitSymbol(n),t=n[0];isPreLikeArray(t)?(t=_Number(t),n[1]==$undefinedValue?e.push(r):(/^\[[\D]+\]/.test(n[1])?e[t]=_KvPair(e[t]):e[t]=_Array(e[t]),handleDeepKey(e[t],n[1],r))):n[1]==$undefinedValue?e[t]=r:(/^\[[\D]+\]/.test(n[1])?e[t]=_KvPair(e[t]):e[t]=_Array(e[t]),handleDeepKey(e[t],n[1],r))}function splitSymbol(e){if(e==$undefinedValue)return defaultSplitArr;var t,a=e;return e.replace(/^\[(.*?)\](.*)?/,function(e,n,r){return a=n,t=r,""}),[a,t]}function isPreLikeArray(e){return""===e||/^\d+$/.test(e)}function parseQuery(e){var i={},o=!1,r="";return(e=isNull(e)?"":e).replace(/([^=&?/#]*?)=([^=&?/#]*)/g,function(e,n,a){a=hpTryToParseStringToBasicType($decodeURIComponent(a)),r=$decodeURIComponent(n),o=!1,""!==r&&(r.replace(/(.*?)(\[.*)/,function(e,n,r){var t=splitSymbol(r);o=!0,isPreLikeArray(t[0])?i[n]=_Array(i[n]):i[n]=_KvPair(i[n]),handleDeepKey(i[n],r,a)}),o||(i[r]=a))}),i}var baseReg="["+$regSpaceStr+"]+";function trim(e,n){var r=getType(e),t=(r===$numberTypeNameBig&&(e=String(e),r=$stringTypeNameBig),"");if(r!==$stringTypeNameBig)return"";switch(n){case 1:t="^"+baseReg;break;case-1:t=baseReg+"$";break;case"*":t=baseReg;break;default:t="^"+baseReg+"|"+baseReg+"$"}return e.replace(new RegExp(t,"g"),"")}function urlToGet(e,n){e=_String(e);var i=isKvPair(n)?n:parseQuery(n),n=parseQuery(e=e.replace(/({{)(.*?)(}})/g,function(e,n,r,t){r=trim(r);var a=i[r];return delete i[r],a})),n=param(i=Object.assign(n,i));return e=n?(e=e.replace(/\?.*/,""))+"?"+n:e}function hpIsEmptyMap(e){var n,r=!0;for(n in e)if(n!==$undefinedValue){r=!1;break}return r}function cloneEasy(e){switch(getType(e)){case $ArrayTypeNameBig:for(var n=[],r=0;r<e.length;r++)n.push(cloneEasy(e[r]));break;case $ObjectTypeNameBig:for(var t in n={},e)n[t]=cloneEasy(e[t]);break;case $FunctionTypeNameBig:function a(){e.apply(this,arguments)}for(var i in e.prototype)a.prototype[i]=e.prototype[i];n=a;break;default:n=e}return n}function isNoData(e,n){var r=!1;return r=isArray(e)&&n.array&&0===e.length||isKvPair(e)&&n.kvPair&&hpIsEmptyMap(e)||isString(e)&&n.string&&""===e||isNull(e)?!0:r}function hander(e,n){if(isKvPair(e))for(var r in e){var t=e[r];(isArray(t)||isKvPair(t))&&hander(t,n),isNoData(t,n)&&delete e[r]}}function shake(e,n){n=Object.assign({string:!0,array:!0,kvPair:!0},n);return hander(e=cloneEasy(e),n),e}function variableHasValue(e,n,r){var t;r=null==r?60:r,e()?n():(clearTimeout(t),setTimeout(function(){variableHasValue(e,n,r)},r))}variableHasValue["async"]=function(n,r){return new Promise(function(e){variableHasValue(n,e,r)})};var DEFAULT_CONFIG={id:"id",children:"children"};function deepFindTreePath(e,n,r){r=Object.assign(DEFAULT_CONFIG,r);for(var t=[],a=cloneEasy(e),i=new Set,o=r["children"];a.length;){var u=a[0];if(i.has(u))t.pop(),a.shift();else if(i.add(u),u[o]&&a.unshift.apply(a,u[o]),t.push(u),n(u))return t}return undefined}function isLikeNumber(e){var n=!1;return"boolean"==typeof e||isArray(e)||null==e||""===e||(e=Number(e),n=!isNaN(e)&&Infinity!=Math.abs(e)),n}function defaultValue(e,n){return isNull(e)?n:e}function repeatString(e,n){var r="";if((e=_String(e)).length*n<1<<28)for(;1==(1&n)&&(r+=e),0!=(n>>>=1);)e+=e;return r}function hpPadString(e,n,r,t){return(e=_String(e)).length>(n>>=0)?e:(n-=e.length,r.length<n&&(r+=repeatString(r,n/r.length)),-1===t?r.slice(0,n)+e:e+r.slice(0,n))}function padStart(e,n,r){return hpPadString(e,n,r,-1)}function padEnd(e,n,r){return hpPadString(e,n,r,1)}function split(e,n){return""!==e?e.split(n):[]}function floorFixed(e,n,r){var e=split(e=trim(_Number(e)),"."),t=e[1]||"";return t.length<n&&(t=padEnd(t,n,$zeroString),r&&(t=t.replace(/0+$/,""))),n<1||!t?e[0]:e[0]+"."+t.substring(0,n)}function roundFixed(e,n,r){e=_Number(e);var t,a=Math.pow(10,n),e=_String(Math.round(e*a)/a);return 0<n&&(t=(a=split(e,"."))[0],(a=a[1]||"").length<n&&(a=padEnd(a,n,$zeroString),e=(a=r?a.replace(/0+$/,""):a)?t+"."+a:t)),e}function deepFindItem(e,r,n){var t,a,i=isNull(n)?"children":n;return function o(e){if(e)for(var n=0;n<e.length;n++){if(a=r(e[n])){t=e[n];break}if(o(e[n][i]),a)break}}(e),t}function flatArrayToTree(e,n){for(var r=(n=_KvPair(n)).id||"id",t=n.pid||"pid",a=n.children||"children",i=0;i<e.length;i++){var o,u=e[i];(o=deepFindItem(e,function(e){return null!=e[r]&&e[r]!=u[r]&&e[r]===u[t]},a))&&(o[a]=_Array(o[a]),o[a].push(u),e.splice(i--,1))}return e}function changeIndex(e,n,r){if(e<0)return n;e+=1;return(n=(n+r)%e)<0&&(n+=e),-0===n?0:n}function getRandom(e,n,r){r=!1===r?0:1;return e=Math.random()*(n-e+r)+e,r?Math.floor(e):e}function getRandomWord(){return $letters[getRandom(0,$letters.length-1)][0]}function uuid(e){e=_Number(e);for(var n="",r=0;r<13;r++)n+=getRandom(1,9);e=(new Date).getTime()*getRandom(1,100);return padEnd(getRandomWord()+Number(n).toString(32)+e.toString(32),20,getRandomWord()+getRandomWord()+getRandomWord())}function _Boolean(e){return!0===e||"true"===e||"1"===e||1===e}function flatTree(e,t){var a=[];return t=defaultValue(t,"children"),function i(e){if(isArray(e))for(var n,r=0;r<e.length;r++)n=e[r],a.push(n),i(n[t])}(e),a}function main(e,a,i,o){o=o||"children";var n=[];return function u(e,n){for(var r=0;r<e.length;r++){var t=i(e[r]);isNull(t)||(n[r]=cloneEasy(t),e[r][o]&&(n[r][a]=[],u(e[r][o],n[r][a])))}}(e,n),n}var events={};function defineEventBus(a){if(events[a])throw'"'+a+'" Has already been registered!';return events[a]=events[a]||[],{on:function(e){events[a].push(e)},emit:function(){for(var e=arguments.length,n=new Array(e),r=0;r<e;r++)n[r]=arguments[r];for(var t=0;t<events[a].length;t++)events[a][t].apply($undefinedValue,n)},off:function(e){if(!e)throw"the hander of off is required!";for(var n=0;n<events[a].length;n++)events[a][n]===e&&events[a].splice(n--,1)},dispose:function(){for(var e=0;e<events[a].length;e++)events[a].splice(e--,1);delete events[a]}}}function forEachTree(e,a,i){i=i||"children",function o(e,n){for(var r=0;r<e.length;r++){var t=cloneEasy(n);a(e[r],t),isArray(e[r][i])&&(t.push(e[r]),o(e[r][i],t))}}(e,[])}function forEach(e,n){for(var r=0;r<e.length;r++)n(e[r],r,e)}function randomColor(){return"rgba("+getRandom(0,255,!0)+","+getRandom(0,255,!0)+","+getRandom(0,255,!0)+",1)"}function emptyFunc(e,n){}var Polling=function(){function e(e){this._timer=void 0,this._timer_info=void 0,this._stamp=0,this._passStamp=0,this._option=void 0,this._option=Object.assign({timeout:6e3,interval:1e3,handler:emptyFunc},e),this._next=this._next.bind(this),this._doOnce=this._doOnce.bind(this),this.done=this.done.bind(this)}var n=e.prototype;return n._next=function(){return clearInterval(this._timer),this._passStamp=+new Date-this._stamp,this._timer=setTimeout(this._doOnce,this._option.interval),this},n._doOnce=function(){if(this._passStamp>=this._option.timeout)return this._option.onMessage&&this._option.onMessage(0),this.done(),this;this._option.handler(this._next,this.done)},n.start=function(){var e,n=this;this._stamp=+new Date,this.done(),this._doOnce();return this._option.onMessage&&(clearInterval(this._timer_info),this._timer_info=setInterval(function(){e=+new Date-n._stamp,0===(e=Math.max(n._option.timeout-e,0))&&n.done(),n._option.onMessage(e)},100)),this},n.done=function(){return clearTimeout(this._timer),clearTimeout(this._timer_info),this},n.dispose=function(){return this.done(),this},e}();function dataPage(e,n,r){if(r<1)throw"页码必须大于0";var t=(r-1)*n,a=t+n;return{current:r,total:e.length,size:n,pages:Math.ceil(e.length/n),data:cloneEasy(e.slice(t,a))}}function basicCheck(e,n,r,t){if(e="【"+e+"】",r&&isEmpty(n))throw"字段"+e+"不能为空";if(getType(n)!==t)switch(t){case"String":n=String(n);break;case"Number":if(!isLikeNumber(n))throw"字段"+e+"必须为数字";n=Number(n)}return n}var fieldCheck={number:function(e,n){return basicCheck(e,n,!(2<arguments.length&&arguments[2]!==undefined)||arguments[2],"Number")},string:function(e,n){return basicCheck(e,n,2<arguments.length&&arguments[2]!==undefined&&arguments[2],"String")}};function uniq(e){return Array.from(new Set(e))}var defaultSortFun=function(e,n){return Number(e)-Number(n)},_names_count=0,_namesMap={};function getIdMap(e){return _namesMap[e]||(_namesMap[e]={id:++_names_count,label:e}),_namesMap[e]}function createUniqIds(e,n){var r=[],t=[];return e.forEach(function(e){e=getIdMap(n[e]);r.push(e.id),t.push(e.label)}),{id:r.join("_"),label:t.join("→")}}function arrayRowToColumn(e,a){var n,r=[],i=(e.forEach(function(e){e=String(e[a.colField]);r.includes(e)||r.push(e)}),r.sort(null!=(t=a.colSort)?t:defaultSortFun),{}),f=(e.forEach(function(n){var e=createUniqIds(a.uniqueRowId,n),r={},t=(a.uniqueRowId.forEach(function(e){r[e]=n[e]}),i[e.id]=i[e.id]||{value:r,name:e.label,data:{}},a.colCreate(n[a.colField]).field);i[e.id].data[t]=i[e.id].data[t]||[],i[e.id].data[t].push(n)}),[]);for(n in i)f.push({name:i[n].name,value:i[n].value,data:i[n].data,summary:{}});var t=r.map(function(e){var n=a.colCreate(e);return{value:e,label:n.label,field:n.field}}),d={};return a.summaryConfig&&(a.summaryConfig.row&&(f=mergeRowSummary(f,a.summaryConfig.row,a.summaryConfig.averageField)),a.summaryConfig.column&&(d=mergeColSummary(f,a.summaryConfig.column,a.summaryConfig.averageField))),{columns:t,data:f,colSummary:d,getExtRow:function(n,e,r){var t,a=f.find(function(e){return e.name===n}),i={};if(!a){var o=e,u=r,c=d[n],l={};if(c)for(var s in c)l[s]=u(c[s][o]);return l}for(t in a.summary)i[t]=r(a.summary[t][e]);return i}}}function getRatio$1(e,n){return e===$undefinedValue||n===$undefinedValue?$undefinedValue:(n-e)/e}function mergeRowSummary(a,i,n){return a.forEach(function(c){var l=i[c.name];if(l){var s,e,f=0,d=0;for(e in c.data)!function(e){d++;var n,r=[],t=0,a=[],i=[],o=(c.data[e].forEach(function(e){r.push(e[l.count.field]);var n=_Number(e[l.value.field]);switch(l.value.mode){case"uniqLength":a.push(e[l.value.field]),a=uniq(a),t=a.length;break;case"sum":case"avg":t+=n}0!==n&&i.push(n)}),0);switch(l.count.mode){case"length":o=r.length;break;case"uniqLength":o=uniq(r).length;break;case"notZeroValue":o=i.length}var u=t;"avg"===l.value.mode&&(u=t/o),f+=u,c.summary[e]={value:u,proportion:0,riseRatio:s?getRatio$1(null==(n=c.summary[s])?void 0:n.value,u):void 0},s=e}(e);c.summary[n]={value:f/d,riseRatio:$undefinedValue,proportion:0}}}),a.forEach(function(e){var n=i[e.name];if(n){var r=a.find(function(e){return e.name===n.proportionBaseField});if(n.proportionBaseField&&r)for(var t in e.summary)e.summary[t].proportion=e.summary[t].value/r.summary[t].value}}),a}function mergeColSummary(l,s,f){var e,d={},m={},n=function(a){m[a]={},d[a]={};var e,i=s[a],n=(l.forEach(function(t){for(var e in t.data)!function(e){d[a][e]=d[a][e]||{data:[],sum:0};var n=[],r=0;switch(t.data[e].forEach(function(e){switch(n.push(e[i.field]),i.mode){case"uniqLength":n=uniq(n);break;case"avg":case"sum":r+=e[i.field];break;case"notZeroLength":0!==_Number(e[i.field])&&r++}}),i.mode){case"uniqLength":n=uniq(n);break;case"avg":r/=t.data[e].length}d[a][e].data=d[a][e].data.concat(n),d[a][e].sum+=r}(e)}),void 0);for(e in d[a]){var r,t=0;switch(i.mode){case"avg":t=d[a][e].sum/l.length;break;case"uniqLength":t=d[a][e].data.length;break;case"notZeroLength":case"sum":t=d[a][e].sum}m[a][e]={value:t,proportion:0,riseRatio:n?getRatio$1(null==(r=m[a][n])?void 0:r.value,t):void 0},n=e}var o,u=0,c=0;for(o in m[a])u+=m[a][o].value,c++;m[a][f]={value:u/c,riseRatio:$undefinedValue,proportion:0}};for(e in s)n(e);return m}function sameRowCellCount(e,n,r,t){var a=1;for(e++;e<t.length;e++){var i=t[e][n];if(i!==r&&!isEmpty(i))break;a++}return a}function findPrevRowSpanNum(e,n,r){for(var t=0;0<=n&&!(0<(t=e[n].$rowSpan[r]));n--);return t}function sameColSellCount(e,n,r,t){var a=1;for(e++;e<t.length;e++){var i=trim(r[t[e]]);if(i!==n&&!isEmpty(i))break;a++}return a}function spanTable(e,u){var c=cloneEasy(e),l={};return u.forEach(function(e,n){var a,i,o;a=e,i=u[n-1],o=0,c.forEach(function(e,n){e.$rowSpan=null!=(t=e.$rowSpan)?t:{};var r,t=e[a];l[a]=null!=(r=l[a])?r:0,1<l[a]?(e.$rowSpan[a]=0,l[a]--):(r=sameRowCellCount(n,a,t,c),void 0!==i&&(t=findPrevRowSpanNum(c,n,i),0<o?t<=o+r?(r=t-o,o=0):o+=r:r<t?o=r:r=t),l[a]=r,e.$rowSpan[a]=l[a])})}),c.forEach(function(t){t.$colSpan={},t.$colField={};var a=0;u.forEach(function(e,n){var r=t[e];1<a?(t.$colSpan[n]=0,t.$colField[e]=0,a--):(a=sameColSellCount(n,r,t,u),t.$colSpan[n]=a,t.$colField[e]=a)})}),c}function thousands(e,a,i){return a=a||3,i=i||",",(isString(e)?e:_String(e)).replace(/([^.]*)?(\.)?(.*)?/,function(e,n,r,t){return _String(n).replace(new RegExp("(.(?=(.{"+a+"})+$))","g"),"$1"+i)+_String(r)+_String(t)})}function mapKvPair(e,n){var r,t={};for(r in e)t[r]=n(cloneEasy(e[r]),r);return t}function isFuzzyMatch(e,n,r){var t=!0;return(e=trim(e,"*"))&&(e=split(e,"").join(".*"),t=new RegExp(e,_String(r)).test(n)),t}function mixInZeroWidthUnicode(e){return split(e,"").join($zeroWidthCode)}function forEachKvPair(e,n){var r,t={},a=-1;for(r in e)a++,t[r]=n(e[r],r,a);return t}function getSortList(e){return e.map(function(e,n){return{value:e,index:n}})}function getSortIndex(e,r){var n=getSortList(e),t=getSortList(e);return t.sort(function(e,n){return r(e.value,n.value)}),n.map(function(n){return t.findIndex(function(e){return n.index===e.index})})}function sortWithIndex(e,n){for(var r=[],t=0;t<e.length;t++)r[t]=e[n[t]];return r}function getRatio(e,n){return 0===e||isNull(e)?0:0===n||isNull(n)?1:e/n}function difference(e,r,t){var a=[];return e.forEach(function(n){r.some(function(e){return t(e,n)})||a.push(n)}),r.forEach(function(n){e.some(function(e){return t(e,n)})||a.some(function(e){return t(e,n)})||a.push(n)}),a}function hpObjectKeys(e){return Object.keys(e)}var AVG_FIELD="sys-row-avg";function getUniqId(e,n){var r=[];return isArray(e)?e.forEach(function(e){r.push(n[e])}):r.push(n[e]),r.join("→")}function _rowToColumn(e,n){var u={},r=n.colField;if(!isNull(r)&&e.length){var a=n.cellSummary;if(e.forEach(function(e){var n=e[r];u[n]=u[n]||{data:[],summary:0,_collect:[]},u[n].data.push(e),a&&(e=e[a.numerator[0]],u[n].summary+=e,u[n]._collect.push(e))}),!isNull(a)){var t,i,o;for(t in u)!function(e){var n=u[e],r=1,t=a.denominator;if(t)switch(t[1]){case"length":r=n.data.map(function(e){return e[t[0]]}).length;break;case"uniqLength":r=uniq(n.data.map(function(e){return e[t[0]]})).length}switch(a.numerator[1]){case"sum":isNull(n.summary)||(n.summary=n.summary/r);break;case"length":n.summary=n._collect.length/r;break;case"uniqLength":n.summary=uniq(n._collect).length/r}}(t);o=i=0,forEachKvPair(u,function(e){i++;e=isNull(e.summary)?0:e.summary;o+=e}),u[AVG_FIELD]={data:[],summary:o/i,_collect:[]},n.colCustom&&forEachKvPair(n.colCustom,function(e,n){var r=c(e.numerator),e=e.denominator?c(e.denominator):1;u[n]={data:[],summary:getRatio(r,e),_collect:[]}})}}return u;function c(i){var o=0,e=hpObjectKeys(u).filter(function(e){var n=[AVG_FIELD].includes(e),e="*"===i[1]||i[1].includes(e);return!n&&e});return isArray(i[1])&&e.sort(function(e,n){return i[1].indexOf(e)-i[1].indexOf(n)}),e.forEach(function(e,n){var r,t,e=u[e],a=0;isNull(i[2])||"value"===i[2]?a=isNull(e.summary)?0:e.summary:"length"===i[2]?(r=i[3])&&(a=e.data.map(function(e){return e[r]}).length):"uniqLength"===i[2]&&(t=i[3])&&(a=uniq(e.data.map(function(e){return e[t]})).length),"sum"===i[0]?o+=a:"max"===i[0]?o=Math.max(o,a):"diff"===i[0]&&(0===n?o=a:o-=a)}),o}}function _groupToList(e,n,r,t){var a,i=[];for(a in e){var o=n===r,u=_groupToList(e[a].child,n,r+1,t);i.push({uidPath:e[a].uidPath,uid:e[a].uid,data:e[a].data,_columnRiseRatio:{},_columnTotal:{},_columnProportion:{},_columns:_rowToColumn(e[a].data,t),isLeaf:o,children:u})}return i}function deepGroup(e,u){var n={},c=0;!function s(e,n,r){for(var t=0;t<n.length;t++){var a=n[t],i=getUniqId(u.path[c].field,a);e[i]=e[i]||{uidPath:r.concat(i),uid:i,data:[],child:{}},e[i].data.push(a)}if(c<u.path.length-1)for(var o in c++,e)s(e[o].child,e[o].data,e[o].uidPath)}(n,e,[]);var e=_groupToList(n,c,0,u),t=(!function a(e,n){var r;e.sort(null==(r=u.path[n])?void 0:r.sort),e.forEach(function(e){a(e.children,n+1)})}(e,0),!function i(e){e.forEach(function(e){var r={};forEachKvPair(e._columns,function(e,n){e=isNull(e.summary)?0:e.summary;r[n]=r[n]||0,r[n]+=e}),e._columnTotal=r,i(e.children)})}(e),{}),l=(e.forEach(function(r){forEachKvPair(r._columns,function(e,n){t[n]=t[n]||0,t[n]+=r._columnTotal[n]})}),[]);return u.colCustom&&forEachKvPair(u.colCustom,function(e,n){e.riseRatio||l.push(n)}),function r(e){var i={},o={};e.forEach(function(e,a){forEachKvPair(e._columns,function(e,n){var r,t;l.includes(n)||(0<a?isNull(r=e.summary)?o[n]=$undefinedValue:(t=null!=(t=i[n])?t:0,o[n]=getRatio(r-t,t)):o[n]=void 0,i[n]=e.summary)}),e._columnRiseRatio=o,r(e.children)})}(e),function o(e,t){e.forEach(function(e,n){var r={};forEachKvPair(e._columns,function(e,n){r[n]=getRatio(e.summary,t[n])}),e._columnProportion=r,o(e.children,e._columnTotal)})}(e,t),{data:e,total:t}}function listGroup(e,n){var s=deepGroup(e,n);function i(e,n,r,t,a){var i=deepFindItem(s.data,function(e){return 0===difference(e.uidPath,n,function(e,n){return e===n}).length}),o=defaultValue(a,"");if(i)try{switch(e){case"_columnRiseRatio":case"_columnTotal":case"_columnProportion":var u=i[e][r];return isNull(u)?o:t(u);default:var c=i[e][r].summary;return isNull(c)?o:t(c,i[e][r].data)}}catch(l){return o}return o}function o(e,n,r,t){return i("_columns",e,n,r,t)}function u(e,n,r,t){return i("_columnProportion",e,n,r,t)}return{data:s.data,getCellValue:o,getCellVerticalRiseRatio:function(e,n,r,t){return i("_columnRiseRatio",e,n,r,t)},getCellVerticalTotal:function(e,n,r,t){var a;return"*"===e?isNull(a=s.total[n])?defaultValue(t,""):r(a):i("_columnTotal",e,n,r,t)},getCellVerticalProportion:u,getRowCellValue:function(n,e,r,t){var a={};return e.forEach(function(e){a[e.id]=o(n,e.field,r,t)}),a},getRowVerticalProportion:function(n,e,r,t){var a={};return e.forEach(function(e){a[e.id]=u(n,e.field,r,t)}),a},getOriginGroupData:function(n,e){var r=deepFindItem(s.data,function(e){return 0===difference(e.uidPath,n,function(e,n){return e===n}).length});return r&&null!=(r=null==(e=r._columns[e])?void 0:e.data)?r:[]},getOriginAllData:function(){return e}}}function union(){for(var e=arguments.length,n=new Array(e),r=0;r<e;r++)n[r]=arguments[r];var t=new Set(n);return Array.from(t)}function filterWithMove(e,n){for(var r=[],t=0;t<e.length;t++){var a=e[t];n(a,t,e)&&(r.push(a),e.splice(t--,1))}return r}var defaUnits=[[1e4,"万"],[1e8,"亿"]];function shortNumber(e,n,r){for(var t=isNull(r)?defaUnits:r,a=(t.sort(function(e,n){return n[0]-e[0]}),e),i="",o=0;o<t.length;o++){var u=t[o],c=e/u[0];if(1<=c){a=c,i=u[1];break}}return{value:a,fmtValue:n(a),unit:i}}export{Polling,_Array,_Boolean,_KvPair,_Number,_String,arrayRowToColumn,changeIndex,cloneEasy,dataPage,deepFindItem,deepFindTreePath,defaultValue,defineEventBus,fieldCheck,filterWithMove,flatTree,floorFixed,forEach,forEachKvPair,forEachTree,getRandom,getRatio,getSortIndex,getType,isArray,isEmpty,isFunction,isFuzzyMatch,isKvPair,isLikeNumber,isNull,isString,listGroup,mapKvPair,main as mapTree,mixInZeroWidthUnicode,padEnd,padStart,param,parseQuery,randomColor,repeatString,roundFixed,shake,shortNumber,sortWithIndex,spanTable,split,thousands,flatArrayToTree as tree,trim,union,urlToGet,uuid,variableHasValue};