1 line
20 KiB
JSON
1 line
20 KiB
JSON
{"remainingRequest":"/Users/kang/Gitea/vue-element-admin/node_modules/babel-loader/lib/index.js!/Users/kang/Gitea/vue-element-admin/node_modules/cache-loader/dist/cjs.js??ref--0-0!/Users/kang/Gitea/vue-element-admin/node_modules/vue-loader/lib/index.js??vue-loader-options!/Users/kang/Gitea/vue-element-admin/src/components/HeaderSearch/index.vue?vue&type=script&lang=js","dependencies":[{"path":"/Users/kang/Gitea/vue-element-admin/src/components/HeaderSearch/index.vue","mtime":1755961551643},{"path":"/Users/kang/Gitea/vue-element-admin/babel.config.js","mtime":1755961549149},{"path":"/Users/kang/Gitea/vue-element-admin/node_modules/cache-loader/dist/cjs.js","mtime":1755961549645},{"path":"/Users/kang/Gitea/vue-element-admin/node_modules/babel-loader/lib/index.js","mtime":1755961549535},{"path":"/Users/kang/Gitea/vue-element-admin/node_modules/cache-loader/dist/cjs.js","mtime":1755961549645},{"path":"/Users/kang/Gitea/vue-element-admin/node_modules/vue-loader/lib/index.js","mtime":1755961551495}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import _toConsumableArray from "/Users/kang/Gitea/vue-element-admin/node_modules/@babel/runtime/helpers/esm/toConsumableArray.js";
import _createForOfIteratorHelper from "/Users/kang/Gitea/vue-element-admin/node_modules/@babel/runtime/helpers/esm/createForOfIteratorHelper.js";
import _regenerator from "/Users/kang/Gitea/vue-element-admin/node_modules/@babel/runtime/helpers/esm/regenerator.js";
import _interopRequireWildcard from "/Users/kang/Gitea/vue-element-admin/node_modules/@babel/runtime/helpers/esm/interopRequireWildcard.js";
import _asyncToGenerator from "/Users/kang/Gitea/vue-element-admin/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js";
import "core-js/modules/es.array.concat.js";
import "core-js/modules/es.array.join.js";
import "core-js/modules/es.object.to-string.js";
import "core-js/modules/es.regexp.exec.js";
import "core-js/modules/es.string.iterator.js";
import "core-js/modules/es.string.search.js";
import "core-js/modules/esnext.iterator.constructor.js";
import "core-js/modules/esnext.iterator.for-each.js";
import "core-js/modules/web.dom-collections.for-each.js";
import "core-js/modules/web.dom-collections.iterator.js";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

// fuse is a lightweight fuzzy-search module
// make search results more in line with expectations
import Fuse from 'fuse.js';
import path from 'path';
import i18n from '@/lang';
export default {
  name: 'HeaderSearch',
  data: function data() {
    return {
      search: '',
      options: [],
      searchPool: [],
      show: false,
      fuse: undefined
    };
  },
  computed: {
    routes: function routes() {
      return this.$store.getters.permission_routes;
    },
    lang: function lang() {
      return this.$store.getters.language;
    },
    supportPinyinSearch: function supportPinyinSearch() {
      return this.$store.state.settings.supportPinyinSearch;
    }
  },
  watch: {
    lang: function lang() {
      this.searchPool = this.generateRoutes(this.routes);
    },
    routes: function routes() {
      this.searchPool = this.generateRoutes(this.routes);
    },
    searchPool: function searchPool(list) {
      // Support pinyin search
      if (this.lang === 'zh' && this.supportPinyinSearch) {
        this.addPinyinField(list);
      }
      this.initFuse(list);
    },
    show: function show(value) {
      if (value) {
        document.body.addEventListener('click', this.close);
      } else {
        document.body.removeEventListener('click', this.close);
      }
    }
  },
  mounted: function mounted() {
    this.searchPool = this.generateRoutes(this.routes);
  },
  methods: {
    addPinyinField: function addPinyinField(list) {
      return _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() {
        var _yield$import, pinyin;
        return _regenerator().w(function (_context) {
          while (1) switch (_context.n) {
            case 0:
              _context.n = 1;
              return Promise.resolve().then(function () {
                return _interopRequireWildcard(require('pinyin'));
              });
            case 1:
              _yield$import = _context.v;
              pinyin = _yield$import.default;
              if (!Array.isArray(list)) {
                _context.n = 2;
                break;
              }
              list.forEach(function (element) {
                var title = element.title;
                if (Array.isArray(title)) {
                  title.forEach(function (v) {
                    v = pinyin(v, {
                      style: pinyin.STYLE_NORMAL
                    }).join('');
                    element.pinyinTitle = v;
                  });
                }
              });
              return _context.a(2, list);
            case 2:
              return _context.a(2);
          }
        }, _callee);
      }))();
    },
    click: function click() {
      this.show = !this.show;
      if (this.show) {
        this.$refs.headerSearchSelect && this.$refs.headerSearchSelect.focus();
      }
    },
    close: function close() {
      this.$refs.headerSearchSelect && this.$refs.headerSearchSelect.blur();
      this.options = [];
      this.show = false;
    },
    change: function change(val) {
      var _this = this;
      this.$router.push(val.path);
      this.search = '';
      this.options = [];
      this.$nextTick(function () {
        _this.show = false;
      });
    },
    initFuse: function initFuse(list) {
      this.fuse = new Fuse(list, {
        shouldSort: true,
        threshold: 0.4,
        location: 0,
        distance: 100,
        maxPatternLength: 32,
        minMatchCharLength: 1,
        keys: [{
          name: 'title',
          weight: 0.7
        }, {
          name: 'pinyinTitle',
          weight: 0.3
        }, {
          name: 'path',
          weight: 0.3
        }]
      });
    },
    // Filter out the routes that can be displayed in the sidebar
    // And generate the internationalized title
    generateRoutes: function generateRoutes(routes) {
      var basePath = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '/';
      var prefixTitle = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
      var res = [];
      var _iterator = _createForOfIteratorHelper(routes),
        _step;
      try {
        for (_iterator.s(); !(_step = _iterator.n()).done;) {
          var router = _step.value;
          // skip hidden router
          if (router.hidden) {
            continue;
          }
          var data = {
            path: path.resolve(basePath, router.path),
            title: _toConsumableArray(prefixTitle)
          };
          if (router.meta && router.meta.title) {
            // generate internationalized title
            var i18ntitle = i18n.t("route.".concat(router.meta.title));
            data.title = [].concat(_toConsumableArray(data.title), [i18ntitle]);
            if (router.redirect !== 'noRedirect') {
              // only push the routes with title
              // special case: need to exclude parent router without redirect
              res.push(data);
            }
          }
          // recursive child routes
          if (router.children) {
            var tempRoutes = this.generateRoutes(router.children, data.path, data.title);
            if (tempRoutes.length >= 1) {
              res = [].concat(_toConsumableArray(res), _toConsumableArray(tempRoutes));
            }
          }
        }
      } catch (err) {
        _iterator.e(err);
      } finally {
        _iterator.f();
      }
      return res;
    },
    querySearch: function querySearch(query) {
      if (query !== '') {
        this.options = this.fuse.search(query);
      } else {
        this.options = [];
      }
    }
  }
};"},{"version":3,"names":["Fuse","path","i18n","name","data","search","options","searchPool","show","fuse","undefined","computed","routes","$store","getters","permission_routes","lang","language","supportPinyinSearch","state","settings","watch","generateRoutes","list","addPinyinField","initFuse","value","document","body","addEventListener","close","removeEventListener","mounted","methods","_asyncToGenerator","_regenerator","m","_callee","_yield$import","pinyin","w","_context","n","Promise","resolve","then","_interopRequireWildcard","require","v","default","Array","isArray","forEach","element","title","style","STYLE_NORMAL","join","pinyinTitle","a","click","$refs","headerSearchSelect","focus","blur","change","val","_this","$router","push","$nextTick","shouldSort","threshold","location","distance","maxPatternLength","minMatchCharLength","keys","weight","basePath","arguments","length","prefixTitle","res","_iterator","_createForOfIteratorHelper","_step","s","done","router","hidden","_toConsumableArray","meta","i18ntitle","t","concat","redirect","children","tempRoutes","err","e","f","querySearch","query"],"sources":["src/components/HeaderSearch/index.vue"],"sourcesContent":["<template>\n <div :class=\"{'show':show}\" class=\"header-search\">\n <svg-icon class-name=\"search-icon\" icon-class=\"search\" @click.stop=\"click\" />\n <el-select\n ref=\"headerSearchSelect\"\n v-model=\"search\"\n :remote-method=\"querySearch\"\n filterable\n default-first-option\n remote\n placeholder=\"Search\"\n class=\"header-search-select\"\n @change=\"change\"\n >\n <el-option v-for=\"item in options\" :key=\"item.path\" :value=\"item\" :label=\"item.title.join(' > ')\" />\n </el-select>\n </div>\n</template>\n\n<script>\n// fuse is a lightweight fuzzy-search module\n// make search results more in line with expectations\nimport Fuse from 'fuse.js'\nimport path from 'path'\nimport i18n from '@/lang'\n\nexport default {\n name: 'HeaderSearch',\n data() {\n return {\n search: '',\n options: [],\n searchPool: [],\n show: false,\n fuse: undefined\n }\n },\n computed: {\n routes() {\n return this.$store.getters.permission_routes\n },\n lang() {\n return this.$store.getters.language\n },\n supportPinyinSearch() {\n return this.$store.state.settings.supportPinyinSearch\n }\n },\n watch: {\n lang() {\n this.searchPool = this.generateRoutes(this.routes)\n },\n routes() {\n this.searchPool = this.generateRoutes(this.routes)\n },\n searchPool(list) {\n // Support pinyin search\n if (this.lang === 'zh' && this.supportPinyinSearch) {\n this.addPinyinField(list)\n }\n this.initFuse(list)\n },\n show(value) {\n if (value) {\n document.body.addEventListener('click', this.close)\n } else {\n document.body.removeEventListener('click', this.close)\n }\n }\n },\n mounted() {\n this.searchPool = this.generateRoutes(this.routes)\n },\n methods: {\n async addPinyinField(list) {\n const { default: pinyin } = await import('pinyin')\n if (Array.isArray(list)) {\n list.forEach(element => {\n const title = element.title\n if (Array.isArray(title)) {\n title.forEach(v => {\n v = pinyin(v, {\n style: pinyin.STYLE_NORMAL\n }).join('')\n element.pinyinTitle = v\n })\n }\n })\n return list\n }\n },\n click() {\n this.show = !this.show\n if (this.show) {\n this.$refs.headerSearchSelect && this.$refs.headerSearchSelect.focus()\n }\n },\n close() {\n this.$refs.headerSearchSelect && this.$refs.headerSearchSelect.blur()\n this.options = []\n this.show = false\n },\n change(val) {\n this.$router.push(val.path)\n this.search = ''\n this.options = []\n this.$nextTick(() => {\n this.show = false\n })\n },\n initFuse(list) {\n this.fuse = new Fuse(list, {\n shouldSort: true,\n threshold: 0.4,\n location: 0,\n distance: 100,\n maxPatternLength: 32,\n minMatchCharLength: 1,\n keys: [{\n name: 'title',\n weight: 0.7\n }, {\n name: 'pinyinTitle',\n weight: 0.3\n }, {\n name: 'path',\n weight: 0.3\n }]\n })\n },\n // Filter out the routes that can be displayed in the sidebar\n // And generate the internationalized title\n generateRoutes(routes, basePath = '/', prefixTitle = []) {\n let res = []\n for (const router of routes) {\n // skip hidden router\n if (router.hidden) { continue }\n const data = {\n path: path.resolve(basePath, router.path),\n title: [...prefixTitle]\n }\n if (router.meta && router.meta.title) {\n // generate internationalized title\n const i18ntitle = i18n.t(`route.${router.meta.title}`)\n data.title = [...data.title, i18ntitle]\n if (router.redirect !== 'noRedirect') {\n // only push the routes with title\n // special case: need to exclude parent router without redirect\n res.push(data)\n }\n }\n // recursive child routes\n if (router.children) {\n const tempRoutes = this.generateRoutes(router.children, data.path, data.title)\n if (tempRoutes.length >= 1) {\n res = [...res, ...tempRoutes]\n }\n }\n }\n return res\n },\n querySearch(query) {\n if (query !== '') {\n this.options = this.fuse.search(query)\n } else {\n this.options = []\n }\n }\n }\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.header-search {\n font-size: 0 !important;\n .search-icon {\n cursor: pointer;\n font-size: 18px;\n vertical-align: middle;\n }\n .header-search-select {\n font-size: 18px;\n transition: width 0.2s;\n width: 0;\n overflow: hidden;\n background: transparent;\n border-radius: 0;\n display: inline-block;\n vertical-align: middle;\n\n ::v-deep .el-input__inner {\n border-radius: 0;\n border: 0;\n padding-left: 0;\n padding-right: 0;\n box-shadow: none !important;\n border-bottom: 1px solid #d9d9d9;\n vertical-align: middle;\n }\n }\n &.show {\n .header-search-select {\n width: 210px;\n margin-left: 10px;\n }\n }\n}\n</style>\n"],"mappings":"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","ignoreList":[]}]} |