mirror of
https://github.com/nuxt/nuxt.git
synced 2025-02-06 13:03:11 +00:00
safer store with try catch
This commit is contained in:
parent
f0fba0b0c5
commit
9fd04a6ec8
@ -2,7 +2,16 @@ import Vue from 'vue'
|
||||
import Vuex from 'vuex'
|
||||
Vue.use(Vuex)
|
||||
|
||||
const files = require.context('~store', false, /^\.\/.*\.js$/)
|
||||
let files
|
||||
let filenames = []
|
||||
|
||||
try {
|
||||
files = require.context('~store', false, /^\.\/.*\.js$/)
|
||||
filenames = files.keys()
|
||||
} catch (e) {
|
||||
console.warn('Nuxt.js store:', e.message)
|
||||
}
|
||||
|
||||
function getModule (filename) {
|
||||
let file = files(filename)
|
||||
return file.default
|
||||
@ -14,7 +23,7 @@ let store
|
||||
let storeData = {}
|
||||
|
||||
// Check if store/index.js returns a vuex store
|
||||
if (files.keys().includes('./index.js')) {
|
||||
if (filenames.includes('./index.js')) {
|
||||
let mainModule = getModule('./index.js')
|
||||
if (mainModule.commit) {
|
||||
store = mainModule
|
||||
@ -26,7 +35,7 @@ if (files.keys().includes('./index.js')) {
|
||||
// Generate the store if there is no store yet
|
||||
if (store == null) {
|
||||
storeData.modules = storeData.modules || {}
|
||||
for (let filename of files.keys()) {
|
||||
for (let filename of filenames) {
|
||||
let name = filename.replace(/^\.\//, '').replace(/\.js$/, '')
|
||||
if (name === 'index') continue
|
||||
storeData.modules[name] = getModule(filename)
|
||||
|
Loading…
Reference in New Issue
Block a user