* remove resolution from post thread
nit
completely remove did cache lookup
move cache check for did to `usePostThreadQuery`
remove resolution from post thread
* helper function
* simplify
* simplify search too
* fix missing check for root or parent quoted post 🤯
* fix thread traversal
116 lines
2.7 KiB
TypeScript
116 lines
2.7 KiB
TypeScript
import {
|
|
AppBskyActorDefs,
|
|
AppBskyFeedDefs,
|
|
AppBskyFeedSearchPosts,
|
|
AtUri,
|
|
} from '@atproto/api'
|
|
import {
|
|
InfiniteData,
|
|
QueryClient,
|
|
QueryKey,
|
|
useInfiniteQuery,
|
|
} from '@tanstack/react-query'
|
|
|
|
import {useAgent} from '#/state/session'
|
|
import {
|
|
didOrHandleUriMatches,
|
|
embedViewRecordToPostView,
|
|
getEmbeddedPost,
|
|
} from './util'
|
|
|
|
const searchPostsQueryKeyRoot = 'search-posts'
|
|
const searchPostsQueryKey = ({query, sort}: {query: string; sort?: string}) => [
|
|
searchPostsQueryKeyRoot,
|
|
query,
|
|
sort,
|
|
]
|
|
|
|
export function useSearchPostsQuery({
|
|
query,
|
|
sort,
|
|
enabled,
|
|
}: {
|
|
query: string
|
|
sort?: 'top' | 'latest'
|
|
enabled?: boolean
|
|
}) {
|
|
const agent = useAgent()
|
|
return useInfiniteQuery<
|
|
AppBskyFeedSearchPosts.OutputSchema,
|
|
Error,
|
|
InfiniteData<AppBskyFeedSearchPosts.OutputSchema>,
|
|
QueryKey,
|
|
string | undefined
|
|
>({
|
|
queryKey: searchPostsQueryKey({query, sort}),
|
|
queryFn: async ({pageParam}) => {
|
|
const res = await agent.app.bsky.feed.searchPosts({
|
|
q: query,
|
|
limit: 25,
|
|
cursor: pageParam,
|
|
sort,
|
|
})
|
|
return res.data
|
|
},
|
|
initialPageParam: undefined,
|
|
getNextPageParam: lastPage => lastPage.cursor,
|
|
enabled,
|
|
})
|
|
}
|
|
|
|
export function* findAllPostsInQueryData(
|
|
queryClient: QueryClient,
|
|
uri: string,
|
|
): Generator<AppBskyFeedDefs.PostView, undefined> {
|
|
const queryDatas = queryClient.getQueriesData<
|
|
InfiniteData<AppBskyFeedSearchPosts.OutputSchema>
|
|
>({
|
|
queryKey: [searchPostsQueryKeyRoot],
|
|
})
|
|
const atUri = new AtUri(uri)
|
|
|
|
for (const [_queryKey, queryData] of queryDatas) {
|
|
if (!queryData?.pages) {
|
|
continue
|
|
}
|
|
for (const page of queryData?.pages) {
|
|
for (const post of page.posts) {
|
|
if (didOrHandleUriMatches(atUri, post)) {
|
|
yield post
|
|
}
|
|
|
|
const quotedPost = getEmbeddedPost(post.embed)
|
|
if (quotedPost && didOrHandleUriMatches(atUri, quotedPost)) {
|
|
yield embedViewRecordToPostView(quotedPost)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
export function* findAllProfilesInQueryData(
|
|
queryClient: QueryClient,
|
|
did: string,
|
|
): Generator<AppBskyActorDefs.ProfileView, undefined> {
|
|
const queryDatas = queryClient.getQueriesData<
|
|
InfiniteData<AppBskyFeedSearchPosts.OutputSchema>
|
|
>({
|
|
queryKey: [searchPostsQueryKeyRoot],
|
|
})
|
|
for (const [_queryKey, queryData] of queryDatas) {
|
|
if (!queryData?.pages) {
|
|
continue
|
|
}
|
|
for (const page of queryData?.pages) {
|
|
for (const post of page.posts) {
|
|
if (post.author.did === did) {
|
|
yield post.author
|
|
}
|
|
const quotedPost = getEmbeddedPost(post.embed)
|
|
if (quotedPost?.author.did === did) {
|
|
yield quotedPost.author
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|