436627e16870232b54e23597393ea1e1.json 15 KB

1
  1. {"remainingRequest":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/thread-loader/dist/cjs.js!/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/babel-loader/lib/index.js!/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/eslint-loader/index.js??ref--13-0!/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/src/store/modules/theme.js","dependencies":[{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/src/store/modules/theme.js","mtime":1616226096000},{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/thread-loader/dist/cjs.js","mtime":499162500000},{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/babel-loader/lib/index.js","mtime":499162500000},{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/eslint-loader/index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import "core-js/modules/es.array.filter";
import "core-js/modules/es.array.for-each";
import "core-js/modules/es.array.index-of";
import "core-js/modules/es.array.slice";
import "core-js/modules/es.array.some";
import "core-js/modules/es.object.to-string";
import "core-js/modules/web.dom-collections.for-each";

/**
 * 主题状态管理
 */
import setting from '@/config/setting'; // 获取屏幕宽度

var screenWidth = document.documentElement.clientWidth || document.body.clientWidth; // 获取本地缓存配置

var cache = {};

try {
  cache = JSON.parse(localStorage.getItem(setting.themeStoreName) || '{}');
} catch (e) {
  console.error(e);
} // 获取缓存的主题配置和缓存的主题css


var cacheTheme = getCache(['sideStyle', 'headStyle', 'tabStyle', 'bodyFull', 'layoutStyle', 'theme', 'showTabs', 'logoAutoSize', 'fixedLayout', 'colorfulIcon', 'sideUniqueOpen'], setting),
    cacheStyle = {},
    cacheStoreName = setting.themeStoreName + '-cache';

if (cacheTheme.theme) {
  try {
    cacheStyle = JSON.parse(localStorage.getItem(cacheStoreName) || '{}');
    if (!cacheStyle || setting.version !== cacheStyle.version) cacheStyle = {};
  } catch (e) {
    console.error(e);
  }
}

export default {
  namespaced: true,
  state: {
    sideStyle: cacheTheme.sideStyle,
    // 侧边栏风格,0默认,1暗色
    headStyle: cacheTheme.headStyle,
    // 顶栏风格,0默认,1暗色,2主色
    tabStyle: cacheTheme.tabStyle,
    // 标签页风格,0默认(下划线),1圆点,2卡片
    bodyFull: cacheTheme.bodyFull,
    // 内容区域宽度铺满
    layoutStyle: cacheTheme.layoutStyle,
    // 布局风格,0默认,1顶部菜单风格,2混合菜单风格
    theme: cacheTheme.theme,
    // 主题色
    showTabs: cacheTheme.showTabs,
    // 是否开启多标签
    logoAutoSize: cacheTheme.logoAutoSize,
    // logo是否自适应宽度
    fixedLayout: cacheTheme.fixedLayout,
    // 是否固定顶栏和侧栏
    colorfulIcon: cacheTheme.colorfulIcon,
    // 侧栏是否多彩图标
    sideUniqueOpen: cacheTheme.sideUniqueOpen,
    // 侧边栏是否只保持一个子菜单展开
    collapse: screenWidth < 992,
    // 是否折叠侧边栏
    screenWidth: screenWidth,
    // 当前屏幕宽度
    showSetting: false,
    // 是否显示主题设置抽屉
    showPassword: false,
    // 是否显示修改密码弹窗
    themeCache: cacheStyle.cache || {},
    // 主题css缓存
    reload: false,
    // 用于刷新
    tabs: [],
    // 当前打开的选项卡
    navActive: 0 // 混合导航模式顶部选中

  },
  mutations: {
    SET: function SET(state, obj) {
      state[obj.key] = obj.value;

      if (['collapse', 'reload', 'showSetting'].indexOf(obj.key) !== -1) {
        // 重新获取屏幕宽度
        var sw = document.documentElement.clientWidth || document.body.clientWidth;
        if (state.screenWidth !== sw) state.screenWidth = sw;
      }

      if (state.showSetting && obj.key !== 'showSetting') {
        var temp = JSON.parse(localStorage.getItem(setting.themeStoreName) || '{}');
        temp[obj.key] = obj.value;
        localStorage.setItem(setting.themeStoreName, JSON.stringify(temp));
      }
    },
    TAB_PUSH: function TAB_PUSH(state, obj) {
      if (!state.tabs.some(function (r) {
        return r.path === obj.path;
      })) state.tabs.push(obj);
    }
  },
  actions: {
    /* 修改配置 */
    set: function set(_ref, obj) {
      var commit = _ref.commit;
      commit('SET', obj);
    },

    /* 切换配置 */
    toggle: function toggle(_ref2, key) {
      var commit = _ref2.commit,
          state = _ref2.state;
      commit('SET', {
        key: key,
        value: !state[key]
      });
    },

    /* 混合菜单模式切换侧边栏显示 */
    setNavActive: function setNavActive(_ref3, index) {
      var commit = _ref3.commit;
      commit('SET', {
        key: 'navActive',
        value: index
      });
    },

    /* 添加新tab */
    tabAdd: function tabAdd(_ref4, obj) {
      var commit = _ref4.commit;
      commit('TAB_PUSH', obj);
    },

    /* 关闭指定tab */
    tabRemove: function tabRemove(_ref5, path) {
      var commit = _ref5.commit,
          state = _ref5.state;
      return new Promise(function (resolve) {
        var last = -1;

        for (var i = 0; i < state.tabs.length; i++) {
          if (state.tabs[i].path === path) {
            break;
          }

          last = i;
        }

        commit('SET', {
          key: 'tabs',
          value: state.tabs.filter(function (d) {
            return d.path !== path;
          })
        });
        resolve(last);
      });
    },

    /* 关闭所有tab */
    tabRemoveAll: function tabRemoveAll(_ref6) {
      var commit = _ref6.commit;
      commit('SET', {
        key: 'tabs',
        value: []
      });
    },

    /* 关闭左侧tab */
    tabRemoveLeft: function tabRemoveLeft(_ref7, path) {
      var commit = _ref7.commit,
          state = _ref7.state;

      for (var i = 0; i < state.tabs.length; i++) {
        if (state.tabs[i].path === path) {
          commit('SET', {
            key: 'tabs',
            value: state.tabs.slice(i)
          });
          break;
        }
      }
    },

    /* 关闭右侧tab */
    tabRemoveRight: function tabRemoveRight(_ref8, path) {
      var commit = _ref8.commit,
          state = _ref8.state;

      for (var i = 0; i < state.tabs.length; i++) {
        if (state.tabs[i].path === path) {
          commit('SET', {
            key: 'tabs',
            value: state.tabs.slice(0, i + 1)
          });
          break;
        }
      }
    },

    /* 关闭其他tab */
    tabRemoveOther: function tabRemoveOther(_ref9, path) {
      var commit = _ref9.commit,
          state = _ref9.state;
      commit('SET', {
        key: 'tabs',
        value: state.tabs.filter(function (d) {
          return d.path === path;
        })
      });
    },

    /* 切换主题 */
    setTheme: function setTheme(_ref10, theme) {
      var commit = _ref10.commit,
          state = _ref10.state;
      return new Promise(function (resolve, reject) {
        if (!theme) {
          // 恢复默认主题
          document.head.querySelectorAll('style[id^="ele-theme-"],link[id^="ele-theme-"]').forEach(function (node) {
            node.parentNode.removeChild(node);
          });
          commit('SET', {
            key: 'theme',
            value: theme
          });
          return resolve();
        } else if (state.themeCache[theme]) {
          // 主题css已经缓存过
          document.head.querySelectorAll('style[id^="ele-theme-"],link[id^="ele-theme-"]').forEach(function (node) {
            node.parentNode.removeChild(node);
          });
          var elem = document.createElement('style');
          elem.id = "ele-theme-".concat(theme);
          elem.setAttribute('type', 'text/css');
          elem.innerHTML = state.themeCache[theme];
          document.head.appendChild(elem);
          commit('SET', {
            key: 'theme',
            value: theme
          });
          return resolve();
        } else {
          // 动态引入主题css
          // 检查主题css模块是否已被加载过
          var oldElem = document.head.querySelector("#ele-theme-".concat(theme, "-js"));

          if (oldElem) {
            // 已被加载过创建css的link标签
            document.head.querySelectorAll('style[id^="ele-theme-"],link[id^="ele-theme-"]').forEach(function (node) {
              node.parentNode.removeChild(node);
            });

            var _elem = document.createElement('link');

            _elem.id = "ele-theme-".concat(theme);

            _elem.setAttribute('type', 'text/css');

            _elem.setAttribute('rel', 'stylesheet');

            _elem.setAttribute('href', oldElem.getAttribute('ele-css'));

            document.head.appendChild(_elem);
            commit('SET', {
              key: 'theme',
              value: theme
            });
            return resolve();
          } // 把head下面相关元素标记为非主题元素


          document.head.querySelectorAll('style:not([id^="ele-theme-"]),link:not([id^="ele-theme-"]),script:not([id^="ele-theme-"])').forEach(function (node) {
            if (!node.getAttribute('ele-theme')) node.setAttribute('ele-theme', 'no');
          }); // 加载主题css模块

          import("@/styles/theme/".concat(theme, ".scss")).then(function () {
            // 移除上次的主题
            document.head.querySelectorAll('style[id^="ele-theme-"],link[id^="ele-theme-"]').forEach(function (node) {
              node.parentNode.removeChild(node);
            }); // 获取import之后的主题标签

            var elem = document.head.querySelectorAll('style:not([ele-theme="no"])');
            elem = elem.length ? elem[elem.length - 1] : null;

            if (!elem) {
              // 可能是style标签也可能是link标签
              elem = document.head.querySelectorAll('link:not([ele-theme="no"])');
              elem = elem.length ? elem[elem.length - 1] : null;
              if (!elem) return reject(new Error('theme element not found.')); // 再找到对应的主题js模块的标签

              var href = elem.getAttribute('href');
              var uuid = href.substring(href.indexOf('chunk-'), href.indexOf('.'));
              var node = document.head.querySelectorAll("script[src^=\"/js/".concat(uuid, "\"]:not([ele-theme=\"no\"])"));

              if (node.length) {
                node[node.length - 1].id = "ele-theme-".concat(theme, "-js");
                node[node.length - 1].setAttribute('ele-css', href); // 记录css的link地址
              }
            }

            elem.id = "ele-theme-".concat(theme);
            commit('SET', {
              key: 'theme',
              value: theme
            }); // 缓存主题css

            if (elem.innerHTML) {
              state.themeCache[theme] = elem.innerHTML;
              var _cache = {};
              _cache[state.theme] = state.themeCache[theme];

              try {
                localStorage.setItem(cacheStoreName, JSON.stringify({
                  version: setting.version,
                  cache: _cache
                }));
              } catch (e) {
                console.error(e);
              }
            }

            return resolve();
          }).catch(function (e) {
            reject(e);
          });
        }
      });
    }
  }
};
/**
 * 获取缓存配置项
 * @param k 配置项
 * @param v 默认值
 */

function getCache(k, v) {
  if (Array.isArray(k)) {
    var obj = {};
    k.forEach(function (t) {
      obj[t] = cache[t] === null || cache[t] === undefined ? v[t] : cache[t];
    });
    return obj;
  } else {
    if (cache[k] === null || cache[k] === undefined) return v;
    return cache[k];
  }
}"},null]}