Blame view

src/views/demo/form/UseForm.vue 9.56 KB
陈文彬 authored
1
<template>
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>
陈文彬 authored
31
32
33
    <CollapseContainer title="useForm示例">
      <BasicForm @register="register" @submit="handleSubmit" />
    </CollapseContainer>
34
  </PageWrapper>
陈文彬 authored
35
</template>
36
陈文彬 authored
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';
42
  import { PageWrapper } from '/@/components/Page';
43
  import { areaRecord } from '/@/api/demo/cascader';
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' },
  ];
陈文彬 authored
52
53
54
55
56
  const schemas: FormSchema[] = [
    {
      field: 'field1',
      component: 'Input',
      label: '字段1',
57
      colProps: { span: 8 },
陈文彬 authored
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 },
陈文彬 authored
70
71
72
73
74
    },
    {
      field: 'field3',
      component: 'DatePicker',
      label: '字段3',
75
      colProps: { span: 8 },
陈文彬 authored
76
77
    },
    {
78
79
80
      field: 'fieldTime',
      component: 'RangePicker',
      label: '时间字段',
81
      colProps: { span: 8 },
82
83
    },
    {
陈文彬 authored
84
85
86
      field: 'field4',
      component: 'Select',
      label: '字段4',
87
      colProps: { span: 8 },
陈文彬 authored
88
89
      componentProps: {
        options: [
90
91
          { label: '选项1', value: '1', key: '1' },
          { label: '选项2', value: '2', key: '2' },
陈文彬 authored
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' },
陈文彬 authored
106
107
108
109
110
111
112
        ],
      },
    },
    {
      field: 'field7',
      component: 'RadioGroup',
      label: '字段7',
113
      colProps: { span: 8 },
陈文彬 authored
114
115
      componentProps: {
        options: [
116
117
          { label: '选项1', value: '1' },
          { label: '选项2', value: '2' },
陈文彬 authored
118
119
120
        ],
      },
    },
121
122
123
124
    {
      field: 'field8',
      component: 'ApiCascader',
      label: '联动',
125
      colProps: { span: 8 },
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 },
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);
        },
      },
    },
陈文彬 authored
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
  ];
陈文彬 authored
300
  export default defineComponent({
301
302
303
304
305
306
307
    components: {
      BasicForm,
      CollapseContainer,
      PageWrapper,
      Drawer,
      Space,
    },
陈文彬 authored
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
331
      const [register, { setProps, setFieldsValue, updateSchema }] = useForm({
陈文彬 authored
332
333
        labelWidth: 120,
        schemas,
334
        actionColOptions: { span: 24 },
335
        fieldMapToTime: [['fieldTime', ['startTime', 'endTime'], 'YYYY-MM']],
陈文彬 authored
336
      });
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 });
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;
      };
陈文彬 authored
377
378
379
      return {
        register,
        schemas,
vben authored
380
        handleSubmit: (values: Recordable) => {
381
          console.log(values);
陈文彬 authored
382
383
        },
        setProps,
384
        handleLoad,
385
386
387
        visible,
        showDrawer,
        settingFormRef,
388
        withClose,
389
390
391
392
        onSettings,
        resetSettings,
        registerSetting,
        handleSubmitSetting,
陈文彬 authored
393
394
395
396
      };
    },
  });
</script>