frontend-dev

Use when creating or modifying Next.js pages, React components, Tailwind CSS styles, API integration, hooks, or i18n.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "frontend-dev" with this command: npx skills add srbhr/resume-matcher/srbhr-resume-matcher-frontend-dev

Frontend Development

Use when creating or modifying Next.js pages, React components, Tailwind CSS styles, API integration, hooks, or i18n.

Before Writing Code

  • Read docs/agent/architecture/frontend-workflow.md for user flow

  • Read docs/agent/design/style-guide.md for Swiss International Style (REQUIRED)

  • Read docs/agent/coding-standards.md for conventions

  • Check existing components in apps/frontend/components/

Non-Negotiable Rules

  • Swiss International Style - ALL UI changes must follow it

  • rounded-none everywhere - no rounded corners, ever

  • Hard shadows - shadow-[4px_4px_0px_0px_#000000] , never soft shadows

  • Run npm run lint before committing

  • Run npm run format before committing

  • Enter key handling on all textareas

Swiss International Style Quick Reference

Element Value

Canvas bg #F0F0E8 / bg-[#F0F0E8]

Ink text #000000

Hyper Blue #1D4ED8 / text-blue-700

Signal Green #15803D / text-green-700

Alert Red #DC2626 / text-red-600

Headers font-serif

Body font-sans

Labels font-mono text-sm uppercase tracking-wider

Borders rounded-none border-2 border-black

Shadows shadow-[4px_4px_0px_0px_#000000]

Hover hover:translate-y-[1px] hover:translate-x-[1px] hover:shadow-none

Anti-Patterns (NEVER)

  • rounded-* (except rounded-none )

  • Gradients or blur shadows

  • Colors outside the palette

  • Pastel or soft colors

  • Decorative icons without function

Patterns

New Component

'use client';

interface MyComponentProps { title: string; onAction: () => void; }

export function MyComponent({ title, onAction }: MyComponentProps) { return ( <div className="bg-white border-2 border-black shadow-[4px_4px_0px_0px_#000000] p-6"> <h3 className="font-serif text-xl mb-4">{title}</h3> <button onClick={onAction} className="rounded-none border-2 border-black px-4 py-2 bg-blue-700 text-white shadow-[2px_2px_0px_0px_#000000] hover:translate-y-[1px] hover:translate-x-[1px] hover:shadow-none transition-all" > Action </button> </div> ); }

Textarea (Enter key fix)

const handleKeyDown = (e: React.KeyboardEvent<HTMLTextAreaElement>) => { if (e.key === 'Enter') e.stopPropagation(); };

<textarea onKeyDown={handleKeyDown} className="w-full rounded-none border-2 border-black p-3 font-sans" />

Bundle Optimization

// Direct icon import (NOT barrel import) import FileText from 'lucide-react/dist/esm/icons/file-text';

// Dynamic import for heavy components import dynamic from 'next/dynamic'; const PDFViewer = dynamic(() => import('./PDFViewer'), { ssr: false });

API Integration

// Use Promise.all for independent fetches const [resumes, jobs] = await Promise.all([ api.get('/api/v1/resumes'), api.get('/api/v1/jobs'), ]);

Checklist

  • npm run lint passes

  • npm run format run

  • rounded-none on all elements

  • Hard shadows, Swiss palette only

  • Correct typography (serif headers, mono labels, sans body)

  • Textareas have Enter key handler

  • Icons imported directly, heavy components use next/dynamic

  • Independent fetches use Promise.all()

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

receiving-code-review

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

code-review

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

backend-dev

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

codebase-navigator

No summary provided by upstream source.

Repository SourceNeeds Review