pleroma-fe/src/modules/api.js

65 lines
1.8 KiB
JavaScript
Raw Normal View History

import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'
2017-06-12 14:00:46 +00:00
import {isArray} from 'lodash'
2017-12-05 10:47:10 +00:00
import { Socket } from 'phoenix'
const api = {
state: {
backendInteractor: backendInteractorService(),
2017-12-05 10:47:10 +00:00
fetchers: {},
2017-12-07 16:20:44 +00:00
socket: null,
chatDisabled: false
},
mutations: {
setBackendInteractor (state, backendInteractor) {
state.backendInteractor = backendInteractor
},
addFetcher (state, {timeline, fetcher}) {
state.fetchers[timeline] = fetcher
},
removeFetcher (state, {timeline}) {
delete state.fetchers[timeline]
2017-12-05 10:47:10 +00:00
},
setSocket (state, socket) {
state.socket = socket
2017-12-07 16:20:44 +00:00
},
setChatDisabled (state, value) {
state.chatDisabled = value
}
},
actions: {
startFetching (store, timeline) {
2017-06-12 14:00:46 +00:00
let userId = false
// This is for user timelines
if (isArray(timeline)) {
userId = timeline[1]
timeline = timeline[0]
}
// Don't start fetching if we already are.
if (!store.state.fetchers[timeline]) {
2017-06-12 14:00:46 +00:00
const fetcher = store.state.backendInteractor.startFetching({timeline, store, userId})
store.commit('addFetcher', {timeline, fetcher})
}
},
stopFetching (store, timeline) {
const fetcher = store.state.fetchers[timeline]
window.clearInterval(fetcher)
store.commit('removeFetcher', {timeline})
2017-12-05 10:47:10 +00:00
},
initializeSocket (store, token) {
// Set up websocket connection
2017-12-07 16:20:44 +00:00
if (!store.state.chatDisabled) {
let socket = new Socket('/socket', {params: {token: token}})
socket.connect()
store.dispatch('initializeChat', socket)
}
},
disableChat (store) {
store.commit('setChatDisabled', true)
}
}
}
export default api