aboutsummaryrefslogtreecommitdiffstats
path: root/packages/web/app/dashboard/lists/components
diff options
context:
space:
mode:
authorMohamedBassem <me@mbassem.com>2024-03-02 14:23:46 +0000
committerMohamedBassem <me@mbassem.com>2024-03-02 14:23:46 +0000
commitcd623ad9d6281389b0a092520c777567fcf5464b (patch)
tree33af8f21d741ed6455ad4b90944c272a99fdd58c /packages/web/app/dashboard/lists/components
parenteeae96553c204097dec8a3c35d86533b3ce055d9 (diff)
downloadkarakeep-cd623ad9d6281389b0a092520c777567fcf5464b.tar.zst
feature: Add an 'All Lists' page
Diffstat (limited to 'packages/web/app/dashboard/lists/components')
-rw-r--r--packages/web/app/dashboard/lists/components/AllListsView.tsx57
1 files changed, 57 insertions, 0 deletions
diff --git a/packages/web/app/dashboard/lists/components/AllListsView.tsx b/packages/web/app/dashboard/lists/components/AllListsView.tsx
new file mode 100644
index 00000000..7c8a9e56
--- /dev/null
+++ b/packages/web/app/dashboard/lists/components/AllListsView.tsx
@@ -0,0 +1,57 @@
+"use client";
+
+import LoadingSpinner from "@/components/ui/spinner";
+import { api } from "@/lib/trpc";
+import { ZBookmarkList } from "@/lib/types/api/lists";
+import { keepPreviousData } from "@tanstack/react-query";
+import Link from "next/link";
+
+function ListItem({
+ name,
+ icon,
+ path,
+}: {
+ name: string;
+ icon: string;
+ path: string;
+}) {
+ return (
+ <Link href={path}>
+ <div className="bg-background rounded-md border border-gray-200 px-4 py-2 text-lg">
+ <p className="text-nowrap">
+ {icon} {name}
+ </p>
+ </div>
+ </Link>
+ );
+}
+
+export default function AllListsView({
+ initialData,
+}: {
+ initialData: ZBookmarkList[];
+}) {
+ const { data: lists } = api.lists.list.useQuery(undefined, {
+ initialData: { lists: initialData },
+ placeholderData: keepPreviousData,
+ });
+
+ if (!lists) {
+ return <LoadingSpinner />;
+ }
+
+ return (
+ <div className="flex flex-col gap-2 md:flex-row">
+ <ListItem name="Favourites" icon="⭐️" path={`/dashboard/favourites`} />
+ <ListItem name="Archive" icon="🗄️" path={`/dashboard/archive`} />
+ {lists.lists.map((l) => (
+ <ListItem
+ key={l.id}
+ name={l.name}
+ icon={l.icon}
+ path={`/dashboard/lists/${l.id}`}
+ />
+ ))}
+ </div>
+ );
+}