refactor(Menu.vue): 菜单TypeScirpt类型约束补充
This commit is contained in:
@@ -28,10 +28,10 @@
|
|||||||
<el-table
|
<el-table
|
||||||
v-loading="loading"
|
v-loading="loading"
|
||||||
:data="menuList"
|
:data="menuList"
|
||||||
row-key="id"
|
|
||||||
highlight-current-row
|
highlight-current-row
|
||||||
:tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
|
:tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
|
||||||
@row-click="handleRowClick"
|
@row-click="handleRowClick"
|
||||||
|
row-key="id"
|
||||||
border
|
border
|
||||||
>
|
>
|
||||||
<el-table-column label="菜单名称">
|
<el-table-column label="菜单名称">
|
||||||
@@ -134,11 +134,13 @@
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item label="图标" prop="icon">
|
<el-form-item label="图标" prop="icon">
|
||||||
<el-popover placement="bottom-start" :width="570" trigger="click" v-model:visible="iconSelectVisible" >
|
<el-popover
|
||||||
<icon-select
|
placement="bottom-start"
|
||||||
ref="iconSelectRef"
|
:width="570"
|
||||||
@selected="selected"
|
trigger="click"
|
||||||
/>
|
v-model:visible="iconSelectVisible"
|
||||||
|
>
|
||||||
|
<icon-select ref="iconSelectRef" @selected="selected" />
|
||||||
<template #reference>
|
<template #reference>
|
||||||
<el-input
|
<el-input
|
||||||
v-model="formData.icon"
|
v-model="formData.icon"
|
||||||
@@ -195,18 +197,28 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
|
import { reactive, ref, unref, onMounted, toRefs } from "vue";
|
||||||
|
|
||||||
|
import { Search, Plus, Edit, Refresh, Delete } from "@element-plus/icons-vue";
|
||||||
|
import { ElForm, ElMessage, ElMessageBox } from "element-plus";
|
||||||
|
|
||||||
|
import { isExternal } from "@/utils/validate";
|
||||||
|
import {
|
||||||
|
Dialog,
|
||||||
|
Option,
|
||||||
|
MenuFormData,
|
||||||
|
MenuItem,
|
||||||
|
MenuQueryParam,
|
||||||
|
} from "@/types";
|
||||||
|
// API 依赖
|
||||||
import {
|
import {
|
||||||
listTableMenus,
|
listTableMenus,
|
||||||
getMenuDetail,
|
getMenuFormDetail,
|
||||||
listTreeSelectMenus,
|
listSelectMenus,
|
||||||
addMenu,
|
addMenu,
|
||||||
deleteMenus,
|
deleteMenus,
|
||||||
updateMenu,
|
updateMenu,
|
||||||
} from "@/api/system/menu";
|
} from "@/api/system/menu";
|
||||||
import { Search, Plus, Edit, Refresh, Delete } from "@element-plus/icons-vue";
|
|
||||||
import { ElForm, ElMessage, ElMessageBox } from "element-plus";
|
|
||||||
import { reactive, ref, unref, onMounted, toRefs } from "vue";
|
|
||||||
import { isExternal } from "@/utils/validate";
|
|
||||||
|
|
||||||
import SvgIcon from "@/components/SvgIcon/index.vue";
|
import SvgIcon from "@/components/SvgIcon/index.vue";
|
||||||
import TreeSelect from "@/components/TreeSelect/index.vue";
|
import TreeSelect from "@/components/TreeSelect/index.vue";
|
||||||
@@ -226,34 +238,22 @@ const state = reactive({
|
|||||||
single: true,
|
single: true,
|
||||||
// 非多个禁用
|
// 非多个禁用
|
||||||
multiple: true,
|
multiple: true,
|
||||||
queryParams: {
|
queryParams: {} as MenuQueryParam,
|
||||||
pageNum: 1,
|
menuList: [] as MenuItem[],
|
||||||
pageSize: 10,
|
|
||||||
name: undefined,
|
|
||||||
},
|
|
||||||
menuList: [],
|
|
||||||
total: 0,
|
total: 0,
|
||||||
dialog: {
|
dialog: {visible:false} as Dialog,
|
||||||
title: "",
|
|
||||||
visible: false,
|
|
||||||
},
|
|
||||||
formData: {
|
formData: {
|
||||||
id: undefined,
|
|
||||||
parentId: 0,
|
parentId: 0,
|
||||||
name: "",
|
|
||||||
visible: 1,
|
visible: 1,
|
||||||
icon: "",
|
|
||||||
sort: 1,
|
sort: 1,
|
||||||
component: "Layout",
|
component: "Layout",
|
||||||
path: "",
|
} as MenuFormData,
|
||||||
redirect: "",
|
|
||||||
},
|
|
||||||
rules: {
|
rules: {
|
||||||
parentId: [{ required: true, message: "请选择顶级菜单", trigger: "blur" }],
|
parentId: [{ required: true, message: "请选择顶级菜单", trigger: "blur" }],
|
||||||
name: [{ required: true, message: "请输入菜单名称", trigger: "blur" }],
|
name: [{ required: true, message: "请输入菜单名称", trigger: "blur" }],
|
||||||
component: [{ required: true, message: "请输入页面路径", trigger: "blur" }],
|
component: [{ required: true, message: "请输入页面路径", trigger: "blur" }],
|
||||||
},
|
},
|
||||||
menuOptions: [] as any[],
|
menuOptions: [] as Option[],
|
||||||
currentRow: undefined,
|
currentRow: undefined,
|
||||||
isExternalPath: false,
|
isExternalPath: false,
|
||||||
iconSelectVisible: false,
|
iconSelectVisible: false,
|
||||||
@@ -281,10 +281,8 @@ function handleQuery() {
|
|||||||
// 重置父组件
|
// 重置父组件
|
||||||
emit("menuClick", null);
|
emit("menuClick", null);
|
||||||
state.loading = true;
|
state.loading = true;
|
||||||
listTableMenus(state.queryParams).then((response) => {
|
listTableMenus(state.queryParams).then(({ data }) => {
|
||||||
const { data, total } = response as any;
|
|
||||||
state.menuList = data;
|
state.menuList = data;
|
||||||
state.total = total;
|
|
||||||
state.loading = false;
|
state.loading = false;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -294,8 +292,8 @@ function handleQuery() {
|
|||||||
*/
|
*/
|
||||||
async function loadTreeSelectMenuOptions() {
|
async function loadTreeSelectMenuOptions() {
|
||||||
const menuOptions: any[] = [];
|
const menuOptions: any[] = [];
|
||||||
await listTreeSelectMenus().then((response) => {
|
await listSelectMenus().then(({ data }) => {
|
||||||
const menuOption = { id: 0, label: "顶级菜单", children: response.data };
|
const menuOption = { value: 0, label: "顶级菜单", children: data };
|
||||||
menuOptions.push(menuOption);
|
menuOptions.push(menuOption);
|
||||||
state.menuOptions = menuOptions;
|
state.menuOptions = menuOptions;
|
||||||
});
|
});
|
||||||
@@ -305,8 +303,7 @@ async function loadTreeSelectMenuOptions() {
|
|||||||
* 重置查询
|
* 重置查询
|
||||||
*/
|
*/
|
||||||
function resetQuery() {
|
function resetQuery() {
|
||||||
const queryForm = unref(queryFormRef);
|
queryFormRef.value.resetFields();
|
||||||
queryForm.resetFields();
|
|
||||||
handleQuery();
|
handleQuery();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -317,6 +314,8 @@ function handleSelectionChange(selection: any) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function handleRowClick(row: any) {
|
function handleRowClick(row: any) {
|
||||||
|
|
||||||
|
console.log('handleRowClick',row)
|
||||||
state.currentRow = JSON.parse(JSON.stringify(row));
|
state.currentRow = JSON.parse(JSON.stringify(row));
|
||||||
emit("menuClick", row);
|
emit("menuClick", row);
|
||||||
}
|
}
|
||||||
@@ -354,17 +353,19 @@ async function handleUpdate(row: any) {
|
|||||||
visible: true,
|
visible: true,
|
||||||
};
|
};
|
||||||
const id = row.id || state.ids;
|
const id = row.id || state.ids;
|
||||||
getMenuDetail(id).then((response) => {
|
getMenuFormDetail(id).then(({ data }) => {
|
||||||
state.formData = response.data;
|
state.formData = data;
|
||||||
const path = state.formData.path as string;
|
// 判断是否外部链接
|
||||||
state.isExternalPath = isExternal(path);
|
state.isExternalPath = isExternal(state.formData.path);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 表单提交
|
||||||
|
*/
|
||||||
function submitForm() {
|
function submitForm() {
|
||||||
const dataForm = unref(dataFormRef);
|
dataFormRef.value.validate((isValid: boolean) => {
|
||||||
dataForm.validate((valid: any) => {
|
if (isValid) {
|
||||||
if (valid) {
|
|
||||||
if (state.formData.id) {
|
if (state.formData.id) {
|
||||||
updateMenu(state.formData.id, state.formData).then((response) => {
|
updateMenu(state.formData.id, state.formData).then((response) => {
|
||||||
ElMessage.success("修改成功");
|
ElMessage.success("修改成功");
|
||||||
@@ -398,29 +399,34 @@ function handleDelete(row: any) {
|
|||||||
.catch(() => ElMessage.info("已取消删除"));
|
.catch(() => ElMessage.info("已取消删除"));
|
||||||
}
|
}
|
||||||
|
|
||||||
// 重置表单
|
/**
|
||||||
|
* 重置表单
|
||||||
|
*/
|
||||||
function resetForm() {
|
function resetForm() {
|
||||||
dataFormRef.value.resetFields();
|
dataFormRef.value.resetFields();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 取消关闭弹窗
|
||||||
|
*/
|
||||||
function cancel() {
|
function cancel() {
|
||||||
state.dialog.visible = false;
|
state.dialog.visible = false;
|
||||||
resetForm();
|
resetForm();
|
||||||
}
|
}
|
||||||
|
|
||||||
function showIconSelect(){
|
/**
|
||||||
|
* 显示图标选择下拉
|
||||||
|
*/
|
||||||
|
function showIconSelect() {
|
||||||
state.iconSelectVisible = true;
|
state.iconSelectVisible = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function selected(name: string) {
|
function selected(name: string) {
|
||||||
state.formData.icon = name;
|
state.formData.icon = name;
|
||||||
state.iconSelectVisible=false
|
state.iconSelectVisible = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
handleQuery();
|
handleQuery();
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped>
|
|
||||||
</style>
|
|
||||||
|
|||||||
Reference in New Issue
Block a user