1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
import {type QueryClient, useQuery} from '@tanstack/react-query'
import {STALE} from '#/state/queries/index'
import {useAgent} from '../session'
const RQKEY_LINK_ROOT = 'resolve-link'
export const RQKEY_LINK = (url: string) => [RQKEY_LINK_ROOT, url]
const RQKEY_GIF_ROOT = 'resolve-gif'
export const RQKEY_GIF = (url: string) => [RQKEY_GIF_ROOT, url]
import {type BskyAgent} from '@atproto/api'
import {type ResolvedLink, resolveGif, resolveLink} from '#/lib/api/resolve'
import {type Gif} from './tenor'
export function useResolveLinkQuery(url: string) {
const agent = useAgent()
return useQuery({
staleTime: STALE.HOURS.ONE,
queryKey: RQKEY_LINK(url),
queryFn: async () => {
return await resolveLink(agent, url)
},
})
}
export function fetchResolveLinkQuery(
queryClient: QueryClient,
agent: BskyAgent,
url: string,
) {
return queryClient.fetchQuery({
staleTime: STALE.HOURS.ONE,
queryKey: RQKEY_LINK(url),
queryFn: async () => {
return await resolveLink(agent, url)
},
})
}
export function precacheResolveLinkQuery(
queryClient: QueryClient,
url: string,
resolvedLink: ResolvedLink,
) {
queryClient.setQueryData(RQKEY_LINK(url), resolvedLink)
}
export function useResolveGifQuery(gif: Gif) {
const agent = useAgent()
return useQuery({
staleTime: STALE.HOURS.ONE,
queryKey: RQKEY_GIF(gif.url),
queryFn: async () => {
return await resolveGif(agent, gif)
},
})
}
export function fetchResolveGifQuery(
queryClient: QueryClient,
agent: BskyAgent,
gif: Gif,
) {
return queryClient.fetchQuery({
staleTime: STALE.HOURS.ONE,
queryKey: RQKEY_GIF(gif.url),
queryFn: async () => {
return await resolveGif(agent, gif)
},
})
}
|