From 2ab66ba8c89f5a8d2b444f2f249494a4444bc3a9 Mon Sep 17 00:00:00 2001 From: Dane Everitt Date: Wed, 18 Jul 2018 22:48:19 -0700 Subject: [PATCH] Add logic to load server data into vuex for the request when visiting a server page --- .../components/dashboard/Dashboard.vue | 2 +- .../scripts/components/server/Server.vue | 74 ++++++++------- .../assets/scripts/models/loadingStates.js | 6 -- resources/assets/scripts/store/index.js | 6 +- .../assets/scripts/store/modules/server.js | 91 +++++++------------ webpack.config.js | 2 +- 6 files changed, 82 insertions(+), 99 deletions(-) delete mode 100644 resources/assets/scripts/models/loadingStates.js diff --git a/resources/assets/scripts/components/dashboard/Dashboard.vue b/resources/assets/scripts/components/dashboard/Dashboard.vue index 79a16fa72..4e1905522 100644 --- a/resources/assets/scripts/components/dashboard/Dashboard.vue +++ b/resources/assets/scripts/components/dashboard/Dashboard.vue @@ -13,7 +13,7 @@
- +
diff --git a/resources/assets/scripts/components/server/Server.vue b/resources/assets/scripts/components/server/Server.vue index 0322d2696..4e20bd209 100644 --- a/resources/assets/scripts/components/server/Server.vue +++ b/resources/assets/scripts/components/server/Server.vue @@ -1,12 +1,17 @@ diff --git a/resources/assets/scripts/models/loadingStates.js b/resources/assets/scripts/models/loadingStates.js deleted file mode 100644 index cd90d4522..000000000 --- a/resources/assets/scripts/models/loadingStates.js +++ /dev/null @@ -1,6 +0,0 @@ -const LoadingState = { - LOADING: 'loading', - DONE: 'done', - ERROR: 'error', -}; -export default LoadingState; diff --git a/resources/assets/scripts/store/index.js b/resources/assets/scripts/store/index.js index 4e0e2663a..cb13880d5 100644 --- a/resources/assets/scripts/store/index.js +++ b/resources/assets/scripts/store/index.js @@ -2,21 +2,23 @@ import Vue from 'vue'; import Vuex from 'vuex'; import auth from './modules/auth'; import dashboard from './modules/dashboard'; +import server from './modules/server'; Vue.use(Vuex); const store = new Vuex.Store({ strict: process.env.NODE_ENV !== 'production', - modules: { auth, dashboard }, + modules: {auth, dashboard, server}, }); if (module.hot) { module.hot.accept(['./modules/auth'], () => { const newAuthModule = require('./modules/auth').default; const newDashboardModule = require('./modules/dashboard').default; + const newServerModule = require('./modules/server').default; store.hotUpdate({ - modules: { newAuthModule, newDashboardModule }, + modules: {newAuthModule, newDashboardModule, newServerModule}, }); }); } diff --git a/resources/assets/scripts/store/modules/server.js b/resources/assets/scripts/store/modules/server.js index 32026896f..59f0f8cd8 100644 --- a/resources/assets/scripts/store/modules/server.js +++ b/resources/assets/scripts/store/modules/server.js @@ -1,64 +1,43 @@ -import LoadingState from '../../models/loadingStates'; import route from '../../../../../vendor/tightenco/ziggy/src/js/route'; +import Server from '../../models/server'; export default { + namespaced: true, state: { - servers: {}, - serverIDs: [], - currentServerID: '', - serverLoadingState: '', - }, - mutations: { - setCurrentServer (state, serverID) { - state.currentServerID = serverID; - }, - setServers (state, servers) { - servers.forEach(s => { - state.servers[s.identifier] = s; - if (!!state.serverIDs.indexOf(s.identifier)) { - state.serverIDs.push(s.identifier) - } - }); - }, - removeServer (state, serverID) { - delete state.servers[serverID]; - state.serverIDs.remove(serverID); - }, - setServerLoadingState (state, s) { - state.serverLoadingState = s; - } - }, - actions: { - loadServers({ commit }) { - commit('setServerLoadingState', LoadingState.LOADING); - window.axios.get(route('api.client.index')) - .then(response => { - commit('setServers', response.data.data.map(o => o.attributes)); - commit('setServerLoadingState', LoadingState.DONE); - }) - .catch(err => { - console.error(err); - const response = err.response; - if (response.data && _.isObject(response.data.errors)) { - response.data.errors.forEach(function (error) { - this.error(error.detail); - }); - } - }) - .finally(() => { - this.loading = false; - }); - }, + server: {}, }, getters: { - currentServer (state) { - return state.servers[state.route.params.serverID]; + }, + actions: { + /** + * + * @param commit + * @param {String} server + * @returns {Promise} + */ + getServer: ({commit}, {server}) => { + return new Promise((resolve, reject) => { + window.axios.get(route('api.client.servers.view', { server })) + .then(response => { + // If there is a 302 redirect or some other odd behavior (basically, response that isnt + // in JSON format) throw an error and don't try to continue with the login. + if (!(response.data instanceof Object)) { + return reject(new Error('An error was encountered while processing this request.')); + } + + if (response.data.object === 'server' && response.data.attributes) { + commit('SERVER_DATA', response.data.attributes) + } + + return resolve(); + }) + .catch(reject); + }); }, - isServersLoading (state) { - return state.serverLoadingState === LoadingState.LOADING; - }, - serverList (state) { - return state.serverIDs.map(k => state.servers[k]); + }, + mutations: { + SERVER_DATA: function (state, data) { + state.server = data; } - } -}; + }, +} diff --git a/webpack.config.js b/webpack.config.js index 8ce74107d..d0e4ac41e 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -68,7 +68,7 @@ const productionPlugins = [ module.exports = { mode: process.env.NODE_ENV, - devtool: process.env.NODE_ENV === 'production' ? false : 'source-map', + devtool: process.env.NODE_ENV === 'production' ? false : 'eval-source-map', performance: { hints: false, },