TenantDrawer.vue 4.29 KB
<template>
  <BasicDrawer
    v-bind="$attrs"
    @register="registerDrawer"
    showFooter
    :title="getTitle"
    width="500px"
    @ok="handleSubmit"
  >
    <BasicForm @register="tenantForm" />
  </BasicDrawer>
</template>
<script lang="ts">
  import { defineComponent, ref, computed, unref } from 'vue';
  import { BasicForm, useForm } from '/@/components/Form/index';
  import { BasicDrawer, useDrawerInner } from '/@/components/Drawer';
  import { useI18n } from '/@/hooks/web/useI18n';
  import { tenantFormSchema } from '/@/views/tenant/list/tenantBaseColumns';
  import { getTenantRoles, updateOrCreateTenant } from '/@/api/tenant/tenantApi';
  import { useMessage } from '/@/hooks/web/useMessage';
  import { FileItem } from '/@/components/Form/src/components/ApiUpload.vue';
  import { buildUUID } from '/@/utils/uuid';

  export default defineComponent({
    name: 'TenantDrawer',
    components: {
      BasicDrawer,
      BasicForm,
    },
    emits: ['success', 'register'],
    setup(_, { emit }) {
      const loading = ref(false);
      const { createMessage } = useMessage();

      const isUpdate = ref(true);

      const [tenantForm, { resetFields, setFieldsValue, updateSchema, validate }] = useForm({
        labelWidth: 100,
        schemas: tenantFormSchema,
        showActionButtonGroup: false,
        baseColProps: { lg: 24, md: 24 },
      });
      const { t } = useI18n(); // 加载国际化

      //默认传递页面数据
      const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
        await resetFields();
        setDrawerProps({ confirmLoading: false });
        isUpdate.value = !!data?.isUpdate;

        //初始化,菜单名称为可用
        await updateSchema({ field: 'title', componentProps: { disabled: false } });
        //如果是编辑操作,设置页面数据
        if (unref(isUpdate)) {
          if (data.record.icon) {
            setFieldsValue({
              icon: [{ uid: buildUUID(), name: 'name', url: data.record.icon } as FileItem],
            });
          }
          getTenantRoles(data.record.tenantId).then((result) => {
            const { icon: _, ...params } = data.record;
            //为表单赋值
            setFieldsValue({
              ...params,
              roleIds: result,
            });
            //编辑模式,菜单名称为不可用
            updateSchema({ field: 'title', componentProps: { disabled: true } });
          });
        }
      });
      //得到页面标题
      const getTitle = computed(() =>
        !unref(isUpdate)
          ? t('routes.common.system.pageSystemTitleCreateTenant')
          : t('routes.common.system.pageSystemTitleEditTenant')
      );

      //提交按钮
      async function handleSubmit() {
        setDrawerProps({ confirmLoading: true });
        try {
          const values = await validate();
          if (Reflect.has(values, 'icon')) {
            const file = (values.icon || []).at(0) || {};
            values.icon = file.url || null;
          }
          const req = {
            id: values.id,
            icon: values.icon,
            name: values.name,
            enabled: values.enabled,
            description: values.description,
            roleIds: values.roleIds,
            tenantId: values.tenantId,
            tenantExpireTime:
              typeof values.tenantExpireTime != 'undefined' && values.tenantExpireTime != null
                ? values.tenantExpireTime.format('YYYY-MM-DD HH:mm:ss')
                : null,
            tenantProfileId: {
              id: values.tenantProfileId,
              entityType: 'TENANT_PROFILE',
            },
          };
          await updateOrCreateTenant(req);
          emit('success');
          createMessage.success(`${unref(isUpdate) ? '编辑' : '新增'}成功`);
          closeDrawer(); //关闭侧框
        } catch (e) {
          if ((e as { code: string }).code === 'ECONNABORTED') {
            emit('success');
            closeDrawer(); //关闭侧框
          }
        } finally {
          setDrawerProps({ confirmLoading: false });
        }
      }
      return {
        registerDrawer,
        tenantForm,
        getTitle,
        handleSubmit,
        loading,
      };
    },
  });
</script>
<style>
  .ant-upload-select-picture-card i {
    font-size: 32px;
    color: #999;
  }
</style>