diff options
| author | MohamedBassem <me@mbassem.com> | 2024-03-05 02:26:10 +0000 |
|---|---|---|
| committer | MohamedBassem <me@mbassem.com> | 2024-03-05 02:26:10 +0000 |
| commit | b8b0a444139358bdf7707034e3a7437babc69db8 (patch) | |
| tree | 73c754d2e76021233852917b24e20ac4e2906420 /packages/web/app/dashboard/preview | |
| parent | b2e64b9cbc95fdc66b8de69ae221fc5e696bf873 (diff) | |
| download | karakeep-b8b0a444139358bdf7707034e3a7437babc69db8.tar.zst | |
feature: Preview page for the stored content of links
Diffstat (limited to 'packages/web/app/dashboard/preview')
| -rw-r--r-- | packages/web/app/dashboard/preview/[bookmarkId]/page.tsx | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/packages/web/app/dashboard/preview/[bookmarkId]/page.tsx b/packages/web/app/dashboard/preview/[bookmarkId]/page.tsx new file mode 100644 index 00000000..030ad2df --- /dev/null +++ b/packages/web/app/dashboard/preview/[bookmarkId]/page.tsx @@ -0,0 +1,64 @@ +import { BackButton } from "@/components/ui/back-button"; +import { api } from "@/server/api/client"; +import { ArrowLeftCircle, CalendarDays, ExternalLink } from "lucide-react"; +import Link from "next/link"; +import Markdown from "react-markdown"; + +export default async function BookmarkPreviewPage({ + params, +}: { + params: { bookmarkId: string }; +}) { + const bookmark = await api.bookmarks.getBookmark({ + bookmarkId: params.bookmarkId, + }); + + const linkHeader = bookmark.content.type == "link" && ( + <div className="flex flex-col space-y-2"> + <p className="text-center text-3xl">{bookmark.content.title}</p> + <Link href={bookmark.content.url} className="mx-auto flex gap-2"> + <span className="my-auto">View Original</span> + <ExternalLink /> + </Link> + </div> + ); + + let content; + switch (bookmark.content.type) { + case "link": { + content = ( + <div + dangerouslySetInnerHTML={{ + __html: bookmark.content.htmlContent || "", + }} + className="prose" + /> + ); + break; + } + case "text": { + content = <Markdown className="prose">{bookmark.content.text}</Markdown>; + break; + } + } + + return ( + <div className="bg-background m-4 min-h-screen space-y-4 rounded-md border p-4"> + <div className="flex justify-between"> + <BackButton className="ghost" variant="ghost"> + <ArrowLeftCircle /> + </BackButton> + <div className="my-auto"> + <span className="my-auto flex gap-2"> + <CalendarDays /> {bookmark.createdAt.toLocaleString()} + </span> + </div> + </div> + <hr /> + {linkHeader} + <div className="mx-auto flex h-full border-x p-2 px-4 lg:w-2/3"> + {content} + </div> + </div> + ); +} |
