1234567891011121314151617181920212223242526272829303132333435363738394041 |
- /* 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
|