hgwms-2098 fix 数据字典弹窗修改

hwork-master
A0066811 2025-11-07 13:22:40 +08:00
parent f264d03008
commit f5751c70d9
4 changed files with 369 additions and 301 deletions

View File

@ -1,71 +1,95 @@
<template> <template>
<a-modal :open="visible" title="修改字典" cancelText="取消" okText="提交" @ok="submit" @cancel="cancel"> <a-modal
<a-form ref="formRef" :model="formState" :rules="formRules" :label-col="labelCol" :wrapper-col="wrapperCol"> :open="visible"
title="修改字典"
cancelText="取消"
okText="提交"
@ok="submit"
@cancel="cancel"
>
<a-form
ref="formRef"
:model="formState"
:rules="formRules"
layout="vertical"
>
<a-row :gutter="[16, 0]">
<a-col :span="12">
<a-form-item ref="label" label="中文标签" name="label"> <a-form-item ref="label" label="中文标签" name="label">
<a-input v-model:value="formState.label" /> <a-input v-model:value="formState.label" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="value" label="标识" name="value"> <a-form-item ref="value" label="标识" name="value">
<a-input v-model:value="formState.value" /> <a-input v-model:value="formState.value" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="code" label="类型" name="code"> <a-form-item ref="code" label="类型" name="code">
<a-input v-model:value="formState.code" /> <a-input v-model:value="formState.code" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="color" label="颜色" name="color"> <a-form-item ref="color" label="颜色" name="color">
<a-input v-model:value="formState.color" /> <a-input v-model:value="formState.color" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="sort" label="排序" name="sort"> <a-form-item ref="sort" label="排序" name="sort">
<a-input-number v-model:value="formState.sort" /> <a-input-number
style="width: 100%"
v-model:value="formState.sort"
/>
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item label="状态" name="enable"> <a-form-item label="状态" name="enable">
<a-switch v-model:checked="formState.enable" /> <a-switch v-model:checked="formState.enable" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="24">
<a-form-item label="备注" name="remark"> <a-form-item label="备注" name="remark">
<a-textarea v-model:value="formState.remark" /> <a-textarea v-model:value="formState.remark" />
</a-form-item> </a-form-item>
</a-col>
</a-row>
</a-form> </a-form>
</a-modal> </a-modal>
</template> </template>
<script> <script>
import { import { message } from "@hwork/ant-design-vue";
message import { edit } from "@/api/module/dictData";
} from '@hwork/ant-design-vue'; import { defineComponent, reactive, ref, toRaw, watch } from "vue";
import { export default defineComponent({
edit
} from "@/api/module/dictData";
import {
defineComponent,
reactive,
ref,
toRaw,
watch
} from "vue";
export default defineComponent({
props: { props: {
visible: { visible: {
type: Boolean, type: Boolean,
}, },
record: { record: {
type: Object, type: Object,
} },
}, },
emit: ["close"], emit: ["close"],
setup(props, context) { setup(props, context) {
const formRef = ref(); const formRef = ref();
const formState = reactive({}); const formState = reactive({});
const formRules = { const formRules = {
name: [{ name: [
{
required: true, required: true,
message: '请输入名称', message: "请输入名称",
trigger: 'blur' trigger: "blur",
}, ], },
code: [{ ],
code: [
{
required: true, required: true,
message: '请输入标识', message: "请输入标识",
trigger: 'blur' trigger: "blur",
}, ] },
],
}; };
watch(props, (props) => { watch(props, (props) => {
@ -77,7 +101,7 @@
formState.sort = props.record.sort; formState.sort = props.record.sort;
formState.enable = props.record.enable; formState.enable = props.record.enable;
formState.remark = props.record.remark; formState.remark = props.record.remark;
}) });
const submit = (e) => { const submit = (e) => {
formRef.value formRef.value
@ -85,24 +109,28 @@
.then(() => { .then(() => {
edit(toRaw(formState)).then((response) => { edit(toRaw(formState)).then((response) => {
if (response.success) { if (response.success) {
message.success({ message
content: '保存成功', .success({
duration: 1 content: "保存成功",
}).then(() => { duration: 1,
})
.then(() => {
cancel(); cancel();
}); });
} else { } else {
message.success({ message
content: '保存失败', .success({
duration: 1 content: "保存失败",
}).then(() => { duration: 1,
})
.then(() => {
cancel(); cancel();
}); });
} }
}); });
}) })
.catch(error => { .catch((error) => {
console.log('error', error); console.log("error", error);
}); });
}; };
@ -119,12 +147,12 @@
formRules, formRules,
labelCol: { labelCol: {
span: 6 span: 6,
}, },
wrapperCol: { wrapperCol: {
span: 18 span: 18,
}, },
}; };
}, },
}); });
</script> </script>

