123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- <template>
- <el-container style="height: 100vh;">
- <el-aside :width="sidebarWidth" style="background-color: #333;overflow: hidden;">
- <div class="sidebar-header" @click="toggleSidebar">
- <el-icon :size="20" color="#fff">
- <Fold v-if="!isCollapse" />
- <Expand v-else />
- </el-icon>
- </div>
- <el-menu
- :default-active="defaultActiveMenu"
- class="el-menu-vertical-demo"
- :collapse="isCollapse"
- background-color="#333"
- text-color="#fff"
- router
- active-text-color="#ffd04b">
- <el-menu-item v-for="menu in menuList" :key="menu.path" :index="menu.path">
- <el-icon><component :is="menu.icon" style="width:20px;height:20px;" /></el-icon>
- <span slot="title">{{ menu.title }}</span>
- </el-menu-item>
- </el-menu>
- </el-aside>
-
- <el-container>
- <el-header class="header-container">
- <el-row>
- <el-col :span="14">
- <h3 class="header-content"><el-icon class="header-icon"><Guide /></el-icon>剑鱼可视化爬虫开发平台 v1.0</h3>
- </el-col>
- <el-col :span="10" style="padding:15px;text-align: right;" v-if="showLogoutModule">
- <!-- <span>当前用户: {{ userName }} / {{ userRole }} </span> -->
- <span>当前用户:{{ userName }} </span>
- <el-tooltip content="退出登录" placement="bottom">
- <el-button type="danger" @click="doLogout">
- <el-icon><SwitchButton /></el-icon>
- </el-button>
- </el-tooltip>
- <el-tooltip content="杀死所有chorme进程" placement="bottom">
- <el-button type="danger" @click="doKillChrome"><el-icon>
- <CloseBold />
- </el-icon></el-button>
- </el-tooltip>
- </el-col>
- </el-row>
- </el-header>
- <el-main>
- <router-view></router-view>
- </el-main>
- </el-container>
- </el-container>
- </template>
- <script setup>
- import { computed, ref } from 'vue';
- import { useStore } from 'vuex';
- import { useRouter } from 'vue-router';
- import { KillAllChrome } from "../wailsjs/go/main/App"
- import {ElMessageBox} from "element-plus";
- const store = useStore()
- const router = useRouter()
- const isCollapse = ref(false);
- const sidebarWidth = ref('140px');
- function toggleSidebar() {
- isCollapse.value = !isCollapse.value;
- sidebarWidth.value = isCollapse.value ? '70px' : '160px';
- }
- toggleSidebar()
- const menuList = computed(() => store.getters.getCurrentMenu)
- const userName = computed(() => store.state.userInfo.s_fullname)
- const userRole = computed(() => store.getters.userRole)
- const showLogoutModule = computed(() => store.state.isAuthenticated)
- const defaultActiveMenu = computed(() => {
- return router.currentRoute.value.path || menuList.value[0]?.path || '/'
- })
- const doLogout = () => {
- router.replace({ name: 'logout' })
- }
- const doKillChrome = () => {
- ElMessageBox.confirm('确定杀死所有chrome进程?', '提示',
- {
- customClass: 'j-confirm-message-box',
- type: 'warning',
- confirmButtonText: '确定',
- cancelButtonText: '取消',
- showCancelButton: false,
- }
- ).then(() => {
- KillAllChrome()
- })
- }
- </script>
- <style>
- body {
- margin: 0;
- }
- .el-header {
- align-items: left;
- height: 10vh;
- }
-
- .sidebar-header {
- height: 60px;
- background-color: #333;
- color: #fff;
- display: flex;
- align-items: center;
- justify-content: center;
- cursor: pointer;
- }
- .el-menu-vertical-demo {
- overflow: hidden;
- border:none;
- }
- .header-container {
- background-color: #F7F7F7;
- padding: 0 12px;
- }
- .header-icon {
- margin-right: 8px;
- }
- .header-content {
- display: flex;
- align-items: center;
- }
- </style>
|