@ecan-bi/datav 1.5.94 → 1.5.96

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.
Files changed (123) hide show
  1. package/dist/index.es.js +13038 -11519
  2. package/dist/index.es.js.map +1 -1
  3. package/dist/index.umd.js +36 -35
  4. package/dist/index.umd.js.map +1 -1
  5. package/dist/style.css +2 -2
  6. package/package.json +2 -1
  7. package/types/container/border/Border.vue.d.ts +8 -8
  8. package/types/container/border/index.d.ts +8 -8
  9. package/types/container/border/props.d.ts +4 -4
  10. package/types/container/circulate/Circulate.vue.d.ts +8 -8
  11. package/types/container/circulate/index.d.ts +8 -8
  12. package/types/container/circulate/props.d.ts +4 -4
  13. package/types/container/tabs/Tabs.vue.d.ts +8 -8
  14. package/types/container/tabs/index.d.ts +8 -8
  15. package/types/container/tabs/props.d.ts +4 -4
  16. package/types/container/template/Template.vue.d.ts +8 -8
  17. package/types/container/template/index.d.ts +8 -8
  18. package/types/container/template/props.d.ts +4 -4
  19. package/types/control/button/Button.vue.d.ts +12 -12
  20. package/types/control/button/index.d.ts +12 -12
  21. package/types/control/button/props.d.ts +6 -6
  22. package/types/control/checkbox/Checkbox.vue.d.ts +8 -8
  23. package/types/control/checkbox/index.d.ts +8 -8
  24. package/types/control/checkbox/props.d.ts +4 -4
  25. package/types/control/date-picker/DatePicker.vue.d.ts +21 -21
  26. package/types/control/date-picker/index.d.ts +21 -21
  27. package/types/control/date-picker/props.d.ts +6 -6
  28. package/types/control/input/Input.vue.d.ts +8 -8
  29. package/types/control/input/index.d.ts +8 -8
  30. package/types/control/input/props.d.ts +4 -4
  31. package/types/control/nav-tab/NavTab.vue.d.ts +8 -8
  32. package/types/control/nav-tab/index.d.ts +8 -8
  33. package/types/control/nav-tab/props.d.ts +4 -4
  34. package/types/control/radio/Radio.vue.d.ts +12 -12
  35. package/types/control/radio/index.d.ts +12 -12
  36. package/types/control/radio/props.d.ts +6 -6
  37. package/types/control/range-picker/RangePicker.vue.d.ts +30 -30
  38. package/types/control/range-picker/index.d.ts +30 -30
  39. package/types/control/range-picker/props.d.ts +6 -6
  40. package/types/control/select/Select.vue.d.ts +8 -8
  41. package/types/control/select/index.d.ts +8 -8
  42. package/types/control/select/props.d.ts +4 -4
  43. package/types/control/tree-select/TreeSelect.vue.d.ts +4 -4
  44. package/types/control/tree-select/index.d.ts +4 -4
  45. package/types/control/tree-select/props.d.ts +4 -4
  46. package/types/graph/bar/Bar.vue.d.ts +12 -12
  47. package/types/graph/bar/index.d.ts +12 -12
  48. package/types/graph/bar/props.d.ts +6 -6
  49. package/types/graph/combo-graph/ComboGraph.vue.d.ts +12 -12
  50. package/types/graph/combo-graph/index.d.ts +12 -12
  51. package/types/graph/combo-graph/props.d.ts +6 -6
  52. package/types/graph/custom-graph/CustomGraph.vue.d.ts +8 -8
  53. package/types/graph/custom-graph/index.d.ts +8 -8
  54. package/types/graph/custom-graph/props.d.ts +4 -4
  55. package/types/graph/gauge/Gauge.vue.d.ts +689 -0
  56. package/types/graph/gauge/index.d.ts +690 -0
  57. package/types/graph/gauge/props.d.ts +338 -0
  58. package/types/graph/index.d.ts +1 -0
  59. package/types/graph/line/Line.vue.d.ts +8 -8
  60. package/types/graph/line/index.d.ts +8 -8
  61. package/types/graph/line/props.d.ts +6 -6
  62. package/types/graph/pie/Pie.vue.d.ts +12 -12
  63. package/types/graph/pie/index.d.ts +12 -12
  64. package/types/graph/pie/props.d.ts +6 -6
  65. package/types/graph/radar/Radar.vue.d.ts +8 -8
  66. package/types/graph/radar/index.d.ts +8 -8
  67. package/types/graph/radar/props.d.ts +6 -6
  68. package/types/graph/scatter/Scatter.vue.d.ts +73 -8
  69. package/types/graph/scatter/index.d.ts +73 -8
  70. package/types/graph/scatter/props.d.ts +39 -4
  71. package/types/hooks/indicator.d.ts +1 -0
  72. package/types/laboratory/ai-analyze/AiAnalyze.vue.d.ts +363 -0
  73. package/types/laboratory/ai-analyze/index.d.ts +364 -0
  74. package/types/laboratory/ai-analyze/props.d.ts +193 -0
  75. package/types/laboratory/data-select/DataSelect.vue.d.ts +8 -8
  76. package/types/laboratory/data-select/index.d.ts +8 -8
  77. package/types/laboratory/data-select/props.d.ts +4 -4
  78. package/types/laboratory/index-panel/IndexPanel.vue.d.ts +8 -8
  79. package/types/laboratory/index-panel/index.d.ts +8 -8
  80. package/types/laboratory/index-panel/props.d.ts +4 -4
  81. package/types/laboratory/index.d.ts +1 -0
  82. package/types/laboratory/pivotTable/PivotTableContainer.vue.d.ts +23 -23
  83. package/types/laboratory/pivotTable/index.d.ts +23 -23
  84. package/types/laboratory/pivotTable/props.d.ts +4 -4
  85. package/types/laboratory/value-line/ValueLine.vue.d.ts +8 -8
  86. package/types/laboratory/value-line/index.d.ts +8 -8
  87. package/types/laboratory/value-line/props.d.ts +6 -6
  88. package/types/map/map/Map.vue.d.ts +8 -8
  89. package/types/map/map/index.d.ts +8 -8
  90. package/types/map/map/props.d.ts +4 -4
  91. package/types/media/iframe/Iframe.vue.d.ts +8 -8
  92. package/types/media/iframe/index.d.ts +8 -8
  93. package/types/media/iframe/props.d.ts +4 -4
  94. package/types/media/image/Image.vue.d.ts +8 -8
  95. package/types/media/image/index.d.ts +8 -8
  96. package/types/media/image/props.d.ts +4 -4
  97. package/types/setting/page-config/PageConfig.vue.d.ts +4 -4
  98. package/types/setting/page-config/index.d.ts +4 -4
  99. package/types/setting/page-config/props.d.ts +2 -2
  100. package/types/setting/provider-config/ProviderConfig.vue.d.ts +4 -4
  101. package/types/setting/provider-config/index.d.ts +4 -4
  102. package/types/setting/provider-config/props.d.ts +2 -2
  103. package/types/table/table/Table.vue.d.ts +12 -12
  104. package/types/table/table/index.d.ts +12 -12
  105. package/types/table/table/props.d.ts +6 -6
  106. package/types/text/counter/Counter.vue.d.ts +8 -8
  107. package/types/text/counter/index.d.ts +8 -8
  108. package/types/text/counter/props.d.ts +4 -4
  109. package/types/text/list/List.vue.d.ts +8 -8
  110. package/types/text/list/index.d.ts +8 -8
  111. package/types/text/list/props.d.ts +4 -4
  112. package/types/text/proportion/Proportion.vue.d.ts +8 -8
  113. package/types/text/proportion/index.d.ts +8 -8
  114. package/types/text/proportion/props.d.ts +4 -4
  115. package/types/text/rectangle/Rectangle.vue.d.ts +8 -8
  116. package/types/text/rectangle/index.d.ts +8 -8
  117. package/types/text/rectangle/props.d.ts +4 -4
  118. package/types/text/text/Text.vue.d.ts +8 -8
  119. package/types/text/text/index.d.ts +8 -8
  120. package/types/text/text/props.d.ts +4 -4
  121. package/types/text/time-display/TimeDisplay.vue.d.ts +8 -8
  122. package/types/text/time-display/index.d.ts +8 -8
  123. package/types/text/time-display/props.d.ts +4 -4
