hgwms-2098 fix 系统权限弹窗修改

hwork-master^2
A0066811 2025-11-07 11:19:50 +08:00
parent ff3740b150
commit f264d03008
3 changed files with 428 additions and 305 deletions

View File

@ -11,13 +11,14 @@
ref="formRef"
:model="formState"
:rules="formRules"
:label-col="labelCol"
:wrapper-col="wrapperCol"
layout="vertical"
>
<a-row :gutter="[16, 0]">
<a-col :span="12">
<a-form-item label="上级" name="parent">
<a-tree-select
v-model:value="formState.parent"
style="width: 100%;"
style="width: 100%"
:dropdown-style="{ maxHeight: '360px', overflow: 'auto' }"
:tree-data="state.powers"
placeholder="上级权限"
@ -27,24 +28,55 @@
>
</a-tree-select>
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="title" label="名称" name="title">
<a-input v-model:value="formState.title" />
</a-form-item>
<a-form-item v-if="state.showComponent" ref="component" label="组件" name="component">
</a-col>
<a-col :span="12">
<a-form-item
v-if="state.showComponent"
ref="component"
label="组件"
name="component"
>
<a-input v-model:value="formState.component" />
</a-form-item>
<a-form-item v-if="state.showPath" ref="path" label="路径" name="path">
</a-col>
<a-col :span="12">
<a-form-item
v-if="state.showPath"
ref="path"
label="路径"
name="path"
>
<a-input v-model:value="formState.path" />
</a-form-item>
<a-form-item v-if="state.showCode" ref="code" label="标识" name="code">
</a-col>
<a-col :span="12">
<a-form-item
v-if="state.showCode"
ref="code"
label="标识"
name="code"
>
<a-input v-model:value="formState.code" />
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item label="图标" name="icon">
<pro-icon-picker v-model:modelValue="formState.icon"></pro-icon-picker>
<pro-icon-picker
v-model:modelValue="formState.icon"
></pro-icon-picker>
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="i18n" label="i18n" name="i18n">
<a-input v-model:value="formState.i18n" />
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="type" label="类型" name="type">
<a-select v-model:value="formState.type" @change="change">
<a-select-option value="0"> 目录 </a-select-option>
@ -52,20 +84,31 @@
<a-select-option value="2"> 按钮 </a-select-option>
</a-select>
</a-form-item>
</a-col>
<a-col :span="12">
<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-col>
<a-col :span="12">
<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>
</a-form>
</a-modal>
</template>
<script>
import { message } from '@hwork/ant-design-vue';
import { message } from "@hwork/ant-design-vue";
import { edit, tree } from "@/api/module/power";
import { defineComponent, reactive, ref, toRaw, watch } from "vue";
export default defineComponent({
@ -74,17 +117,16 @@ export default defineComponent({
type: Boolean,
},
record: {
type: Object
}
type: Object,
},
},
emit: ["close"],
setup(props, context) {
const state = reactive({
depts: [],
showComponent: true,
showPath: true,
showCode: false
showCode: false,
});
const formRef = ref();
@ -107,7 +149,7 @@ export default defineComponent({
formState.sort = props.record.sort;
formState.remark = props.record.remark;
formState.parent = props.record.parent;
if(formState.type === '2') {
if (formState.type === "2") {
state.showComponent = false;
state.showPath = false;
state.showCode = true;
@ -116,17 +158,19 @@ export default defineComponent({
state.showPath = true;
state.showCode = false;
}
})
});
const formRules = {
title: [{ required: true, message: '请输入权限名称', trigger: 'blur'}],
i18n: [{ required: true, message: '请输入 i18n', trigger: 'blur'}],
type: [{ required: true, message: '请输入权限类型', trigger: 'blur'}],
parent: [{ required: true, message: '请选择上级权限', trigger: 'change'}]
title: [{ required: true, message: "请输入权限名称", trigger: "blur" }],
i18n: [{ required: true, message: "请输入 i18n", trigger: "blur" }],
type: [{ required: true, message: "请输入权限类型", trigger: "blur" }],
parent: [
{ required: true, message: "请选择上级权限", trigger: "change" },
],
};
const change = function (val) {
if(val === '2') {
if (val === "2") {
state.showComponent = false;
state.showPath = false;
state.showCode = true;
@ -135,7 +179,7 @@ export default defineComponent({
state.showPath = true;
state.showCode = false;
}
}
};
const submit = (e) => {
formRef.value
@ -143,18 +187,18 @@ export default defineComponent({
.then(() => {
edit(toRaw(formState)).then((response) => {
if (response.success) {
message.success({ content: '保存成功', duration: 1 }).then(()=>{
message.success({ content: "保存成功", duration: 1 }).then(() => {
cancel();
});
} else {
message.success({ content: '保存失败', duration: 1 }).then(()=>{
message.success({ content: "保存失败", duration: 1 }).then(() => {
cancel();
});
}
});
})
.catch(error => {
console.log('error', error);
.catch((error) => {
console.log("error", error);
});
};
@ -165,14 +209,16 @@ export default defineComponent({
const loadPower = () => {
tree({}).then((response) => {
response.data = [{
response.data = [
{
id: "0",
title: "顶级菜单",
children: response.data
}]
children: response.data,
},
];
state.powers = response.data;
})
}
});
};
loadPower();
@ -188,7 +234,12 @@ export default defineComponent({
labelCol: { span: 6 },
wrapperCol: { span: 18 },
replaceFields: {children:'children', title:'title', key:'id', value: 'id' }
replaceFields: {
children: "children",
title: "title",
key: "id",
value: "id",
},
};
},
});

View File

@ -11,9 +11,10 @@
ref="formRef"
:model="formState"
:rules="formRules"
:label-col="labelCol"
:wrapper-col="wrapperCol"
layout="vertical"
>
<a-row :gutter="[16, 0]">
<a-col :span="12">
<a-form-item label="上级" name="parent">
<a-tree-select
v-model:value="formState.parent"
@ -26,18 +27,28 @@
>
</a-tree-select>
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="title" label="名称" name="title">
<a-input v-model:value="formState.title" />
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="component" label="组件" name="component">
<a-input v-model:value="formState.component" />
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="path" label="路径" name="path">
<a-input v-model:value="formState.path" />
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="i18n" label="i18n" name="i18n">
<a-input v-model:value="formState.i18n" />
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="type" label="类型" name="type">
<a-select v-model:value="formState.type">
<a-select-option value="0"> 目录 </a-select-option>
@ -45,20 +56,28 @@
<a-select-option value="2"> 按钮 </a-select-option>
</a-select>
</a-form-item>
</a-col>
<a-col :span="12">
<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-col>
<a-col :span="12">
<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>
</a-form>
</a-modal>
</template>
<script>
import { message } from '@hwork/ant-design-vue';
import { message } from "@hwork/ant-design-vue";
import { save, tree } from "@/api/module/power";
import { defineComponent, reactive, ref, toRaw, watch } from "vue";
export default defineComponent({
@ -67,15 +86,14 @@ export default defineComponent({
type: Boolean,
},
record: {
type: Object
}
type: Object,
},
},
emit: ["close"],
setup(props, context) {
const state = reactive({
depts: [],
})
});
const formRef = ref();
@ -94,15 +112,19 @@ export default defineComponent({
formState.i18n = props.record.i18n;
formState.remark = props.record.remark;
formState.parent = props.record.parent;
})
});
const formRules = {
title: [{ required: true, message: '请输入权限名称', trigger: 'blur'}],
component: [{ required: true, message: '请输入路由组件', trigger: 'blur'}],
path: [{ required: true, message: '请输入路由地址', trigger: 'blur'}],
i18n: [{ required: true, message: '请输入 i18n', trigger: 'blur'}],
type: [{ required: true, message: '请输入权限类型', trigger: 'blur'}],
parent: [{ required: true, message: '请选择上级权限', trigger: 'change'}]
title: [{ required: true, message: "请输入权限名称", trigger: "blur" }],
component: [
{ required: true, message: "请输入路由组件", trigger: "blur" },
],
path: [{ required: true, message: "请输入路由地址", trigger: "blur" }],
i18n: [{ required: true, message: "请输入 i18n", trigger: "blur" }],
type: [{ required: true, message: "请输入权限类型", trigger: "blur" }],
parent: [
{ required: true, message: "请选择上级权限", trigger: "change" },
],
};
const submit = (e) => {
@ -118,8 +140,8 @@ export default defineComponent({
const loadPower = () => {
tree({}).then((response) => {
state.powers = response.data;
})
}
});
};
loadPower();
@ -134,7 +156,12 @@ export default defineComponent({
labelCol: { span: 6 },
wrapperCol: { span: 18 },
replaceFields: {children:'children', title:'title', key:'id', value: 'id' }
replaceFields: {
children: "children",
title: "title",
key: "id",
value: "id",
},
};
},
});

View File

@ -1,7 +1,19 @@
<template>
<a-modal :open="visible" title="新增权限" cancelText="取消" okText="提交" @ok="submit" @cancel="cancel">
<a-form ref="formRef" :model="formState" :rules="formRules" :label-col="labelCol" :wrapper-col="wrapperCol">
<a-row :gutter='[1,1]'>
<a-modal
: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="type" label="类型" name="type">
<a-select v-model:value="formState.type" @change="change">
@ -20,58 +32,76 @@
</a-select>
</a-form-item>
</a-col>
</a-row>
<a-col :span="12">
<a-form-item label="上级" name="parent">
<a-tree-select v-model:value="formState.parent" style="width: 100%;"
:dropdown-style="{ maxHeight: '360px', overflow: 'auto' }" :tree-data="state.powers" placeholder="上级权限"
replace tree-default-expand-all :replaceFields="replaceFields">
<a-tree-select
v-model:value="formState.parent"
style="width: 100%"
:dropdown-style="{ maxHeight: '360px', overflow: 'auto' }"
:tree-data="state.powers"
placeholder="上级权限"
replace
tree-default-expand-all
:replaceFields="replaceFields"
>
</a-tree-select>
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="title" label="名称" name="title">
<a-input v-model:value="formState.title" />
</a-form-item>
<a-form-item v-if="state.showComponent" ref="component" label="组件" name="component">
</a-col>
<a-col :span="12" v-if="state.showComponent">
<a-form-item ref="component" label="组件" name="component">
<a-input v-model:value="formState.component" />
</a-form-item>
<a-form-item v-if="state.showPath" ref="path" label="路径" name="path">
</a-col>
<a-col :span="12" v-if="state.showPath">
<a-form-item ref="path" label="路径" name="path">
<a-input v-model:value="formState.path" />
</a-form-item>
<a-form-item v-if="state.showCode" ref="code" label="标识" name="code">
</a-col>
<a-col :span="12" v-if="state.showCode">
<a-form-item ref="code" label="标识" name="code">
<a-input v-model:value="formState.code" />
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item label="图标" name="icon">
<pro-icon-picker v-model:modelValue="formState.icon"></pro-icon-picker>
<pro-icon-picker
v-model:modelValue="formState.icon"
></pro-icon-picker>
</a-form-item>
</a-col>
<a-col :span="12">
<a-form-item ref="i18n" label="i18n" name="i18n">
<a-input v-model:value="formState.i18n" />
</a-form-item>
</a-col>
<a-col :span="12">
<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-col>
<a-col :span="12">
<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>
</a-form>
</a-modal>
</template>
<script>
import {
message
} from "@hwork/ant-design-vue";
import {
save,
tree
} from "@/api/module/power";
import {
defineComponent,
reactive,
ref,
toRaw,
watch
} from "vue";
import { message } from "@hwork/ant-design-vue";
import { save, tree } from "@/api/module/power";
import { defineComponent, reactive, ref, toRaw, watch } from "vue";
export default defineComponent({
props: {
visible: {
@ -80,12 +110,11 @@
},
emit: ["close"],
setup(props, context) {
const state = reactive({
depts: [],
showComponent: true,
showPath: true,
showCode: false
showCode: false,
});
const formRef = ref();
@ -98,31 +127,41 @@
});
const formRules = {
title: [{
title: [
{
required: true,
message: "请输入权限名称",
trigger: "blur"
}],
i18n: [{
trigger: "blur",
},
],
i18n: [
{
required: true,
message: "请输入 i18n",
trigger: "blur"
}],
type: [{
trigger: "blur",
},
],
type: [
{
required: true,
message: "请输入权限类型",
trigger: "blur"
}],
clientType: [{
trigger: "blur",
},
],
clientType: [
{
required: true,
message: "请选择权限终端类型",
trigger: "blur"
}],
parent: [{
trigger: "blur",
},
],
parent: [
{
required: true,
message: "请选择上级权限",
trigger: "change"
}],
trigger: "change",
},
],
};
const submit = (e) => {
@ -131,17 +170,21 @@
.then(() => {
save(toRaw(formState)).then((response) => {
if (response.success) {
message.success({
message
.success({
content: "保存成功",
duration: 1
}).then(() => {
duration: 1,
})
.then(() => {
cancel();
});
} else {
message.success({
message
.success({
content: "保存失败",
duration: 1
}).then(() => {
duration: 1,
})
.then(() => {
cancel();
});
}
@ -159,17 +202,19 @@
const loadPower = () => {
tree({}).then((response) => {
response.data = [{
response.data = [
{
id: "0",
title: "顶级菜单",
children: response.data
}]
children: response.data,
},
];
state.powers = response.data;
});
};
const change = function (val) {
if (val === '2') {
if (val === "2") {
state.showComponent = false;
state.showPath = false;
state.showCode = true;
@ -178,7 +223,7 @@
state.showPath = true;
state.showCode = false;
}
}
};
loadPower();
@ -192,10 +237,10 @@
formRules,
labelCol: {
span: 6
span: 6,
},
wrapperCol: {
span: 18
span: 18,
},
replaceFields: {