2017-04-13 23:24:31 +02:00
|
|
|
import Vue from 'vue'
|
|
|
|
|
|
|
|
import * as types from './mutations-types'
|
|
|
|
|
|
|
|
export const state = {
|
|
|
|
flats: [],
|
2017-05-02 18:35:34 +02:00
|
|
|
timeToPlaces: [],
|
|
|
|
loading: false
|
2017-04-13 23:24:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export const mutations = {
|
|
|
|
[types.REPLACE_FLATS] (state, { flats }) {
|
2017-05-02 18:35:34 +02:00
|
|
|
state.loading = false
|
2017-04-13 23:24:31 +02:00
|
|
|
state.flats = flats
|
|
|
|
},
|
|
|
|
[types.MERGE_FLATS] (state, { flats }) {
|
2017-05-02 18:35:34 +02:00
|
|
|
state.loading = false
|
2017-04-13 23:24:31 +02:00
|
|
|
flats.forEach(flat => {
|
|
|
|
const flatIndex = state.flats.findIndex(storedFlat => storedFlat.id === flat.id)
|
|
|
|
|
|
|
|
if (flatIndex > -1) {
|
|
|
|
Vue.set(state.flats, flatIndex, flat)
|
|
|
|
} else {
|
|
|
|
state.flats.push(flat)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
[types.UPDATE_FLAT_STATUS] (state, { flatId, newStatus }) {
|
2017-05-02 18:35:34 +02:00
|
|
|
state.loading = false
|
2017-04-13 23:24:31 +02:00
|
|
|
const index = state.flats.findIndex(flat => flat.id === flatId)
|
|
|
|
if (index > -1) {
|
|
|
|
Vue.set(state.flats[index], 'status', newStatus)
|
|
|
|
}
|
|
|
|
},
|
2017-05-03 19:17:19 +02:00
|
|
|
[types.UPDATE_FLAT_NOTES] (state, { flatId, newNotes }) {
|
|
|
|
state.loading = false
|
|
|
|
const index = state.flats.findIndex(flat => flat.id === flatId)
|
|
|
|
if (index > -1) {
|
|
|
|
Vue.set(state.flats[index], 'notes', newNotes)
|
|
|
|
}
|
|
|
|
},
|
2017-04-13 23:24:31 +02:00
|
|
|
[types.RECEIVE_TIME_TO_PLACES] (state, { timeToPlaces }) {
|
2017-05-02 18:35:34 +02:00
|
|
|
state.loading = false
|
2017-04-13 23:24:31 +02:00
|
|
|
state.timeToPlaces = timeToPlaces
|
2017-05-02 18:35:34 +02:00
|
|
|
},
|
|
|
|
[types.IS_LOADING] (state) {
|
|
|
|
state.loading = true
|
2017-04-13 23:24:31 +02:00
|
|
|
}
|
|
|
|
}
|