2022-11-22 16:03:36 +03:00
|
|
|
import type { Ref } from 'vue'
|
2022-12-17 19:55:29 +03:00
|
|
|
import type { Account, Relationship, Status } from 'masto'
|
2022-11-29 23:51:52 +03:00
|
|
|
import { withoutProtocol } from 'ufo'
|
2023-01-03 03:11:10 +03:00
|
|
|
import type { ElkMasto, UserLogin } from '~/types'
|
2022-11-21 18:07:55 +03:00
|
|
|
|
2022-12-17 19:55:29 +03:00
|
|
|
export const useMasto = () => useNuxtApp().$masto as ElkMasto
|
2022-12-02 11:52:00 +03:00
|
|
|
|
2022-12-17 19:55:29 +03:00
|
|
|
export const isMastoInitialised = computed(() => process.client && useMasto().loggedIn.value)
|
2022-12-02 11:52:00 +03:00
|
|
|
|
2023-01-03 12:53:31 +03:00
|
|
|
export const onMastoInit = (cb: () => unknown) => {
|
|
|
|
watchOnce(isMastoInitialised, () => {
|
|
|
|
cb()
|
|
|
|
}, { immediate: isMastoInitialised.value })
|
|
|
|
}
|
|
|
|
|
2022-11-26 18:06:30 +03:00
|
|
|
export function getDisplayName(account?: Account, options?: { rich?: boolean }) {
|
|
|
|
const displayName = account?.displayName || account?.username || ''
|
|
|
|
if (options?.rich)
|
|
|
|
return displayName
|
|
|
|
return displayName.replace(/:([\w-]+?):/g, '')
|
2022-11-21 18:07:55 +03:00
|
|
|
}
|
2022-11-22 16:03:36 +03:00
|
|
|
|
2022-11-26 19:37:15 +03:00
|
|
|
export function getShortHandle({ acct }: Account) {
|
2022-11-27 09:34:38 +03:00
|
|
|
if (!acct)
|
|
|
|
return ''
|
2022-11-26 19:37:15 +03:00
|
|
|
return `@${acct.includes('@') ? acct.split('@')[0] : acct}`
|
2022-11-24 01:40:35 +03:00
|
|
|
}
|
|
|
|
|
2022-12-04 10:18:11 +03:00
|
|
|
export function getServerName(account: Account) {
|
2022-12-28 19:01:13 +03:00
|
|
|
if (account.acct?.includes('@'))
|
2022-12-04 10:18:11 +03:00
|
|
|
return account.acct.split('@')[1]
|
2022-12-20 03:16:15 +03:00
|
|
|
// We should only lack the server name if we're on the same server as the account
|
|
|
|
return currentInstance.value?.uri || ''
|
2022-12-04 10:18:11 +03:00
|
|
|
}
|
|
|
|
|
2023-01-03 03:11:10 +03:00
|
|
|
export function getFullHandle(_account: Account | UserLogin) {
|
|
|
|
if ('guest' in _account && _account.guest)
|
|
|
|
return `[anonymous]@${_account.server}`
|
|
|
|
|
|
|
|
const account = 'server' in _account ? _account.account : _account
|
2022-11-25 20:50:03 +03:00
|
|
|
const handle = `@${account.acct}`
|
|
|
|
if (!currentUser.value || account.acct.includes('@'))
|
|
|
|
return handle
|
2022-11-26 11:33:32 +03:00
|
|
|
return `${handle}@${getServerName(account)}`
|
2022-11-25 20:50:03 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
export function toShortHandle(fullHandle: string) {
|
|
|
|
if (!currentUser.value)
|
|
|
|
return fullHandle
|
|
|
|
const server = currentUser.value.server
|
|
|
|
if (fullHandle.endsWith(`@${server}`))
|
|
|
|
return fullHandle.slice(0, -server.length - 1)
|
|
|
|
return fullHandle
|
|
|
|
}
|
|
|
|
|
2022-12-22 23:15:06 +03:00
|
|
|
export function extractAccountHandle(account: Account) {
|
2022-12-04 22:56:33 +03:00
|
|
|
let handle = getFullHandle(account).slice(1)
|
2022-12-20 03:16:15 +03:00
|
|
|
const uri = currentInstance.value?.uri ?? currentServer.value
|
|
|
|
if (currentInstance.value && handle.endsWith(`@${uri}`))
|
|
|
|
handle = handle.slice(0, -uri.length - 1)
|
2022-12-04 22:56:33 +03:00
|
|
|
|
2022-12-22 23:15:06 +03:00
|
|
|
return handle
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getAccountRoute(account: Account) {
|
2022-11-30 20:15:18 +03:00
|
|
|
return useRouter().resolve({
|
|
|
|
name: 'account-index',
|
|
|
|
params: {
|
2022-12-04 22:56:33 +03:00
|
|
|
server: currentServer.value,
|
2022-12-22 23:15:06 +03:00
|
|
|
account: extractAccountHandle(account),
|
2022-11-30 20:15:18 +03:00
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
export function getAccountFollowingRoute(account: Account) {
|
|
|
|
return useRouter().resolve({
|
|
|
|
name: 'account-following',
|
|
|
|
params: {
|
2022-12-04 22:56:33 +03:00
|
|
|
server: currentServer.value,
|
2022-12-22 23:15:06 +03:00
|
|
|
account: extractAccountHandle(account),
|
2022-11-30 20:15:18 +03:00
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
export function getAccountFollowersRoute(account: Account) {
|
|
|
|
return useRouter().resolve({
|
|
|
|
name: 'account-followers',
|
|
|
|
params: {
|
2022-12-04 22:56:33 +03:00
|
|
|
server: currentServer.value,
|
2022-12-22 23:15:06 +03:00
|
|
|
account: extractAccountHandle(account),
|
2022-11-30 20:15:18 +03:00
|
|
|
},
|
|
|
|
})
|
2022-11-24 01:40:35 +03:00
|
|
|
}
|
|
|
|
|
2022-11-30 20:15:18 +03:00
|
|
|
export function getStatusRoute(status: Status) {
|
|
|
|
return useRouter().resolve({
|
|
|
|
name: 'status',
|
|
|
|
params: {
|
2022-12-04 22:56:33 +03:00
|
|
|
server: currentServer.value,
|
2022-12-22 23:15:06 +03:00
|
|
|
account: extractAccountHandle(status.account),
|
2022-11-30 20:15:18 +03:00
|
|
|
status: status.id,
|
|
|
|
},
|
|
|
|
})
|
2022-11-26 02:49:56 +03:00
|
|
|
}
|
|
|
|
|
2022-12-29 17:44:26 +03:00
|
|
|
export function getTagRoute(tag: string) {
|
|
|
|
return useRouter().resolve({
|
|
|
|
name: 'tag',
|
|
|
|
params: {
|
|
|
|
server: currentServer.value,
|
|
|
|
tag,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-12-01 09:46:26 +03:00
|
|
|
export function getStatusPermalinkRoute(status: Status) {
|
2022-12-04 22:56:33 +03:00
|
|
|
return status.url ? withoutProtocol(status.url) : null
|
2022-11-29 23:51:52 +03:00
|
|
|
}
|
|
|
|
|
2022-11-30 20:15:18 +03:00
|
|
|
export function getStatusInReplyToRoute(status: Status) {
|
|
|
|
return useRouter().resolve({
|
|
|
|
name: 'status-by-id',
|
|
|
|
params: {
|
2022-12-04 22:56:33 +03:00
|
|
|
server: currentServer.value,
|
2022-11-30 20:15:18 +03:00
|
|
|
status: status.inReplyToId,
|
|
|
|
},
|
|
|
|
})
|
2022-11-24 01:40:35 +03:00
|
|
|
}
|
|
|
|
|
2022-11-24 17:20:50 +03:00
|
|
|
export function useAccountHandle(account: Account, fullServer = true) {
|
2022-11-25 20:50:03 +03:00
|
|
|
return computed(() => fullServer
|
|
|
|
? getFullHandle(account)
|
|
|
|
: getShortHandle(account),
|
|
|
|
)
|
2022-11-24 17:20:50 +03:00
|
|
|
}
|
|
|
|
|
2022-11-22 16:03:36 +03:00
|
|
|
// 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
|
|
|
|
|
2022-11-23 16:59:29 +03:00
|
|
|
const requestedRelationships = new Map<string, Ref<Relationship | undefined>>()
|
2022-11-22 16:03:36 +03:00
|
|
|
let timeoutHandle: NodeJS.Timeout | undefined
|
|
|
|
|
|
|
|
export function useRelationship(account: Account): Ref<Relationship | undefined> {
|
2022-12-04 22:56:33 +03:00
|
|
|
if (!currentUser.value)
|
|
|
|
return ref()
|
2022-11-22 16:03:36 +03:00
|
|
|
let relationship = requestedRelationships.get(account.id)
|
|
|
|
if (relationship)
|
|
|
|
return relationship
|
|
|
|
relationship = ref<Relationship | undefined>()
|
|
|
|
requestedRelationships.set(account.id, relationship)
|
|
|
|
if (timeoutHandle)
|
|
|
|
clearTimeout(timeoutHandle)
|
|
|
|
timeoutHandle = setTimeout(() => {
|
|
|
|
timeoutHandle = undefined
|
|
|
|
fetchRelationships()
|
|
|
|
}, 100)
|
|
|
|
return relationship
|
|
|
|
}
|
|
|
|
|
|
|
|
async function fetchRelationships() {
|
2022-11-28 23:44:50 +03:00
|
|
|
const requested = Array.from(requestedRelationships.entries()).filter(([, r]) => !r.value)
|
2022-11-26 18:42:58 +03:00
|
|
|
const relationships = await useMasto().accounts.fetchRelationships(requested.map(([id]) => id))
|
2022-11-22 16:03:36 +03:00
|
|
|
for (let i = 0; i < requested.length; i++)
|
|
|
|
requested[i][1].value = relationships[i]
|
|
|
|
}
|