385 lines
8.5 KiB
TypeScript
385 lines
8.5 KiB
TypeScript
|
import {BasicColumn} from '/@/components/Table';
|
||
|
import {FormSchema} from '/@/components/Table';
|
||
|
import {h} from 'vue';
|
||
|
import {Icon} from '/@/components/Icon';
|
||
|
import {duplicateCheck} from "../user/user.api";
|
||
|
import {ajaxGetDictItems} from "./menu.api";
|
||
|
import {render} from "/@/utils/common/renderUtils";
|
||
|
import { Select } from 'ant-design-vue';
|
||
|
const isDir = (type) => type === 0;
|
||
|
const isMenu = (type) => type === 1;
|
||
|
const isButton = (type) => type === 2;
|
||
|
|
||
|
// 定义可选择的组件类型
|
||
|
export enum ComponentTypes {
|
||
|
Default = 'layouts/default/index',
|
||
|
IFrame = 'sys/iframe/FrameBlank',
|
||
|
}
|
||
|
|
||
|
export const columns: BasicColumn[] = [
|
||
|
{
|
||
|
title: '菜单名称',
|
||
|
dataIndex: 'name',
|
||
|
width: 200,
|
||
|
align: 'left',
|
||
|
},
|
||
|
{
|
||
|
title: '菜单类型',
|
||
|
dataIndex: 'menuType',
|
||
|
width: 150,
|
||
|
customRender: ({text}) => {
|
||
|
return render.renderDict(text, 'menu_type')
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
title: '图标',
|
||
|
dataIndex: 'icon',
|
||
|
width: 50,
|
||
|
customRender: ({record}) => {
|
||
|
return h(Icon, {icon: record.icon});
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
title: '组件',
|
||
|
dataIndex: 'component',
|
||
|
align: 'left',
|
||
|
width: 150,
|
||
|
},
|
||
|
{
|
||
|
title: '路径',
|
||
|
dataIndex: 'url',
|
||
|
align: 'left',
|
||
|
width: 150,
|
||
|
},
|
||
|
{
|
||
|
title: '排序',
|
||
|
dataIndex: 'sortNo',
|
||
|
width: 50,
|
||
|
}
|
||
|
];
|
||
|
|
||
|
export const searchFormSchema: FormSchema[] = [
|
||
|
{
|
||
|
field: 'name',
|
||
|
label: '菜单名称',
|
||
|
component: 'Input',
|
||
|
colProps: {span: 8},
|
||
|
}
|
||
|
];
|
||
|
|
||
|
export const formSchema: FormSchema[] = [
|
||
|
{
|
||
|
label: 'id',
|
||
|
field: 'id',
|
||
|
component: 'Input',
|
||
|
show: false
|
||
|
},
|
||
|
{
|
||
|
field: 'menuType',
|
||
|
label: '菜单类型',
|
||
|
component: 'RadioButtonGroup',
|
||
|
defaultValue: 0,
|
||
|
componentProps: ({formActionType}) => {
|
||
|
return {
|
||
|
options: [
|
||
|
{label: '一级菜单', value: 0},
|
||
|
{label: '子菜单', value: 1},
|
||
|
{label: '按钮/权限', value: 2},
|
||
|
],
|
||
|
onChange: e => {
|
||
|
const {updateSchema,clearValidate} = formActionType
|
||
|
const label = isButton(e) ? '按钮/权限' : '菜单名称';
|
||
|
//清除校验
|
||
|
clearValidate();
|
||
|
updateSchema([{
|
||
|
field: 'name',
|
||
|
label: label
|
||
|
},{
|
||
|
field: 'url',
|
||
|
required: !isButton(e)
|
||
|
}]);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
field: 'name',
|
||
|
label: '菜单名称',
|
||
|
component: 'Input',
|
||
|
required: true,
|
||
|
},
|
||
|
{
|
||
|
field: 'parentId',
|
||
|
label: '上级菜单',
|
||
|
component: 'TreeSelect',
|
||
|
required: true,
|
||
|
componentProps: {
|
||
|
replaceFields: {
|
||
|
title: 'name',
|
||
|
key: 'id',
|
||
|
value: 'id',
|
||
|
},
|
||
|
dropdownStyle:{
|
||
|
maxHeight:'50vh'
|
||
|
},
|
||
|
getPopupContainer: (node) => node.parentNode
|
||
|
},
|
||
|
ifShow: ({values}) => !isDir(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'url',
|
||
|
label: '访问路径',
|
||
|
component: 'Input',
|
||
|
required: true,
|
||
|
ifShow: ({ values }) => !(values.component === ComponentTypes.IFrame && values.internalOrExternal),
|
||
|
},
|
||
|
{
|
||
|
field: 'component',
|
||
|
label: '前端组件',
|
||
|
component: 'Input',
|
||
|
componentProps: {
|
||
|
placeholder:'请输入前端组件'
|
||
|
},
|
||
|
required: true,
|
||
|
ifShow: ({values}) => !isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'frameSrc',
|
||
|
label: 'Iframe地址',
|
||
|
component: 'Input',
|
||
|
rules: [
|
||
|
{ required: true, message: '请输入Iframe地址' },
|
||
|
{ type: 'url', message: '请输入正确的url地址' },
|
||
|
],
|
||
|
ifShow: ({ values }) => !isButton(values.menuType) && values.component === ComponentTypes.IFrame,
|
||
|
},
|
||
|
{
|
||
|
field: 'redirect',
|
||
|
label: '默认跳转地址',
|
||
|
component: 'Input',
|
||
|
ifShow: ({values}) => isDir(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'perms',
|
||
|
label: '授权标识',
|
||
|
component: 'Input',
|
||
|
ifShow: ({values}) => isButton(values.menuType),
|
||
|
dynamicRules: ({model}) => {
|
||
|
return [
|
||
|
{
|
||
|
required: false,
|
||
|
validator: (_, value) => {
|
||
|
return new Promise((resolve, reject) => {
|
||
|
let params = {
|
||
|
tableName: "sys_permission",
|
||
|
fieldName: "perms",
|
||
|
fieldVal: value,
|
||
|
dataId: model.id,
|
||
|
};
|
||
|
duplicateCheck(params)
|
||
|
.then((res) => {
|
||
|
res.success ? resolve() : reject(res.message || '校验失败');
|
||
|
}).catch((err) => {
|
||
|
reject(err.message || '校验失败');
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
},
|
||
|
];
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
field: 'permsType',
|
||
|
label: '授权策略',
|
||
|
component: 'RadioGroup',
|
||
|
defaultValue: '1',
|
||
|
helpMessage: ['可见/可访问(授权后可见/可访问)', '可编辑(未授权时禁用)'],
|
||
|
componentProps: {
|
||
|
options: [
|
||
|
{label: '可见/可访问', value: '1'},
|
||
|
{label: '可编辑', value: '2'},
|
||
|
],
|
||
|
},
|
||
|
ifShow: ({values}) => isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'status',
|
||
|
label: '状态',
|
||
|
component: 'RadioGroup',
|
||
|
defaultValue: '1',
|
||
|
componentProps: {
|
||
|
options: [
|
||
|
{label: '有效', value: '1'},
|
||
|
{label: '无效', value: '0'},
|
||
|
],
|
||
|
},
|
||
|
ifShow: ({values}) => isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'icon',
|
||
|
label: '菜单图标',
|
||
|
component: 'IconPicker',
|
||
|
ifShow: ({values}) => !isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'sortNo',
|
||
|
label: '排序',
|
||
|
component: 'InputNumber',
|
||
|
defaultValue: 1,
|
||
|
ifShow: ({values}) => !isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'route',
|
||
|
label: '是否路由菜单',
|
||
|
component: 'Switch',
|
||
|
defaultValue: true,
|
||
|
componentProps: {
|
||
|
checkedChildren: "是",
|
||
|
unCheckedChildren: "否"
|
||
|
},
|
||
|
ifShow: ({values}) => !isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'hidden',
|
||
|
label: '隐藏路由',
|
||
|
component: 'Switch',
|
||
|
defaultValue: 0,
|
||
|
componentProps: {
|
||
|
checkedChildren: "是",
|
||
|
unCheckedChildren: "否"
|
||
|
},
|
||
|
ifShow: ({values}) => !isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'hideTab',
|
||
|
label: '隐藏Tab',
|
||
|
component: 'Switch',
|
||
|
defaultValue: 0,
|
||
|
componentProps: {
|
||
|
checkedChildren: '是',
|
||
|
unCheckedChildren: '否',
|
||
|
},
|
||
|
ifShow: ({ values }) => !isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'keepAlive',
|
||
|
label: '是否缓存路由',
|
||
|
component: 'Switch',
|
||
|
defaultValue: false,
|
||
|
componentProps: {
|
||
|
checkedChildren: "是",
|
||
|
unCheckedChildren: "否"
|
||
|
},
|
||
|
ifShow: ({values}) => !isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'alwaysShow',
|
||
|
label: '聚合路由',
|
||
|
component: 'Switch',
|
||
|
defaultValue: false,
|
||
|
componentProps: {
|
||
|
checkedChildren: "是",
|
||
|
unCheckedChildren: "否"
|
||
|
},
|
||
|
ifShow: ({values}) => !isButton(values.menuType),
|
||
|
},
|
||
|
{
|
||
|
field: 'internalOrExternal',
|
||
|
label: '打开方式',
|
||
|
component: 'Switch',
|
||
|
defaultValue: false,
|
||
|
componentProps: {
|
||
|
checkedChildren: "外部",
|
||
|
unCheckedChildren: "内部"
|
||
|
},
|
||
|
ifShow: ({values}) => !isButton(values.menuType),
|
||
|
}
|
||
|
];
|
||
|
|
||
|
export const dataRuleColumns: BasicColumn[] = [
|
||
|
{
|
||
|
title: '规则名称',
|
||
|
dataIndex: 'ruleName',
|
||
|
width: 150,
|
||
|
},
|
||
|
{
|
||
|
title: '规则字段',
|
||
|
dataIndex: 'ruleColumn',
|
||
|
width: 100,
|
||
|
},
|
||
|
{
|
||
|
title: '规则值',
|
||
|
dataIndex: 'ruleValue',
|
||
|
width: 100,
|
||
|
}
|
||
|
];
|
||
|
|
||
|
export const dataRuleSearchFormSchema: FormSchema[] = [
|
||
|
{
|
||
|
field: 'ruleName',
|
||
|
label: '规则名称',
|
||
|
component: 'Input',
|
||
|
colProps: {span: 6},
|
||
|
},
|
||
|
{
|
||
|
field: 'ruleValue',
|
||
|
label: '规则值',
|
||
|
component: 'Input',
|
||
|
colProps: {span: 6},
|
||
|
}
|
||
|
];
|
||
|
|
||
|
export const dataRuleFormSchema: FormSchema[] = [
|
||
|
{
|
||
|
label: 'id',
|
||
|
field: 'id',
|
||
|
component: 'Input',
|
||
|
show: false
|
||
|
},
|
||
|
{
|
||
|
field: 'ruleName',
|
||
|
label: '规则名称',
|
||
|
component: 'Input',
|
||
|
required: true,
|
||
|
},
|
||
|
{
|
||
|
field: 'ruleColumn',
|
||
|
label: '规则字段',
|
||
|
component: 'Input',
|
||
|
ifShow: ({values}) => {
|
||
|
return values.ruleConditions !== 'USE_SQL_RULES'
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
field: 'ruleConditions',
|
||
|
label: '条件规则',
|
||
|
required: true,
|
||
|
component: 'ApiSelect',
|
||
|
componentProps: {
|
||
|
api: ajaxGetDictItems,
|
||
|
params:{code:'rule_conditions'},
|
||
|
labelField: 'text',
|
||
|
valueField: 'value',
|
||
|
getPopupContainer: (node) => document.body,
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
field: 'ruleValue',
|
||
|
label: '规则值',
|
||
|
component: 'Input',
|
||
|
required: true,
|
||
|
},
|
||
|
{
|
||
|
field: 'status',
|
||
|
label: '状态',
|
||
|
component: 'RadioButtonGroup',
|
||
|
defaultValue: '1',
|
||
|
componentProps: {
|
||
|
options: [
|
||
|
{label: '无效', value: '0'},
|
||
|
{label: '有效', value: '1'},
|
||
|
],
|
||
|
}
|
||
|
}
|
||
|
];
|