|
1
|
<template>
|
vben
authored
|
2
|
<PageWrapper title="UseForm操作示例">
|
|
3
|
<a-button class="mb-4" type="primary" @click="showDrawer"> 更改设置 </a-button>
|
|
4
5
|
<Drawer v-model:visible="visible" title="更改设置" placement="right">
|
|
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<BasicForm ref="settingFormRef" @register="registerSetting" @submit="handleSubmitSetting">
<template #other>
<Space>
<a-button
@click="() => withClose({ resetButtonOptions: { disabled: true, text: '重置New' } })"
>
修改重置按钮
</a-button>
<a-button
@click="() => withClose({ submitButtonOptions: { disabled: true, loading: true } })"
>
修改查询按钮
</a-button>
<a-button @click="handleLoad" class="mr-2"> 联动回显 </a-button>
</Space>
</template>
</BasicForm>
|
|
23
24
25
26
27
28
29
30
|
<template #extra>
<Space>
<a-button @click="resetSettings">重置设置</a-button>
<a-button type="primary" @click="onSettings">应用</a-button>
</Space>
</template>
</Drawer>
|
|
31
32
33
|
<CollapseContainer title="useForm示例">
<BasicForm @register="register" @submit="handleSubmit" />
</CollapseContainer>
|
vben
authored
|
34
|
</PageWrapper>
|
|
35
|
</template>
|
|
36
|
|
|
37
|
<script lang="ts">
|
|
38
39
|
import { defineComponent, ref } from 'vue';
import { Drawer, Space } from 'ant-design-vue';
|
|
40
|
import { BasicForm, FormSchema, useForm, type FormProps } from '/@/components/Form';
|
|
41
|
import { CollapseContainer } from '/@/components/Container';
|
vben
authored
|
42
|
import { PageWrapper } from '/@/components/Page';
|
Jobin
authored
|
43
|
import { areaRecord } from '/@/api/demo/cascader';
|
vben
authored
|
44
|
|
|
45
46
47
48
49
50
51
|
const sizeList = [
{ value: 'large', label: 'large' },
{ value: 'middle', label: 'middle' },
{ value: 'small', label: 'small' },
{ value: 'default', label: 'defualt' },
];
|
|
52
53
54
55
56
|
const schemas: FormSchema[] = [
{
field: 'field1',
component: 'Input',
label: '字段1',
|
|
57
|
colProps: { span: 8 },
|
|
58
59
60
61
62
63
64
65
66
67
68
|
componentProps: {
placeholder: '自定义placeholder',
onChange: (e: any) => {
console.log(e);
},
},
},
{
field: 'field2',
component: 'Input',
label: '字段2',
|
|
69
|
colProps: { span: 8 },
|
|
70
71
72
73
74
|
},
{
field: 'field3',
component: 'DatePicker',
label: '字段3',
|
|
75
|
colProps: { span: 8 },
|
|
76
77
|
},
{
|
Vben
authored
|
78
79
80
|
field: 'fieldTime',
component: 'RangePicker',
label: '时间字段',
|
|
81
|
colProps: { span: 8 },
|
Vben
authored
|
82
83
|
},
{
|
|
84
85
86
|
field: 'field4',
component: 'Select',
label: '字段4',
|
|
87
|
colProps: { span: 8 },
|
|
88
89
|
componentProps: {
options: [
|
|
90
91
|
{ label: '选项1', value: '1', key: '1' },
{ label: '选项2', value: '2', key: '2' },
|
|
92
93
94
95
96
97
98
99
100
101
102
103
|
],
},
},
{
field: 'field5',
component: 'CheckboxGroup',
label: '字段5',
colProps: {
span: 8,
},
componentProps: {
options: [
|
|
104
105
|
{ label: '选项1', value: '1' },
{ label: '选项2', value: '2' },
|
|
106
107
108
109
110
111
112
|
],
},
},
{
field: 'field7',
component: 'RadioGroup',
label: '字段7',
|
|
113
|
colProps: { span: 8 },
|
|
114
115
|
componentProps: {
options: [
|
|
116
117
|
{ label: '选项1', value: '1' },
{ label: '选项2', value: '2' },
|
|
118
119
120
|
],
},
},
|
Jobin
authored
|
121
122
123
124
|
{
field: 'field8',
component: 'ApiCascader',
label: '联动',
|
|
125
|
colProps: { span: 8 },
|
Jobin
authored
|
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
|
componentProps: {
api: areaRecord,
apiParamKey: 'parentCode',
dataField: 'data',
labelField: 'name',
valueField: 'code',
initFetchParams: {
parentCode: '',
},
isLeaf: (record) => {
return !(record.levelType < 3);
},
},
},
{
field: 'field9',
component: 'ApiCascader',
label: '联动回显',
|
|
144
|
colProps: { span: 8 },
|
Jobin
authored
|
145
146
147
148
149
150
151
152
153
154
155
156
157
158
|
componentProps: {
api: areaRecord,
apiParamKey: 'parentCode',
dataField: 'data',
labelField: 'name',
valueField: 'code',
initFetchParams: {
parentCode: '',
},
isLeaf: (record) => {
return !(record.levelType < 3);
},
},
},
|
|
159
160
|
];
|
|
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
|
const formSchemas: FormSchema[] = [
{
field: '',
component: 'Divider',
label: '基础属性',
colProps: { span: 24 },
componentProps: {
orientation: 'center',
},
},
{
field: 'labelWidth',
defaultValue: 120,
component: 'InputNumber',
label: 'labelWidth',
colProps: { span: 24 },
componentProps: {
size: 'small',
},
},
{
field: 'size',
defaultValue: 'default',
component: 'Select',
label: 'size',
colProps: { span: 24 },
componentProps: {
options: sizeList,
size: 'small',
},
},
{
field: 'disabled',
defaultValue: false,
component: 'Switch',
label: 'disabled',
colProps: { span: 24 },
componentProps: {
size: 'small',
},
},
{
field: 'compact',
defaultValue: false,
component: 'Switch',
label: 'compact',
colProps: { span: 24 },
componentProps: {
size: 'small',
},
},
{
field: '',
component: 'Divider',
label: '网格布局',
colProps: { span: 24 },
componentProps: {
orientation: 'center',
},
},
{
field: 'actionColOptions.span',
component: 'Slider',
defaultValue: 24,
label: 'span',
colProps: { span: 24 },
componentProps: {
min: 1,
max: 24,
},
},
{
field: '',
component: 'Divider',
label: '操作按钮',
colProps: { span: 24 },
componentProps: {
orientation: 'center',
},
},
{
field: 'showActionButtonGroup',
defaultValue: true,
component: 'Switch',
label: '操作按钮',
colProps: { span: 24 },
componentProps: ({ formActionType }) => {
return {
size: 'small',
onChange: async (val: boolean) => {
formActionType.updateSchema([
{ field: 'showResetButton', componentProps: { disabled: !val } },
{
field: 'showSubmitButton',
componentProps: { disabled: !val },
},
]);
},
};
},
},
{
field: 'showResetButton',
defaultValue: true,
component: 'Switch',
label: '重置按钮',
colProps: { span: 24 },
componentProps: {
size: 'small',
},
},
{
field: 'showSubmitButton',
defaultValue: true,
component: 'Switch',
label: '提交按钮',
colProps: { span: 24 },
componentProps: {
size: 'small',
},
},
|
|
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
|
{
field: '',
component: 'Divider',
label: '其他事件',
colProps: { span: 24 },
componentProps: {
orientation: 'center',
},
},
{
field: 'other',
component: 'Input',
label: '',
colProps: { span: 24 },
colSlot: 'other',
},
|
|
298
299
|
];
|
|
300
|
export default defineComponent({
|
|
301
302
303
304
305
306
307
|
components: {
BasicForm,
CollapseContainer,
PageWrapper,
Drawer,
Space,
},
|
|
308
|
setup() {
|
|
309
310
311
312
313
314
315
316
317
318
319
|
const visible = ref<boolean>(false);
const settingFormRef = ref();
const [registerSetting] = useForm({
labelWidth: 80,
schemas: formSchemas,
compact: true,
actionColOptions: { span: 24 },
showActionButtonGroup: false,
});
const resetSettings = async () => {
|
|
320
321
322
|
setProps({ resetButtonOptions: { disabled: false, text: '重置' } });
setProps({ submitButtonOptions: { disabled: false, loading: false } });
await setFieldsValue({ field9: [] });
|
|
323
324
325
326
327
328
329
|
await settingFormRef.value?.resetFields();
};
const handleSubmitSetting = async (values: Recordable) => {
await setProps(values);
visible.value = false;
};
|
vben
authored
|
330
|
|
Jobin
authored
|
331
|
const [register, { setProps, setFieldsValue, updateSchema }] = useForm({
|
|
332
333
|
labelWidth: 120,
schemas,
|
|
334
|
actionColOptions: { span: 24 },
|
Vben
authored
|
335
|
fieldMapToTime: [['fieldTime', ['startTime', 'endTime'], 'YYYY-MM']],
|
|
336
|
});
|
Jobin
authored
|
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
|
async function handleLoad() {
const promiseFn = function () {
return new Promise((resolve) => {
setTimeout(() => {
resolve({
field9: ['430000', '430100', '430102'],
province: '湖南省',
city: '长沙市',
district: '岳麓区',
});
}, 1000);
});
};
const item = await promiseFn();
const { field9, province, city, district } = item as any;
await updateSchema({
field: 'field9',
componentProps: {
displayRenderArray: [province, city, district],
},
});
|
|
361
|
await setFieldsValue({ field9 });
|
Jobin
authored
|
362
363
|
}
|
|
364
365
366
367
368
369
370
371
|
const showDrawer = () => {
visible.value = true;
};
const onSettings = () => {
settingFormRef.value?.submit();
};
|
|
372
373
374
375
376
|
const withClose = (formProps: Partial<FormProps>) => {
setProps(formProps);
visible.value = false;
};
|
|
377
378
379
|
return {
register,
schemas,
|
vben
authored
|
380
|
handleSubmit: (values: Recordable) => {
|
|
381
|
console.log(values);
|
|
382
383
|
},
setProps,
|
Jobin
authored
|
384
|
handleLoad,
|
|
385
386
387
|
visible,
showDrawer,
settingFormRef,
|
|
388
|
withClose,
|
|
389
390
391
392
|
onSettings,
resetSettings,
registerSetting,
handleSubmitSetting,
|
|
393
394
395
396
|
};
},
});
</script>
|