wms_vue/src/view/config/modal/edit.vue

137 lines
3.4 KiB
Vue
Raw Normal View History

2025-08-07 15:16:23 +08:00
<template>
<a-modal
2025-11-03 16:40:10 +08:00
:open="visible"
2025-08-07 15:16:23 +08:00
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="24">
<a-form-item ref="name" label="描述" name="name">
<a-textarea v-model:value="formState.name" />
</a-form-item>
</a-col>
<a-col :span="24">
<a-form-item ref="code" label="编号" name="code">
<a-input v-model:value="formState.code" />
</a-form-item>
</a-col>
<a-col :span="24">
<a-form-item ref="value" label="值" name="value">
<a-textarea v-model:value="formState.value" />
</a-form-item>
</a-col>
<a-col :span="24">
<a-form-item label="状态" name="enable">
<a-switch v-model:checked="formState.enable" />
</a-form-item>
</a-col>
<a-col :span="24">
<a-form-item label="备注" name="remark">
<a-textarea v-model:value="formState.remark" />
</a-form-item>
</a-col>
</a-row>
2025-08-07 15:16:23 +08:00
</a-form>
</a-modal>
</template>
<script>
import { message } from "@hwork/ant-design-vue";
2025-08-07 15:16:23 +08:00
import { edit } from "@/api/module/config";
import { defineComponent, reactive, ref, toRaw, watch } from "vue";
const key = "edit";
export default defineComponent({
props: {
visible: {
type: Boolean,
},
record: {
type: Object,
},
2025-08-07 15:16:23 +08:00
},
emit: ["close"],
setup(props, context) {
const formRef = ref();
2025-08-07 15:16:23 +08:00
let formState = reactive({});
const formRules = {
name: [{ required: true, message: "请输入配置描述", trigger: "blur" }],
code: [{ required: true, message: "请输入配置编号", trigger: "blur" }],
value: [{ required: true, message: "请输入配置值", trigger: "blur" }],
2025-08-07 15:16:23 +08:00
};
watch(props, (props) => {
formState.id = props.record.id;
formState.name = props.record.name;
formState.code = props.record.code;
formState.value = props.record.value;
formState.remark = props.record.remark;
formState.enable = props.record.enable;
});
2025-08-07 15:16:23 +08:00
const submit = (e) => {
formRef.value
.validate()
.then(() => {
message.loading({
content: "提交中...",
key,
});
edit(toRaw(formState)).then((response) => {
2025-08-07 15:16:23 +08:00
if (response.success) {
message
.success({
content: "保存成功",
key,
duration: 1,
})
.then(() => {
cancel();
});
2025-08-07 15:16:23 +08:00
} else {
message
.error({
content: "保存失败",
key,
duration: 1,
})
.then(() => {
cancel();
});
2025-08-07 15:16:23 +08:00
}
});
})
.catch((error) => {
console.log("error", error);
});
};
const cancel = (e) => {
formRef.value.resetFields();
context.emit("close", false);
};
return {
submit,
cancel,
formRef,
formState,
formRules,
2025-08-07 15:16:23 +08:00
labelCol: { span: 6 },
wrapperCol: { span: 18 },
};
},
});
</script>