aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDhravya <[email protected]>2024-07-14 21:43:41 -0500
committerDhravya <[email protected]>2024-07-14 21:43:41 -0500
commit49d257ac2c399123f18f8f4fc8a701e56c7349ae (patch)
tree6754b0e1f46a96a1bc449e561ad6202bd53e6a2d
parentadded sentry (diff)
downloadarchived-supermemory-49d257ac2c399123f18f8f4fc8a701e56c7349ae.tar.xz
archived-supermemory-49d257ac2c399123f18f8f4fc8a701e56c7349ae.zip
added breadcrumbs for easier navigation on web
-rw-r--r--apps/web/app/(dash)/header/autoBreadCrumbs.tsx47
-rw-r--r--apps/web/app/(dash)/header/header.tsx19
-rw-r--r--apps/web/app/(dash)/home/page.tsx3
-rw-r--r--apps/web/app/layout.tsx1
-rw-r--r--apps/web/app/sentry-example-page/page.tsx85
-rw-r--r--apps/web/next.config.mjs3
-rw-r--r--apps/web/package.json1
-rw-r--r--package.json2
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",