f0f22956cbd40ab3ecf7adf3e0eb211e.json 33 KB

1
  1. {"remainingRequest":"D:\\test\\ssi-satoken\\ui\\node_modules\\babel-loader\\lib\\index.js!D:\\test\\ssi-satoken\\ui\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!D:\\test\\ssi-satoken\\ui\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\test\\ssi-satoken\\ui\\src\\layout\\components\\TagsView\\index.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\test\\ssi-satoken\\ui\\src\\layout\\components\\TagsView\\index.vue","mtime":1697787637637},{"path":"D:\\test\\ssi-satoken\\ui\\babel.config.js","mtime":1696909835000},{"path":"D:\\test\\ssi-satoken\\ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1669864538178},{"path":"D:\\test\\ssi-satoken\\ui\\node_modules\\babel-loader\\lib\\index.js","mtime":1669864538095},{"path":"D:\\test\\ssi-satoken\\ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1669864538178},{"path":"D:\\test\\ssi-satoken\\ui\\node_modules\\vue-loader\\lib\\index.js","mtime":1697679531049}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:"use strict";

var _interopRequireDefault = require("D:/test/ssi-satoken/ui/node_modules/@babel/runtime/helpers/interopRequireDefault.js").default;
Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.default = void 0;
var _createForOfIteratorHelper2 = _interopRequireDefault(require("D:/test/ssi-satoken/ui/node_modules/@babel/runtime/helpers/createForOfIteratorHelper.js"));
var _toConsumableArray2 = _interopRequireDefault(require("D:/test/ssi-satoken/ui/node_modules/@babel/runtime/helpers/toConsumableArray.js"));
var _objectSpread2 = _interopRequireDefault(require("D:/test/ssi-satoken/ui/node_modules/@babel/runtime/helpers/objectSpread2.js"));
require("core-js/modules/es.object.to-string.js");
require("core-js/modules/web.dom-collections.for-each.js");
require("core-js/modules/es.function.name.js");
require("core-js/modules/es.array.push.js");
require("core-js/modules/es.array.concat.js");
require("core-js/modules/es.string.link.js");
require("core-js/modules/es.array.find.js");
require("core-js/modules/es.array.slice.js");
require("core-js/modules/es.regexp.exec.js");
require("core-js/modules/es.string.replace.js");
var _ScrollPane = _interopRequireDefault(require("./ScrollPane"));
var _path = _interopRequireDefault(require("path"));
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
var _default = {
  components: {
    ScrollPane: _ScrollPane.default
  },
  data: function data() {
    return {
      visible: false,
      top: 0,
      left: 0,
      selectedTag: {},
      affixTags: []
    };
  },
  computed: {
    visitedViews: function visitedViews() {
      var view = this.$store.state.tagsView.visitedViews;
      var finnalView = [];
      view.forEach(function (value, index, array) {
        if (value.name === undefined) {
          finnalView.push(value);
        } else {
          if (value.name !== "首页") {
            finnalView.push(value);
          }
        }
      });
      return finnalView;
      //return this.$store.state.tagsView.visitedViews
    },
    routes: function routes() {
      var finnalRoutes = [];
      var routes = this.$router.options.routes;
      routes.forEach(function (value, index, array) {
        if (value.redirect === undefined) {
          finnalRoutes.push(value);
        } else {
          if (value.redirect !== "/dashboard") {
            finnalRoutes.push(value);
          }
        }
      });
      // console.log(finnalRoutes)
      return finnalRoutes;
      // return this.$router.options.routes
      // return this.$store.state.permission.routes
    },
    theme: function theme() {
      return this.$store.state.settings.theme;
    }
  },
  watch: {
    $route: function $route() {
      this.addTags();
      this.moveToCurrentTag();
    },
    visible: function visible(value) {
      if (value) {
        document.body.addEventListener('click', this.closeMenu);
      } else {
        document.body.removeEventListener('click', this.closeMenu);
      }
    }
  },
  destroyed: function destroyed() {
    this.$store.dispatch('tagsView/delAllVisitedViews', this.$route);
  },
  mounted: function mounted() {
    this.initTags();
    this.addTags();
  },
  methods: {
    isActive: function isActive(route) {
      return route.path === this.$route.path;
    },
    activeStyle: function activeStyle(tag) {
      if (!this.isActive(tag)) return {};
      return {
        "background-color": this.theme,
        "border-color": this.theme
      };
    },
    isAffix: function isAffix(tag) {
      return tag.meta && tag.meta.affix;
    },
    isFirstView: function isFirstView() {
      try {
        return this.selectedTag.fullPath === '/index' || this.selectedTag.fullPath === this.visitedViews[1].fullPath;
      } catch (err) {
        return false;
      }
    },
    isLastView: function isLastView() {
      try {
        return this.selectedTag.fullPath === this.visitedViews[this.visitedViews.length - 1].fullPath;
      } catch (err) {
        return false;
      }
    },
    filterAffixTags: function filterAffixTags(routes) {
      var _this = this;
      var basePath = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '/';
      var tags = [];
      routes.forEach(function (route) {
        if (route.meta && route.meta.affix) {
          var tagPath = _path.default.resolve(basePath, route.path);
          tags.push({
            fullPath: tagPath,
            path: tagPath,
            name: route.name,
            meta: (0, _objectSpread2.default)({}, route.meta)
          });
        }
        if (route.children) {
          var tempTags = _this.filterAffixTags(route.children, route.path);
          if (tempTags.length >= 1) {
            tags = [].concat((0, _toConsumableArray2.default)(tags), (0, _toConsumableArray2.default)(tempTags));
          }
        }
      });
      return tags;
    },
    initTags: function initTags() {
      var affixTags = this.affixTags = this.filterAffixTags(this.routes);
      var _iterator = (0, _createForOfIteratorHelper2.default)(affixTags),
        _step;
      try {
        for (_iterator.s(); !(_step = _iterator.n()).done;) {
          var tag = _step.value;
          // Must have tag name
          if (tag.name) {
            this.$store.dispatch('tagsView/addVisitedView', tag);
          }
        }
      } catch (err) {
        _iterator.e(err);
      } finally {
        _iterator.f();
      }
    },
    addTags: function addTags() {
      var name = this.$route.name;
      if (name) {
        this.$store.dispatch('tagsView/addView', this.$route);
        if (this.$route.meta.link) {
          this.$store.dispatch('tagsView/addIframeView', this.$route);
        }
      }
      return false;
    },
    moveToCurrentTag: function moveToCurrentTag() {
      var _this2 = this;
      var tags = this.$refs.tag;
      // console.log(this.$route)
      if (tags === undefined) {
        this.$store.dispatch('tagsView/updateVisitedView', this.$route);
      } else {
        this.$nextTick(function () {
          var _iterator2 = (0, _createForOfIteratorHelper2.default)(tags),
            _step2;
          try {
            for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
              var tag = _step2.value;
              if (tag.to.path === _this2.$route.path) {
                _this2.$refs.scrollPane.moveToTarget(tag);
                // when query is different then update
                if (tag.to.fullPath !== _this2.$route.fullPath) {
                  _this2.$store.dispatch('tagsView/updateVisitedView', _this2.$route);
                }
                break;
              }
            }
          } catch (err) {
            _iterator2.e(err);
          } finally {
            _iterator2.f();
          }
        });
      }
    },
    refreshSelectedTag: function refreshSelectedTag(view) {
      this.$tab.refreshPage(view);
      if (this.$route.meta.link) {
        this.$store.dispatch('tagsView/delIframeView', this.$route);
      }
    },
    closeSelectedTag: function closeSelectedTag(view) {
      var _this3 = this;
      this.$tab.closePage(view).then(function (_ref) {
        var visitedViews = _ref.visitedViews;
        if (_this3.isActive(view)) {
          _this3.toLastView(visitedViews, view);
        }
      });
    },
    closeRightTags: function closeRightTags() {
      var _this4 = this;
      this.$tab.closeRightPage(this.selectedTag).then(function (visitedViews) {
        if (!visitedViews.find(function (i) {
          return i.fullPath === _this4.$route.fullPath;
        })) {
          _this4.toLastView(visitedViews);
        }
      });
    },
    closeLeftTags: function closeLeftTags() {
      var _this5 = this;
      this.$tab.closeLeftPage(this.selectedTag).then(function (visitedViews) {
        if (!visitedViews.find(function (i) {
          return i.fullPath === _this5.$route.fullPath;
        })) {
          _this5.toLastView(visitedViews);
        }
      });
    },
    closeOthersTags: function closeOthersTags() {
      var _this6 = this;
      this.$router.push(this.selectedTag).catch(function () {});
      this.$tab.closeOtherPage(this.selectedTag).then(function () {
        _this6.moveToCurrentTag();
      });
    },
    closeAllTags: function closeAllTags(view) {
      var _this7 = this;
      this.$tab.closeAllPage().then(function (_ref2) {
        var visitedViews = _ref2.visitedViews;
        if (_this7.affixTags.some(function (tag) {
          return tag.path === _this7.$route.path;
        })) {
          return;
        }
        _this7.toLastView(visitedViews, view);
      });
    },
    toLastView: function toLastView(visitedViews, view) {
      var latestView = visitedViews.slice(-1)[0];
      if (latestView) {
        this.$router.push(latestView.fullPath);
      } else {
        // now the default is to redirect to the home page if there is no tags-view,
        // you can adjust it according to your needs.
        if (view.name === 'Dashboard') {
          // to reload home page
          this.$router.replace({
            path: '/redirect' + view.fullPath
          });
        } else {
          this.$router.push('/');
        }
      }
    },
    openMenu: function openMenu(tag, e) {
      var menuMinWidth = 105;
      var offsetLeft = this.$el.getBoundingClientRect().left; // container margin left
      var offsetWidth = this.$el.offsetWidth; // container width
      var maxLeft = offsetWidth - menuMinWidth; // left boundary
      var left = e.clientX - offsetLeft + 15; // 15: margin right

      if (left > maxLeft) {
        this.left = maxLeft;
      } else {
        this.left = left;
      }
      this.top = e.clientY;
      this.visible = true;
      this.selectedTag = tag;
    },
    closeMenu: function closeMenu() {
      this.visible = false;
    },
    handleScroll: function handleScroll() {
      this.closeMenu();
    }
  }
};
exports.default = _default;"},{"version":3,"names":["_ScrollPane","_interopRequireDefault","require","_path","components","ScrollPane","data","visible","top","left","selectedTag","affixTags","computed","visitedViews","view","$store","state","tagsView","finnalView","forEach","value","index","array","name","undefined","push","routes","finnalRoutes","$router","options","redirect","theme","settings","watch","$route","addTags","moveToCurrentTag","document","body","addEventListener","closeMenu","removeEventListener","destroyed","dispatch","mounted","initTags","methods","isActive","route","path","activeStyle","tag","isAffix","meta","affix","isFirstView","fullPath","err","isLastView","length","filterAffixTags","_this","basePath","arguments","tags","tagPath","resolve","_objectSpread2","default","children","tempTags","concat","_toConsumableArray2","_iterator","_createForOfIteratorHelper2","_step","s","n","done","e","f","link","_this2","$refs","$nextTick","_iterator2","_step2","to","scrollPane","moveToTarget","refreshSelectedTag","$tab","refreshPage","closeSelectedTag","_this3","closePage","then","_ref","toLastView","closeRightTags","_this4","closeRightPage","find","i","closeLeftTags","_this5","closeLeftPage","closeOthersTags","_this6","catch","closeOtherPage","closeAllTags","_this7","closeAllPage","_ref2","some","latestView","slice","replace","openMenu","menuMinWidth","offsetLeft","$el","getBoundingClientRect","offsetWidth","maxLeft","clientX","clientY","handleScroll","exports","_default"],"sources":["src/layout/components/TagsView/index.vue"],"sourcesContent":["<template>\r\n <div id=\"tags-view-container\" class=\"tags-view-container\">\r\n <scroll-pane ref=\"scrollPane\" class=\"tags-view-wrapper\" @scroll=\"handleScroll\">\r\n <router-link\r\n v-for=\"tag in visitedViews\"\r\n ref=\"tag\"\r\n :key=\"tag.path\"\r\n :class=\"isActive(tag)?'active':''\"\r\n :to=\"{ path: tag.path, query: tag.query, fullPath: tag.fullPath }\"\r\n tag=\"span\"\r\n class=\"tags-view-item\"\r\n :style=\"activeStyle(tag)\"\r\n @click.middle.native=\"!isAffix(tag)?closeSelectedTag(tag):''\"\r\n @contextmenu.prevent.native=\"openMenu(tag,$event)\"\r\n >\r\n {{ tag.title }}\r\n <span v-if=\"!isAffix(tag)\" class=\"el-icon-close\" @click.prevent.stop=\"closeSelectedTag(tag)\" />\r\n </router-link>\r\n </scroll-pane>\r\n <ul v-show=\"visible\" :style=\"{left:left+'px',top:top+'px'}\" class=\"contextmenu\">\r\n <li @click=\"refreshSelectedTag(selectedTag)\"><i class=\"el-icon-refresh-right\"></i> 刷新页面</li>\r\n <li v-if=\"!isAffix(selectedTag)\" @click=\"closeSelectedTag(selectedTag)\"><i class=\"el-icon-close\"></i> 关闭当前</li>\r\n <li @click=\"closeOthersTags\"><i class=\"el-icon-circle-close\"></i> 关闭其他</li>\r\n <li v-if=\"!isFirstView()\" @click=\"closeLeftTags\"><i class=\"el-icon-back\"></i> 关闭左侧</li>\r\n <li v-if=\"!isLastView()\" @click=\"closeRightTags\"><i class=\"el-icon-right\"></i> 关闭右侧</li>\r\n <li @click=\"closeAllTags(selectedTag)\"><i class=\"el-icon-circle-close\"></i> 全部关闭</li>\r\n </ul>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport ScrollPane from './ScrollPane'\r\nimport path from 'path'\r\n\r\nexport default {\r\n components: { ScrollPane },\r\n data() {\r\n return {\r\n visible: false,\r\n top: 0,\r\n left: 0,\r\n selectedTag: {},\r\n affixTags: []\r\n }\r\n },\r\n computed: {\r\n visitedViews() {\r\n let view = this.$store.state.tagsView.visitedViews\r\n let finnalView = []\r\n view.forEach((value,index,array)=>{\r\n if(value.name === undefined){\r\n finnalView.push(value)\r\n }else{\r\n if(value.name !== \"首页\")\r\n {\r\n finnalView.push(value)\r\n }\r\n }\r\n })\r\n return finnalView\r\n //return this.$store.state.tagsView.visitedViews\r\n },\r\n routes() {\r\n let finnalRoutes = []\r\n let routes = this.$router.options.routes\r\n routes.forEach((value,index,array)=>{\r\n if(value.redirect === undefined){\r\n finnalRoutes.push(value)\r\n }else{\r\n if(value.redirect !== \"/dashboard\")\r\n {\r\n finnalRoutes.push(value)\r\n }\r\n }\r\n })\r\n // console.log(finnalRoutes)\r\n return finnalRoutes\r\n // return this.$router.options.routes\r\n // return this.$store.state.permission.routes\r\n },\r\n theme() {\r\n return this.$store.state.settings.theme;\r\n }\r\n },\r\n watch: {\r\n $route() {\r\n this.addTags()\r\n this.moveToCurrentTag()\r\n },\r\n visible(value) {\r\n if (value) {\r\n document.body.addEventListener('click', this.closeMenu)\r\n } else {\r\n document.body.removeEventListener('click', this.closeMenu)\r\n }\r\n }\r\n },\r\n destroyed() {\r\n this.$store.dispatch('tagsView/delAllVisitedViews', this.$route)\r\n },\r\n mounted() {\r\n this.initTags()\r\n this.addTags()\r\n },\r\n methods: {\r\n isActive(route) {\r\n return route.path === this.$route.path\r\n },\r\n activeStyle(tag) {\r\n if (!this.isActive(tag)) return {};\r\n return {\r\n \"background-color\": this.theme,\r\n \"border-color\": this.theme\r\n };\r\n },\r\n isAffix(tag) {\r\n return tag.meta && tag.meta.affix\r\n },\r\n isFirstView() {\r\n try {\r\n return this.selectedTag.fullPath === '/index' || this.selectedTag.fullPath === this.visitedViews[1].fullPath\r\n } catch (err) {\r\n return false\r\n }\r\n },\r\n isLastView() {\r\n try {\r\n return this.selectedTag.fullPath === this.visitedViews[this.visitedViews.length - 1].fullPath\r\n } catch (err) {\r\n return false\r\n }\r\n },\r\n filterAffixTags(routes, basePath = '/') {\r\n let tags = []\r\n routes.forEach(route => {\r\n if (route.meta && route.meta.affix) {\r\n const tagPath = path.resolve(basePath, route.path)\r\n tags.push({\r\n fullPath: tagPath,\r\n path: tagPath,\r\n name: route.name,\r\n meta: { ...route.meta }\r\n })\r\n }\r\n if (route.children) {\r\n const tempTags = this.filterAffixTags(route.children, route.path)\r\n if (tempTags.length >= 1) {\r\n tags = [...tags, ...tempTags]\r\n }\r\n }\r\n })\r\n return tags\r\n },\r\n initTags() {\r\n const affixTags = this.affixTags = this.filterAffixTags(this.routes)\r\n for (const tag of affixTags) {\r\n // Must have tag name\r\n if (tag.name) {\r\n this.$store.dispatch('tagsView/addVisitedView', tag)\r\n }\r\n }\r\n },\r\n addTags() {\r\n const { name } = this.$route\r\n if (name) {\r\n this.$store.dispatch('tagsView/addView', this.$route)\r\n if (this.$route.meta.link) {\r\n this.$store.dispatch('tagsView/addIframeView', this.$route)\r\n }\r\n }\r\n return false\r\n },\r\n moveToCurrentTag() {\r\n const tags = this.$refs.tag\r\n // console.log(this.$route)\r\n if(tags === undefined){\r\n this.$store.dispatch('tagsView/updateVisitedView', this.$route)\r\n }else{\r\n this.$nextTick(() => {\r\n for (const tag of tags) {\r\n if (tag.to.path === this.$route.path) {\r\n this.$refs.scrollPane.moveToTarget(tag)\r\n // when query is different then update\r\n if (tag.to.fullPath !== this.$route.fullPath) {\r\n this.$store.dispatch('tagsView/updateVisitedView', this.$route)\r\n }\r\n break\r\n }\r\n }\r\n })\r\n }\r\n\r\n },\r\n refreshSelectedTag(view) {\r\n this.$tab.refreshPage(view);\r\n if (this.$route.meta.link) {\r\n this.$store.dispatch('tagsView/delIframeView', this.$route)\r\n }\r\n },\r\n closeSelectedTag(view) {\r\n this.$tab.closePage(view).then(({ visitedViews }) => {\r\n if (this.isActive(view)) {\r\n this.toLastView(visitedViews, view)\r\n }\r\n })\r\n },\r\n closeRightTags() {\r\n this.$tab.closeRightPage(this.selectedTag).then(visitedViews => {\r\n if (!visitedViews.find(i => i.fullPath === this.$route.fullPath)) {\r\n this.toLastView(visitedViews)\r\n }\r\n })\r\n },\r\n closeLeftTags() {\r\n this.$tab.closeLeftPage(this.selectedTag).then(visitedViews => {\r\n if (!visitedViews.find(i => i.fullPath === this.$route.fullPath)) {\r\n this.toLastView(visitedViews)\r\n }\r\n })\r\n },\r\n closeOthersTags() {\r\n this.$router.push(this.selectedTag).catch(()=>{});\r\n this.$tab.closeOtherPage(this.selectedTag).then(() => {\r\n this.moveToCurrentTag()\r\n })\r\n },\r\n closeAllTags(view) {\r\n this.$tab.closeAllPage().then(({ visitedViews }) => {\r\n if (this.affixTags.some(tag => tag.path === this.$route.path)) {\r\n return\r\n }\r\n this.toLastView(visitedViews, view)\r\n })\r\n },\r\n toLastView(visitedViews, view) {\r\n const latestView = visitedViews.slice(-1)[0]\r\n if (latestView) {\r\n this.$router.push(latestView.fullPath)\r\n } else {\r\n // now the default is to redirect to the home page if there is no tags-view,\r\n // you can adjust it according to your needs.\r\n if (view.name === 'Dashboard') {\r\n // to reload home page\r\n this.$router.replace({ path: '/redirect' + view.fullPath })\r\n } else {\r\n this.$router.push('/')\r\n }\r\n }\r\n },\r\n openMenu(tag, e) {\r\n const menuMinWidth = 105\r\n const offsetLeft = this.$el.getBoundingClientRect().left // container margin left\r\n const offsetWidth = this.$el.offsetWidth // container width\r\n const maxLeft = offsetWidth - menuMinWidth // left boundary\r\n const left = e.clientX - offsetLeft + 15 // 15: margin right\r\n\r\n if (left > maxLeft) {\r\n this.left = maxLeft\r\n } else {\r\n this.left = left\r\n }\r\n\r\n this.top = e.clientY\r\n this.visible = true\r\n this.selectedTag = tag\r\n },\r\n closeMenu() {\r\n this.visible = false\r\n },\r\n handleScroll() {\r\n this.closeMenu()\r\n }\r\n }\r\n}\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.tags-view-container {\r\n height: 34px;\r\n width: 100%;\r\n background: #fff;\r\n border-bottom: 1px solid #d8dce5;\r\n box-shadow: 0 1px 3px 0 rgba(0, 0, 0, .12), 0 0 3px 0 rgba(0, 0, 0, .04);\r\n .tags-view-wrapper {\r\n .tags-view-item {\r\n display: inline-block;\r\n position: relative;\r\n cursor: pointer;\r\n height: 26px;\r\n line-height: 26px;\r\n border: 1px solid #d8dce5;\r\n color: #495060;\r\n background: #fff;\r\n padding: 0 8px;\r\n font-size: 12px;\r\n margin-left: 5px;\r\n margin-top: 4px;\r\n &:first-of-type {\r\n margin-left: 15px;\r\n }\r\n &:last-of-type {\r\n margin-right: 15px;\r\n }\r\n &.active {\r\n background-color: #42b983;\r\n color: #fff;\r\n border-color: #42b983;\r\n &::before {\r\n content: '';\r\n background: #fff;\r\n display: inline-block;\r\n width: 8px;\r\n height: 8px;\r\n border-radius: 50%;\r\n position: relative;\r\n margin-right: 2px;\r\n }\r\n }\r\n }\r\n }\r\n .contextmenu {\r\n margin: 0;\r\n background: #fff;\r\n z-index: 3000;\r\n position: absolute;\r\n list-style-type: none;\r\n padding: 5px 0;\r\n border-radius: 4px;\r\n font-size: 12px;\r\n font-weight: 400;\r\n color: #333;\r\n box-shadow: 2px 2px 3px 0 rgba(0, 0, 0, .3);\r\n li {\r\n margin: 0;\r\n padding: 7px 16px;\r\n cursor: pointer;\r\n &:hover {\r\n background: #eee;\r\n }\r\n }\r\n }\r\n}\r\n</style>\r\n\r\n<style lang=\"scss\">\r\n//reset element css of el-icon-close\r\n.tags-view-wrapper {\r\n .tags-view-item {\r\n .el-icon-close {\r\n width: 16px;\r\n height: 16px;\r\n vertical-align: 2px;\r\n border-radius: 50%;\r\n text-align: center;\r\n transition: all .3s cubic-bezier(.645, .045, .355, 1);\r\n transform-origin: 100% 50%;\r\n &:before {\r\n transform: scale(.6);\r\n display: inline-block;\r\n vertical-align: -3px;\r\n }\r\n &:hover {\r\n background-color: #b4bccc;\r\n color: #fff;\r\n }\r\n }\r\n }\r\n}\r\n</style>\r\n"],"mappings":"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"}]}