2023-04-05 21:06:37 -06:00
|
|
|
import { useInterfaceStore } from '../../stores/interface.js'
|
2018-08-13 13:17:10 +03:00
|
|
|
import apiService from '../api/api.service.js'
|
2020-09-04 11:19:53 +03:00
|
|
|
import { promiseInterval } from '../promise_interval/promise_interval.js'
|
2018-08-13 13:17:10 +03:00
|
|
|
|
2021-02-01 12:55:23 +02:00
|
|
|
// For using include_types when fetching notifications.
|
|
|
|
|
// Note: chat_mention excluded as pleroma-fe polls them separately
|
|
|
|
|
const mastoApiNotificationTypes = [
|
|
|
|
|
'mention',
|
|
|
|
|
'favourite',
|
|
|
|
|
'reblog',
|
|
|
|
|
'follow',
|
|
|
|
|
'move',
|
|
|
|
|
'pleroma:emoji_reaction',
|
|
|
|
|
'pleroma:report'
|
|
|
|
|
]
|
|
|
|
|
|
2019-07-05 10:02:14 +03:00
|
|
|
const update = ({ store, notifications, older }) => {
|
2018-08-13 13:17:10 +03:00
|
|
|
store.dispatch('addNewNotifications', { notifications, older })
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-13 22:17:10 +02:00
|
|
|
const fetchAndUpdate = ({ store, credentials, older = false, since }) => {
|
2018-08-13 13:17:10 +03:00
|
|
|
const args = { credentials }
|
2019-10-06 23:28:30 +03:00
|
|
|
const { getters } = store
|
2018-08-13 13:17:10 +03:00
|
|
|
const rootState = store.rootState || store.state
|
|
|
|
|
const timelineData = rootState.statuses.notifications
|
2019-10-06 23:28:30 +03:00
|
|
|
const hideMutedPosts = getters.mergedConfig.hideMutedPosts
|
2019-09-04 12:19:39 +03:00
|
|
|
|
2022-08-06 22:15:34 -06:00
|
|
|
args.includeTypes = mastoApiNotificationTypes
|
2022-07-31 12:35:48 +03:00
|
|
|
args.withMuted = !hideMutedPosts
|
2018-08-13 13:17:10 +03:00
|
|
|
|
2022-07-31 12:35:48 +03:00
|
|
|
args.timeline = 'notifications'
|
2018-08-13 13:17:10 +03:00
|
|
|
if (older) {
|
|
|
|
|
if (timelineData.minId !== Number.POSITIVE_INFINITY) {
|
2022-07-31 12:35:48 +03:00
|
|
|
args.until = timelineData.minId
|
2018-08-13 13:17:10 +03:00
|
|
|
}
|
2019-03-18 12:30:34 -04:00
|
|
|
return fetchNotifications({ store, args, older })
|
2018-08-13 13:17:10 +03:00
|
|
|
} else {
|
2019-03-18 12:30:34 -04:00
|
|
|
// fetch new notifications
|
2021-01-13 22:17:10 +02:00
|
|
|
if (since === undefined && timelineData.maxId !== Number.POSITIVE_INFINITY) {
|
2022-07-31 12:35:48 +03:00
|
|
|
args.since = timelineData.maxId
|
2021-01-13 22:17:10 +02:00
|
|
|
} else if (since !== null) {
|
2022-07-31 12:35:48 +03:00
|
|
|
args.since = since
|
2019-02-25 12:12:49 -05:00
|
|
|
}
|
2019-03-18 12:30:34 -04:00
|
|
|
const result = fetchNotifications({ store, args, older })
|
|
|
|
|
|
2020-07-01 17:55:42 +03:00
|
|
|
// 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 12:30:34 -04:00
|
|
|
const notifications = timelineData.data
|
2020-01-14 11:13:59 +02:00
|
|
|
const readNotifsIds = notifications.filter(n => n.seen).map(n => n.id)
|
2020-07-01 17:55:42 +03:00
|
|
|
const numUnseenNotifs = notifications.length - readNotifsIds.length
|
2020-07-17 12:01:01 +03:00
|
|
|
if (numUnseenNotifs > 0 && readNotifsIds.length > 0) {
|
2022-07-31 12:35:48 +03:00
|
|
|
args.since = Math.max(...readNotifsIds)
|
2019-03-18 12:30:34 -04:00
|
|
|
fetchNotifications({ store, args, older })
|
|
|
|
|
}
|
2020-09-02 20:40:47 +03:00
|
|
|
|
2019-03-18 12:30:34 -04:00
|
|
|
return result
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-08-13 13:17:10 +03:00
|
|
|
|
2019-03-18 12:30:34 -04:00
|
|
|
const fetchNotifications = ({ store, args, older }) => {
|
2018-08-13 13:17:10 +03:00
|
|
|
return apiService.fetchTimeline(args)
|
2020-11-10 14:28:10 +02:00
|
|
|
.then((response) => {
|
|
|
|
|
if (response.errors) {
|
|
|
|
|
throw new Error(`${response.status} ${response.statusText}`)
|
|
|
|
|
}
|
|
|
|
|
const notifications = response.data
|
2019-03-18 12:30:34 -04:00
|
|
|
update({ store, notifications, older })
|
2019-01-29 21:04:52 +02:00
|
|
|
return notifications
|
2020-11-10 14:28:10 +02:00
|
|
|
})
|
|
|
|
|
.catch((error) => {
|
2023-04-05 21:06:37 -06:00
|
|
|
useInterfaceStore().pushGlobalNotice({
|
2020-11-10 14:28:10 +02:00
|
|
|
level: 'error',
|
|
|
|
|
messageKey: 'notifications.error',
|
|
|
|
|
messageArgs: [error.message],
|
|
|
|
|
timeout: 5000
|
|
|
|
|
})
|
2020-12-04 12:48:15 +02:00
|
|
|
console.error(error)
|
2020-11-10 14:28:10 +02:00
|
|
|
})
|
2018-08-13 13:17:10 +03:00
|
|
|
}
|
|
|
|
|
|
2019-07-05 10:02:14 +03:00
|
|
|
const startFetching = ({ credentials, store }) => {
|
2018-08-20 19:58:49 +03:00
|
|
|
// 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)
|
2020-09-02 22:12:50 +03:00
|
|
|
const boundFetchAndUpdate = () => fetchAndUpdate({ credentials, store })
|
|
|
|
|
boundFetchAndUpdate()
|
2020-09-04 11:19:53 +03:00
|
|
|
return promiseInterval(boundFetchAndUpdate, 10000)
|
2018-08-13 13:17:10 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const notificationsFetcher = {
|
|
|
|
|
fetchAndUpdate,
|
|
|
|
|
startFetching
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default notificationsFetcher
|