45 lines
1.2 KiB
JavaScript
45 lines
1.2 KiB
JavaScript
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 store = new Vuex.Store({
|
||
modules,
|
||
getters,
|
||
actions: {
|
||
load(context) {
|
||
return this.dispatch("loadUser").then(() => {
|
||
const promises = [];
|
||
return Promise.all(promises);
|
||
})
|
||
},
|
||
unload(context) {
|
||
context.commit("clear");
|
||
}
|
||
},
|
||
plugins: [
|
||
createPersistedState({
|
||
key: 'vuex',
|
||
// 存储数据中的哪些数据(如果是模块下具体的数据需要加上模块名称,如 user.token)
|
||
paths: ['user.userId', 'user.username']
|
||
})
|
||
]
|
||
})
|
||
|
||
export default store
|