Awesome-omni-skill ui-skills
Opinionated constraints for building better interfaces with agents.
install
source · Clone the upstream repo
git clone https://github.com/diegosouzapw/awesome-omni-skill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/diegosouzapw/awesome-omni-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/development/ui-skills-quanphm" ~/.claude/skills/diegosouzapw-awesome-omni-skill-ui-skills-5cd539 && rm -rf "$T"
manifest:
skills/development/ui-skills-quanphm/SKILL.mdsource content
UI Skills
When invoked, apply these opinionated constraints for building better interfaces.
How to use
-
/ui-skills
Apply these constraints to any UI work in this conversation. -
/ui-skills <file>
Review the file against all constraints below and output:- violations (quote the exact line/snippet)
- why it matters (1 short sentence)
- a concrete fix (code-level suggestion)
Stack
- MUST use Tailwind CSS defaults unless custom values already exist or are explicitly requested
- 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
- SHOULD 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-* - SHOULD use
for square elements instead ofsize-*
+w-*h-*
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