#
Junjie
2024-09-10 83e34f69b7b5edf713d25bbec164e47f924edb31
#
2个文件已修改
108 ■■■■ 已修改文件
zy-asrs-admin/src/assets/main.css 66 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
zy-asrs-admin/src/views/IndexView.vue 42 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
zy-asrs-admin/src/assets/main.css
@@ -101,13 +101,67 @@
}
.tabs-fixed {
  width: 100%;
  position: relative;
  top: -64px;
  left: -24px;
  display: flex;
}
.tabs-arrow-left {
  position: absolute;
  width: 40px;
  height: 30px;
  background: #fff;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  padding: 20px 0px;
  cursor: pointer;
  margin-right: 5px;
  user-select: none;
}
.tabs-arrow-right {
  position: absolute;
  right: -54px;
  width: 40px;
  height: 30px;
  background: #fff;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  padding: 20px 0px;
  cursor: pointer;
  margin-right: 5px;
  user-select: none;
}
.tabs-arrow-left {
  float: left;
}
.tabs-content {
  width: 97%;
  display: flex;
  margin-left: 45px;
  margin-right: 25px;
  overflow-x: scroll;
  will-change: transform;
  transition: transform 0.3s;
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE and Edge */
}
.tabs-content-item {
  flex: 10;
  display: flex;
}
.tabs-item {
  min-width: 120px;
  height: 30px;
  background: #fff;
  display: flex;
@@ -120,8 +174,8 @@
}
.tabs-item>div:nth-child(1) {
  margin-right: 10px;
  margin-left: 10px;
  margin-right: 5px;
  margin-left: 5px;
}
.tabs-item>div:nth-child(1):hover {
@@ -129,13 +183,13 @@
}
.tabs-item>div:nth-child(2) {
  margin-right: 10px;
  margin-left: 10px;
  margin-right: 5px;
  margin-left: 5px;
}
.tabs-item>div:nth-child(3) {
  margin-right: 10px;
  margin-left: 10px;
  margin-right: 5px;
  margin-left: 5px;
}
.tabs-item>div:nth-child(3):hover {
zy-asrs-admin/src/views/IndexView.vue
@@ -14,6 +14,8 @@
  UserOutlined,
  TranslationOutlined,
  ApartmentOutlined,
  CaretLeftOutlined,
  CaretRightOutlined,
} from "@ant-design/icons-vue";
import { formatMessage, loadData } from '@/utils/localeUtils.js';
import AiView from '@/components/ai/index.vue'
@@ -29,6 +31,7 @@
let isRouterAlive = ref(true);
const menuCache = ref([]);
const hostList = ref([]);
const tabsContent = ref(null);
const components = {
  ...Icons,
@@ -210,6 +213,16 @@
  window.location.reload();
}
const handleScroll = (data) => {
  let position = tabsContent.value.scrollLeft;
  let offset = position * 0.1 + 30;
  if (data == 'left') {
    tabsContent.value.scrollLeft = position - offset;
  } else {
    tabsContent.value.scrollLeft = position + offset;
  }
}
</script>
<template>
@@ -303,17 +316,30 @@
      </a-layout-header>
      <a-layout-content class="content-view">
        <div class="tabs-fixed">
          <div v-for="(item, index) in routerCacheList" :key="index" @click="switchTabs(item)" class="tabs-item"
            :class="currentCache == item.name ? 'tabs-item-active' : ''">
            <div :class="currentCache == item.name ? '' : 'tabs-item-reload-none'" @click="reloadTabs" @click.stop>
              <RedoOutlined />
            </div>
            <div>{{ formatMessage(item.languageId, item.name) }}</div>
            <div @click="closeTabs(item)" @click.stop>
              <CloseOutlined />
          <div class="tabs-arrow-left" @click="handleScroll('left')">
            <CaretLeftOutlined />
          </div>
          <div class="tabs-content" ref="tabsContent">
            <div class="tabs-content-item">
              <div v-for="(item, index) in routerCacheList" :key="index" @click="switchTabs(item)" class="tabs-item"
                :class="currentCache == item.name ? 'tabs-item-active' : ''">
                <div :class="currentCache == item.name ? '' : 'tabs-item-reload-none'" @click="reloadTabs" @click.stop>
                  <RedoOutlined />
                </div>
                <div>{{ formatMessage(item.languageId, item.name) }}</div>
                <div @click="closeTabs(item)" @click.stop>
                  <CloseOutlined />
                </div>
              </div>
            </div>
          </div>
          <div class="tabs-arrow-right" @click="handleScroll('right')">
            <CaretRightOutlined />
          </div>
        </div>
        <router-view v-slot="{ Component, route }" v-if="isRouterAlive">
          <keep-alive :include="routerCache">
            <component :is="Component" @pageReload="reloadTabs" />