safer store with try catch

This commit is contained in:
Brendan 2017-01-02 10:13:53 +01:00
parent f0fba0b0c5
commit 9fd04a6ec8

View File

@ -2,7 +2,16 @@ import Vue from 'vue'
import Vuex from 'vuex' import Vuex from 'vuex'
Vue.use(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) { function getModule (filename) {
let file = files(filename) let file = files(filename)
return file.default return file.default
@ -14,7 +23,7 @@ let store
let storeData = {} let storeData = {}
// Check if store/index.js returns a vuex store // 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') let mainModule = getModule('./index.js')
if (mainModule.commit) { if (mainModule.commit) {
store = mainModule store = mainModule
@ -26,7 +35,7 @@ if (files.keys().includes('./index.js')) {
// Generate the store if there is no store yet // Generate the store if there is no store yet
if (store == null) { if (store == null) {
storeData.modules = storeData.modules || {} storeData.modules = storeData.modules || {}
for (let filename of files.keys()) { 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] = getModule(filename)