@antsoo-lib/core 3.0.0 → 3.0.1

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 (43) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/dist/core.css +1 -1
  3. package/dist/index.cjs +1 -1
  4. package/dist/index.js +6 -5
  5. package/dist/types/BaseSearch/index.d.ts +1 -1
  6. package/dist/types/BaseTable/index.d.ts +5 -475
  7. package/dist/types/Form/CoreForm.d.ts +82 -0
  8. package/dist/types/SSelectPage/index.d.ts +102 -0
  9. package/package.json +3 -3
  10. package/src/BaseSearch/index.vue +371 -371
  11. package/src/BaseTable/index.vue +910 -910
  12. package/src/Form/CoreForm.vue +782 -782
  13. package/src/Form/types.ts +86 -86
  14. package/src/SSelectPage/index.vue +607 -607
  15. package/src/index.ts +17 -17
  16. package/src/render/AreaCascader.tsx +64 -64
  17. package/src/render/AutoComplete.tsx +101 -101
  18. package/src/render/Button.tsx +62 -62
  19. package/src/render/Cascader.tsx +45 -45
  20. package/src/render/Checkbox.tsx +65 -65
  21. package/src/render/CheckboxGroup.tsx +57 -57
  22. package/src/render/Custom.tsx +19 -19
  23. package/src/render/DatePicker.tsx +83 -83
  24. package/src/render/Input.tsx +140 -140
  25. package/src/render/InputGroup.tsx +115 -115
  26. package/src/render/InputNumber.tsx +205 -205
  27. package/src/render/InputPassword.tsx +81 -81
  28. package/src/render/InputRange.tsx +154 -154
  29. package/src/render/RadioGroup.tsx +63 -63
  30. package/src/render/Select.tsx +96 -96
  31. package/src/render/SselectPage.tsx +107 -107
  32. package/src/render/Switch.tsx +60 -60
  33. package/src/render/Tree.tsx +136 -136
  34. package/src/render/TreeSelect.tsx +81 -81
  35. package/src/render/Upload.tsx +91 -91
  36. package/src/render/helper.tsx +221 -221
  37. package/src/render/index.ts +108 -108
  38. package/src/render/registry.ts +20 -20
  39. package/src/render/state.ts +37 -37
  40. package/src/render/types.ts +567 -567
  41. package/src/utils/attrMapping.ts +106 -106
  42. package/vite.config.ts +61 -61
  43. package/.turbo/turbo-build.log +0 -40
