gohttpdUi/src/components/Setting/index.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>