elk/composables/masto/relationship.ts

34 lines
1.3 KiB
TypeScript
Raw Normal View History

2023-01-08 09:21:09 +03:00
import type { mastodon } from 'masto'
2023-01-06 21:40:15 +03:00
import type { Ref } from 'vue'
// Batch requests for relationships when used in the UI
// We don't want to hold to old values, so every time a Relationship is needed it
// is requested again from the server to show the latest state
2023-01-08 09:21:09 +03:00
const requestedRelationships = new Map<string, Ref<mastodon.v1.Relationship | undefined>>()
2023-01-06 21:40:15 +03:00
let timeoutHandle: NodeJS.Timeout | undefined
2023-01-08 09:21:09 +03:00
export function useRelationship(account: mastodon.v1.Account): Ref<mastodon.v1.Relationship | undefined> {
2023-01-06 21:40:15 +03:00
if (!currentUser.value)
return ref()
let relationship = requestedRelationships.get(account.id)
if (relationship)
return relationship
2023-01-08 09:21:09 +03:00
relationship = ref<mastodon.v1.Relationship | undefined>()
2023-01-06 21:40:15 +03:00
requestedRelationships.set(account.id, relationship)
if (timeoutHandle)
clearTimeout(timeoutHandle)
timeoutHandle = setTimeout(() => {
timeoutHandle = undefined
fetchRelationships()
}, 100)
return relationship
}
async function fetchRelationships() {
const requested = Array.from(requestedRelationships.entries()).filter(([, r]) => !r.value)
2023-01-08 09:21:09 +03:00
const relationships = await useMasto().v1.accounts.fetchRelationships(requested.map(([id]) => id))
2023-01-06 21:40:15 +03:00
for (let i = 0; i < requested.length; i++)
requested[i][1].value = relationships[i]
}