更新仪表盘
This commit is contained in:
@@ -1,86 +1,109 @@
|
||||
<template>
|
||||
<a-modal :open="visible" :title="isEdit ? $t('common.editArea') : $t('common.addArea')" :width="600"
|
||||
:ok-text="$t('common.confirm')" :cancel-text="$t('common.cancel')" @ok="handleConfirm" @cancel="handleClose"
|
||||
:after-close="handleClose">
|
||||
<a-form ref="formRef" :model="formData" :label-col="{ span: 5 }">
|
||||
<a-form-item v-if="!isEdit" name="code" :label="$t('common.areaCode')"
|
||||
:rules="[{ required: true, message: $t('common.pleaseEnter') + $t('common.areaCode') }]">
|
||||
<a-input v-model:value="formData.code" :placeholder="$t('common.pleaseEnter')" :maxlength="20" />
|
||||
<a-modal :title="titleMap[mode]" :open="visible" :width="500" :destroy-on-close="true" :mask-closable="false"
|
||||
:footer="null" @cancel="handleCancel">
|
||||
<a-form :model="form" :rules="rules" :disabled="mode === 'show'" ref="dialogForm" :label-col="{ span: 5 }"
|
||||
:wrapper-col="{ span: 18 }">
|
||||
<a-form-item v-if="mode === 'add'" label="地区编码" name="code">
|
||||
<a-input v-model:value="form.code" placeholder="请输入地区编码" allow-clear />
|
||||
</a-form-item>
|
||||
|
||||
<a-form-item name="title" :label="$t('common.areaName')"
|
||||
:rules="[{ required: true, message: $t('common.pleaseEnter') + $t('common.areaName') }]">
|
||||
<a-input v-model:value="formData.title" :placeholder="$t('common.pleaseEnter')" :maxlength="50" />
|
||||
<a-form-item label="地区名称" name="title">
|
||||
<a-input v-model:value="form.title" placeholder="请输入地区名称" allow-clear />
|
||||
</a-form-item>
|
||||
|
||||
<a-form-item name="parent_code" :label="$t('common.parentArea')">
|
||||
<a-tree-select v-model:value="formData.parent_code" :tree-data="areaTreeData"
|
||||
:placeholder="$t('common.pleaseSelect')"
|
||||
:field-names="{ label: 'title', value: 'code', children: 'children' }" allow-clear show-search
|
||||
tree-default-expand-all />
|
||||
<a-form-item label="上级地区" name="parent_code">
|
||||
<a-tree-select v-model:value="form.parent_code" :tree-data="areaTreeData"
|
||||
:field-names="{ label: 'title', value: 'code', children: 'children' }" tree-default-expand-all
|
||||
show-search placeholder="请选择上级地区" allow-clear tree-node-filter-prop="title" />
|
||||
</a-form-item>
|
||||
|
||||
<a-form-item name="status" :label="$t('common.status')"
|
||||
:rules="[{ required: true, message: $t('common.pleaseSelect') + $t('common.status') }]">
|
||||
<a-radio-group v-model:value="formData.status">
|
||||
<a-radio :value="1">{{ $t('common.enabled') }}</a-radio>
|
||||
<a-radio :value="0">{{ $t('common.disabled') }}</a-radio>
|
||||
<a-form-item label="状态" name="status">
|
||||
<a-radio-group v-model:value="form.status">
|
||||
<a-radio :value="1">正常</a-radio>
|
||||
<a-radio :value="0">禁用</a-radio>
|
||||
</a-radio-group>
|
||||
</a-form-item>
|
||||
</a-form>
|
||||
<template #footer>
|
||||
<a-button @click="handleCancel">取 消</a-button>
|
||||
<a-button v-if="mode !== 'show'" type="primary" :loading="isSaveing" @click="submit">保 存</a-button>
|
||||
</template>
|
||||
</a-modal>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
import { ref, reactive, watch } from 'vue'
|
||||
import { ref, reactive } from 'vue'
|
||||
import { message } from 'ant-design-vue'
|
||||
import systemApi from '@/api/system'
|
||||
|
||||
// 定义组件名称
|
||||
defineOptions({
|
||||
name: 'AreaModal',
|
||||
})
|
||||
const emit = defineEmits(['success', 'closed'])
|
||||
|
||||
const props = defineProps({
|
||||
visible: {
|
||||
type: Boolean,
|
||||
default: false,
|
||||
},
|
||||
// 是否为编辑模式
|
||||
isEdit: {
|
||||
type: Boolean,
|
||||
default: false,
|
||||
},
|
||||
// 编辑时的初始数据
|
||||
initialData: {
|
||||
type: Object,
|
||||
default: () => ({}),
|
||||
},
|
||||
})
|
||||
|
||||
const emit = defineEmits(['update:visible', 'confirm'])
|
||||
|
||||
const formRef = ref(null)
|
||||
const areaTreeData = ref([])
|
||||
const mode = ref('add')
|
||||
const titleMap = {
|
||||
add: '新增地区',
|
||||
edit: '编辑地区',
|
||||
show: '查看地区'
|
||||
}
|
||||
const visible = ref(false)
|
||||
const isSaveing = ref(false)
|
||||
|
||||
// 表单数据
|
||||
const formData = reactive({
|
||||
const form = reactive({
|
||||
id: null,
|
||||
code: '',
|
||||
title: '',
|
||||
parent_code: null,
|
||||
status: 1,
|
||||
status: 1
|
||||
})
|
||||
|
||||
// 获取地区树数据
|
||||
const fetchAreaTree = async () => {
|
||||
// 表单引用
|
||||
const dialogForm = ref()
|
||||
|
||||
// 验证规则
|
||||
const rules = {
|
||||
code: [
|
||||
{ required: true, message: '请输入地区编码', trigger: 'blur' }
|
||||
],
|
||||
title: [
|
||||
{ required: true, message: '请输入地区名称', trigger: 'blur' }
|
||||
]
|
||||
}
|
||||
|
||||
// 地区树数据
|
||||
const areaTreeData = ref([])
|
||||
|
||||
// 显示对话框
|
||||
const open = (openMode = 'add') => {
|
||||
mode.value = openMode
|
||||
visible.value = true
|
||||
if (openMode !== 'show') {
|
||||
loadAreaTree()
|
||||
}
|
||||
return {
|
||||
setData,
|
||||
open,
|
||||
close
|
||||
}
|
||||
}
|
||||
|
||||
// 关闭对话框
|
||||
const close = () => {
|
||||
visible.value = false
|
||||
}
|
||||
|
||||
// 处理取消
|
||||
const handleCancel = () => {
|
||||
emit('closed')
|
||||
visible.value = false
|
||||
}
|
||||
|
||||
// 加载地区树数据
|
||||
const loadAreaTree = async () => {
|
||||
try {
|
||||
const res = await systemApi.area.list.get({ pageSize: 1000 })
|
||||
if (res.code === 200 || res.code === 1) {
|
||||
if (res.code === 1) {
|
||||
const list = res.data.list || res.data || []
|
||||
areaTreeData.value = buildTree(list)
|
||||
}
|
||||
} catch (error) {
|
||||
console.error('获取地区树失败:', error)
|
||||
console.error('加载地区树失败:', error)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -106,62 +129,49 @@ const buildTree = (list) => {
|
||||
return roots
|
||||
}
|
||||
|
||||
// 监听弹窗显示和初始数据变化
|
||||
watch(
|
||||
() => props.initialData,
|
||||
(newVal) => {
|
||||
if (props.isEdit && Object.keys(newVal).length > 0) {
|
||||
formData.id = newVal.id || null
|
||||
formData.code = newVal.code || ''
|
||||
formData.title = newVal.title || ''
|
||||
formData.parent_code = newVal.parent_code || null
|
||||
formData.status = newVal.status ?? 1
|
||||
}
|
||||
},
|
||||
{ immediate: true },
|
||||
)
|
||||
|
||||
// 监听弹窗打开,加载地区树数据
|
||||
watch(
|
||||
() => props.visible,
|
||||
(newVal) => {
|
||||
if (newVal) {
|
||||
fetchAreaTree()
|
||||
}
|
||||
},
|
||||
)
|
||||
|
||||
// 监听弹窗关闭,重置表单
|
||||
watch(
|
||||
() => props.visible,
|
||||
(newVal) => {
|
||||
if (!newVal) {
|
||||
handleClose()
|
||||
}
|
||||
},
|
||||
)
|
||||
|
||||
// 确认提交
|
||||
const handleConfirm = async () => {
|
||||
// 表单提交方法
|
||||
const submit = async () => {
|
||||
try {
|
||||
const values = await formRef.value.validate()
|
||||
emit('confirm', values)
|
||||
} catch {
|
||||
// 表单验证错误,不处理
|
||||
await dialogForm.value.validate()
|
||||
isSaveing.value = true
|
||||
let res = {}
|
||||
if (mode.value === 'add') {
|
||||
res = await systemApi.area.add.post(form)
|
||||
} else {
|
||||
res = await systemApi.area.edit.post(form)
|
||||
}
|
||||
|
||||
isSaveing.value = false
|
||||
if (res.code === 1) {
|
||||
emit('success', form, mode.value)
|
||||
visible.value = false
|
||||
message.success('操作成功')
|
||||
} else {
|
||||
message.error(res.message || '操作失败')
|
||||
}
|
||||
} catch (error) {
|
||||
isSaveing.value = false
|
||||
console.error('表单验证失败', error)
|
||||
}
|
||||
}
|
||||
|
||||
// 关闭弹窗并重置表单
|
||||
const handleClose = () => {
|
||||
formRef.value?.resetFields()
|
||||
formData.id = null
|
||||
formData.code = ''
|
||||
formData.title = ''
|
||||
formData.parent_code = null
|
||||
formData.status = 1
|
||||
emit('update:visible', false)
|
||||
// 表单注入数据
|
||||
const setData = (data) => {
|
||||
form.id = data.id
|
||||
form.code = data.code
|
||||
form.title = data.title
|
||||
form.parent_code = data.parent_code
|
||||
form.status = data.status ?? 1
|
||||
}
|
||||
|
||||
// 暴露方法给父组件
|
||||
defineExpose({
|
||||
open,
|
||||
setData,
|
||||
close
|
||||
})
|
||||
</script>
|
||||
|
||||
<style scoped lang="scss">
|
||||
// 弹窗样式可根据需要添加</style>
|
||||
// 弹窗样式可根据需要添加
|
||||
</style>
|
||||
|
||||
Reference in New Issue
Block a user