diff --git a/src/app/[locale]/(marketing)/cursor/layout.tsx b/src/app/[locale]/(marketing)/cursor/layout.tsx index 6a93a204..7cf32a56 100644 --- a/src/app/[locale]/(marketing)/cursor/layout.tsx +++ b/src/app/[locale]/(marketing)/cursor/layout.tsx @@ -1,16 +1,65 @@ +"use client"; + +import { useEffect, useState } from "react"; +import { MenuIcon, XIcon } from "lucide-react"; import { ThemeProvider } from "next-themes"; + +import { Button } from "@/components/ui/button"; import { Menu } from "@/components/cursor/menu"; export default function Layout({ children }: { children: React.ReactNode }) { + const [isMenuOpen, setIsMenuOpen] = useState(false); + const [isMobile, setIsMobile] = useState(false); + + useEffect(() => { + const checkIsMobile = () => { + setIsMobile(window.innerWidth < 768); + }; + + checkIsMobile(); + window.addEventListener("resize", checkIsMobile); + + return () => window.removeEventListener("resize", checkIsMobile); + }, []); + return ( -
-
- +
+ {/* 移动端菜单切换按钮 */} + {isMobile && ( + + )} + + {/* 侧边菜单 */} +
+
+ +
-
+ + {/* 主内容区 */} +
{children}
+ + {/* 遮罩层 */} + {isMobile && isMenuOpen && ( +
setIsMenuOpen(false)} + /> + )}
); diff --git a/src/components/layout/navbar.tsx b/src/components/layout/navbar.tsx index 78b05990..b3bea2d6 100644 --- a/src/components/layout/navbar.tsx +++ b/src/components/layout/navbar.tsx @@ -78,57 +78,38 @@ export function NavBar({ scroll = false }: NavBarProps) { ) : null}
-
- {/* right header for docs */} - {documentation ? ( -
-
- -
-
- -
-
- +
+ + {session ? ( + +
-
- ) : null} - - {session ? ( - + Dashboard + + + + ) : status === "unauthenticated" ? ( - - ) : status === "unauthenticated" ? ( - - ) : ( - - )} + ) : ( + + )} +
diff --git a/src/components/sections/hero-landing.tsx b/src/components/sections/hero-landing.tsx index 4762131a..0e702ec0 100644 --- a/src/components/sections/hero-landing.tsx +++ b/src/components/sections/hero-landing.tsx @@ -1,13 +1,13 @@ +import { useTranslations } from "next-intl"; import Link from "next/link"; -import { env } from "@/env.mjs"; -import { siteConfig } from "@/config/site"; -import { cn, nFormatter } from "@/lib/utils"; -import { buttonVariants } from "@/components/ui/button"; + import { Icons } from "@/components/shared/icons"; -import { useTranslations } from 'next-intl'; +import { buttonVariants } from "@/components/ui/button"; +import { env } from "@/env.mjs"; +import { cn } from "@/lib/utils"; export default async function HeroLanding() { - const t = useTranslations('HeroLanding'); + const t = useTranslations("HeroLanding"); const { stargazers_count: stars } = await fetch( "https://api.github.com/repos/mickasmt/next-saas-stripe-starter", { @@ -36,14 +36,14 @@ export default async function HeroLanding() { target="_blank" > 🎉 - {t('introducing')}  Next Auth - Roles Template on + {t("introducing")}  Next + Auth Roles Template on

- {t('kickoff')}{" "} + {t("kickoff")}{" "} - {t('saasStarter')} + {t("saasStarter")}

@@ -51,7 +51,7 @@ export default async function HeroLanding() { className="max-w-2xl text-balance leading-normal text-muted-foreground sm:text-xl sm:leading-8" style={{ animationDelay: "0.35s", animationFillMode: "forwards" }} > - {t('description')} + {t("description")}

- {t('goPricing')} + {t("goPricing")} - -

- {t('starOn')} {t('github')}{" "} - {nFormatter(stars)} -

- - - {t('goCursorRules')} + {t("goCursorRules")}
); -} \ No newline at end of file +} diff --git a/src/locales/cn.json b/src/locales/cn.json index 6952a0c5..ed208260 100644 --- a/src/locales/cn.json +++ b/src/locales/cn.json @@ -10,7 +10,7 @@ "goPricing": "查看定价", "starOn": "在", "github": "GitHub 上加星", - "goCursorRules": "去查看 Cursor 提示词" + "goCursorRules": "Go Cursor Rules" }, "layout": { "english": "英文",