增加路由和material图标

This commit is contained in:
Gary Fu
2023-12-24 15:42:48 +08:00
parent f4f25798b9
commit 9b777948c9
16 changed files with 242 additions and 45 deletions

View File

@@ -8,7 +8,10 @@ defineProps({
</script>
<template>
<el-icon v-if="icon">
<el-icon
v-if="icon"
v-bind="$attrs"
>
<component
:is="icon"
/>

View File

@@ -1,5 +1,7 @@
<script setup>
defineProps({
import { computed } from 'vue'
const props = defineProps({
menuItem: {
type: Object,
required: true
@@ -9,25 +11,41 @@ defineProps({
required: false
}
})
const isSubMenu = computed(() => {
const menuItem = props.menuItem
return !menuItem.isDropdown && menuItem.children && menuItem.children.length
})
const isDropdown = computed(() => {
const menuItem = props.menuItem
return menuItem.isDropdown && menuItem.children && menuItem.children.length
})
const menuCls = computed(() => {
const menuItem = props.menuItem
if (!menuItem.menuCls && menuItem.isDropdown) {
return 'padding-left1 padding-right1'
}
return menuItem.menuCls
})
</script>
<template>
<div
v-if="menuItem.isSplit"
:key="menuItem.index||index"
:class="menuItem.menuCls"
:class="menuCls"
>
{{ menuItem.splitText }}
</div>
<el-sub-menu
v-else-if="menuItem.children && menuItem.children.length"
v-else-if="isSubMenu"
:key="menuItem.index||index"
:index="`${menuItem.index||index}`"
:class="menuItem.menuCls"
:class="menuCls"
v-bind="menuItem.attrs"
>
<template #title>
<common-icon
:size="menuItem.iconSize"
:icon="menuItem.icon"
/>
<span v-if="menuItem.labelKey||menuItem.label">
@@ -45,15 +63,48 @@ defineProps({
:menu-item="childMenu"
/>
</el-sub-menu>
<el-menu-item
v-else-if="isDropdown"
:key="menuItem.index||index"
:class="menuCls"
>
<el-dropdown>
<span class="el-dropdown-link">
<common-icon
:size="menuItem.iconSize"
:icon="menuItem.icon"
/>
<span v-if="menuItem.labelKey||menuItem.label">
{{ menuItem.labelKey?$t(menuItem.labelKey):menuItem.label }}
</span>
</span>
<template #dropdown>
<el-dropdown-item
v-for="(childMenu, childIdx) in menuItem.children"
:key="childMenu.index||childIdx"
@click="childMenu.click&&childMenu.click()"
>
<common-icon
:size="childMenu.iconSize"
:icon="childMenu.icon"
/>
<span v-if="childMenu.labelKey||childMenu.label">
{{ childMenu.labelKey?$t(childMenu.labelKey):childMenu.label }}
</span>
</el-dropdown-item>
</template>
</el-dropdown>
</el-menu-item>
<el-menu-item
v-else
:class="menuItem.menuCls"
:class="menuCls"
:route="menuItem.route"
v-bind="menuItem.attrs"
:index="menuItem.index"
@click="menuItem.click&&menuItem.click()"
>
<common-icon
:size="menuItem.iconSize"
:icon="menuItem.icon"
/>
<template #title>

View File

@@ -1,34 +1,16 @@
<script setup>
import { computed } from 'vue'
import { filterMenus } from '@/components/utils'
const props = defineProps({
menus: {
type: Array,
required: true
},
collapse: {
type: Boolean
}
})
const menuItems = computed(() => {
return filterMenus(props.menus)
})
const calcWithIf = menuItem => {
['icon', 'labelKey', 'label', 'html'].forEach(key => {
const keyIf = menuItem[`${key}If`]
if (keyIf) {
menuItem[key] = keyIf(menuItem)
}
})
}
const filterMenus = menus => menus.filter(menu => !menu.disabled)
.map(menu => {
calcWithIf(menu)
if (menu.children && menu.children.length) {
menu.children = filterMenus(menu.children)
}
return menu
})
</script>
<template>
@@ -36,8 +18,8 @@ const filterMenus = menus => menus.filter(menu => !menu.disabled)
v-bind="$attrs"
:default-active="$route.path"
router
:collapse="collapse"
>
<slot name="before" />
<template
v-for="(menuItem, index) in menuItems"
:key="index"
@@ -47,6 +29,7 @@ const filterMenus = menus => menus.filter(menu => !menu.disabled)
:index="index"
/>
</template>
<slot name="default" />
</el-menu>
</template>

View File

@@ -0,0 +1,16 @@
const calcWithIf = menuItem => {
['icon', 'labelKey', 'label', 'html'].forEach(key => {
const keyIf = menuItem[`${key}If`]
if (keyIf) {
menuItem[key] = keyIf(menuItem)
}
})
}
export const filterMenus = menus => menus.filter(menu => !menu.disabled)
.map(menu => {
calcWithIf(menu)
if (menu.children && menu.children.length) {
menu.children = filterMenus(menu.children)
}
return menu
})