Stackedit/src/store/index.js

58 lines
1.3 KiB
JavaScript
Raw Normal View History

2017-07-23 18:42:08 +00:00
import createLogger from 'vuex/dist/logger';
import Vue from 'vue';
import Vuex from 'vuex';
2017-08-17 23:10:35 +00:00
import utils from '../services/utils';
import contentState from './modules/contentState';
import syncContent from './modules/syncContent';
import content from './modules/content';
import file from './modules/file';
import folder from './modules/folder';
import data from './modules/data';
2017-07-23 18:42:08 +00:00
import layout from './modules/layout';
import editor from './modules/editor';
2017-07-31 09:04:01 +00:00
import explorer from './modules/explorer';
import modal from './modules/modal';
2017-08-15 10:43:26 +00:00
import queue from './modules/queue';
2017-07-23 18:42:08 +00:00
Vue.use(Vuex);
const debug = process.env.NODE_ENV !== 'production';
2017-08-17 23:10:35 +00:00
export default new Vuex.Store({
state: {
ready: false,
},
2017-08-17 23:10:35 +00:00
getters: {
allItemMap: (state) => {
const result = {};
utils.types.forEach(type => Object.assign(result, state[type].itemMap));
return result;
},
syncedItemMap: (state) => {
const result = {};
['file', 'folder'].forEach(type => Object.assign(result, state[type].itemMap));
return result;
},
},
mutations: {
setReady: (state) => {
state.ready = true;
},
},
2017-07-23 18:42:08 +00:00
modules: {
2017-08-17 23:10:35 +00:00
contentState,
syncContent,
content,
file,
folder,
data,
2017-07-23 18:42:08 +00:00
layout,
editor,
2017-07-31 09:04:01 +00:00
explorer,
modal,
2017-08-15 10:43:26 +00:00
queue,
2017-07-23 18:42:08 +00:00
},
strict: debug,
2017-07-27 20:19:52 +00:00
plugins: debug ? [createLogger()] : [],
2017-07-23 18:42:08 +00:00
});