yandere_fe/src/services/notifications_fetcher/notifications_fetcher.service.js

64 lines
2.1 KiB
JavaScript
Raw Normal View History

2018-08-13 03:17:10 -07:00
import apiService from '../api/api.service.js'
const update = ({store, notifications, older}) => {
store.dispatch('setNotificationsError', { value: false })
store.dispatch('addNewNotifications', { notifications, older })
}
const fetchAndUpdate = ({store, credentials, older = false}) => {
const args = { credentials }
const rootState = store.rootState || store.state
const timelineData = rootState.statuses.notifications
2019-03-18 09:30:34 -07:00
args['timeline'] = 'notifications'
2018-08-13 03:17:10 -07:00
if (older) {
if (timelineData.minId !== Number.POSITIVE_INFINITY) {
args['until'] = timelineData.minId
}
2019-03-18 09:30:34 -07:00
return fetchNotifications({ store, args, older })
2018-08-13 03:17:10 -07:00
} else {
2019-03-18 09:30:34 -07:00
// fetch new notifications
if (timelineData.maxId !== Number.POSITIVE_INFINITY) {
args['since'] = timelineData.maxId
}
2019-03-18 09:30:34 -07:00
const result = fetchNotifications({ store, args, older })
// load unread notifications repeatedly to provide consistency between browser tabs
const notifications = timelineData.data
const unread = notifications.filter(n => !n.seen).map(n => n.id)
if (unread.length) {
args['since'] = Math.min(...unread)
fetchNotifications({ store, args, older })
}
2018-08-13 03:17:10 -07:00
2019-03-18 09:30:34 -07:00
return result
}
}
2018-08-13 03:17:10 -07:00
2019-03-18 09:30:34 -07:00
const fetchNotifications = ({ store, args, older }) => {
2018-08-13 03:17:10 -07:00
return apiService.fetchTimeline(args)
.then((notifications) => {
2019-03-18 09:30:34 -07:00
update({ store, notifications, older })
return notifications
2018-08-13 03:17:10 -07:00
}, () => store.dispatch('setNotificationsError', { value: true }))
.catch(() => store.dispatch('setNotificationsError', { value: true }))
2018-08-13 03:17:10 -07:00
}
const startFetching = ({credentials, store}) => {
fetchAndUpdate({ credentials, store })
const boundFetchAndUpdate = () => fetchAndUpdate({ credentials, store })
// Initially there's set flag to silence all desktop notifications so
// that there won't spam of them when user just opened up the FE we
// reset that flag after a while to show new notifications once again.
setTimeout(() => store.dispatch('setNotificationsSilence', false), 10000)
2018-08-13 03:17:10 -07:00
return setInterval(boundFetchAndUpdate, 10000)
}
const notificationsFetcher = {
fetchAndUpdate,
startFetching
}
export default notificationsFetcher