Learn-skills.dev ui-skills
Opinionated constraints for building better interfaces with agents. Apply when writing UI code, implementing designs, or reviewing frontend components. Use within DevDocs workflow during development phase for UI-related tasks. Triggers on keywords like "UI", "界面", "前端", "组件", "animation", "动画", "layout", "布局".
install
source · Clone the upstream repo
git clone https://github.com/NeverSight/learn-skills.dev
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/NeverSight/learn-skills.dev "$T" && mkdir -p ~/.claude/skills && cp -r "$T/data/skills-md/ab300819/skills/ui-skills" ~/.claude/skills/neversight-learn-skills-dev-ui-skills && rm -rf "$T"
manifest:
data/skills-md/ab300819/skills/ui-skills/SKILL.mdsource content
UI Skills
构建更好界面的意见约束。在 DevDocs 流程开发阶段实现 UI 相关任务时应用此 skill。
Language
- Accept questions in both Chinese and English
- Always respond in Chinese
Stack
- MUST use Tailwind CSS defaults (spacing, radius, shadows) before custom values
- MUST use
(formerlymotion/react
) when JavaScript animation is requiredframer-motion - SHOULD use
for entrance and micro-animations in Tailwind CSStw-animate-css - MUST use
utility (cn
+clsx
) for class logictailwind-merge
Components
- MUST use accessible component primitives for anything with keyboard or focus behavior (
,Base UI
,React Aria
)Radix - MUST use the project’s existing component primitives first
- NEVER mix primitive systems within the same interaction surface
- SHOULD prefer
for new primitives if compatible with the stackBase UI - MUST add an
to icon-only buttonsaria-label - NEVER rebuild keyboard or focus behavior by hand unless explicitly requested
Interaction
- MUST use an
for destructive or irreversible actionsAlertDialog - SHOULD use structural skeletons for loading states
- NEVER use
, useh-screenh-dvh - MUST respect
for fixed elementssafe-area-inset - MUST show errors next to where the action happens
- NEVER block paste in
orinput
elementstextarea
Animation
- NEVER add animation unless it is explicitly requested
- MUST animate only compositor props (
,transform
)opacity - NEVER animate layout properties (
,width
,height
,top
,left
,margin
)padding - SHOULD avoid animating paint properties (
,background
) except for small, local UI (text, icons)color - SHOULD use
on entranceease-out - NEVER exceed
for interaction feedback200ms - MUST pause looping animations when off-screen
- MUST respect
prefers-reduced-motion - NEVER introduce custom easing curves unless explicitly requested
- SHOULD avoid animating large images or full-screen surfaces
Typography
- MUST use
for headings andtext-balance
for body/paragraphstext-pretty - MUST use
for datatabular-nums - SHOULD use
ortruncate
for dense UIline-clamp - NEVER modify
(letter-spacing
) unless explicitly requestedtracking-
Layout
- MUST use a fixed
scale (no arbitraryz-index
)z-x - SHOULD use
for square elements instead ofsize-x
+w-xh-x
Performance
- NEVER animate large
orblur()
surfacesbackdrop-filter - NEVER apply
outside an active animationwill-change - NEVER use
for anything that can be expressed as render logicuseEffect
Design
- NEVER use gradients unless explicitly requested
- NEVER use purple or multicolor gradients
- NEVER use glow effects as primary affordances
- SHOULD use Tailwind CSS default shadow scale unless explicitly requested
- MUST give empty states one clear next action
- SHOULD limit accent color usage to one per view
- SHOULD use existing theme or Tailwind CSS color tokens before introducing new ones