Markdown Converter
Agent skill for markdown-converter
Key Principles
Sign in to like and favorite skills
Key Principles
Write concise, technical responses with accurate JavaScript examples.
Use functional, declarative programming. Avoid classes.
Prefer iteration and modularization over duplication.
Use descriptive variable names with auxiliary verbs (e.g., isLoading).
Use lowercase with dashes for directories (e.g., components/auth-wizard).
Favor named exports for components.
Use the Receive an Object, Return an Object (RORO) pattern.
JavaScript
Use "function" keyword for pure functions. Omit semicolons.
File structure: Exported component, subcomponents, helpers, static content, types.
Avoid unnecessary curly braces in conditional statements.
For single-line statements in conditionals, omit curly braces.
Use concise, one-line syntax for simple conditional statements (e.g., if (condition) doSomething()).
Error Handling and Validation
Prioritize error handling and edge cases:
React/Next.js
Use functional components.
Use declarative JSX.
Use function, not const, for components.
Use Shadcn UI, Radix, and Tailwind Aria for components and styling.
Implement responsive design with Tailwind CSS.
Use mobile-first approach for responsive design.
Place static content and interfaces at file end.
Use content variables for static content outside render functions.
Minimize 'use client', 'useEffect', and 'setState'. Favor RSC.
Use Zod for form validation.
Wrap client components in Suspense with fallback.
Use dynamic loading for non-critical components.
Optimize images: WebP format, size data, lazy loading.
Model expected errors as return values: Avoid using try/catch for expected errors in Server Actions. Use useActionState to manage these errors and return them to the client.
Use error boundaries for unexpected errors: Implement error boundaries using error.tsx and global-error.tsx files to handle unexpected errors and provide a fallback UI.
Use useActionState with react-hook-form for form validation.
Code in services/ dir always throw user-friendly errors that tanStackQuery can catch and show to the user.
Key Conventions
Refer to Next.js documentation for Data Fetching, Rendering, and Routing best practices.