2016-11-26 09:57:08 -08:00
|
|
|
import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'
|
|
|
|
|
|
|
|
const api = {
|
|
|
|
state: {
|
2017-02-16 02:17:47 -08:00
|
|
|
backendInteractor: backendInteractorService(),
|
|
|
|
fetchers: {}
|
2016-11-26 09:57:08 -08:00
|
|
|
},
|
|
|
|
mutations: {
|
|
|
|
setBackendInteractor (state, backendInteractor) {
|
|
|
|
state.backendInteractor = backendInteractor
|
2017-02-16 02:17:47 -08:00
|
|
|
},
|
|
|
|
addFetcher (state, {timeline, fetcher}) {
|
|
|
|
state.fetchers[timeline] = fetcher
|
|
|
|
},
|
|
|
|
removeFetcher (state, {timeline}) {
|
|
|
|
delete state.fetchers[timeline]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
actions: {
|
|
|
|
startFetching (store, timeline) {
|
|
|
|
// Don't start fetching if we already are.
|
|
|
|
if (!store.state.fetchers[timeline]) {
|
|
|
|
const fetcher = store.state.backendInteractor.startFetching({timeline, store})
|
|
|
|
store.commit('addFetcher', {timeline, fetcher})
|
|
|
|
}
|
|
|
|
},
|
|
|
|
stopFetching (store, timeline) {
|
|
|
|
const fetcher = store.state.fetchers[timeline]
|
|
|
|
window.clearInterval(fetcher)
|
|
|
|
store.commit('removeFetcher', {timeline})
|
2016-11-26 09:57:08 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default api
|