Blame view

Yi.Vben5.Vue3/apps/web-antd/src/views/system/post/post-drawer.vue 2.82 KB
515fceeb   “wangming”   框架初始化
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
  <script setup lang="ts">
  import { computed, ref } from 'vue';
  
  import { useVbenDrawer } from '@vben/common-ui';
  import { $t } from '@vben/locales';
  import { addFullName, cloneDeep } from '@vben/utils';
  
  import { useVbenForm } from '#/adapter/form';
  import { postAdd, postInfo, postUpdate } from '#/api/system/post';
  import { getDeptTree } from '#/api/system/user';
  import { defaultFormValueGetter, useBeforeCloseDiff } from '#/utils/popup';
  
  import { drawerSchema } from './data';
  
  const emit = defineEmits<{ reload: [] }>();
  
  const isUpdate = ref(false);
  const title = computed(() => {
    return isUpdate.value ? $t('pages.common.edit') : $t('pages.common.add');
  });
  
  const [BasicForm, formApi] = useVbenForm({
    commonConfig: {
      formItemClass: 'col-span-2',
      componentProps: {
        class: 'w-full',
      },
      labelWidth: 80,
    },
    schema: drawerSchema(),
    showDefaultActions: false,
    wrapperClass: 'grid-cols-2',
  });
  
  async function setupDeptSelect() {
    const deptTree = await getDeptTree();
    // 选中后显示在输入框的值 即父节点 / 子节点
    addFullName(deptTree, 'deptName', ' / ');
    formApi.updateSchema([
      {
        componentProps: {
          fieldNames: { label: 'deptName', value: 'id' },
          treeData: deptTree,
          treeDefaultExpandAll: true,
          treeLine: { showLeafIcon: false },
          // 选中后显示在输入框的值
          treeNodeLabelProp: 'fullName',
        },
        fieldName: 'deptId',
      },
    ]);
  }
  
  const { onBeforeClose, markInitialized, resetInitialized } = useBeforeCloseDiff(
    {
      initializedGetter: defaultFormValueGetter(formApi),
      currentGetter: defaultFormValueGetter(formApi),
    },
  );
  
  const [BasicDrawer, drawerApi] = useVbenDrawer({
    onBeforeClose,
    onClosed: handleClosed,
    onConfirm: handleConfirm,
    async onOpenChange(isOpen) {
      if (!isOpen) {
        return null;
      }
      drawerApi.drawerLoading(true);
      const { id } = drawerApi.getData() as { id?: string };
      isUpdate.value = !!id;
      // 初始化
      await setupDeptSelect();
      // 更新 && 赋值
      if (isUpdate.value && id) {
        const record = await postInfo(id);
        await formApi.setValues(record);
      }
      await markInitialized();
      drawerApi.drawerLoading(false);
    },
  });
  
  async function handleConfirm() {
    try {
      drawerApi.lock(true);
      const { valid } = await formApi.validate();
      if (!valid) {
        return;
      }
      const data = cloneDeep(await formApi.getValues());
      await (isUpdate.value ? postUpdate(data) : postAdd(data));
      resetInitialized();
      emit('reload');
      drawerApi.close();
    } catch (error) {
      console.error(error);
    } finally {
      drawerApi.lock(false);
    }
  }
  
  async function handleClosed() {
    await formApi.resetForm();
    resetInitialized();
  }
  </script>
  
  <template>
    <BasicDrawer :title="title" class="w-[600px]">
      <BasicForm />
    </BasicDrawer>
  </template>