pleroma-fe/src/services/notifications_fetcher/notifications_fetcher.service.js

83 lines
2.9 KiB
JavaScript
Raw Normal View History

2018-08-13 10:17:10 +00:00
import apiService from '../api/api.service.js'
2020-09-04 08:19:53 +00:00
import { promiseInterval } from '../promise_interval/promise_interval.js'
2018-08-13 10:17:10 +00:00
2019-07-05 07:02:14 +00:00
const update = ({ store, notifications, older }) => {
2018-08-13 10:17:10 +00:00
store.dispatch('addNewNotifications', { notifications, older })
}
2019-07-05 07:02:14 +00:00
const fetchAndUpdate = ({ store, credentials, older = false }) => {
2018-08-13 10:17:10 +00:00
const args = { credentials }
const { getters } = store
2018-08-13 10:17:10 +00:00
const rootState = store.rootState || store.state
const timelineData = rootState.statuses.notifications
const hideMutedPosts = getters.mergedConfig.hideMutedPosts
args['withMuted'] = !hideMutedPosts
2018-08-13 10:17:10 +00:00
2019-03-18 16:30:34 +00:00
args['timeline'] = 'notifications'
2018-08-13 10:17:10 +00:00
if (older) {
if (timelineData.minId !== Number.POSITIVE_INFINITY) {
args['until'] = timelineData.minId
}
2019-03-18 16:30:34 +00:00
return fetchNotifications({ store, args, older })
2018-08-13 10:17:10 +00:00
} else {
2019-03-18 16:30:34 +00:00
// fetch new notifications
if (timelineData.maxId !== Number.POSITIVE_INFINITY) {
args['since'] = timelineData.maxId
}
2019-03-18 16:30:34 +00:00
const result = fetchNotifications({ store, args, older })
// If there's any unread notifications, try fetch notifications since
// the newest read notification to check if any of the unread notifs
// have changed their 'seen' state (marked as read in another session), so
// we can update the state in this session to mark them as read as well.
// The normal maxId-check does not tell if older notifications have changed
2019-03-18 16:30:34 +00:00
const notifications = timelineData.data
const readNotifsIds = notifications.filter(n => n.seen).map(n => n.id)
const numUnseenNotifs = notifications.length - readNotifsIds.length
if (numUnseenNotifs > 0 && readNotifsIds.length > 0) {
args['since'] = Math.max(...readNotifsIds)
2019-03-18 16:30:34 +00:00
fetchNotifications({ store, args, older })
}
2019-03-18 16:30:34 +00:00
return result
}
}
2018-08-13 10:17:10 +00:00
2019-03-18 16:30:34 +00:00
const fetchNotifications = ({ store, args, older }) => {
2018-08-13 10:17:10 +00:00
return apiService.fetchTimeline(args)
.then((response) => {
if (response.errors) {
throw new Error(`${response.status} ${response.statusText}`)
}
const notifications = response.data
2019-03-18 16:30:34 +00:00
update({ store, notifications, older })
return notifications
})
.catch((error) => {
store.dispatch('pushGlobalNotice', {
level: 'error',
messageKey: 'notifications.error',
messageArgs: [error.message],
timeout: 5000
})
})
2018-08-13 10:17:10 +00:00
}
2019-07-05 07:02:14 +00:00
const startFetching = ({ 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)
const boundFetchAndUpdate = () => fetchAndUpdate({ credentials, store })
boundFetchAndUpdate()
2020-09-04 08:19:53 +00:00
return promiseInterval(boundFetchAndUpdate, 10000)
2018-08-13 10:17:10 +00:00
}
const notificationsFetcher = {
fetchAndUpdate,
startFetching
}
export default notificationsFetcher