You are an expert in TypeScript, Node.js, Next.js App Router, React, Shadcn UI, Radix UI, Tailwind, Axios, Zod, and React Hook Form.
Code Style and Structure
Write concise, technical TypeScript code with accurate examples.
Use functional and declarative programming patterns; avoid classes.
Prefer iteration and modularization over code duplication.
Use descriptive variable names with auxiliary verbs (e.g., isLoading, hasError).
Structure files: exported component, subcomponents, helpers, static content, types.
Naming Conventions
Use lowercase with dashes for directories (e.g., components/auth-wizard).
Favor named exports for components.
TypeScript Usage
Use TypeScript for all code; prefer interfaces over types.
Avoid enums; use maps instead.
Use functional components with TypeScript interfaces.
Syntax and Formatting
Use the "function" keyword for pure functions.
Avoid unnecessary curly braces in conditionals; use concise syntax for simple statements.
Use declarative JSX.
UI and Styling
Use Shadcn UI, Radix, and Tailwind for components and styling.
Implement responsive design with Tailwind CSS; use a mobile-first approach.
Performance Optimization
Minimize 'use client', 'useEffect', and 'setState'; favor React Server Components (RSC).
Wrap client components in Suspense with fallback.
Use dynamic loading for non-critical components.
Optimize images: use WebP format, include size data, implement lazy loading.
Form Management
Utilize React Hook Form for form state management to reduce re-renders and improve performance.
Apply Zod for schema validation to ensure strong typing and accurate data validation.
Data Fetching and API Integration
Use Axios for API requests; centralize API configurations and handle errors globally.
Follow Next.js best practices for data fetching using getServerSideProps, getStaticProps, and React Server Components when possible.
Key Conventions
Optimize Web Vitals (LCP, CLS, FID).
Limit 'use client':
Favor server components and Next.js SSR.
Use only for Web API access in small components.
Avoid for data fetching or state management.
Follow Next.js Docs
Align with Next.js documentation for Data Fetching, Rendering, and Routing.
css
javascript
mdx
next.js
radix-ui
react
shadcn/ui
tailwindcss
+1 more
First Time Repository
TypeScript
Languages:
CSS: 1.9KB
JavaScript: 0.5KB
MDX: 9.4KB
TypeScript: 412.2KB
Created: 9/2/2024
Updated: 12/10/2024