diff options
Diffstat (limited to 'frontend/src/pages/ReadArticles.tsx')
| -rw-r--r-- | frontend/src/pages/ReadArticles.tsx | 73 |
1 files changed, 38 insertions, 35 deletions
diff --git a/frontend/src/pages/ReadArticles.tsx b/frontend/src/pages/ReadArticles.tsx index f90c3c9..2538446 100644 --- a/frontend/src/pages/ReadArticles.tsx +++ b/frontend/src/pages/ReadArticles.tsx @@ -1,45 +1,48 @@ -import { useQuery } from "urql"; -import { ArticleList } from "../components"; -import { GetReadArticlesDocument } from "../graphql/generated/graphql"; - -const urqlContextArticle = { additionalTypenames: ["Article"] }; +import { useSearch } from "wouter"; +import { ArticleList, FeedSidebar } from "../components"; +import { usePaginatedArticles } from "../hooks/usePaginatedArticles"; export function ReadArticles() { - const [{ data, fetching, error }] = useQuery({ - query: GetReadArticlesDocument, - context: urqlContextArticle, - }); - - if (fetching) { - return ( - <div className="py-8 text-center"> - <p className="text-sm text-stone-400">Loading read articles...</p> - </div> - ); - } + const search = useSearch(); + const params = new URLSearchParams(search); + const feedId = params.get("feed"); - if (error) { - return ( - <div className="rounded-lg bg-red-50 p-4 text-sm text-red-600"> - Error: {error.message} - </div> - ); - } + const { articles, hasNextPage, loading, loadingMore, loadMore, error } = + usePaginatedArticles({ isReadView: true, feedId }); return ( - <div> - <div className="mb-6"> - <h1 className="text-xl font-semibold text-stone-900">Read</h1> - {data?.readArticles && ( - <p className="mt-1 text-sm text-stone-400"> - {data.readArticles.length} article - {data.readArticles.length !== 1 ? "s" : ""} - </p> + <div className="flex gap-8"> + <FeedSidebar basePath="/read" /> + <div className="min-w-0 flex-1"> + <div className="mb-6"> + <h1 className="text-xl font-semibold text-stone-900">Read</h1> + {!loading && articles.length > 0 && ( + <p className="mt-1 text-sm text-stone-400"> + {articles.length} + {hasNextPage ? "+" : ""} article + {articles.length !== 1 ? "s" : ""} + </p> + )} + </div> + {loading ? ( + <div className="py-8 text-center"> + <p className="text-sm text-stone-400">Loading read articles...</p> + </div> + ) : error ? ( + <div className="rounded-lg bg-red-50 p-4 text-sm text-red-600"> + Error: {error.message} + </div> + ) : ( + <ArticleList + articles={articles} + isReadView={true} + isSingleFeed={!!feedId} + hasNextPage={hasNextPage} + loadingMore={loadingMore} + onLoadMore={loadMore} + /> )} </div> - {data?.readArticles && ( - <ArticleList articles={data.readArticles} isReadView={true} /> - )} </div> ); } |
