| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342 |
- <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>
|