mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-23 22:25:12 +00:00
Create nested modules for each folder in ./store
This commit is contained in:
parent
5ff6424e09
commit
78ea2591c2
@ -2,7 +2,7 @@ import Vue from 'vue'
|
|||||||
import Vuex from 'vuex'
|
import Vuex from 'vuex'
|
||||||
Vue.use(Vuex)
|
Vue.use(Vuex)
|
||||||
|
|
||||||
let files = require.context('~/store', false, /^\.\/.*\.js$/)
|
let files = require.context('~/store', true, /^\.\/.*\.js$/)
|
||||||
let filenames = files.keys()
|
let filenames = files.keys()
|
||||||
|
|
||||||
function getModule (filename) {
|
function getModule (filename) {
|
||||||
@ -12,6 +12,18 @@ function getModule (filename) {
|
|||||||
: file
|
: file
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getModuleNamespace (storeData, namePath) {
|
||||||
|
if (namePath.length == 1) return storeData.modules
|
||||||
|
|
||||||
|
let namespace = namePath.shift()
|
||||||
|
|
||||||
|
storeData.modules[namespace] = storeData.modules[namespace] || {}
|
||||||
|
storeData.modules[namespace].namespaced = true
|
||||||
|
storeData.modules[namespace].modules = storeData.modules[namespace].modules || {}
|
||||||
|
|
||||||
|
return getModuleNamespace(storeData.modules[namespace], namePath)
|
||||||
|
}
|
||||||
|
|
||||||
let store
|
let store
|
||||||
let storeData = {}
|
let storeData = {}
|
||||||
|
|
||||||
@ -31,8 +43,13 @@ if (store == null) {
|
|||||||
for (let filename of filenames) {
|
for (let filename of filenames) {
|
||||||
let name = filename.replace(/^\.\//, '').replace(/\.js$/, '')
|
let name = filename.replace(/^\.\//, '').replace(/\.js$/, '')
|
||||||
if (name === 'index') continue
|
if (name === 'index') continue
|
||||||
storeData.modules[name] = getModule(filename)
|
|
||||||
storeData.modules[name].namespaced = true
|
let namePath = name.split(/\//)
|
||||||
|
let module = getModuleNamespace(storeData, namePath)
|
||||||
|
|
||||||
|
name = namePath.pop()
|
||||||
|
module[name] = getModule(filename)
|
||||||
|
module[name].namespaced = true
|
||||||
}
|
}
|
||||||
store = new Vuex.Store(storeData)
|
store = new Vuex.Store(storeData)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user