@@ -354,16 +354,16 @@ export declare const EcanRadar: import("../../utils/withInstall").SFCWithInstall
354
354
  default?: number;
355
355
  };
356
356
  dataType: {
357
- type?: import("vue").PropType<"indicator" | "request" | "component" | "static">;
358
- default?: "indicator" | "request" | "component" | "static";
357
+ type?: import("vue").PropType<"component" | "indicator" | "request" | "static">;
358
+ default?: "component" | "indicator" | "request" | "static";
359
359
  };
360
360
  scale?: {
361
361
  type?: import("vue").PropType<number>;
362
362
  default?: number;
363
363
  };
364
364
  requestParamsMode: {
365
- type?: import("vue").PropType<"2" | "1">;
366
- default?: "2" | "1";
365
+ type?: import("vue").PropType<"1" | "2">;
366
+ default?: "1" | "2";
367
367
  };
368
368
  customRequestParams: {
369
369
  type?: import("vue").PropType<string>;
@@ -855,16 +855,16 @@ export declare const EcanRadar: import("../../utils/withInstall").SFCWithInstall
855
855
  default?: number;
856
856
  };
857
857
  dataType: {
858
- type?: import("vue").PropType<"indicator" | "request" | "component" | "static">;
859
- default?: "indicator" | "request" | "component" | "static";
858
+ type?: import("vue").PropType<"component" | "indicator" | "request" | "static">;
859
+ default?: "component" | "indicator" | "request" | "static";
860
860
  };