@@ -79,242 +79,7 @@ declare function __VLS_template(): {
79
79
  slots: any;
80
80
  refs: {
81
81
  basetable: unknown;
82
- paginationRef: import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('vue').ExtractPropTypes<{
83
- total: NumberConstructor;
84
- defaultCurrent: NumberConstructor;
85
- disabled: {
86
- type: BooleanConstructor;
87
- default: boolean;
88
- };
89
- current: NumberConstructor;
90
- defaultPageSize: NumberConstructor;
91
- pageSize: NumberConstructor;
92
- hideOnSinglePage: {
93
- type: BooleanConstructor;
94
- default: boolean;
95
- };
96
- showSizeChanger: {
97
- type: BooleanConstructor;
98
- default: boolean;
99
- };
100
- pageSizeOptions: {
101
- type: import('vue').PropType<(string | number)[]>;
102
- default: (string | number)[];
103
- };
104
- buildOptionText: {
105
- type: import('vue').PropType<(opt: {
106
- value: any;
107
- }) => any>;
108
- default: (opt: {
109
- value: any;
110
- }) => any;
111
- };
112
- showQuickJumper: {
113
- type: import('vue').PropType<boolean | {
114
- goButton?: any;
115
- }>;
116
- default: boolean | {
117
- goButton?: any;
118
- };
119
- };
120
- showTotal: {
121
- type: import('vue').PropType<(total: number, range: [number, number]) => any>;
122
- default: (total: number, range: [number, number]) => any;
123
- };
124
- size: {
125
- type: import('vue').PropType<"small" | "default">;
126
- default: "small" | "default";
127
- };
128
- simple: {
129
- type: BooleanConstructor;
130
- default: boolean;
131
- };
132
- locale: ObjectConstructor;
133
- prefixCls: StringConstructor;
134
- selectPrefixCls: StringConstructor;
135
- totalBoundaryShowSizeChanger: NumberConstructor;
136
- selectComponentClass: StringConstructor;
137
- itemRender: {
138
- type: import('vue').PropType<(opt: {
139
- page: number;
140
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
141
- originalElement: any;
142
- }) => any>;
143
- default: (opt: {
144
- page: number;
145
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
146
- originalElement: any;
147
- }) => any;
148
- };
149
- role: StringConstructor;
150
- responsive: BooleanConstructor;
151
- showLessItems: {
152
- type: BooleanConstructor;
153
- default: boolean;
154
- };
155
- onChange: {
156
- type: import('vue').PropType<(page: number, pageSize: number) => void>;
157
- default: (page: number, pageSize: number) => void;
158
- };
159
- onShowSizeChange: {
160
- type: import('vue').PropType<(current: number, size: number) => void>;
161
- default: (current: number, size: number) => void;
162
- };
163
- 'onUpdate:current': {
164
- type: import('vue').PropType<(current: number) => void>;
165
- default: (current: number) => void;
166
- };
167
- 'onUpdate:pageSize': {
168
- type: import('vue').PropType<(size: number) => void>;
169
- default: (size: number) => void;
170
- };
171
- }>> & Readonly<{}>, () => import('../../packages/components/dist/es/_util/type').VueNode, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {
172
- size: "small" | "default";
173
- disabled: boolean;
174
- onChange: (page: number, pageSize: number) => void;
175
- buildOptionText: (opt: {
176
- value: any;
177
- }) => any;
178
- pageSizeOptions: (string | number)[];
179
- itemRender: (opt: {
180
- page: number;
181
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
182
- originalElement: any;
183
- }) => any;
184
- showTotal: (total: number, range: [number, number]) => any;
185
- hideOnSinglePage: boolean;
186
- showSizeChanger: boolean;
187
- showLessItems: boolean;
188
- showQuickJumper: boolean | {
189
- goButton?: any;
190
- };
191
- simple: boolean;
192
- responsive: boolean;
193
- onShowSizeChange: (current: number, size: number) => void;
194
- 'onUpdate:current': (current: number) => void;
195
- 'onUpdate:pageSize': (size: number) => void;
196
- }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {}, any, import('vue').ComponentProvideOptions, {
197
- P: {};
198
- B: {};
199
- D: {};
200
- C: {};
201
- M: {};
202
- Defaults: {};
203
- }, Readonly<import('vue').ExtractPropTypes<{
204
- total: NumberConstructor;
205
- defaultCurrent: NumberConstructor;
206
- disabled: {
207
- type: BooleanConstructor;
208
- default: boolean;
209
- };
210
- current: NumberConstructor;
211
- defaultPageSize: NumberConstructor;
212
- pageSize: NumberConstructor;
213
- hideOnSinglePage: {
214
- type: BooleanConstructor;
215
- default: boolean;
216
- };
217
- showSizeChanger: {
218
- type: BooleanConstructor;
219
- default: boolean;
220
- };
221
- pageSizeOptions: {
222
- type: import('vue').PropType<(string | number)[]>;
223
- default: (string | number)[];
224
- };
225
- buildOptionText: {
226
- type: import('vue').PropType<(opt: {
227
- value: any;
228
- }) => any>;
229
- default: (opt: {
230
- value: any;
231
- }) => any;
232
- };
233
- showQuickJumper: {
234
- type: import('vue').PropType<boolean | {
235
- goButton?: any;
236
- }>;
237
- default: boolean | {
238
- goButton?: any;
239
- };
240
- };
241
- showTotal: {
242
- type: import('vue').PropType<(total: number, range: [number, number]) => any>;
243
- default: (total: number, range: [number, number]) => any;
244
- };
245
- size: {
246
- type: import('vue').PropType<"small" | "default">;
247
- default: "small" | "default";
248
- };
249
- simple: {
250
- type: BooleanConstructor;
251
- default: boolean;
252
- };
253
- locale: ObjectConstructor;
254
- prefixCls: StringConstructor;
255
- selectPrefixCls: StringConstructor;
256
- totalBoundaryShowSizeChanger: NumberConstructor;
257
- selectComponentClass: StringConstructor;
258
- itemRender: {
259
- type: import('vue').PropType<(opt: {
260
- page: number;
261
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
262
- originalElement: any;
263
- }) => any>;
264
- default: (opt: {
265
- page: number;
266
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
267
- originalElement: any;
268
- }) => any;
269
- };
270
- role: StringConstructor;
271
- responsive: BooleanConstructor;
272
- showLessItems: {
273
- type: BooleanConstructor;
274
- default: boolean;
275
- };
276
- onChange: {
277
- type: import('vue').PropType<(page: number, pageSize: number) => void>;
278
- default: (page: number, pageSize: number) => void;
279
- };
280
- onShowSizeChange: {
281
- type: import('vue').PropType<(current: number, size: number) => void>;
282
- default: (current: number, size: number) => void;
283
- };
284
- 'onUpdate:current': {
285
- type: import('vue').PropType<(current: number) => void>;
286
- default: (current: number) => void;
287
- };
288
- 'onUpdate:pageSize': {
289
- type: import('vue').PropType<(size: number) => void>;
290
- default: (size: number) => void;
291
- };
292
- }>> & Readonly<{}>, () => import('../../packages/components/dist/es/_util/type').VueNode, {}, {}, {}, {
293
- size: "small" | "default";
294
- disabled: boolean;
295
- onChange: (page: number, pageSize: number) => void;
296
- buildOptionText: (opt: {
297
- value: any;
298
- }) => any;
299
- pageSizeOptions: (string | number)[];
300
- itemRender: (opt: {
301
- page: number;
302
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
303
- originalElement: any;
304
- }) => any;
305
- showTotal: (total: number, range: [number, number]) => any;
306
- hideOnSinglePage: boolean;
307
- showSizeChanger: boolean;
308
- showLessItems: boolean;
309
- showQuickJumper: boolean | {
310
- goButton?: any;
311
- };
312
- simple: boolean;
313
- responsive: boolean;
314
- onShowSizeChange: (current: number, size: number) => void;
315
- 'onUpdate:current': (current: number) => void;
316
- 'onUpdate:pageSize': (size: number) => void;
317
- }> | null;
82
+ paginationRef: any;
318
83
  };
319
84
  rootEl: any;
320
85
  };
