隐藏非必要的页面
This commit is contained in:
@@ -1,134 +1,31 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="footer flx-align-center pl10">
|
<div class="footer flx-align-center pl10">
|
||||||
<el-dropdown>
|
|
||||||
<div class="change_mode">
|
|
||||||
{{ title }}
|
|
||||||
<el-icon class="el-icon--right change_mode_down"><arrow-down /></el-icon>
|
|
||||||
<el-icon class="el-icon--right change_mode_up"><arrow-up /></el-icon>
|
|
||||||
</div>
|
|
||||||
<template #dropdown>
|
|
||||||
<el-dropdown-menu>
|
|
||||||
<el-dropdown-item
|
|
||||||
v-for="item in modeList"
|
|
||||||
:key="item.key"
|
|
||||||
:disabled="!item.activated"
|
|
||||||
@click="handelOpen(item.code, item.key)"
|
|
||||||
>
|
|
||||||
{{ item.name }}
|
|
||||||
</el-dropdown-item>
|
|
||||||
</el-dropdown-menu>
|
|
||||||
</template>
|
|
||||||
</el-dropdown>
|
|
||||||
<p style="margin: 0">
|
<p style="margin: 0">
|
||||||
<a href="http://www.shining-electric.com/" target="_blank">2024 © 南京灿能电力自动化股份有限公司</a>
|
<a href="http://www.shining-electric.com/" target="_blank">2024 南京耀能电力自动化股份有限公司</a>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import { computed } from 'vue'
|
|
||||||
import { HOME_URL } from '@/config'
|
|
||||||
import { useAuthStore } from '@/stores/modules/auth'
|
|
||||||
import { useModeStore } from '@/stores/modules/mode' // 引入模式 store
|
|
||||||
import { useTabsStore } from '@/stores/modules/tabs'
|
|
||||||
import { useRouter } from 'vue-router'
|
|
||||||
import { initDynamicRouter } from '@/routers/modules/dynamicRouter'
|
|
||||||
|
|
||||||
const router = useRouter()
|
|
||||||
const authStore = useAuthStore()
|
|
||||||
const modeStore = useModeStore()
|
|
||||||
const tabsStore = useTabsStore()
|
|
||||||
|
|
||||||
const title = computed(() => {
|
|
||||||
return modeStore.currentMode === '' ? '选择模块' : modeStore.currentMode + '模块'
|
|
||||||
})
|
|
||||||
const activateInfo = authStore.activateInfo
|
|
||||||
const isActivateOpen = import.meta.env.VITE_ACTIVATE_OPEN
|
|
||||||
const modeList = [
|
|
||||||
{
|
|
||||||
name: '模拟式模块',
|
|
||||||
code: '模拟式',
|
|
||||||
key: 'simulate',
|
|
||||||
activated: isActivateOpen === 'true' ? activateInfo.simulate.permanently === 1 : true
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: '数字式模块',
|
|
||||||
code: '数字式',
|
|
||||||
key: 'digital',
|
|
||||||
activated: isActivateOpen === 'true' ? activateInfo.digital.permanently === 1 : true
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: '比对式模块',
|
|
||||||
code: '比对式',
|
|
||||||
key: 'contrast',
|
|
||||||
activated: isActivateOpen === 'true' ? activateInfo.contrast.permanently === 1 : true
|
|
||||||
}
|
|
||||||
]
|
|
||||||
const handelOpen = async (item: string, key: string) => {
|
|
||||||
if (isActivateOpen === 'true' && activateInfo[key].permanently !== 1) {
|
|
||||||
ElMessage.warning(`${item}模块未激活`)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
await authStore.setShowMenu()
|
|
||||||
modeStore.setCurrentMode(item) // 将模式code存入 store
|
|
||||||
// 强制刷新页面
|
|
||||||
await tabsStore.closeMultipleTab()
|
|
||||||
await initDynamicRouter()
|
|
||||||
|
|
||||||
// 只有当目标路径与当前路径不同时才跳转
|
|
||||||
if (router.currentRoute.value.path !== HOME_URL) {
|
|
||||||
await router.push({ path: HOME_URL })
|
|
||||||
} else {
|
|
||||||
// 如果已在目标页面,手动触发组件更新
|
|
||||||
window.location.reload() // 或者采用其他方式刷新数据
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
@use './index.scss';
|
@use './index.scss';
|
||||||
|
|
||||||
.footer {
|
.footer {
|
||||||
position: relative;
|
position: relative;
|
||||||
background-color: var(--el-color-primary);
|
background-color: var(--el-color-primary);
|
||||||
// .el-button:hover {
|
|
||||||
// background-color: var(--el-color-primary) !important;
|
|
||||||
// border: none !important;
|
|
||||||
// outline: none !important;
|
|
||||||
// }
|
|
||||||
.change_mode {
|
|
||||||
color: #fff;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: flex-start;
|
|
||||||
height: 100%;
|
|
||||||
width: auto;
|
|
||||||
font-size: 14px;
|
|
||||||
.change_mode_down {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
.change_mode_up {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.change_mode:hover {
|
|
||||||
.change_mode_down {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.change_mode_up {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.el-dropdown {
|
|
||||||
z-index: 1001;
|
|
||||||
}
|
|
||||||
p {
|
p {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
text-align: right;
|
text-align: right;
|
||||||
line-height: 40px;
|
line-height: 40px;
|
||||||
|
|
||||||
a {
|
a {
|
||||||
color: #fff;
|
color: #fff;
|
||||||
margin-right: 25px; // 增加右边距
|
margin-right: 25px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,14 +22,6 @@
|
|||||||
<el-icon><Edit /></el-icon>
|
<el-icon><Edit /></el-icon>
|
||||||
{{ t('header.changePassword') }}
|
{{ t('header.changePassword') }}
|
||||||
</el-dropdown-item>
|
</el-dropdown-item>
|
||||||
<el-dropdown-item @click="changeMode" v-if="authStore.showMenuFlag">
|
|
||||||
<el-icon><Switch /></el-icon>
|
|
||||||
{{ t('header.changeMode') }}
|
|
||||||
</el-dropdown-item>
|
|
||||||
<el-dropdown-item @click="openDialog('versionRegisterRef')">
|
|
||||||
<el-icon><SetUp /></el-icon>
|
|
||||||
{{ t('header.versionRegister') }}
|
|
||||||
</el-dropdown-item>
|
|
||||||
<el-dropdown trigger="hover" placement="left-start" v-if="userStore.userInfo.loginName == 'root'">
|
<el-dropdown trigger="hover" placement="left-start" v-if="userStore.userInfo.loginName == 'root'">
|
||||||
<div class="custom-dropdown-trigger">
|
<div class="custom-dropdown-trigger">
|
||||||
<el-icon><Tools /></el-icon>
|
<el-icon><Tools /></el-icon>
|
||||||
@@ -62,24 +54,20 @@
|
|||||||
<InfoDialog ref="infoRef"></InfoDialog>
|
<InfoDialog ref="infoRef"></InfoDialog>
|
||||||
<!-- passwordDialog -->
|
<!-- passwordDialog -->
|
||||||
<PasswordDialog ref="passwordRef"></PasswordDialog>
|
<PasswordDialog ref="passwordRef"></PasswordDialog>
|
||||||
<!-- versionRegisterDialog -->
|
|
||||||
<VersionDialog ref="versionRegisterRef"></VersionDialog>
|
|
||||||
<!-- ThemeDialog -->
|
<!-- ThemeDialog -->
|
||||||
<ThemeDialog ref="themeRef"></ThemeDialog>
|
<ThemeDialog ref="themeRef"></ThemeDialog>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { computed, ref } from 'vue'
|
import { computed, ref } from 'vue'
|
||||||
import { HOME_URL, LOGIN_URL } from '@/config'
|
import { LOGIN_URL } from '@/config'
|
||||||
import { useRouter } from 'vue-router'
|
import { useRouter } from 'vue-router'
|
||||||
import { useUserStore } from '@/stores/modules/user'
|
import { useUserStore } from '@/stores/modules/user'
|
||||||
import { ElMessage, ElMessageBox } from 'element-plus'
|
import { ElMessage, ElMessageBox } from 'element-plus'
|
||||||
import InfoDialog from './InfoDialog.vue'
|
import InfoDialog from './InfoDialog.vue'
|
||||||
import PasswordDialog from './PasswordDialog.vue'
|
import PasswordDialog from './PasswordDialog.vue'
|
||||||
import ThemeDialog from './ThemeDialog.vue'
|
import ThemeDialog from './ThemeDialog.vue'
|
||||||
import VersionDialog from '@/views/system/versionRegister/index.vue'
|
import { Avatar, Sunny, Tools } from '@element-plus/icons-vue'
|
||||||
import { Avatar, Sunny, Switch, Tools } from '@element-plus/icons-vue'
|
|
||||||
import { useAuthStore } from '@/stores/modules/auth'
|
|
||||||
import { useDictStore } from '@/stores/modules/dict'
|
import { useDictStore } from '@/stores/modules/dict'
|
||||||
import { useAppSceneStore } from '@/stores/modules/mode'
|
import { useAppSceneStore } from '@/stores/modules/mode'
|
||||||
import { useI18n } from 'vue-i18n'
|
import { useI18n } from 'vue-i18n'
|
||||||
@@ -90,7 +78,6 @@ const dictStore = useDictStore()
|
|||||||
const username = computed(() => userStore.userInfo.name)
|
const username = computed(() => userStore.userInfo.name)
|
||||||
|
|
||||||
const router = useRouter()
|
const router = useRouter()
|
||||||
const authStore = useAuthStore()
|
|
||||||
|
|
||||||
// 初始化 i18n
|
// 初始化 i18n
|
||||||
const { t } = useI18n() // 使用 t 方法替代 $t
|
const { t } = useI18n() // 使用 t 方法替代 $t
|
||||||
@@ -111,12 +98,10 @@ const logout = () => {
|
|||||||
// 打开修改密码和个人信息弹窗
|
// 打开修改密码和个人信息弹窗
|
||||||
const infoRef = ref<InstanceType<typeof InfoDialog> | null>(null)
|
const infoRef = ref<InstanceType<typeof InfoDialog> | null>(null)
|
||||||
const passwordRef = ref<InstanceType<typeof PasswordDialog> | null>(null)
|
const passwordRef = ref<InstanceType<typeof PasswordDialog> | null>(null)
|
||||||
const versionRegisterRef = ref<InstanceType<typeof VersionDialog> | null>(null)
|
|
||||||
const themeRef = ref<InstanceType<typeof ThemeDialog> | null>(null)
|
const themeRef = ref<InstanceType<typeof ThemeDialog> | null>(null)
|
||||||
const openDialog = (ref: string) => {
|
const openDialog = (ref: string) => {
|
||||||
if (ref == 'infoRef') infoRef.value?.openDialog()
|
if (ref == 'infoRef') infoRef.value?.openDialog()
|
||||||
if (ref == 'passwordRef') passwordRef.value?.openDialog()
|
if (ref == 'passwordRef') passwordRef.value?.openDialog()
|
||||||
if (ref == 'versionRegisterRef') versionRegisterRef.value?.openDialog()
|
|
||||||
if (ref == 'themeRef') themeRef.value?.openDialog()
|
if (ref == 'themeRef') themeRef.value?.openDialog()
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -130,10 +115,6 @@ const changeScene = async (value: string) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//模式切换
|
//模式切换
|
||||||
const changeMode = async () => {
|
|
||||||
authStore.changeModel()
|
|
||||||
await router.push(HOME_URL)
|
|
||||||
}
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
|
|||||||
Reference in New Issue
Block a user