View File

@ -11,35 +11,53 @@
ref="formRef" ref="formRef"
:model="formState" :model="formState"
:rules="formRules" :rules="formRules"
:label-col="labelCol" layout="vertical"
:wrapper-col="wrapperCol"
> >
<a-row :gutter="[16, 0]">
<a-col :span="12">
<a-form-item ref="label" label="中文标签" name="label"> <a-form-item ref="label" label="中文标签" name="label">
<a-input v-model:value="formState.label" /> <a-input v-model:value="formState.label" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="value" label="标识" name="value"> <a-form-item ref="value" label="标识" name="value">
<a-input v-model:value="formState.value" /> <a-input v-model:value="formState.value" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="code" label="类型" name="code"> <a-form-item ref="code" label="类型" name="code">
<a-input v-model:value="formState.code" /> <a-input v-model:value="formState.code" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="color" label="颜色" name="color"> <a-form-item ref="color" label="颜色" name="color">
<a-input v-model:value="formState.color" /> <a-input v-model:value="formState.color" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="sort" label="排序" name="sort"> <a-form-item ref="sort" label="排序" name="sort">
<a-input-number v-model:value="formState.sort" /> <a-input-number
style="width: 100%"
v-model:value="formState.sort"
/>
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item label="状态" name="enable"> <a-form-item label="状态" name="enable">
<a-switch v-model:checked="formState.enable" /> <a-switch v-model:checked="formState.enable" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="24">
<a-form-item label="备注" name="remark"> <a-form-item label="备注" name="remark">
<a-textarea v-model:value="formState.remark" /> <a-textarea v-model:value="formState.remark" />
</a-form-item> </a-form-item>
</a-col>
</a-row>
</a-form> </a-form>
</a-modal> </a-modal>
</template> </template>
<script> <script>
import { message } from '@hwork/ant-design-vue'; import { message } from "@hwork/ant-design-vue";
import { save } from "@/api/module/dictData"; import { save } from "@/api/module/dictData";
import { defineComponent, reactive, ref, toRaw, watch } from "vue"; import { defineComponent, reactive, ref, toRaw, watch } from "vue";
export default defineComponent({ export default defineComponent({
@ -49,11 +67,10 @@ export default defineComponent({
}, },
record: { record: {
type: Object, type: Object,
} },
}, },
emit: ["close"], emit: ["close"],
setup(props, context) { setup(props, context) {
const formRef = ref(); const formRef = ref();
const formState = reactive({ const formState = reactive({
@ -61,37 +78,33 @@ export default defineComponent({
enable: "true", enable: "true",
}); });
watch(props,(props)=>{ watch(props, (props) => {
formState.code = props.record.code formState.code = props.record.code;
}) });
const formRules = { const formRules = {
name: [ name: [{ required: true, message: "请输入名称", trigger: "blur" }],
{ required: true, message: '请输入名称', trigger: 'blur'}, code: [{ required: true, message: "请输入标识", trigger: "blur" }],
],
code: [
{ required: true, message: '请输入标识', trigger: 'blur'},
]
}; };
const submit = (e) => { const submit = (e) => {
formRef.value formRef.value
.validate() .validate()
.then(() => { .then(() => {
save(toRaw(formState)).then((response)=>{ save(toRaw(formState)).then((response) => {
if(response.success){ if (response.success) {
message.success({ content: '保存成功', duration: 1 }).then(()=>{ message.success({ content: "保存成功", duration: 1 }).then(() => {
cancel(); cancel();
}); });
}else{ } else {
message.success({ content: '保存失败', duration: 1 }).then(()=>{ message.success({ content: "保存失败", duration: 1 }).then(() => {
cancel(); cancel();
}); });
} }
}); });
}) })
.catch(error => { .catch((error) => {
console.log('error', error); console.log("error", error);
}); });
}; };

View File

@ -1,65 +1,82 @@
<template> <template>
<a-modal :open="visible" title="修改字典" cancelText="取消" okText="提交" @ok="submit" @cancel="cancel"> <a-modal
<a-form ref="formRef" :model="formState" :rules="formRules" :label-col="labelCol" :wrapper-col="wrapperCol"> :open="visible"
title="修改字典"
cancelText="取消"
okText="提交"
@ok="submit"
@cancel="cancel"
>
<a-form
ref="formRef"
:model="formState"
:rules="formRules"
layout="vertical"
>
<a-row :gutter="[16, 0]">
<a-col :span="12">
<a-form-item ref="name" label="名称" name="name"> <a-form-item ref="name" label="名称" name="name">
<a-input v-model:value="formState.name" /> <a-input v-model:value="formState.name" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="code" label="标识" name="code"> <a-form-item ref="code" label="标识" name="code">
<a-input v-model:value="formState.code" /> <a-input v-model:value="formState.code" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="sort" label="排序" name="sort"> <a-form-item ref="sort" label="排序" name="sort">
<a-input-number v-model:value="formState.sort" /> <a-input-number style="width: 100%" v-model:value="formState.sort" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item label="状态" name="enable"> <a-form-item label="状态" name="enable">
<a-switch v-model:checked="formState.enable" /> <a-switch v-model:checked="formState.enable" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="24">
<a-form-item label="备注" name="remark"> <a-form-item label="备注" name="remark">
<a-textarea v-model:value="formState.remark" /> <a-textarea v-model:value="formState.remark" />
</a-form-item> </a-form-item>
</a-col>
</a-row>
</a-form> </a-form>
</a-modal> </a-modal>
</template> </template>
<script> <script>
import { import { message } from "@hwork/ant-design-vue";
message import { edit } from "@/api/module/dict";
} from '@hwork/ant-design-vue'; import { defineComponent, reactive, ref, toRaw, watch } from "vue";
import { export default defineComponent({
edit
} from "@/api/module/dict";
import {
defineComponent,
reactive,
ref,
toRaw,
watch
} from "vue";
export default defineComponent({
props: { props: {
visible: { visible: {
type: Boolean, type: Boolean,
}, },
record: { record: {
type: Object, type: Object,
} },
}, },
emit: ["close"], emit: ["close"],
setup(props, context) { setup(props, context) {
const formRef = ref(); const formRef = ref();
const formState = reactive({}); const formState = reactive({});
const formRules = { const formRules = {
name: [{ name: [
{
required: true, required: true,
message: '请输入名称', message: "请输入名称",
trigger: 'blur' trigger: "blur",
}, ], },
code: [{ ],
code: [
{
required: true, required: true,
message: '请输入标识', message: "请输入标识",
trigger: 'blur' trigger: "blur",
}, ] },
],
}; };
watch(props, (props) => { watch(props, (props) => {
@ -69,7 +86,7 @@
formState.sort = props.record.sort; formState.sort = props.record.sort;
formState.enable = props.record.enable; formState.enable = props.record.enable;
formState.remark = props.record.remark; formState.remark = props.record.remark;
}) });
const submit = (e) => { const submit = (e) => {
formRef.value formRef.value
@ -77,24 +94,28 @@
.then(() => { .then(() => {
edit(toRaw(formState)).then((response) => { edit(toRaw(formState)).then((response) => {
if (response.success) { if (response.success) {
message.success({ message
content: '保存成功', .success({
duration: 1 content: "保存成功",
}).then(() => { duration: 1,
})
.then(() => {
cancel(); cancel();
}); });
} else { } else {
message.success({ message
content: '保存失败', .success({
duration: 1 content: "保存失败",
}).then(() => { duration: 1,
})
.then(() => {
cancel(); cancel();
}); });
} }
}); });
}) })
.catch(error => { .catch((error) => {
console.log('error', error); console.log("error", error);
}); });
}; };
@ -111,12 +132,12 @@
formRules, formRules,
labelCol: { labelCol: {
span: 6 span: 6,
}, },
wrapperCol: { wrapperCol: {
span: 18 span: 18,
}, },
}; };
}, },
}); });
</script> </script>

View File

@ -11,29 +11,40 @@
ref="formRef" ref="formRef"
:model="formState" :model="formState"
:rules="formRules" :rules="formRules"
:label-col="labelCol" layout="vertical"
:wrapper-col="wrapperCol"
> >
<a-row :gutter="[16, 0]">
<a-col :span="12">
<a-form-item ref="name" label="名称" name="name"> <a-form-item ref="name" label="名称" name="name">
<a-input v-model:value="formState.name" /> <a-input v-model:value="formState.name" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="code" label="标识" name="code"> <a-form-item ref="code" label="标识" name="code">
<a-input v-model:value="formState.code" /> <a-input v-model:value="formState.code" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="sort" label="排序" name="sort"> <a-form-item ref="sort" label="排序" name="sort">
<a-input-number v-model:value="formState.sort" /> <a-input-number style="width: 100%" v-model:value="formState.sort" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="12">
<a-form-item label="状态" name="enable"> <a-form-item label="状态" name="enable">
<a-switch v-model:checked="formState.enable" /> <a-switch v-model:checked="formState.enable" />
</a-form-item> </a-form-item>
</a-col>
<a-col :span="24">
<a-form-item label="备注" name="remark"> <a-form-item label="备注" name="remark">
<a-textarea v-model:value="formState.remark" /> <a-textarea v-model:value="formState.remark" />
</a-form-item> </a-form-item>
</a-col>
</a-row>
</a-form> </a-form>
</a-modal> </a-modal>
</template> </template>
<script> <script>
import { message } from '@hwork/ant-design-vue'; import { message } from "@hwork/ant-design-vue";
import { save } from "@/api/module/dict"; import { save } from "@/api/module/dict";
import { defineComponent, reactive, ref, toRaw } from "vue"; import { defineComponent, reactive, ref, toRaw } from "vue";
export default defineComponent({ export default defineComponent({
@ -44,7 +55,6 @@ export default defineComponent({
}, },
emit: ["close"], emit: ["close"],
setup(props, context) { setup(props, context) {
const formRef = ref(); const formRef = ref();
const formState = reactive({ const formState = reactive({
@ -53,32 +63,28 @@ export default defineComponent({
}); });
const formRules = { const formRules = {
name: [ name: [{ required: true, message: "请输入名称", trigger: "blur" }],
{ required: true, message: '请输入名称', trigger: 'blur'}, code: [{ required: true, message: "请输入标识", trigger: "blur" }],
],
code: [
{ required: true, message: '请输入标识', trigger: 'blur'},
]
}; };
const submit = (e) => { const submit = (e) => {
formRef.value formRef.value
.validate() .validate()
.then(() => { .then(() => {
save(toRaw(formState)).then((response)=>{ save(toRaw(formState)).then((response) => {
if(response.success){ if (response.success) {
message.success({ content: '保存成功', duration: 1 }).then(()=>{ message.success({ content: "保存成功", duration: 1 }).then(() => {
cancel(); cancel();
}); });
}else{ } else {
message.success({ content: '保存失败', duration: 1 }).then(()=>{ message.success({ content: "保存失败", duration: 1 }).then(() => {
cancel(); cancel();
}); });
} }
}); });
}) })
.catch(error => { .catch((error) => {
console.log('error', error); console.log("error", error);
}); });
}; };