@@ -404,16 +169,16 @@ declare const __VLS_component: import('vue').DefineComponent<Props, {
404
169
  }) => any) | undefined;
405
170
  onSortChange?: ((params: VxeGridDefines.SortChangeEventParams<any>) => any) | undefined;
406
171
  }>, {
407
- loading: boolean;
408
172
  checkbox: boolean;
409
173
  radio: boolean;
410
- height: string;
411
- tree: boolean;
412
174
  drag: boolean;
175
+ height: string;
176
+ loading: boolean;
413
177
  pager: boolean;
414
178
  seq: boolean;
415
179
  showFooter: boolean;
416
180
  total: number;
181
+ tree: boolean;
417
182
  lToolBarCount: number | (() => number);
418
183
  rToolBarCount: number | (() => number);
419
184
  permissions: string[];
@@ -424,242 +189,7 @@ declare const __VLS_component: import('vue').DefineComponent<Props, {
424
189
  hoverColor: string | null;
425
190
  }, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
426
191
  basetable: unknown;
427
- paginationRef: import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('vue').ExtractPropTypes<{
428
- total: NumberConstructor;
429
- defaultCurrent: NumberConstructor;
430
- disabled: {
431
- type: BooleanConstructor;
432
- default: boolean;
433
- };
434
- current: NumberConstructor;
435
- defaultPageSize: NumberConstructor;
436
- pageSize: NumberConstructor;
437
- hideOnSinglePage: {
438
- type: BooleanConstructor;
439
- default: boolean;
440
- };
441
- showSizeChanger: {
442
- type: BooleanConstructor;
443
- default: boolean;
444
- };
445
- pageSizeOptions: {
446
- type: import('vue').PropType<(string | number)[]>;
447
- default: (string | number)[];
448
- };
449
- buildOptionText: {
450
- type: import('vue').PropType<(opt: {
451
- value: any;
452
- }) => any>;
453
- default: (opt: {
454
- value: any;
455
- }) => any;
456
- };
457
- showQuickJumper: {
458
- type: import('vue').PropType<boolean | {
459
- goButton?: any;
460
- }>;
461
- default: boolean | {
462
- goButton?: any;
463
- };
464
- };
465
- showTotal: {
466
- type: import('vue').PropType<(total: number, range: [number, number]) => any>;
467
- default: (total: number, range: [number, number]) => any;
468
- };
469
- size: {
470
- type: import('vue').PropType<"small" | "default">;
471
- default: "small" | "default";
472
- };
473
- simple: {
474
- type: BooleanConstructor;
475
- default: boolean;
476
- };
477
- locale: ObjectConstructor;
478
- prefixCls: StringConstructor;
479
- selectPrefixCls: StringConstructor;
480
- totalBoundaryShowSizeChanger: NumberConstructor;
481
- selectComponentClass: StringConstructor;
482
- itemRender: {
483
- type: import('vue').PropType<(opt: {
484
- page: number;
485
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
486
- originalElement: any;
487
- }) => any>;
488
- default: (opt: {
489
- page: number;
490
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
491
- originalElement: any;
492
- }) => any;
493
- };
494
- role: StringConstructor;
495
- responsive: BooleanConstructor;
496
- showLessItems: {
497
- type: BooleanConstructor;
498
- default: boolean;
499
- };
500
- onChange: {
501
- type: import('vue').PropType<(page: number, pageSize: number) => void>;
502
- default: (page: number, pageSize: number) => void;
503
- };
504
- onShowSizeChange: {
505
- type: import('vue').PropType<(current: number, size: number) => void>;
506
- default: (current: number, size: number) => void;
507
- };
508
- 'onUpdate:current': {
509
- type: import('vue').PropType<(current: number) => void>;
510
- default: (current: number) => void;
511
- };
512
- 'onUpdate:pageSize': {
513
- type: import('vue').PropType<(size: number) => void>;
514
- default: (size: number) => void;
515
- };
516
- }>> & Readonly<{}>, () => import('../../packages/components/dist/es/_util/type').VueNode, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {
517
- size: "small" | "default";
518
- disabled: boolean;
519
- onChange: (page: number, pageSize: number) => void;
520
- buildOptionText: (opt: {
521
- value: any;
522
- }) => any;
523
- pageSizeOptions: (string | number)[];
524
- itemRender: (opt: {
525
- page: number;
526
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
527
- originalElement: any;
528
- }) => any;
529
- showTotal: (total: number, range: [number, number]) => any;
530
- hideOnSinglePage: boolean;
531
- showSizeChanger: boolean;
532
- showLessItems: boolean;
533
- showQuickJumper: boolean | {
534
- goButton?: any;
535
- };
536
- simple: boolean;
537
- responsive: boolean;
538
- onShowSizeChange: (current: number, size: number) => void;
539
- 'onUpdate:current': (current: number) => void;
540
- 'onUpdate:pageSize': (size: number) => void;
541
- }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {}, any, import('vue').ComponentProvideOptions, {
542
- P: {};
543
- B: {};
544
- D: {};
545
- C: {};
546
- M: {};
547
- Defaults: {};
548
- }, Readonly<import('vue').ExtractPropTypes<{
549
- total: NumberConstructor;
550
- defaultCurrent: NumberConstructor;
551
- disabled: {
552
- type: BooleanConstructor;
553
- default: boolean;
554
- };
555
- current: NumberConstructor;
556
- defaultPageSize: NumberConstructor;
557
- pageSize: NumberConstructor;
558
- hideOnSinglePage: {
559
- type: BooleanConstructor;
560
- default: boolean;
561
- };
562
- showSizeChanger: {
563
- type: BooleanConstructor;
564
- default: boolean;
565
- };
566
- pageSizeOptions: {
567
- type: import('vue').PropType<(string | number)[]>;
568
- default: (string | number)[];
569
- };
570
- buildOptionText: {
571
- type: import('vue').PropType<(opt: {
572
- value: any;
573
- }) => any>;
574
- default: (opt: {
575
- value: any;
576
- }) => any;
577
- };
578
- showQuickJumper: {
579
- type: import('vue').PropType<boolean | {
580
- goButton?: any;
581
- }>;
582
- default: boolean | {
583
- goButton?: any;
584
- };
585
- };
586
- showTotal: {
587
- type: import('vue').PropType<(total: number, range: [number, number]) => any>;
588
- default: (total: number, range: [number, number]) => any;
589
- };
590
- size: {
591
- type: import('vue').PropType<"small" | "default">;
592
- default: "small" | "default";
593
- };
594
- simple: {
595
- type: BooleanConstructor;
596
- default: boolean;
597
- };
598
- locale: ObjectConstructor;
599
- prefixCls: StringConstructor;
600
- selectPrefixCls: StringConstructor;
601
- totalBoundaryShowSizeChanger: NumberConstructor;
602
- selectComponentClass: StringConstructor;
603
- itemRender: {
604
- type: import('vue').PropType<(opt: {
605
- page: number;
606
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
607
- originalElement: any;
608
- }) => any>;
609
- default: (opt: {
610
- page: number;
611
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
612
- originalElement: any;
613
- }) => any;
614
- };
615
- role: StringConstructor;
616
- responsive: BooleanConstructor;
617
- showLessItems: {
618
- type: BooleanConstructor;
619
- default: boolean;
620
- };
621
- onChange: {
622
- type: import('vue').PropType<(page: number, pageSize: number) => void>;
623
- default: (page: number, pageSize: number) => void;
624
- };
625
- onShowSizeChange: {
626
- type: import('vue').PropType<(current: number, size: number) => void>;
627
- default: (current: number, size: number) => void;
628
- };
629
- 'onUpdate:current': {
630
- type: import('vue').PropType<(current: number) => void>;
631
- default: (current: number) => void;
632
- };
633
- 'onUpdate:pageSize': {
634
- type: import('vue').PropType<(size: number) => void>;
635
- default: (size: number) => void;
636
- };
637
- }>> & Readonly<{}>, () => import('../../packages/components/dist/es/_util/type').VueNode, {}, {}, {}, {
638
- size: "small" | "default";
639
- disabled: boolean;
640
- onChange: (page: number, pageSize: number) => void;
641
- buildOptionText: (opt: {
642
- value: any;
643
- }) => any;
644
- pageSizeOptions: (string | number)[];
645
- itemRender: (opt: {
646
- page: number;
647
- type: "page" | "prev" | "next" | "jump-prev" | "jump-next";
648
- originalElement: any;
649
- }) => any;
650
- showTotal: (total: number, range: [number, number]) => any;
651
- hideOnSinglePage: boolean;
652
- showSizeChanger: boolean;
653
- showLessItems: boolean;
654
- showQuickJumper: boolean | {
655
- goButton?: any;
656
- };
657
- simple: boolean;
658
- responsive: boolean;
659
- onShowSizeChange: (current: number, size: number) => void;
660
- 'onUpdate:current': (current: number) => void;
661
- 'onUpdate:pageSize': (size: number) => void;
662
- }> | null;
192
+ paginationRef: any;
663
193
  }, any>;
