index.vue 1.45 KB
<template>
  <BasicModal
    v-bind="$attrs"
    width="55rem"
    @register="register"
    :title="getTitle"
    @ok="handleSubmit"
  >
    <BasicForm :showResetButton="false" :showSubmitButton="false" @register="registerForm" />
  </BasicModal>
</template>
<script lang="ts">
  import { defineComponent, ref, computed, unref } from 'vue';
  import { BasicModal, useModalInner } from '/@/components/Modal';
  import { BasicForm, useForm } from '/@/components/Form';
  import { formSchema } from './config';

  export default defineComponent({
    name: 'DetailTemplate',
    components: {
      BasicModal,
      BasicForm,
    },
    emits: ['success', 'register', 'getAllFieldsEnab'],
    setup(_, { emit }) {
      const isUpdate = ref(true);
      const [registerForm, { getFieldsValue, resetFields }] = useForm({
        labelWidth: 120,
        schemas: formSchema,
      });
      const getTitle = computed(() => (!unref(isUpdate) ? '新增报警日程表' : '编辑报警日程表'));
      const [register, { closeModal }] = useModalInner((data) => {
        isUpdate.value = !!data?.isUpdate;
      });
      const resetDataFunc = () => {
        resetFields();
      };
      const handleSubmit = () => {
        const values = getFieldsValue();
        emit('getAllFieldsEnab', values);
        closeModal();
      };
      return {
        resetDataFunc,
        registerForm,
        handleSubmit,
        register,
        getTitle,
      };
    },
  });
</script>