861
861
  scale?: {
862
862
  type?: import("vue").PropType<number>;
863
863
  default?: number;
864
864
  };
865
865
  requestParamsMode: {
866
- type?: import("vue").PropType<"2" | "1">;
867
- default?: "2" | "1";
866
+ type?: import("vue").PropType<"1" | "2">;
867
+ default?: "1" | "2";
868
868
  };
869
869
  customRequestParams: {
870
870
  type?: import("vue").PropType<string>;
@@ -159,9 +159,9 @@ export declare const radarProps: {
159
159
  requestInterval: number;
160
160
  requestParams: import('../../utils/props').RequestParams;
161
161
  requestSort: number;
162
- dataType: "indicator" | "request" | "component" | "static";
162
+ dataType: "component" | "indicator" | "request" | "static";
163
163
  scale?: number;
164
- requestParamsMode: "2" | "1";
164
+ requestParamsMode: "1" | "2";
165
165
  customRequestParams: string;
166
166
  dataSetParam?: any;
167
167
  requestType?: any;
@@ -530,16 +530,16 @@ export declare const radarComponentProps: {
530
530
  default?: number;
531
531
  };
532
532
  dataType: {
533
- type?: import("vue").PropType<"indicator" | "request" | "component" | "static">;
534
- default?: "indicator" | "request" | "component" | "static";
533
+ type?: import("vue").PropType<"component" | "indicator" | "request" | "static">;
534
+ default?: "component" | "indicator" | "request" | "static";
535
535
  };
536
536
  scale?: {
537
537
  type?: import("vue").PropType<number>;
538
538
  default?: number;
539
539
  };
540
540
  requestParamsMode: {
541
- type?: import("vue").PropType<"2" | "1">;
542
- default?: "2" | "1";
541
+ type?: import("vue").PropType<"1" | "2">;
542
+ default?: "1" | "2";
543
543
  };
544
544
  customRequestParams: {
545
545
  type?: import("vue").PropType<string>;
@@ -349,6 +349,34 @@ declare const _sfc_main: import("vue").DefineComponent<{
349
349
  type?: import("vue").PropType<string>;
350
350
  default?: string;
351
351
  };
352
+ labelShow: {
353
+ type?: import("vue").PropType<boolean>;
354
+ default?: boolean;
355
+ };
356
+ labelFontSize: {
357
+ type?: import("vue").PropType<string>;
358
+ default?: string;
359
+ };
360
+ labelPosition: {
361
+ type?: import("vue").PropType<"top" | "left" | "right" | "bottom" | "inside">;
362
+ default?: "top" | "left" | "right" | "bottom" | "inside";
363
+ };
364
+ labelColor: {
365
+ type?: import("vue").PropType<string>;
366
+ default?: string;
367
+ };
368
+ labelWidth: {
369
+ type?: import("vue").PropType<number>;
370
+ default?: number;
371
+ };
372
+ labelOverflow: {
373
+ type?: import("vue").PropType<"none" | "truncate" | "break">;
374
+ default?: "none" | "truncate" | "break";
375
+ };
376
+ labelFormatter: {
377
+ type?: import("vue").PropType<string>;
378
+ default?: string;
379
+ };
352
380
  id: {
353
381
  type?: import("vue").PropType<string>;
354
382
  default?: string;
@@ -438,16 +466,16 @@ declare const _sfc_main: import("vue").DefineComponent<{
438
466
  default?: number;
439
467
  };
440
468
  dataType: {
441
- type?: import("vue").PropType<"indicator" | "request" | "component" | "static">;
442
- default?: "indicator" | "request" | "component" | "static";
469
+ type?: import("vue").PropType<"component" | "indicator" | "request" | "static">;
470
+ default?: "component" | "indicator" | "request" | "static";
443
471
  };
444
472
  scale?: {
445
473
  type?: import("vue").PropType<number>;
446
474
  default?: number;
447
475
  };
448
476
  requestParamsMode: {
449
- type?: import("vue").PropType<"2" | "1">;
450
- default?: "2" | "1";
477
+ type?: import("vue").PropType<"1" | "2">;
478
+ default?: "1" | "2";
451
479
  };
452
480
  customRequestParams: {
453
481
  type?: import("vue").PropType<string>;
@@ -655,6 +683,15 @@ declare const _sfc_main: import("vue").DefineComponent<{
655
683
  itemStyle: {
656
684
  color: string;
657
685
  };
686
+ label: {
687
+ show: boolean;
688
+ fontSize: string;
689
+ position: "top" | "left" | "right" | "bottom" | "inside";
690
+ color: string;
691
+ width: number;
692
+ overflow: "none" | "truncate" | "break";
693
+ formatter: (params: any) => string;
694
+ };
658
695
  markLine: {
659
696
  symbol: string[];
660
697
  data: any[];
@@ -1025,6 +1062,34 @@ declare const _sfc_main: import("vue").DefineComponent<{
1025
1062
  type?: import("vue").PropType<string>;
1026
1063
  default?: string;
1027
1064
  };
1065
+ labelShow: {
1066
+ type?: import("vue").PropType<boolean>;
1067
+ default?: boolean;
1068
+ };
1069
+ labelFontSize: {
1070
+ type?: import("vue").PropType<string>;
1071
+ default?: string;
1072
+ };
1073
+ labelPosition: {
1074
+ type?: import("vue").PropType<"top" | "left" | "right" | "bottom" | "inside">;
1075
+ default?: "top" | "left" | "right" | "bottom" | "inside";
1076
+ };
1077
+ labelColor: {
1078
+ type?: import("vue").PropType<string>;
1079
+ default?: string;
1080
+ };
1081
+ labelWidth: {
1082
+ type?: import("vue").PropType<number>;
1083
+ default?: number;
1084
+ };
1085
+ labelOverflow: {
1086
+ type?: import("vue").PropType<"none" | "truncate" | "break">;
1087
+ default?: "none" | "truncate" | "break";
1088
+ };
1089
+ labelFormatter: {
1090
+ type?: import("vue").PropType<string>;
1091
+ default?: string;
1092
+ };
1028
1093
  id: {
1029
1094
  type?: import("vue").PropType<string>;
1030
1095
  default?: string;
@@ -1114,16 +1179,16 @@ declare const _sfc_main: import("vue").DefineComponent<{
1114
1179
  default?: number;
1115
1180
  };
1116
1181
  dataType: {
1117
- type?: import("vue").PropType<"indicator" | "request" | "component" | "static">;
1118
- default?: "indicator" | "request" | "component" | "static";
1182
+ type?: import("vue").PropType<"component" | "indicator" | "request" | "static">;
1183
+ default?: "component" | "indicator" | "request" | "static";
1119
1184
  };
1120
1185
  scale?: {
1121
1186
  type?: import("vue").PropType<number>;
1122
1187
  default?: number;
1123
1188
  };
1124
1189
  requestParamsMode: {
1125
- type?: import("vue").PropType<"2" | "1">;
1126
- default?: "2" | "1";
1190
+ type?: import("vue").PropType<"1" | "2">;
1191
+ default?: "1" | "2";
1127
1192
  };
1128
1193
  customRequestParams: {
1129
1194
  type?: import("vue").PropType<string>;
@@ -349,6 +349,34 @@ export declare const EcanScatter: import('../../utils/withInstall').SFCWithInsta
349
349
  type?: import("vue").PropType<string>;
350
350
  default?: string;
351
351
  };
352
+ labelShow: {
353
+ type?: import("vue").PropType<boolean>;
354
+ default?: boolean;
355
+ };
356
+ labelFontSize: {
357
+ type?: import("vue").PropType<string>;
358
+ default?: string;
359
+ };
360
+ labelPosition: {
361
+ type?: import("vue").PropType<"top" | "left" | "right" | "bottom" | "inside">;
362
+ default?: "top" | "left" | "right" | "bottom" | "inside";
363
+ };
364
+ labelColor: {
365
+ type?: import("vue").PropType<string>;
366
+ default?: string;
367
+ };
368
+ labelWidth: {
369
+ type?: import("vue").PropType<number>;
370
+ default?: number;
371
+ };
372
+ labelOverflow: {
373
+ type?: import("vue").PropType<"none" | "truncate" | "break">;
374
+ default?: "none" | "truncate" | "break";
375
+ };
376
+ labelFormatter: {
377
+ type?: import("vue").PropType<string>;
378
+ default?: string;
379
+ };
352
380
  id: {
353
381
  type?: import("vue").PropType<string>;
354
382
  default?: string;
@@ -438,16 +466,16 @@ export declare const EcanScatter: import('../../utils/withInstall').SFCWithInsta
438
466
  default?: number;
439
467
  };
440
468
  dataType: {
441
- type?: import("vue").PropType<"indicator" | "request" | "component" | "static">;
442
- default?: "indicator" | "request" | "component" | "static";
469
+ type?: import("vue").PropType<"component" | "indicator" | "request" | "static">;
470
+ default?: "component" | "indicator" | "request" | "static";
443
471
  };
444
472
  scale?: {
445
473
  type?: import("vue").PropType<number>;
446
474
  default?: number;
447
475
  };
448
476
  requestParamsMode: {
449
- type?: import("vue").PropType<"2" | "1">;
450
- default?: "2" | "1";
477
+ type?: import("vue").PropType<"1" | "2">;
478
+ default?: "1" | "2";
451
479
  };
452
480
  customRequestParams: {
453
481
  type?: import("vue").PropType<string>;
@@ -655,6 +683,15 @@ export declare const EcanScatter: import('../../utils/withInstall').SFCWithInsta
655
683
  itemStyle: {
656
684
  color: string;
657
685
  };
686
+ label: {
687
+ show: boolean;
688
+ fontSize: string;
689
+ position: "top" | "left" | "right" | "bottom" | "inside";
690
+ color: string;
691
+ width: number;
692
+ overflow: "none" | "truncate" | "break";
693
+ formatter: (params: any) => string;
694
+ };
658
695
  markLine: {
659
696
  symbol: string[];
660
697
  data: any[];
@@ -1025,6 +1062,34 @@ export declare const EcanScatter: import('../../utils/withInstall').SFCWithInsta
1025
1062
  type?: import("vue").PropType<string>;
1026
1063
  default?: string;
1027
1064
  };
1065
+ labelShow: {
1066
+ type?: import("vue").PropType<boolean>;
1067
+ default?: boolean;
1068
+ };
1069
+ labelFontSize: {
1070
+ type?: import("vue").PropType<string>;
1071
+ default?: string;
1072
+ };
1073
+ labelPosition: {
1074
+ type?: import("vue").PropType<"top" | "left" | "right" | "bottom" | "inside">;
1075
+ default?: "top" | "left" | "right" | "bottom" | "inside";
1076
+ };
1077
+ labelColor: {
1078
+ type?: import("vue").PropType<string>;
1079
+ default?: string;
1080
+ };
1081
+ labelWidth: {
1082
+ type?: import("vue").PropType<number>;
1083
+ default?: number;
1084
+ };
1085
+ labelOverflow: {
1086
+ type?: import("vue").PropType<"none" | "truncate" | "break">;
1087
+ default?: "none" | "truncate" | "break";
1088
+ };
1089
+ labelFormatter: {
1090
+ type?: import("vue").PropType<string>;
1091
+ default?: string;
1092
+ };
1028
1093
  id: {
1029
1094
  type?: import("vue").PropType<string>;
1030
1095
  default?: string;
@@ -1114,16 +1179,16 @@ export declare const EcanScatter: import('../../utils/withInstall').SFCWithInsta
1114
1179
  default?: number;
1115
1180
  };
1116
1181
  dataType: {
1117
- type?: import("vue").PropType<"indicator" | "request" | "component" | "static">;
1118
- default?: "indicator" | "request" | "component" | "static";
1182
+ type?: import("vue").PropType<"component" | "indicator" | "request" | "static">;
1183
+ default?: "component" | "indicator" | "request" | "static";
1119
1184
  };
1120
1185
  scale?: {
1121
1186
  type?: import("vue").PropType<number>;
1122
1187
  default?: number;
1123
1188
  };
1124
1189
  requestParamsMode: {
1125
- type?: import("vue").PropType<"2" | "1">;
1126
- default?: "2" | "1";
1190
+ type?: import("vue").PropType<"1" | "2">;
1191
+ default?: "1" | "2";
1127
1192
  };
1128
1193
  customRequestParams: {
1129
1194
  type?: import("vue").PropType<string>;
@@ -93,6 +93,13 @@ export interface ScatterProps extends Props {
93
93
  tipText: string;
94
94
  tipTextColor: string;
95
95
  tipTextFontSize: string;
96
+ labelShow: boolean;
97
+ labelFontSize: string;
98
+ labelPosition: 'inside' | 'top' | 'bottom' | 'right' | 'left';
99
+ labelColor: string;
100
+ labelWidth: number;
101
+ labelOverflow: 'none' | 'truncate' | 'break';
102
+ labelFormatter: string;
96
103
  }
97
104
  export declare const scatterProps: ScatterProps;
98
105
  export declare const scatterComponentProps: {
@@ -446,6 +453,34 @@ export declare const scatterComponentProps: {
446
453
  type?: import("vue").PropType<string>;
447
454
  default?: string;
448
455
  };
456
+ labelShow: {
457
+ type?: import("vue").PropType<boolean>;
458
+ default?: boolean;
459
+ };
460
+ labelFontSize: {
461
+ type?: import("vue").PropType<string>;
462
+ default?: string;
463
+ };
464
+ labelPosition: {
465
+ type?: import("vue").PropType<"top" | "left" | "right" | "bottom" | "inside">;
466
+ default?: "top" | "left" | "right" | "bottom" | "inside";
467
+ };
468
+ labelColor: {
469
+ type?: import("vue").PropType<string>;
470
+ default?: string;
471
+ };
472
+ labelWidth: {
473
+ type?: import("vue").PropType<number>;
474
+ default?: number;
475
+ };
476
+ labelOverflow: {
477
+ type?: import("vue").PropType<"none" | "truncate" | "break">;
478
+ default?: "none" | "truncate" | "break";
479
+ };
480
+ labelFormatter: {
481
+ type?: import("vue").PropType<string>;
482
+ default?: string;
483
+ };
449
484
  id: {
450
485
  type?: import("vue").PropType<string>;
451
486
  default?: string;
@@ -535,16 +570,16 @@ export declare const scatterComponentProps: {
535
570
  default?: number;
536
571
  };
537
572
  dataType: {
538
- type?: import("vue").PropType<"indicator" | "request" | "component" | "static">;
539
- default?: "indicator" | "request" | "component" | "static";
573
+ type?: import("vue").PropType<"component" | "indicator" | "request" | "static">;
574
+ default?: "component" | "indicator" | "request" | "static";
540
575
  };
541
576
  scale?: {
542
577
  type?: import("vue").PropType<number>;
543
578
  default?: number;
544
579
  };
545
580
  requestParamsMode: {
546
- type?: import("vue").PropType<"2" | "1">;
547
- default?: "2" | "1";
581
+ type?: import("vue").PropType<"1" | "2">;
582
+ default?: "1" | "2";
548
583
  };
549
584
  customRequestParams: {
550
585
  type?: import("vue").PropType<string>;
@@ -0,0 +1 @@
1
+ export declare const formatIndicatorParams: (props: any, otherParams?: any) => any;