'admin-21.01.05:新增vuex,编写布局配置相对应功能'

This commit is contained in:
lyt 2021-01-05 18:11:13 +08:00
parent e9f6aae01e
commit c0a369c6d0
11 changed files with 228 additions and 89 deletions

View File

@ -10,7 +10,8 @@
"mitt": "^2.1.0", "mitt": "^2.1.0",
"sortablejs": "^1.10.2", "sortablejs": "^1.10.2",
"vue": "^3.0.5", "vue": "^3.0.5",
"vue-router": "^4.0.2" "vue-router": "^4.0.2",
"vuex": "^4.0.0-rc.2"
}, },
"devDependencies": { "devDependencies": {
"@types/sortablejs": "^1.10.6", "@types/sortablejs": "^1.10.6",

View File

@ -1,6 +1,7 @@
import { createApp } from 'vue' import { createApp } from 'vue'
import App from './App.vue' import App from './App.vue'
import router from './router' import router from './router'
import { store, key } from './store'
import ElementPlus from 'element-plus' import ElementPlus from 'element-plus'
import 'element-plus/lib/theme-chalk/index.css' import 'element-plus/lib/theme-chalk/index.css'
@ -9,5 +10,5 @@ import lang from 'element-plus/lib/locale/lang/zh-cn'
import mitt from "mitt" import mitt from "mitt"
const app = createApp(App) const app = createApp(App)
app.use(router).use(ElementPlus, { locale: lang }).mount('#app') app.use(router).use(store, key).use(ElementPlus, { locale: lang }).mount('#app')
app.config.globalProperties.mittBus = mitt() app.config.globalProperties.mittBus = mitt()

View File

@ -1 +1,47 @@
const bb: string = '' import { InjectionKey } from 'vue'
import { createStore, useStore as baseUseStore, Store } from 'vuex'
import themeConfig from '../utils/themeConfig'
export interface RootStateTypes {
themeConfig: {
isDrawer: boolean,
primary: string,
success: string,
info: string,
warning: string,
danger: string,
topBar: string,
menuBar: string,
topBarColor: string,
menuBarColor: string,
isTopBarColorGradual: boolean,
isMenuBarColorGradual: boolean,
isMenuBarColorHighlight: boolean,
isCollapse: boolean,
isUniqueOpened: boolean,
isFixedHeader: boolean,
isCollapse1: boolean,
menuWidth: number,
}
}
export const key: InjectionKey<Store<RootStateTypes>> = Symbol()
export const store = createStore<RootStateTypes>({
state: {
themeConfig
},
mutations: {
getThemeConfig(state: any, data: object) {
state.themeConfig = Object.assign({}, data)
}
},
actions: {
setThemeConfig({ commit }, data: object) {
commit('getThemeConfig', data)
}
}
})
export function useStore() {
return baseUseStore(key)
}

View File

@ -41,13 +41,23 @@ body,
} }
.el-main { .el-main {
padding: 0 !important; padding: 0 !important;
}
.el-main-overflow-unset {
overflow: unset !important; overflow: unset !important;
} }
.el-main-overflow-auto {
overflow: auto !important;
}
.el-scrollbar { .el-scrollbar {
width: 100%; width: 100%;
} }
.layout-aside-width { .layout-aside-width240 {
width: 240px !important; width: 240px !important;
transition: width 0.3s ease;
}
.layout-aside-width64 {
width: 64px !important;
transition: width 0.3s ease;
} }
.layout-scrollbar { .layout-scrollbar {
@extend .el-scrollbar; @extend .el-scrollbar;

View File

@ -0,0 +1,21 @@
// 布局配置
export default {
isDrawer: false,
primary: "#409eff",
success: "#67c23a",
info: "#909399",
warning: "#e6a23c",
danger: "#f56c6c",
topBar: "#ffffff",
menuBar: "#29384d",
topBarColor: "#606266",
menuBarColor: "#e6e6e6",
isTopBarColorGradual: false,
isMenuBarColorGradual: false,
isMenuBarColorHighlight: false,
isCollapse: false,
isUniqueOpened: false,
isFixedHeader: false,
isCollapse1: false,
menuWidth: 240,
}

View File

@ -1,5 +1,5 @@
<template> <template>
<el-aside class="layout-aside-width"> <el-aside :class="isCollapse ? 'layout-aside-width64' : 'layout-aside-width240'">
<el-scrollbar> <el-scrollbar>
<Vertical :menuList="menuList" /> <Vertical :menuList="menuList" />
</el-scrollbar> </el-scrollbar>
@ -8,11 +8,13 @@
<script lang="ts"> <script lang="ts">
import Vertical from "/@/views/layout/navMenu/vertical.vue"; import Vertical from "/@/views/layout/navMenu/vertical.vue";
import { toRefs, reactive } from "vue"; import { toRefs, reactive, computed } from "vue";
import { useStore } from "/@/store/index.ts";
export default { export default {
name: "layoutAside", name: "layoutAside",
components: { Vertical }, components: { Vertical },
setup() { setup() {
const store = useStore();
const state = reactive({ const state = reactive({
menuList: [ menuList: [
{ {
@ -62,7 +64,11 @@ export default {
}, },
], ],
}); });
const isCollapse = computed(() => {
return store.state.themeConfig.isCollapse;
});
return { return {
isCollapse,
...toRefs(state), ...toRefs(state),
}; };
}, },

View File

@ -1,8 +1,9 @@
<template> <template>
<el-main> <el-main :class="getThemeConfig.isFixedHeader ? 'el-main-overflow-auto' : 'el-main-overflow-unset'">
<el-scrollbar class="layout-scrollbar" style="min-height: calc(100vh - 84px);"> <!-- <el-main> -->
<el-scrollbar class="layout-scrollbar" style="min-height: calc(100vh - 84px);" ref="layoutScrollbarRef">
<router-view v-slot="{ Component }"> <router-view v-slot="{ Component }">
<transition appear :name="transitionName" mode="out-in"> <transition :name="transitionName" mode="out-in">
<div :key="key"> <div :key="key">
<keep-alive> <keep-alive>
<component :is="Component" /> <component :is="Component" />
@ -15,21 +16,41 @@
</template> </template>
<script lang="ts"> <script lang="ts">
import { computed, defineComponent, toRefs, reactive } from "vue"; import {
computed,
defineComponent,
toRefs,
reactive,
getCurrentInstance,
watch,
} from "vue";
import { useRoute, onBeforeRouteUpdate } from "vue-router"; import { useRoute, onBeforeRouteUpdate } from "vue-router";
import { useStore } from "/@/store/index.ts";
export default defineComponent({ export default defineComponent({
name: "layoutMain", name: "layoutMain",
setup() { setup() {
const { proxy } = getCurrentInstance();
const store = useStore();
const route = useRoute(); const route = useRoute();
const state = reactive({ const state = reactive({
transitionName: "slide-right", transitionName: "slide-right",
}); });
const getThemeConfig = computed(() => {
return store.state.themeConfig;
});
const key = computed(() => route.path); const key = computed(() => route.path);
onBeforeRouteUpdate((to, from) => { onBeforeRouteUpdate((to, from) => {
state.transitionName = state.transitionName =
to.meta.index > from.meta.index ? "slide-right" : "slide-left"; to.meta.index > from.meta.index ? "slide-right" : "slide-left";
}); });
return { key, ...toRefs(state) }; watch(store.state.themeConfig, (val) => {
proxy.$refs.layoutScrollbarRef.update();
});
return {
getThemeConfig,
key,
...toRefs(state),
};
}, },
}); });
</script> </script>

View File

@ -3,7 +3,7 @@
<Aside /> <Aside />
<el-container> <el-container>
<el-scrollbar> <el-scrollbar>
<div class="layout-container-header-main"> <div class="layout-container-header-main" :class="{'vh100': getThemeConfig.isFixedHeader}">
<Header /> <Header />
<Main /> <Main />
</div> </div>
@ -13,11 +13,22 @@
</template> </template>
<script> <script>
import { computed } from 'vue'
import { useStore } from "/@/store/index.ts";
import Aside from '/@/views/layout/component/aside.vue'; import Aside from '/@/views/layout/component/aside.vue';
import Header from '/@/views/layout/component/header.vue'; import Header from '/@/views/layout/component/header.vue';
import Main from '/@/views/layout/component/main.vue'; import Main from '/@/views/layout/component/main.vue';
export default { export default {
name: 'layoutFashion', name: 'layoutFashion',
components: { Aside, Header, Main } components: { Aside, Header, Main },
setup() {
const store = useStore();
const getThemeConfig = computed(() => {
return store.state.themeConfig;
});
return {
getThemeConfig
}
}
} }
</script> </script>

View File

@ -1,6 +1,7 @@
<template> <template>
<div class="layout-navbars-breadcrumb"> <div class="layout-navbars-breadcrumb">
<i class="el-icon-s-fold layout-navbars-breadcrumb-icon"></i> <i class="layout-navbars-breadcrumb-icon" :class="isCollapse ? 'el-icon-s-unfold' : 'el-icon-s-fold'"
@click="onThemeConfigChange"></i>
<el-breadcrumb> <el-breadcrumb>
<transition-group name="breadcrumb" mode="out-in"> <transition-group name="breadcrumb" mode="out-in">
<el-breadcrumb-item v-for="(v,k) in breadcrumbList" :key="v.meta.title"> <el-breadcrumb-item v-for="(v,k) in breadcrumbList" :key="v.meta.title">
@ -13,11 +14,20 @@
</template> </template>
<script lang="ts"> <script lang="ts">
import { toRefs, reactive, onBeforeMount } from "vue"; import {
toRefs,
reactive,
onBeforeMount,
computed,
getCurrentInstance,
} from "vue";
import { onBeforeRouteUpdate, useRoute, useRouter } from "vue-router"; import { onBeforeRouteUpdate, useRoute, useRouter } from "vue-router";
import { useStore } from "/@/store/index.ts";
export default { export default {
name: "layoutBreadcrumb", name: "layoutBreadcrumb",
setup() { setup() {
const { proxy } = getCurrentInstance();
const store = useStore();
const route = useRoute(); const route = useRoute();
const router = useRouter(); const router = useRouter();
const state = reactive({ const state = reactive({
@ -31,6 +41,14 @@ export default {
if (redirect) router.push(redirect); if (redirect) router.push(redirect);
else router.push(path); else router.push(path);
}; };
const onThemeConfigChange = () => {
proxy.mittBus.emit("onMenuClick");
store.state.themeConfig.isCollapse = !store.state.themeConfig.isCollapse;
store.dispatch("setThemeConfig", store.state.themeConfig);
};
const isCollapse = computed(() => {
return store.state.themeConfig.isCollapse;
});
onBeforeMount(() => { onBeforeMount(() => {
state.breadcrumbList = route.matched; state.breadcrumbList = route.matched;
}); });
@ -38,6 +56,8 @@ export default {
getBreadcrumbList(to.matched); getBreadcrumbList(to.matched);
}); });
return { return {
onThemeConfigChange,
isCollapse,
onBreadcrumbClick, onBreadcrumbClick,
...toRefs(state), ...toRefs(state),
}; };

View File

@ -1,41 +1,41 @@
<template> <template>
<div class="layout-breadcrumb-seting"> <div class="layout-breadcrumb-seting">
<el-drawer title="布局配置" v-model="isDrawer" direction="rtl" destroy-on-close size="240px"> <el-drawer title="布局配置" v-model="getThemeConfig.isDrawer" direction="rtl" destroy-on-close size="240px">
<el-scrollbar class="layout-breadcrumb-seting-bar"> <el-scrollbar class="layout-breadcrumb-seting-bar">
<!-- 全局主题 --> <!-- 全局主题 -->
<el-divider content-position="left">全局主题</el-divider> <el-divider content-position="left">全局主题</el-divider>
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">primary</div> <div class="layout-breadcrumb-seting-bar-flex-label">primary</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-color-picker v-model="primary" size="small" @change="onColorPickerChange('primary')"> <el-color-picker v-model="getThemeConfig.primary" size="small" @change="onColorPickerChange('primary')">
</el-color-picker> </el-color-picker>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">success</div> <div class="layout-breadcrumb-seting-bar-flex-label">success</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-color-picker v-model="success" size="small" @change="onColorPickerChange('success')"> <el-color-picker v-model="getThemeConfig.success" size="small" @change="onColorPickerChange('success')">
</el-color-picker> </el-color-picker>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">info</div> <div class="layout-breadcrumb-seting-bar-flex-label">info</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-color-picker v-model="info" size="small" @change="onColorPickerChange('info')"> <el-color-picker v-model="getThemeConfig.info" size="small" @change="onColorPickerChange('info')">
</el-color-picker> </el-color-picker>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">warning</div> <div class="layout-breadcrumb-seting-bar-flex-label">warning</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-color-picker v-model="warning" size="small" @change="onColorPickerChange('warning')"> <el-color-picker v-model="getThemeConfig.warning" size="small" @change="onColorPickerChange('warning')">
</el-color-picker> </el-color-picker>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">danger</div> <div class="layout-breadcrumb-seting-bar-flex-label">danger</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-color-picker v-model="danger" size="small" @change="onColorPickerChange('danger')"> <el-color-picker v-model="getThemeConfig.danger" size="small" @change="onColorPickerChange('danger')">
</el-color-picker> </el-color-picker>
</div> </div>
</div> </div>
@ -43,47 +43,49 @@
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">顶栏背景</div> <div class="layout-breadcrumb-seting-bar-flex-label">顶栏背景</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-color-picker v-model="topBar" size="small" @change="onBgColorPickerChange('topBar')"> <el-color-picker v-model="getThemeConfig.topBar" size="small" @change="onBgColorPickerChange('topBar')">
</el-color-picker> </el-color-picker>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">菜单背景</div> <div class="layout-breadcrumb-seting-bar-flex-label">菜单背景</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-color-picker v-model="menuBar" size="small" @change="onBgColorPickerChange('menuBar')"> <el-color-picker v-model="getThemeConfig.menuBar" size="small" @change="onBgColorPickerChange('menuBar')">
</el-color-picker> </el-color-picker>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">顶栏默认字体颜色</div> <div class="layout-breadcrumb-seting-bar-flex-label">顶栏默认字体颜色</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-color-picker v-model="topBarColor" size="small" @change="onBgColorPickerChange('topBarColor')"> <el-color-picker v-model="getThemeConfig.topBarColor" size="small"
@change="onBgColorPickerChange('topBarColor')">
</el-color-picker> </el-color-picker>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">菜单默认字体颜色</div> <div class="layout-breadcrumb-seting-bar-flex-label">菜单默认字体颜色</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-color-picker v-model="menuBarColor" size="small" @change="onBgColorPickerChange('menuBarColor')"> <el-color-picker v-model="getThemeConfig.menuBarColor" size="small"
@change="onBgColorPickerChange('menuBarColor')">
</el-color-picker> </el-color-picker>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt10"> <div class="layout-breadcrumb-seting-bar-flex mt10">
<div class="layout-breadcrumb-seting-bar-flex-label">顶栏背景渐变</div> <div class="layout-breadcrumb-seting-bar-flex-label">顶栏背景渐变</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isTopBarColorGradual" @change="onTopBarGradualChange"></el-switch> <el-switch v-model="getThemeConfig.isTopBarColorGradual" @change="onTopBarGradualChange"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt14"> <div class="layout-breadcrumb-seting-bar-flex mt14">
<div class="layout-breadcrumb-seting-bar-flex-label">菜单背景渐变</div> <div class="layout-breadcrumb-seting-bar-flex-label">菜单背景渐变</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isMenuBarColorGradual" @change="onMenuBarGradualChange"></el-switch> <el-switch v-model="getThemeConfig.isMenuBarColorGradual" @change="onMenuBarGradualChange"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt14"> <div class="layout-breadcrumb-seting-bar-flex mt14">
<div class="layout-breadcrumb-seting-bar-flex-label">菜单字体背景高亮</div> <div class="layout-breadcrumb-seting-bar-flex-label">菜单字体背景高亮</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isMenuBarColorHighlight" @change="onMenuBarHighlightChange"></el-switch> <el-switch v-model="getThemeConfig.isMenuBarColorHighlight" @change="onMenuBarHighlightChange"></el-switch>
</div> </div>
</div> </div>
@ -92,46 +94,40 @@
<div class="layout-breadcrumb-seting-bar-flex"> <div class="layout-breadcrumb-seting-bar-flex">
<div class="layout-breadcrumb-seting-bar-flex-label">菜单水平折叠</div> <div class="layout-breadcrumb-seting-bar-flex-label">菜单水平折叠</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isCollapse" @change="onThemeConfigChange"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">菜单手风琴</div> <div class="layout-breadcrumb-seting-bar-flex-label">菜单手风琴</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isUniqueOpened" @change="onsetThemeConfigChange"></el-switch>
</div>
</div>
<div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">菜单折叠动画</div>
<div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">固定 Header</div> <div class="layout-breadcrumb-seting-bar-flex-label">固定 Header</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isFixedHeader"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">自动分割菜单</div> <div class="layout-breadcrumb-seting-bar-flex-label">自动分割菜单</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">菜单展开宽度</div> <div class="layout-breadcrumb-seting-bar-flex-label">菜单展开宽度</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-input-number v-model="menuWidth" controls-position="right" :min="1" :max="999" size="mini" <el-input-number v-model="getThemeConfig.menuWidth" controls-position="right" :min="1" :max="999"
style="width:90px;"> size="mini" style="width:90px;">
</el-input-number> </el-input-number>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt11"> <div class="layout-breadcrumb-seting-bar-flex mt11">
<div class="layout-breadcrumb-seting-bar-flex-label">自动锁屏</div> <div class="layout-breadcrumb-seting-bar-flex-label">自动锁屏</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-input-number v-model="menuWidth" controls-position="right" :min="1" :max="999" size="mini" <el-input-number v-model="getThemeConfig.menuWidth" controls-position="right" :min="1" :max="999"
style="width:90px;"> size="mini" style="width:90px;">
</el-input-number> </el-input-number>
</div> </div>
</div> </div>
@ -141,49 +137,49 @@
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">侧边栏 Logo</div> <div class="layout-breadcrumb-seting-bar-flex-label">侧边栏 Logo</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">面包屑 Breadcrumb</div> <div class="layout-breadcrumb-seting-bar-flex-label">面包屑 Breadcrumb</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">开启 Tagsview</div> <div class="layout-breadcrumb-seting-bar-flex-label">开启 Tagsview</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">开启 Footer</div> <div class="layout-breadcrumb-seting-bar-flex-label">开启 Footer</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">灰色模式</div> <div class="layout-breadcrumb-seting-bar-flex-label">灰色模式</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">色弱模式</div> <div class="layout-breadcrumb-seting-bar-flex-label">色弱模式</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">开启水印</div> <div class="layout-breadcrumb-seting-bar-flex-label">开启水印</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="isCollapse"></el-switch> <el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
</div> </div>
</div> </div>
<div class="layout-breadcrumb-seting-bar-flex mt15"> <div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">水印文案</div> <div class="layout-breadcrumb-seting-bar-flex-label">水印文案</div>
<div class="layout-breadcrumb-seting-bar-flex-value"> <div class="layout-breadcrumb-seting-bar-flex-value">
<el-input v-model="menuWidth" size="mini" style="width:90px;"></el-input> <el-input v-model="getThemeConfig.menuWidth" size="mini" style="width:90px;"></el-input>
</div> </div>
</div> </div>
@ -270,43 +266,31 @@
<script lang="ts"> <script lang="ts">
import { import {
toRefs,
reactive,
nextTick, nextTick,
onBeforeMount, onBeforeMount,
onUnmounted, onUnmounted,
getCurrentInstance, getCurrentInstance,
defineComponent,
computed,
} from "vue"; } from "vue";
import { useStore } from "/@/store/index.ts";
import { getLightColor } from "/@/utils/theme.ts"; import { getLightColor } from "/@/utils/theme.ts";
export default { export default defineComponent({
name: "layoutBreadcrumbSeting", name: "layoutBreadcrumbSeting",
setup() { setup() {
const { proxy } = getCurrentInstance(); const { proxy } = getCurrentInstance();
const state = reactive({ const store = useStore();
isDrawer: false, const getThemeConfig = computed(() => {
primary: "#409eff", return store.state.themeConfig;
success: "#67c23a",
info: "#909399",
warning: "#e6a23c",
danger: "#f56c6c",
topBar: "#ffffff",
menuBar: "#29384d",
topBarColor: "#606266",
menuBarColor: "#e6e6e6",
isTopBarColorGradual: false,
isMenuBarColorGradual: false,
isMenuBarColorHighlight: false,
isCollapse: false,
menuWidth: 240,
}); });
const openDrawer = () => { const openDrawer = () => {
state.isDrawer = true; getThemeConfig.value.isDrawer = true;
}; };
const closeDrawer = () => { const closeDrawer = () => {
state.isDrawer = false; getThemeConfig.value.isDrawer = false;
}; };
const onColorPickerChange = (color: string) => { const onColorPickerChange = (color: string) => {
setPropertyFun(`--color-${color}`, state[color]); setPropertyFun(`--color-${color}`, getThemeConfig.value[color]);
}; };
const setPropertyFun = (color: string, targetVal: any) => { const setPropertyFun = (color: string, targetVal: any) => {
document.documentElement.style.setProperty(color, targetVal); document.documentElement.style.setProperty(color, targetVal);
@ -318,22 +302,25 @@ export default {
} }
}; };
const onBgColorPickerChange = (bg: string) => { const onBgColorPickerChange = (bg: string) => {
document.documentElement.style.setProperty(`--bg-${bg}`, state[bg]); document.documentElement.style.setProperty(
`--bg-${bg}`,
getThemeConfig.value[bg]
);
onTopBarGradualChange(); onTopBarGradualChange();
onMenuBarGradualChange(); onMenuBarGradualChange();
}; };
const onTopBarGradualChange = () => { const onTopBarGradualChange = () => {
setGraduaFun( setGraduaFun(
".layout-navbars-breadcrumb-index", ".layout-navbars-breadcrumb-index",
state.isTopBarColorGradual, getThemeConfig.value.isTopBarColorGradual,
state.topBar getThemeConfig.value.topBar
); );
}; };
const onMenuBarGradualChange = () => { const onMenuBarGradualChange = () => {
setGraduaFun( setGraduaFun(
".layout-container .el-aside", ".layout-container .el-aside",
state.isMenuBarColorGradual, getThemeConfig.value.isMenuBarColorGradual,
state.menuBar getThemeConfig.value.menuBar
); );
}; };
const setGraduaFun = (el: string, bool: boolean, color: string) => { const setGraduaFun = (el: string, bool: boolean, color: string) => {
@ -352,13 +339,22 @@ export default {
}; };
const onMenuBarHighlightChange = () => { const onMenuBarHighlightChange = () => {
nextTick(() => { nextTick(() => {
setTimeout(() => {
let els = document.querySelector(".el-menu-item.is-active"); let els = document.querySelector(".el-menu-item.is-active");
let attr = "el-menu-item is-active"; let attr = "el-menu-item is-active";
if (state.isMenuBarColorHighlight) if (getThemeConfig.value.isMenuBarColorHighlight)
els.setAttribute("class", `${attr} add-is-active`); els.setAttribute("class", `${attr} add-is-active`);
else els.setAttribute("class", `${attr}`); else els.setAttribute("class", `${attr}`);
}, 0);
}); });
}; };
const onThemeConfigChange = () => {
store.dispatch("setThemeConfig", getThemeConfig.value);
onMenuBarHighlightChange();
};
const onsetThemeConfigChange = () => {
store.dispatch("setThemeConfig", getThemeConfig.value);
};
onBeforeMount(() => { onBeforeMount(() => {
proxy.mittBus.on("onMenuClick", () => { proxy.mittBus.on("onMenuClick", () => {
onMenuBarHighlightChange(); onMenuBarHighlightChange();
@ -375,10 +371,12 @@ export default {
onTopBarGradualChange, onTopBarGradualChange,
onMenuBarGradualChange, onMenuBarGradualChange,
onMenuBarHighlightChange, onMenuBarHighlightChange,
...toRefs(state), onThemeConfigChange,
onsetThemeConfigChange,
getThemeConfig,
}; };
}, },
}; });
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">

View File

@ -1,5 +1,6 @@
<template> <template>
<el-menu router :default-active="defaultActive" background-color="transparent" @select="onMenuClick"> <el-menu router :default-active="defaultActive" background-color="transparent" :collapse="getThemeConfig.isCollapse"
:unique-opened="getThemeConfig.isUniqueOpened" :collapse-transition="false">
<template v-for="val in menuList"> <template v-for="val in menuList">
<el-submenu :index="val.path" v-if="val.children && val.children.length > 0" :key="val.path"> <el-submenu :index="val.path" v-if="val.children && val.children.length > 0" :key="val.path">
<template #title> <template #title>
@ -26,6 +27,7 @@ import {
getCurrentInstance, getCurrentInstance,
} from "vue"; } from "vue";
import { useRoute, onBeforeRouteUpdate } from "vue-router"; import { useRoute, onBeforeRouteUpdate } from "vue-router";
import { useStore } from "/@/store/index.ts";
import SubItem from "/@/views/layout/navMenu/subItem.vue"; import SubItem from "/@/views/layout/navMenu/subItem.vue";
export default defineComponent({ export default defineComponent({
name: "navMenuVertical", name: "navMenuVertical",
@ -40,6 +42,7 @@ export default defineComponent({
}, },
setup(props) { setup(props) {
const { proxy } = getCurrentInstance(); const { proxy } = getCurrentInstance();
const store = useStore();
const route = useRoute(); const route = useRoute();
const state = reactive({ const state = reactive({
defaultActive: route.path, defaultActive: route.path,
@ -47,15 +50,16 @@ export default defineComponent({
const menuList = computed(() => { const menuList = computed(() => {
return props.menuList; return props.menuList;
}); });
const getThemeConfig = computed(() => {
return store.state.themeConfig;
});
onBeforeRouteUpdate((to) => { onBeforeRouteUpdate((to) => {
state.defaultActive = to.path; state.defaultActive = to.path;
});
const onMenuClick = (index, path) => {
proxy.mittBus.emit("onMenuClick"); proxy.mittBus.emit("onMenuClick");
}; });
return { return {
menuList, menuList,
onMenuClick, getThemeConfig,
...toRefs(state), ...toRefs(state),
}; };
}, },