2018-03-25 02:35:47 +00:00
|
|
|
import _ from 'lodash'
|
2017-05-21 20:43:58 +00:00
|
|
|
import Vue from 'vue'
|
|
|
|
import Vuex from 'vuex'
|
|
|
|
|
|
|
|
Vue.use(Vuex)
|
|
|
|
|
|
|
|
export default new Vuex.Store({
|
|
|
|
state: {
|
2018-03-25 02:35:47 +00:00
|
|
|
loadingStack: [],
|
|
|
|
notification: {
|
|
|
|
message: '',
|
|
|
|
style: 'primary',
|
|
|
|
icon: 'cached',
|
|
|
|
isActive: false
|
|
|
|
}
|
2017-05-21 20:43:58 +00:00
|
|
|
},
|
2018-03-25 02:35:47 +00:00
|
|
|
getters: {
|
|
|
|
isLoading: state => { return state.loadingStack.length > 0 }
|
2017-05-21 20:43:58 +00:00
|
|
|
},
|
2018-03-25 02:35:47 +00:00
|
|
|
mutations: {
|
|
|
|
loadingStart (state, stackName) {
|
|
|
|
state.loadingStack = _.union(state.loadingStack, [stackName])
|
|
|
|
},
|
|
|
|
loadingStop (state, stackName) {
|
|
|
|
state.loadingStack = _.without(state.loadingStack, stackName)
|
|
|
|
},
|
|
|
|
showNotification (state, opts) {
|
|
|
|
state.notification = _.defaults(opts, {
|
|
|
|
message: '',
|
|
|
|
style: 'primary',
|
|
|
|
icon: 'cached',
|
|
|
|
isActive: true
|
|
|
|
})
|
|
|
|
},
|
|
|
|
updateNotificationState (state, newState) {
|
|
|
|
state.notification.isActive = newState
|
|
|
|
}
|
2017-05-21 20:43:58 +00:00
|
|
|
},
|
2018-03-25 02:35:47 +00:00
|
|
|
actions: { },
|
|
|
|
modules: { }
|
2017-05-21 20:43:58 +00:00
|
|
|
})
|