pleroma-fe/src/modules/api.js

78 lines
2.4 KiB
JavaScript
Raw Normal View History

import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'
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,
followRequests: []
},
mutations: {
setBackendInteractor (state, backendInteractor) {
state.backendInteractor = backendInteractor
},
2019-04-04 16:06:53 +00:00
addFetcher (state, { fetcherName, fetcher }) {
2019-04-04 16:03:56 +00:00
state.fetchers[fetcherName] = fetcher
},
2019-04-04 16:03:56 +00:00
removeFetcher (state, { fetcherName }) {
delete state.fetchers[fetcherName]
2017-12-05 10:47:10 +00:00
},
setWsToken (state, token) {
state.wsToken = token
},
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
},
setFollowRequests (state, value) {
state.followRequests = value
}
},
actions: {
2019-04-04 16:06:53 +00:00
startFetchingTimeline (store, { timeline = 'friends', tag = false, userId = false }) {
// Don't start fetching if we already are.
2019-02-07 23:23:18 +00:00
if (store.state.fetchers[timeline]) return
2019-04-04 16:03:56 +00:00
const fetcher = store.state.backendInteractor.startFetchingTimeline({ timeline, store, userId, tag })
store.commit('addFetcher', { fetcherName: timeline, fetcher })
},
2019-04-04 16:03:56 +00:00
startFetchingNotifications (store) {
// Don't start fetching if we already are.
if (store.state.fetchers['notifications']) return
const fetcher = store.state.backendInteractor.startFetchingNotifications({ store })
store.commit('addFetcher', { fetcherName: 'notifications', fetcher })
},
stopFetching (store, fetcherName) {
const fetcher = store.state.fetchers[fetcherName]
window.clearInterval(fetcher)
2019-04-04 16:03:56 +00:00
store.commit('removeFetcher', { fetcherName })
2017-12-05 10:47:10 +00:00
},
setWsToken (store, token) {
store.commit('setWsToken', token)
},
initializeSocket (store) {
2017-12-05 10:47:10 +00:00
// Set up websocket connection
2017-12-07 16:20:44 +00:00
if (!store.state.chatDisabled) {
const token = store.state.wsToken
const socket = new Socket('/socket', {params: {token}})
2017-12-07 16:20:44 +00:00
socket.connect()
store.dispatch('initializeChat', socket)
}
},
disableChat (store) {
store.commit('setChatDisabled', true)
},
removeFollowRequest (store, request) {
let requests = store.state.followRequests.filter((it) => it !== request)
store.commit('setFollowRequests', requests)
}
}
}
export default api