You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
besure_web/src/views/mes/printTemplate/PrintTemplateForm.vue

147 lines
5.6 KiB
Vue

<template>
<Dialog :title="dialogTitle" v-model="dialogVisible">
<el-form ref="formRef" :model="formData" :rules="formRules" label-width="120px" v-loading="formLoading">
<el-form-item prop="templateCode">
<template #label>
<span>
{{ t('TemplateManagement.PrintTemplate.templateCode') }}
<el-tooltip :content="t('TemplateManagement.PrintTemplate.templateCodeTooltip')" placement="top">
<Icon icon="ep:question-filled" />
</el-tooltip>
</span>
</template>
<el-row :gutter="10" style="width: 100%;">
<el-col :xs="24" :sm="18" :md="16" :lg="14" :xl="12">
<el-input v-model="formData.templateCode" :placeholder="t('TemplateManagement.PrintTemplate.placeholderTemplateCode')" :disabled="formData.isAutoCode || formType === 'update'" />
</el-col>
<el-col :xs="24" :sm="6" :md="4" :lg="3" :xl="2">
<el-switch v-model="formData.isAutoCode" :disabled="formType === 'update'" />
</el-col>
</el-row>
</el-form-item>
<el-form-item :label="t('TemplateManagement.PrintTemplate.templateName')" prop="templateName">
<el-input v-model="formData.templateName" :placeholder="t('TemplateManagement.PrintTemplate.placeholderTemplateName')" />
</el-form-item>
<el-form-item :label="t('TemplateManagement.PrintTemplate.templateBizType')" prop="templateBizType">
<el-radio-group v-model="formData.templateBizType">
<el-radio value="1">{{ t('TemplateManagement.PrintTemplate.bizTypePrint') }}</el-radio>
<el-radio value="2">{{ t('TemplateManagement.PrintTemplate.bizTypeReport') }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item :label="t('TemplateManagement.PrintTemplate.templateType')" prop="templateType">
<el-select v-model="formData.templateType" :placeholder="t('TemplateManagement.PrintTemplate.placeholderTemplateType')" class="!w-full">
<el-option v-for="dict in templateTypeDictOptions" :key="dict.value" :label="dict.label" :value="dict.value" />
</el-select>
</el-form-item>
<el-form-item :label="t('TemplateManagement.PrintTemplate.isEnable')" prop="isEnable">
<el-switch v-model="formData.isEnable" />
</el-form-item>
<el-form-item :label="t('TemplateManagement.PrintTemplate.remark')" prop="remark">
<el-input v-model="formData.remark" :placeholder="t('TemplateManagement.PrintTemplate.placeholderRemark')" />
</el-form-item>
</el-form>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading">{{ t('common.ok') }}</el-button>
<el-button @click="dialogVisible = false">{{ t('common.cancel') }}</el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { PrintTemplateApi, PrintTemplateVO } from '@/api/mes/printtemplate'
import { getIntDictOptions } from '@/utils/dict'
defineOptions({ name: 'PrintTemplateForm' })
const { t } = useI18n()
const message = useMessage()
const dialogVisible = ref(false)
const dialogTitle = ref('')
const formLoading = ref(false)
const formType = ref('')
const formData = ref({
id: undefined,
templateCode: undefined,
isAutoCode: true,
templateName: undefined,
templateType: undefined,
templateBizType: '1',
remark: undefined,
isEnable: true,
})
const formRules = computed(() => ({
templateCode: formData.value.isAutoCode ? [] : [{ required: true, message: t('TemplateManagement.PrintTemplate.validatorCodeRequired'), trigger: 'blur' }],
templateName: [{ required: true, message: t('TemplateManagement.PrintTemplate.validatorNameRequired'), trigger: 'blur' }],
templateType: [{ required: true, message: t('TemplateManagement.PrintTemplate.validatorTypeRequired'), trigger: 'change' }],
templateBizType: [{ required: true, message: '请选择模板分类', trigger: 'change' }],
}))
const formRef = ref()
const templateTypeDictOptions = computed(() => {
const dictType = formData.value.templateBizType === '2' ? 'report_template_type' : 'print_template_type'
return getIntDictOptions(dictType)
})
watch(() => formData.value.templateBizType, () => {
formData.value.templateType = undefined
})
const open = async (type: string, id?: number, bizType?: string) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
if (bizType) {
formData.value.templateBizType = bizType
}
if (id) {
formLoading.value = true
try {
formData.value = await PrintTemplateApi.getPrintTemplate(id)
} finally {
formLoading.value = false
}
}
}
defineExpose({ open })
const emit = defineEmits(['success'])
const submitForm = async () => {
await formRef.value.validate()
formLoading.value = true
try {
const data = formData.value as unknown as PrintTemplateVO
const { isAutoCode, ...submitData } = data as any
if (isAutoCode) {
delete submitData.templateCode
}
if (formType.value === 'create') {
await PrintTemplateApi.createPrintTemplate(submitData)
message.success(t('common.createSuccess'))
} else {
await PrintTemplateApi.updatePrintTemplate(submitData)
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
emit('success')
} finally {
formLoading.value = false
}
}
const resetForm = () => {
formData.value = {
id: undefined,
templateCode: undefined,
isAutoCode: true,
templateName: undefined,
templateType: undefined,
templateBizType: '1',
remark: undefined,
isEnable: true,
}
formRef.value?.resetFields()
}
</script>