664
194
  declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
665
195
  export default _default;
@@ -0,0 +1,82 @@
1
+ import { AnyObject } from '../../packages/shared/index.ts';
2
+ import { BaseFormProps, FormField } from './types';
3
+ interface GetAccessParams {
4
+ operation: 'get';
5
+ keys: string[] | string;
6
+ }
7
+ interface SetAccessParams {
8
+ operation: 'set';
9
+ keys: string[] | string;
10
+ values: AnyObject;
11
+ }
12
+ type AccessFormFieldsParams = GetAccessParams | SetAccessParams;
13
+ type AccessFormFieldsResult = {
14
+ success: true;
15
+ operation: 'get';
16
+ keys: string[];
17
+ data: AnyObject;
18
+ missingKeys?: string[];
19
+ } | {
20
+ success: true;
21
+ operation: 'set';
22
+ keys: string[];
23
+ applied: string[];
24
+ skipped: string[];
25
+ } | {
26
+ success: false;
27
+ message: string;
28
+ };
29
+ declare function accessFormFields(params: AccessFormFieldsParams): AccessFormFieldsResult;
30
+ declare function __VLS_template(): {
31
+ attrs: Partial<{}>;
32
+ slots: {
33
+ search?(_: {}): any;
34
+ actions?(_: {}): any;
35
+ };
36
+ refs: {
37
+ formRef: any;
38
+ };
39
+ rootEl: HTMLDivElement;
40
+ };
41
+ type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
42
+ declare const __VLS_component: import('vue').DefineComponent<BaseFormProps, {
43
+ getFormValue: (key?: string[]) => AnyObject;
44
+ setFormValue: (values: AnyObject, key?: string[]) => void;
45
+ accessFormFields: typeof accessFormFields;
46
+ resetFormValue: (key?: string[]) => void;
47
+ validateForm: () => Promise<{
48
+ valid: boolean;
49
+ errors?: any;
50
+ }>;
51
+ validateFields: (fieldKey: string[]) => Promise<{
52
+ valid: boolean;
53
+ errors?: any;
54
+ }>;
55
+ clearValidate: (fieldKeys?: string[]) => void;
56
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
57
+ change: (value: AnyObject) => any;
58
+ "update:value": (value: AnyObject) => any;
59
+ }, string, import('vue').PublicProps, Readonly<BaseFormProps> & Readonly<{
60
+ onChange?: ((value: AnyObject) => any) | undefined;
61
+ "onUpdate:value"?: ((value: AnyObject) => any) | undefined;
62
+ }>, {
63
+ value: AnyObject;
64
+ disabled: boolean;
65
+ fields: FormField[];
66
+ labelWidth: number;
67
+ labelPosition: "horizontal" | "vertical";
68
+ labelAlign: "left" | "right";
69
+ inlineActions: boolean;
70
+ actionsSpan: number;
71
+ colon: boolean;
72
+ gutter: number | [number, number];
73
+ }, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
74
+ formRef: any;
75
+ }, HTMLDivElement>;
76
+ declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
77
+ export default _default;
78
+ type __VLS_WithTemplateSlots<T, S> = T & {
79
+ new (): {
80
+ $slots: S;
81
+ };
82
+ };
@@ -0,0 +1,102 @@
1
+ import { SelectProps } from '../../packages/components/index.ts';
2
+ import { AnyObject } from '../../packages/shared/index.ts';
3
+ interface RequestConfig {
4
+ method?: 'GET' | 'POST';
5
+ url: string;
6
+ headers?: Record<string, string>;
7
+ params?: AnyObject;
8
+ data?: AnyObject;
9
+ }
10
+ type Requester = (config: Required<Pick<RequestConfig, 'method' | 'url'>> & RequestConfig) => Promise<any>;
11
+ interface ApiConfig extends RequestConfig {
12
+ request?: Requester;
13
+ }
14
+ interface DataMapping {
15
+ list?: string;
16
+ total?: string;
17
+ value?: string;
18
+ label?: string;
19
+ }
20
+ interface PaginationConfig {
21
+ pageField?: string;
22
+ pageSizeField?: string;
23
+ searchField?: string;
24
+ searchContains?: string;
25
+ }
26
+ interface Props extends /* @vue-ignore */ Omit<SelectProps, 'options' | 'loading'> {
27
+ placeholder?: string;
28
+ allowClear?: boolean;
29
+ showSearch?: boolean;
30
+ disabled?: boolean;
31
+ maxTagCount?: 'responsive' | number;
32
+ size?: 'large' | 'middle' | 'small';
33
+ mode?: 'multiple' | 'tags';
34
+ value?: any;
35
+ api: ApiConfig;
36
+ dataMapping?: DataMapping;
37
+ pagination?: boolean;
38
+ paginationConfig?: PaginationConfig;
39
+ pageSize?: number;
40
+ searchDelay?: number;
41
+ extraParams?: AnyObject;
42
+ params?: AnyObject;
43
+ transformData?: (data: any) => any;
44
+ autoLoad?: boolean;
45
+ attr?: Record<string, string>;
46
+ }
47
+ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToOption<Props>, {
48
+ pagination: boolean;
49
+ pageSize: number;
50
+ searchDelay: number;
51
+ extraParams: () => {};
52
+ params: () => {};
53
+ autoLoad: boolean;
54
+ allowClear: boolean;
55
+ showSearch: boolean;
56
+ placeholder: string;
57
+ maxTagCount: number;
58
+ }>>, {
59
+ reload: () => void;
60
+ fetchData: () => Promise<void> | void;
61
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
62
+ search: (value: string) => any;
63
+ clear: () => any;
64
+ change: (value: any, option: any, allOptions: any) => any;
65
+ "update:value": (value: any) => any;
66
+ }, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToOption<Props>, {
67
+ pagination: boolean;
68
+ pageSize: number;
69
+ searchDelay: number;
70
+ extraParams: () => {};
71
+ params: () => {};
72
+ autoLoad: boolean;
73
+ allowClear: boolean;
74
+ showSearch: boolean;
75
+ placeholder: string;
76
+ maxTagCount: number;
77
+ }>>> & Readonly<{
78
+ onSearch?: ((value: string) => any) | undefined;
79
+ onClear?: (() => any) | undefined;
80
+ onChange?: ((value: any, option: any, allOptions: any) => any) | undefined;
81
+ "onUpdate:value"?: ((value: any) => any) | undefined;
82
+ }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
83
+ selectRef: any;
84
+ }, any>;
85
+ export default _default;
86
+ type __VLS_WithDefaults<P, D> = {
87
+ [K in keyof Pick<P, keyof P>]: K extends keyof D ? __VLS_PrettifyLocal<P[K] & {
88
+ default: D[K];
89
+ }> : P[K];
90
+ };
91
+ type __VLS_NonUndefinedable<T> = T extends undefined ? never : T;
92
+ type __VLS_TypePropsToOption<T> = {
93
+ [K in keyof T]-?: {} extends Pick<T, K> ? {
94
+ type: import('vue').PropType<__VLS_NonUndefinedable<T[K]>>;
95
+ } : {
96
+ type: import('vue').PropType<T[K]>;
97
+ required: true;
98
+ };
99
+ };
100
+ type __VLS_PrettifyLocal<T> = {
101
+ [K in keyof T]: T[K];
102
+ } & {};