PteroTheme/resources/assets/scripts/store/index.ts

35 lines
1.0 KiB
TypeScript
Raw Normal View History

import Vue from 'vue';
2018-06-03 23:45:01 +01:00
import Vuex from 'vuex';
2018-12-17 02:57:34 +00:00
import auth from './modules/auth';
import dashboard from './modules/dashboard';
import server from './modules/server';
import socket from './modules/socket';
import {ApplicationState} from "./types";
2018-06-03 23:45:01 +01:00
Vue.use(Vuex);
2018-12-17 02:57:34 +00:00
const store = new Vuex.Store<ApplicationState>({
2018-06-06 07:42:34 +01:00
strict: process.env.NODE_ENV !== 'production',
modules: {auth, dashboard, server, socket},
});
if (module.hot) {
module.hot.accept(['./modules/auth'], () => {
const newAuthModule = require('./modules/auth').default;
2018-07-16 01:53:40 +01:00
const newDashboardModule = require('./modules/dashboard').default;
const newServerModule = require('./modules/server').default;
const newSocketModule = require('./modules/socket').default;
store.hotUpdate({
modules: {
auth: newAuthModule,
dashboard: newDashboardModule,
server: newServerModule,
socket: newSocketModule
},
});
2018-06-03 23:45:01 +01:00
});
}
2018-06-03 23:45:01 +01:00
export default store;