186 lines
5.4 KiB
Vue
186 lines
5.4 KiB
Vue
<template>
|
|
<div class="setting__content">
|
|
<div class="setting__title">导航栏布局</div>
|
|
<div class="icon__wrap">
|
|
<span :class="{'icon--active': layout==='Classic'}" @click="setLayout('Classic')">
|
|
<el-tooltip effect="dark" content="经典布局" placement="bottom">
|
|
<svg-icon icon-class="layout-classic" class="setting-svg-icon" />
|
|
</el-tooltip>
|
|
</span>
|
|
<span :class="{'icon--active': layout==='LeftTop'}" @click="setLayout('LeftTop')">
|
|
<el-tooltip effect="dark" content="左侧顶部布局" placement="bottom">
|
|
<svg-icon icon-class="layout-topLeft" class="setting-svg-icon" />
|
|
</el-tooltip>
|
|
</span>
|
|
<span :class="{'icon--active': layout==='Top'}" @click="setLayout('Top')">
|
|
<el-tooltip effect="dark" content="顶部布局" placement="bottom">
|
|
<svg-icon icon-class="layout-top" class="setting-svg-icon" />
|
|
</el-tooltip>
|
|
</span>
|
|
</div>
|
|
|
|
<div class="setting__title">侧边菜单主题</div>
|
|
|
|
<div class="setting__title">顶部菜单主题</div>
|
|
|
|
<div class="setting__title">界面功能</div>
|
|
<!-- <div class="setting__item">
|
|
<span>固定顶部操作栏</span>
|
|
<el-switch v-model="fixedNavbar" @change="setFixedNavbar" />
|
|
</div>
|
|
<div class="setting__item">
|
|
<span>固定标签页</span>
|
|
<el-switch v-model="fixedTags" @change="setFixedTags" />
|
|
</div> -->
|
|
<div class="setting__item">
|
|
<span>固定Header</span>
|
|
<el-switch v-model="fixedHeader" @change="setFixedHeader" />
|
|
</div>
|
|
|
|
<div class="setting__title">界面显示</div>
|
|
<div class="setting__item">
|
|
<span>顶部操作栏</span>
|
|
<el-switch v-model="navbar" @change="setNavbar" />
|
|
</div>
|
|
<div class="setting__item">
|
|
<span>侧边栏缩收</span>
|
|
<el-switch v-model="hamburger" @change="setHamburger" />
|
|
</div>
|
|
<div class="setting__item">
|
|
<span>面包屑</span>
|
|
<el-switch v-model="breadcrumb" @change="setBreadcrumb" />
|
|
</div>
|
|
<div class="setting__item">
|
|
<span>全屏按钮</span>
|
|
<el-switch v-model="screenfull" @change="setScreenfull" />
|
|
</div>
|
|
<div class="setting__item">
|
|
<span>用户头像</span>
|
|
<el-switch v-model="userInfo" @change="setUserInfo" />
|
|
</div>
|
|
<div class="setting__item">
|
|
<span>标签页</span>
|
|
<el-switch v-model="tagsView" @change="setTagsView" />
|
|
</div>
|
|
<div class="setting__item">
|
|
<span>LOGO</span>
|
|
<el-switch v-model="logo" @change="setLogo" />
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { defineComponent, computed, ref } from 'vue'
|
|
import { appStore } from '_p/index/store/modules/app'
|
|
export default defineComponent({
|
|
name: 'Setting',
|
|
setup() {
|
|
const layout = computed(() => appStore.layout)
|
|
function setLayout(mode: 'Classic' | 'LeftTop' | 'Top' | 'Test') {
|
|
if (mode === layout.value) return
|
|
appStore.SetLayout(mode)
|
|
}
|
|
|
|
// const fixedNavbar = ref<boolean>(appStore.fixedNavbar)
|
|
// function setFixedNavbar(fixedNavbar: boolean) {
|
|
// appStore.SetFixedNavbar(fixedNavbar)
|
|
// }
|
|
|
|
// const fixedTags = ref<boolean>(appStore.fixedTags)
|
|
// function setFixedTags(fixedTags: boolean) {
|
|
// appStore.SetFixedTags(fixedTags)
|
|
// }
|
|
|
|
const fixedHeader = ref<boolean>(appStore.fixedHeader)
|
|
function setFixedHeader(fixedHeader: boolean) {
|
|
appStore.SetFixedHeader(fixedHeader)
|
|
}
|
|
|
|
const navbar = ref<boolean>(appStore.showNavbar)
|
|
function setNavbar(navbar: boolean) {
|
|
appStore.SetShowNavbar(navbar)
|
|
}
|
|
|
|
const hamburger = ref<boolean>(appStore.showHamburger)
|
|
function setHamburger(hamburger: boolean) {
|
|
appStore.SetHamburger(hamburger)
|
|
}
|
|
|
|
const breadcrumb = ref<boolean>(appStore.showBreadcrumb)
|
|
function setBreadcrumb(breadcrumb: boolean) {
|
|
appStore.SetBreadcrumb(breadcrumb)
|
|
}
|
|
|
|
const screenfull = ref<boolean>(appStore.showScreenfull)
|
|
function setScreenfull(screenfull: boolean) {
|
|
appStore.SetScreenfull(screenfull)
|
|
}
|
|
|
|
const userInfo = ref<boolean>(appStore.showUserInfo)
|
|
function setUserInfo(userInfo: boolean) {
|
|
appStore.SetUserInfo(userInfo)
|
|
}
|
|
|
|
const tagsView = ref<boolean>(appStore.showTags)
|
|
function setTagsView(tagsView: boolean) {
|
|
appStore.SetShowTags(tagsView)
|
|
}
|
|
|
|
const logo = ref<boolean>(appStore.showLogo)
|
|
function setLogo(logo: boolean) {
|
|
appStore.SetShowLogo(logo)
|
|
}
|
|
|
|
return {
|
|
layout, setLayout,
|
|
// fixedNavbar, setFixedNavbar,
|
|
// fixedTags, setFixedTags,
|
|
fixedHeader, setFixedHeader,
|
|
navbar, setNavbar,
|
|
hamburger, setHamburger,
|
|
breadcrumb, setBreadcrumb,
|
|
screenfull, setScreenfull,
|
|
userInfo, setUserInfo,
|
|
tagsView, setTagsView,
|
|
logo, setLogo
|
|
}
|
|
}
|
|
})
|
|
</script>
|
|
|
|
<style lang="less" scoped>
|
|
.setting__content {
|
|
background: @appBg;
|
|
padding: 0 20px;
|
|
.setting__title {
|
|
text-align: center;
|
|
padding-top: 20px;
|
|
}
|
|
.icon__wrap {
|
|
text-align: center;
|
|
margin-top: 15px;
|
|
&>span {
|
|
display: inline-block;
|
|
padding: 5px 10px;
|
|
border: 2px solid @appBg;
|
|
.setting-svg-icon {
|
|
font-size: 60px;
|
|
cursor: pointer;
|
|
}
|
|
.setting-svg-icon:nth-of-type(2) {
|
|
margin: 0 10px;
|
|
}
|
|
}
|
|
.icon--active {
|
|
border: 2px solid #018ffb;
|
|
border-radius: 4px;
|
|
}
|
|
}
|
|
.setting__item {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
margin: 16px 0;
|
|
}
|
|
}
|
|
</style>
|