2023-01-08 15:21:09 +09:00
|
|
|
import type { mastodon } from 'masto'
|
2023-01-07 03:40:15 +09: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 15:21:09 +09:00
|
|
|
const requestedRelationships = new Map<string, Ref<mastodon.v1.Relationship | undefined>>()
|
2023-01-07 03:40:15 +09:00
|
|
|
let timeoutHandle: NodeJS.Timeout | undefined
|
|
|
|
|
2023-01-08 15:21:09 +09:00
|
|
|
export function useRelationship(account: mastodon.v1.Account): Ref<mastodon.v1.Relationship | undefined> {
|
2023-01-07 03:40:15 +09:00
|
|
|
if (!currentUser.value)
|
|
|
|
return ref()
|
|
|
|
let relationship = requestedRelationships.get(account.id)
|
|
|
|
if (relationship)
|
|
|
|
return relationship
|
2023-01-08 15:21:09 +09:00
|
|
|
relationship = ref<mastodon.v1.Relationship | undefined>()
|
2023-01-07 03:40:15 +09: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-15 17:38:02 +09:00
|
|
|
const relationships = await useMastoClient().v1.accounts.fetchRelationships(requested.map(([id]) => id))
|
2023-01-07 03:40:15 +09:00
|
|
|
for (let i = 0; i < requested.length; i++)
|
|
|
|
requested[i][1].value = relationships[i]
|
|
|
|
}
|