/* eslint-disable no-undef */ import Vue from 'vue' import Vuex from 'vuex' import getters from './getters' import createPersistedState from 'vuex-persistedstate' Vue.use(Vuex) // https://webpack.js.org/guides/dependency-management/#requirecontext const modulesFiles = require.context('./modules', true, /\.js$/) // you do not need `import app from './modules/app'` // it will auto require all vuex module from modules file const modules = modulesFiles.keys().reduce((modules, modulePath) => { // set './app.js' => 'app' const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1') const value = modulesFiles(modulePath) modules[moduleName] = value.default return modules }, {}) const vuexPersisted = createPersistedState({ storage: window.sessionStorage, key: 'yunti', reducer(state) { // 配置需要持久化的数据,有需要在此添加 return { global: { cache_keys: state.global.cache_keys } } } }) const store = new Vuex.Store({ modules, getters, plugins: [vuexPersisted] }) export default store