mirror of
https://github.com/pure-admin/vue-pure-admin.git
synced 2025-06-04 07:27:41 +08:00
343 lines
9.3 KiB
Vue
343 lines
9.3 KiB
Vue
<script setup lang="ts">
|
|
import { ref } from "vue";
|
|
import ReCol from "@/components/ReCol";
|
|
import { formRules } from "./utils/rule";
|
|
import { FormProps } from "./utils/types";
|
|
import { transformI18n } from "@/plugins/i18n";
|
|
import { IconSelect } from "@/components/ReIcon";
|
|
import Segmented from "@/components/ReSegmented";
|
|
import ReAnimateSelector from "@/components/ReAnimateSelector";
|
|
import {
|
|
menuTypeOptions,
|
|
showLinkOptions,
|
|
fixedTagOptions,
|
|
keepAliveOptions,
|
|
hiddenTagOptions,
|
|
showParentOptions,
|
|
frameLoadingOptions
|
|
} from "./utils/enums";
|
|
|
|
const props = withDefaults(defineProps<FormProps>(), {
|
|
formInline: () => ({
|
|
menuType: 0,
|
|
higherMenuOptions: [],
|
|
parentId: 0,
|
|
title: "",
|
|
name: "",
|
|
path: "",
|
|
component: "",
|
|
rank: 99,
|
|
redirect: "",
|
|
icon: "",
|
|
extraIcon: "",
|
|
enterTransition: "",
|
|
leaveTransition: "",
|
|
activePath: "",
|
|
auths: "",
|
|
frameSrc: "",
|
|
frameLoading: true,
|
|
keepAlive: false,
|
|
hiddenTag: false,
|
|
fixedTag: false,
|
|
showLink: true,
|
|
showParent: false
|
|
})
|
|
});
|
|
|
|
const ruleFormRef = ref();
|
|
const newFormInline = ref(props.formInline);
|
|
|
|
function getRef() {
|
|
return ruleFormRef.value;
|
|
}
|
|
|
|
defineExpose({ getRef });
|
|
</script>
|
|
|
|
<template>
|
|
<el-form
|
|
ref="ruleFormRef"
|
|
:model="newFormInline"
|
|
:rules="formRules"
|
|
label-width="82px"
|
|
>
|
|
<el-row :gutter="30">
|
|
<re-col>
|
|
<el-form-item label="菜单类型">
|
|
<Segmented
|
|
v-model="newFormInline.menuType"
|
|
:options="menuTypeOptions"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col>
|
|
<el-form-item label="上级菜单">
|
|
<el-cascader
|
|
v-model="newFormInline.parentId"
|
|
class="w-full"
|
|
:options="newFormInline.higherMenuOptions"
|
|
:props="{
|
|
value: 'id',
|
|
label: 'title',
|
|
emitPath: false,
|
|
checkStrictly: true
|
|
}"
|
|
clearable
|
|
filterable
|
|
placeholder="请选择上级菜单"
|
|
>
|
|
<template #default="{ node, data }">
|
|
<span>{{ transformI18n(data.title) }}</span>
|
|
<span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
|
|
</template>
|
|
</el-cascader>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="菜单名称" prop="title">
|
|
<el-input
|
|
v-model="newFormInline.title"
|
|
clearable
|
|
placeholder="请输入菜单名称"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
<re-col v-if="newFormInline.menuType !== 3" :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="路由名称" prop="name">
|
|
<el-input
|
|
v-model="newFormInline.name"
|
|
clearable
|
|
placeholder="请输入路由名称"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col v-if="newFormInline.menuType !== 3" :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="路由路径" prop="path">
|
|
<el-input
|
|
v-model="newFormInline.path"
|
|
clearable
|
|
placeholder="请输入路由路径"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
<re-col
|
|
v-show="newFormInline.menuType === 0"
|
|
:value="12"
|
|
:xs="24"
|
|
:sm="24"
|
|
>
|
|
<el-form-item label="组件路径">
|
|
<el-input
|
|
v-model="newFormInline.component"
|
|
clearable
|
|
placeholder="请输入组件路径"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="菜单排序">
|
|
<el-input-number
|
|
v-model="newFormInline.rank"
|
|
class="w-full!"
|
|
:min="1"
|
|
:max="9999"
|
|
controls-position="right"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
<re-col
|
|
v-show="newFormInline.menuType === 0"
|
|
:value="12"
|
|
:xs="24"
|
|
:sm="24"
|
|
>
|
|
<el-form-item label="路由重定向">
|
|
<el-input
|
|
v-model="newFormInline.redirect"
|
|
clearable
|
|
placeholder="请输入默认跳转地址"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col
|
|
v-show="newFormInline.menuType !== 3"
|
|
:value="12"
|
|
:xs="24"
|
|
:sm="24"
|
|
>
|
|
<el-form-item label="菜单图标">
|
|
<IconSelect v-model="newFormInline.icon" class="w-full" />
|
|
</el-form-item>
|
|
</re-col>
|
|
<re-col
|
|
v-show="newFormInline.menuType !== 3"
|
|
:value="12"
|
|
:xs="24"
|
|
:sm="24"
|
|
>
|
|
<el-form-item label="右侧图标">
|
|
<el-input
|
|
v-model="newFormInline.extraIcon"
|
|
clearable
|
|
placeholder="菜单名称右侧的额外图标"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col v-show="newFormInline.menuType < 2" :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="进场动画">
|
|
<ReAnimateSelector
|
|
v-model="newFormInline.enterTransition"
|
|
placeholder="请选择页面进场加载动画"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
<re-col v-show="newFormInline.menuType < 2" :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="离场动画">
|
|
<ReAnimateSelector
|
|
v-model="newFormInline.leaveTransition"
|
|
placeholder="请选择页面离场加载动画"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col
|
|
v-show="newFormInline.menuType === 0"
|
|
:value="12"
|
|
:xs="24"
|
|
:sm="24"
|
|
>
|
|
<el-form-item label="菜单激活">
|
|
<el-input
|
|
v-model="newFormInline.activePath"
|
|
clearable
|
|
placeholder="请输入需要激活的菜单"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
<re-col v-if="newFormInline.menuType === 3" :value="12" :xs="24" :sm="24">
|
|
<!-- 按钮级别权限设置 -->
|
|
<el-form-item label="权限标识" prop="auths">
|
|
<el-input
|
|
v-model="newFormInline.auths"
|
|
clearable
|
|
placeholder="请输入权限标识"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col
|
|
v-show="newFormInline.menuType === 1"
|
|
:value="12"
|
|
:xs="24"
|
|
:sm="24"
|
|
>
|
|
<!-- iframe -->
|
|
<el-form-item label="链接地址">
|
|
<el-input
|
|
v-model="newFormInline.frameSrc"
|
|
clearable
|
|
placeholder="请输入 iframe 链接地址"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
<re-col v-if="newFormInline.menuType === 1" :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="加载动画">
|
|
<Segmented
|
|
:modelValue="newFormInline.frameLoading ? 0 : 1"
|
|
:options="frameLoadingOptions"
|
|
@change="
|
|
({ option: { value } }) => {
|
|
newFormInline.frameLoading = value;
|
|
}
|
|
"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col
|
|
v-show="newFormInline.menuType !== 3"
|
|
:value="12"
|
|
:xs="24"
|
|
:sm="24"
|
|
>
|
|
<el-form-item label="菜单">
|
|
<Segmented
|
|
:modelValue="newFormInline.showLink ? 0 : 1"
|
|
:options="showLinkOptions"
|
|
@change="
|
|
({ option: { value } }) => {
|
|
newFormInline.showLink = value;
|
|
}
|
|
"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
<re-col
|
|
v-show="newFormInline.menuType !== 3"
|
|
:value="12"
|
|
:xs="24"
|
|
:sm="24"
|
|
>
|
|
<el-form-item label="父级菜单">
|
|
<Segmented
|
|
:modelValue="newFormInline.showParent ? 0 : 1"
|
|
:options="showParentOptions"
|
|
@change="
|
|
({ option: { value } }) => {
|
|
newFormInline.showParent = value;
|
|
}
|
|
"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col v-show="newFormInline.menuType < 2" :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="缓存页面">
|
|
<Segmented
|
|
:modelValue="newFormInline.keepAlive ? 0 : 1"
|
|
:options="keepAliveOptions"
|
|
@change="
|
|
({ option: { value } }) => {
|
|
newFormInline.keepAlive = value;
|
|
}
|
|
"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
|
|
<re-col v-show="newFormInline.menuType < 2" :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="标签页">
|
|
<Segmented
|
|
:modelValue="newFormInline.hiddenTag ? 1 : 0"
|
|
:options="hiddenTagOptions"
|
|
@change="
|
|
({ option: { value } }) => {
|
|
newFormInline.hiddenTag = value;
|
|
}
|
|
"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
<re-col v-show="newFormInline.menuType < 2" :value="12" :xs="24" :sm="24">
|
|
<el-form-item label="固定标签页">
|
|
<Segmented
|
|
:modelValue="newFormInline.fixedTag ? 0 : 1"
|
|
:options="fixedTagOptions"
|
|
@change="
|
|
({ option: { value } }) => {
|
|
newFormInline.fixedTag = value;
|
|
}
|
|
"
|
|
/>
|
|
</el-form-item>
|
|
</re-col>
|
|
</el-row>
|
|
</el-form>
|
|
</template>
|