初始化
This commit is contained in:
130
saiadmin-vue/src/views/system/dict/edit-data.vue
Normal file
130
saiadmin-vue/src/views/system/dict/edit-data.vue
Normal file
@@ -0,0 +1,130 @@
|
||||
<template>
|
||||
<component
|
||||
is="a-modal"
|
||||
v-model:visible="visible"
|
||||
:width="tool.getDevice() === 'mobile' ? '100%' : '600px'"
|
||||
:title="title"
|
||||
:mask-closable="false"
|
||||
:ok-loading="loading"
|
||||
@cancel="close"
|
||||
@before-ok="submit">
|
||||
<!-- 表单信息 start -->
|
||||
<a-form ref="formRef" :model="formData" :rules="rules" :auto-label-width="true">
|
||||
<a-form-item label="字典标签" field="label">
|
||||
<a-input v-model="formData.label" placeholder="请输入字典标签" />
|
||||
</a-form-item>
|
||||
<a-form-item label="字典键值" field="value">
|
||||
<a-input v-model="formData.value" placeholder="请输入字典键值" />
|
||||
</a-form-item>
|
||||
<a-form-item label="颜色" field="color">
|
||||
<ma-color-picker v-model="formData.color" />
|
||||
</a-form-item>
|
||||
<a-form-item label="排序" field="sort">
|
||||
<a-input-number v-model="formData.sort" placeholder="请输入排序" />
|
||||
</a-form-item>
|
||||
<a-form-item label="状态" field="status">
|
||||
<sa-radio v-model="formData.status" dict="data_status" placeholder="请选择状态" />
|
||||
</a-form-item>
|
||||
<a-form-item label="备注" field="remark">
|
||||
<a-textarea v-model="formData.remark" placeholder="请输入备注" />
|
||||
</a-form-item>
|
||||
</a-form>
|
||||
<!-- 表单信息 end -->
|
||||
</component>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
import { ref, reactive, computed } from 'vue'
|
||||
import { Message } from '@arco-design/web-vue'
|
||||
import tool from '@/utils/tool'
|
||||
import { dict } from '@/api/system/dict'
|
||||
|
||||
const emit = defineEmits(['success'])
|
||||
|
||||
// 引用定义
|
||||
const formRef = ref()
|
||||
const mode = ref('')
|
||||
const visible = ref(false)
|
||||
const loading = ref(false)
|
||||
|
||||
let title = computed(() => {
|
||||
return '字典数据' + (mode.value == 'add' ? '-新增' : '-编辑')
|
||||
})
|
||||
|
||||
// 表单初始值
|
||||
const initialFormData = {
|
||||
id: '',
|
||||
type_id: null,
|
||||
code: '',
|
||||
label: '',
|
||||
value: '',
|
||||
color: '',
|
||||
status: 1,
|
||||
sort: 100,
|
||||
remark: '',
|
||||
}
|
||||
|
||||
// 表单信息
|
||||
const formData = reactive({ ...initialFormData })
|
||||
|
||||
// 验证规则
|
||||
const rules = {
|
||||
label: [{ required: true, message: '字典标签不能为空' }],
|
||||
value: [{ required: true, message: '字典键值不能为空' }],
|
||||
}
|
||||
|
||||
// 打开弹框
|
||||
const open = async (type = 'add') => {
|
||||
mode.value = type
|
||||
// 重置表单数据
|
||||
Object.assign(formData, initialFormData)
|
||||
formRef.value.clearValidate()
|
||||
visible.value = true
|
||||
await initPage()
|
||||
}
|
||||
|
||||
// 初始化页面数据
|
||||
const initPage = async () => {}
|
||||
|
||||
// 设置数据
|
||||
const setFormData = async (data) => {
|
||||
for (const key in formData) {
|
||||
if (data[key] != null && data[key] != undefined) {
|
||||
formData[key] = data[key]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 数据保存
|
||||
const submit = async (done) => {
|
||||
const validate = await formRef.value?.validate()
|
||||
if (!validate) {
|
||||
loading.value = true
|
||||
let data = { ...formData }
|
||||
let result = {}
|
||||
if (mode.value === 'add') {
|
||||
// 添加数据
|
||||
data.id = undefined
|
||||
result = await dict.addDictData(data)
|
||||
} else {
|
||||
// 修改数据
|
||||
result = await dict.editDictData(data.id, data)
|
||||
}
|
||||
if (result.code === 200) {
|
||||
Message.success('操作成功')
|
||||
emit('success')
|
||||
done(true)
|
||||
}
|
||||
// 防止连续点击提交
|
||||
setTimeout(() => {
|
||||
loading.value = false
|
||||
}, 500)
|
||||
}
|
||||
done(false)
|
||||
}
|
||||
|
||||
// 关闭弹窗
|
||||
const close = () => (visible.value = false)
|
||||
|
||||
defineExpose({ open, setFormData })
|
||||
</script>
|
||||
Reference in New Issue
Block a user