diff options
| author | Dhravya <[email protected]> | 2024-07-14 21:43:41 -0500 |
|---|---|---|
| committer | Dhravya <[email protected]> | 2024-07-14 21:43:41 -0500 |
| commit | 49d257ac2c399123f18f8f4fc8a701e56c7349ae (patch) | |
| tree | 6754b0e1f46a96a1bc449e561ad6202bd53e6a2d | |
| parent | added sentry (diff) | |
| download | archived-supermemory-49d257ac2c399123f18f8f4fc8a701e56c7349ae.tar.xz archived-supermemory-49d257ac2c399123f18f8f4fc8a701e56c7349ae.zip | |
added breadcrumbs for easier navigation on web
| -rw-r--r-- | apps/web/app/(dash)/header/autoBreadCrumbs.tsx | 47 | ||||
| -rw-r--r-- | apps/web/app/(dash)/header/header.tsx | 19 | ||||
| -rw-r--r-- | apps/web/app/(dash)/home/page.tsx | 3 | ||||
| -rw-r--r-- | apps/web/app/layout.tsx | 1 | ||||
| -rw-r--r-- | apps/web/app/sentry-example-page/page.tsx | 85 | ||||
| -rw-r--r-- | apps/web/next.config.mjs | 3 | ||||
| -rw-r--r-- | apps/web/package.json | 1 | ||||
| -rw-r--r-- | package.json | 2 |
8 files changed, 62 insertions, 99 deletions
diff --git a/apps/web/app/(dash)/header/autoBreadCrumbs.tsx b/apps/web/app/(dash)/header/autoBreadCrumbs.tsx new file mode 100644 index 00000000..5767ca6f --- /dev/null +++ b/apps/web/app/(dash)/header/autoBreadCrumbs.tsx @@ -0,0 +1,47 @@ +"use client"; + +import { + Breadcrumb, + BreadcrumbItem, + BreadcrumbLink, + BreadcrumbList, + BreadcrumbSeparator, +} from "@repo/ui/shadcn/breadcrumb"; +import { usePathname } from "next/navigation"; +import React from "react"; + +function AutoBreadCrumbs() { + const pathname = usePathname(); + + console.log(pathname.split("/").filter(Boolean)); + + return ( + <Breadcrumb className="hidden md:block"> + <BreadcrumbList> + {!pathname.startsWith("/home") && ( + <> + <BreadcrumbItem> + <BreadcrumbLink href="/">Home</BreadcrumbLink> + </BreadcrumbItem> + <BreadcrumbSeparator hidden={pathname.split("/").length === 1} /> + </> + )} + {pathname + .split("/") + .filter(Boolean) + .map((path, idx, paths) => ( + <> + <BreadcrumbItem key={path}> + <BreadcrumbLink href={`/${paths.slice(0, idx + 1).join("/")}`}> + {path.charAt(0).toUpperCase() + path.slice(1)} + </BreadcrumbLink> + </BreadcrumbItem> + <BreadcrumbSeparator hidden={idx === paths.length - 1} /> + </> + ))} + </BreadcrumbList> + </Breadcrumb> + ); +} + +export default AutoBreadCrumbs; diff --git a/apps/web/app/(dash)/header/header.tsx b/apps/web/app/(dash)/header/header.tsx index 9154ead8..0fc28227 100644 --- a/apps/web/app/(dash)/header/header.tsx +++ b/apps/web/app/(dash)/header/header.tsx @@ -5,6 +5,7 @@ import Logo from "../../../public/logo.svg"; import { getChatHistory } from "../../actions/fetchers"; import NewChatButton from "./newChatButton"; +import AutoBreadCrumbs from "./autoBreadCrumbs"; async function Header() { const chatThreads = await getChatHistory(); @@ -16,13 +17,17 @@ async function Header() { return ( <div className="p-4 relative z-30 h-16 flex items-center"> <div className="w-full flex items-center justify-between"> - <Link className="" href="/home"> - <Image - src={Logo} - alt="SuperMemory logo" - className="hover:brightness-125 duration-200" - /> - </Link> + <div className="flex items-center gap-4"> + <Link className="" href="/home"> + <Image + src={Logo} + alt="SuperMemory logo" + className="hover:brightness-125 duration-200 w-full h-full" + /> + </Link> + + <AutoBreadCrumbs /> + </div> <div className="flex items-center gap-2"> <NewChatButton /> diff --git a/apps/web/app/(dash)/home/page.tsx b/apps/web/app/(dash)/home/page.tsx index 27f037a8..a3a3b946 100644 --- a/apps/web/app/(dash)/home/page.tsx +++ b/apps/web/app/(dash)/home/page.tsx @@ -2,14 +2,11 @@ import React, { useEffect, useState } from "react"; import QueryInput from "./queryinput"; -import { homeSearchParamsCache } from "@/lib/searchParams"; import { getSessionAuthToken, getSpaces } from "@/app/actions/fetchers"; import { useRouter } from "next/navigation"; import { createChatThread, linkTelegramToUser } from "@/app/actions/doers"; import { toast } from "sonner"; -import { useSession } from "next-auth/react"; import { motion } from "framer-motion"; -import BackgroundPlus from "@/app/(landing)/GridPatterns/PlusGrid"; import { variants } from "./homeVariants"; const slap = { diff --git a/apps/web/app/layout.tsx b/apps/web/app/layout.tsx index 1527c8a0..affe0cfb 100644 --- a/apps/web/app/layout.tsx +++ b/apps/web/app/layout.tsx @@ -5,7 +5,6 @@ import { Inter } from "next/font/google"; import { GeistSans } from "geist/font/sans"; import { GeistMono } from "geist/font/mono"; import { cn } from "@repo/ui/lib/utils"; -import BackgroundPlus from "./(landing)/GridPatterns/PlusGrid"; import { Toaster } from "@repo/ui/shadcn/toaster"; const inter = Inter({ subsets: ["latin"] }); diff --git a/apps/web/app/sentry-example-page/page.tsx b/apps/web/app/sentry-example-page/page.tsx deleted file mode 100644 index 9c5d2a3a..00000000 --- a/apps/web/app/sentry-example-page/page.tsx +++ /dev/null @@ -1,85 +0,0 @@ -"use client"; - -import Head from "next/head"; -import * as Sentry from "@sentry/nextjs"; - -export default function Page() { - return ( - <div> - <Head> - <title>Sentry Onboarding</title> - <meta name="description" content="Test Sentry for your Next.js app!" /> - </Head> - - <main - style={{ - minHeight: "100vh", - display: "flex", - flexDirection: "column", - justifyContent: "center", - alignItems: "center", - }} - > - <h1 style={{ fontSize: "4rem", margin: "14px 0" }}> - <svg - style={{ - height: "1em", - }} - xmlns="http://www.w3.org/2000/svg" - viewBox="0 0 200 44" - > - <path - fill="currentColor" - d="M124.32,28.28,109.56,9.22h-3.68V34.77h3.73V15.19l15.18,19.58h3.26V9.22h-3.73ZM87.15,23.54h13.23V20.22H87.14V12.53h14.93V9.21H83.34V34.77h18.92V31.45H87.14ZM71.59,20.3h0C66.44,19.06,65,18.08,65,15.7c0-2.14,1.89-3.59,4.71-3.59a12.06,12.06,0,0,1,7.07,2.55l2-2.83a14.1,14.1,0,0,0-9-3c-5.06,0-8.59,3-8.59,7.27,0,4.6,3,6.19,8.46,7.52C74.51,24.74,76,25.78,76,28.11s-2,3.77-5.09,3.77a12.34,12.34,0,0,1-8.3-3.26l-2.25,2.69a15.94,15.94,0,0,0,10.42,3.85c5.48,0,9-2.95,9-7.51C79.75,23.79,77.47,21.72,71.59,20.3ZM195.7,9.22l-7.69,12-7.64-12h-4.46L186,24.67V34.78h3.84V24.55L200,9.22Zm-64.63,3.46h8.37v22.1h3.84V12.68h8.37V9.22H131.08ZM169.41,24.8c3.86-1.07,6-3.77,6-7.63,0-4.91-3.59-8-9.38-8H154.67V34.76h3.8V25.58h6.45l6.48,9.2h4.44l-7-9.82Zm-10.95-2.5V12.6h7.17c3.74,0,5.88,1.77,5.88,4.84s-2.29,4.86-5.84,4.86Z M29,2.26a4.67,4.67,0,0,0-8,0L14.42,13.53A32.21,32.21,0,0,1,32.17,40.19H27.55A27.68,27.68,0,0,0,12.09,17.47L6,28a15.92,15.92,0,0,1,9.23,12.17H4.62A.76.76,0,0,1,4,39.06l2.94-5a10.74,10.74,0,0,0-3.36-1.9l-2.91,5a4.54,4.54,0,0,0,1.69,6.24A4.66,4.66,0,0,0,4.62,44H19.15a19.4,19.4,0,0,0-8-17.31l2.31-4A23.87,23.87,0,0,1,23.76,44H36.07a35.88,35.88,0,0,0-16.41-31.8l4.67-8a.77.77,0,0,1,1.05-.27c.53.29,20.29,34.77,20.66,35.17a.76.76,0,0,1-.68,1.13H40.6q.09,1.91,0,3.81h4.78A4.59,4.59,0,0,0,50,39.43a4.49,4.49,0,0,0-.62-2.28Z" - ></path> - </svg> - </h1> - - <p>Get started by sending us a sample error:</p> - <button - type="button" - style={{ - padding: "12px", - cursor: "pointer", - backgroundColor: "#AD6CAA", - borderRadius: "4px", - border: "none", - color: "white", - fontSize: "14px", - margin: "18px", - }} - onClick={async () => { - await Sentry.startSpan( - { - name: "Example Frontend Span", - op: "test", - }, - async () => { - const res = await fetch("/api/sentry-example-api"); - if (!res.ok) { - throw new Error("Sentry Example Frontend Error"); - } - }, - ); - }} - > - Throw error! - </button> - - <p> - Next, look for the error on the{" "} - <a href="https://none-h00.sentry.io/issues/?project=4503929866354688"> - Issues Page - </a> - . - </p> - <p style={{ marginTop: "24px" }}> - For more information, see{" "} - <a href="https://docs.sentry.io/platforms/javascript/guides/nextjs/"> - https://docs.sentry.io/platforms/javascript/guides/nextjs/ - </a> - </p> - </main> - </div> - ); -} diff --git a/apps/web/next.config.mjs b/apps/web/next.config.mjs index ca5266e1..12929a8c 100644 --- a/apps/web/next.config.mjs +++ b/apps/web/next.config.mjs @@ -16,7 +16,7 @@ let selectedCofig = baseNextConfig; if (process.env.NODE_ENV === "development") { selectedCofig = MillionLint.next({ rsc: true, - })(nextConfig); + })(baseNextConfig); } export default withSentryConfig(selectedCofig, { @@ -25,7 +25,6 @@ export default withSentryConfig(selectedCofig, { org: "none-h00", project: "javascript-nextjs", - // Only print logs for uploading source maps in CI silent: !process.env.CI, diff --git a/apps/web/package.json b/apps/web/package.json index 1b3b2ab0..3a5771d8 100644 --- a/apps/web/package.json +++ b/apps/web/package.json @@ -20,6 +20,7 @@ "@million/lint": "^1.0.0-rc.11", "@radix-ui/react-dialog": "^1.0.5", "@radix-ui/react-popover": "^1.0.7", + "@radix-ui/react-slot": "^1.1.0", "@sentry/nextjs": "^8", "cmdk": "^1.0.0", "lowlight": "^3.1.0", diff --git a/package.json b/package.json index 38669d01..217e717a 100644 --- a/package.json +++ b/package.json @@ -66,7 +66,7 @@ "@radix-ui/react-scroll-area": "^1.0.5", "@radix-ui/react-select": "^2.0.0", "@radix-ui/react-separator": "^1.0.3", - "@radix-ui/react-slot": "^1.0.2", + "@radix-ui/react-slot": "^1.1.0", "@radix-ui/react-switch": "^1.1.0", "@radix-ui/react-tabs": "^1.0.4", "@radix-ui/react-toast": "^1.1.5", |