2016-11-26 17:57:08 +00:00
|
|
|
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'
|
2016-11-26 17:57:08 +00:00
|
|
|
|
|
|
|
const api = {
|
|
|
|
state: {
|
2017-02-16 10:17:47 +00:00
|
|
|
backendInteractor: backendInteractorService(),
|
2017-12-05 10:47:10 +00:00
|
|
|
fetchers: {},
|
2017-12-07 16:20:44 +00:00
|
|
|
socket: null,
|
2018-06-07 01:24:31 +00:00
|
|
|
chatDisabled: false,
|
|
|
|
followRequests: []
|
2016-11-26 17:57:08 +00:00
|
|
|
},
|
|
|
|
mutations: {
|
|
|
|
setBackendInteractor (state, backendInteractor) {
|
|
|
|
state.backendInteractor = backendInteractor
|
2017-02-16 10:17:47 +00:00
|
|
|
},
|
|
|
|
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
|
2018-06-07 01:24:31 +00:00
|
|
|
},
|
|
|
|
setFollowRequests (state, value) {
|
|
|
|
state.followRequests = value
|
2017-02-16 10:17:47 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
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]
|
|
|
|
}
|
|
|
|
|
2017-02-16 10:17:47 +00:00
|
|
|
// 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})
|
2017-02-16 10:17:47 +00:00
|
|
|
store.commit('addFetcher', {timeline, fetcher})
|
|
|
|
}
|
|
|
|
},
|
2018-08-16 10:12:31 +00:00
|
|
|
fetchOldPost (store, { postId }) {
|
|
|
|
store.state.backendInteractor.fetchOldPost({ store, postId })
|
|
|
|
},
|
2017-02-16 10:17:47 +00:00
|
|
|
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)
|
2018-06-07 01:24:31 +00:00
|
|
|
},
|
|
|
|
removeFollowRequest (store, request) {
|
|
|
|
let requests = store.state.followRequests.filter((it) => it !== request)
|
|
|
|
store.commit('setFollowRequests', requests)
|
2016-11-26 17:57:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default api
|