|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
// import Vue from 'vue'
// import Vuex from 'vuex'
// import getters from './getters'
// import app from './modules/app'
// import settings from './modules/settings'
// import user from './modules/user'
// Vue.use(Vuex)
// const store = new Vuex.Store({
// modules: {
// app,
// settings,
// user
// },
// getters
// })
// export default store
|
|
21
22
23
|
import Vue from 'vue'
import Vuex from 'vuex'
import getters from './getters'
|
|
24
|
import flow from './modules/flow'
|
|
25
|
|
|
26
|
Vue.use(Vuex)
|
|
27
|
|
|
28
|
// https://webpack.js.org/guides/dependency-management/#requirecontext
|
|
29
|
const modulesFiles = require.context('./modules', true, /\.js$/)
|
|
30
31
32
33
34
|
// 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'
|
|
35
36
37
38
39
|
const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1')
const value = modulesFiles(modulePath)
modules[moduleName] = value.default
return modules
}, {})
|
|
40
|
|
|
41
|
export default new Vuex.Store({
|
|
42
|
modules,
|
|
43
|
getters
|
|
44
45
|
});
|
|
46
|
|