Smithery Logo
MCPsSkillsDocsPricing
Login
Smithery Logo

Accelerating the Agent Economy

Resources

DocumentationPrivacy PolicySystem Status

Company

PricingAboutBlog

Connect

© 2026 Smithery. All rights reserved.

    aiskillstore

    next-js-patterns

    aiskillstore/next-js-patterns
    Coding
    133
    3 installs

    About

    SKILL.md

    Install

    Install via Skills CLI

    or add to your agent
    • Claude Code
      Claude Code
    • Codex
      Codex
    • OpenClaw
      OpenClaw
    • Cursor
      Cursor
    • Amp
      Amp
    • GitHub Copilot
      GitHub Copilot
    • Gemini CLI
      Gemini CLI
    • Kilo Code
      Kilo Code
    • Junie
      Junie
    • Replit
      Replit
    • Windsurf
      Windsurf
    • Cline
      Cline
    • Continue
      Continue
    • OpenCode
      OpenCode
    • OpenHands
      OpenHands
    • Roo Code
      Roo Code
    • Augment
      Augment
    • Goose
      Goose
    • Trae
      Trae
    • Zencoder
      Zencoder
    • Antigravity
      Antigravity
    ├─
    ├─
    └─

    About

    Best practices and patterns for Next.js App Router, Server Actions, and Routing in this project.

    SKILL.md

    Next.js Patterns

    App Router

    We use the Next.js 15 App Router located in app/.

    Pages

    • Location: app/[route]/page.tsx
    • Component: Default export function.
    • Client vs Server: Use "use client" directive at the top for components requiring state (useState, useEffect) or browser APIs. otherwise default to Server Components.

    Layouts

    • Location: app/layout.tsx (Root), app/[route]/layout.tsx (Nested).
    • Purpose: Wrappers for pages, holding navigation, fonts, and metadata.

    Navigation

    • Use Link from next/link for internal navigation.
    • Use useRouter from next/navigation for programmatic navigation (inside Client Components).
    import Link from "next/link";
    import { useRouter } from "next/navigation";
    
    // Link
    <Link href="/dashboard">Dashboard</Link>
    
    // Router
    const router = useRouter();
    router.push('/login');
    

    Data Fetching

    • Server Components: Fetch directly using await fetch() or DB calls.
    • Client Components: Use useEffect or SWR/TanStack Query (if added later). Currently using standard fetch in useEffect.

    Font Optimization

    • We use next/font/google (e.g., Poppins) in app/layout.tsx.
    • Variable fonts are passed to body className.

    Metadata

    • Define export const metadata: Metadata = { ... } in page.tsx or layout.tsx for SEO.
    Recommended Servers
    Vercel Grep
    Vercel Grep
    ThinAir Geo
    ThinAir Geo
    InstantDB
    InstantDB
    Repository
    aiskillstore/marketplace
    Files