Дизайн-система и UI-аудит: контрастность, focus states, touch targets, 161 цветовая палитра, 57 шрифтовых сочетаний. Поддержка 10 стеков: React, SwiftUI, Flutter и другие.
npx -y skills add nextlevelbuilder/ui-ux-pro-max-skill --skill ui-ux-pro-max --agent claude-codeИсчерпывающее руководство по дизайну для веб- и мобильных приложений. Содержит 50+ стилей, 161 цветовую палитру, 57 пар шрифтов, 161 тип продукта с правилами обоснования, 99 UX-правил и 25 типов диаграмм для 10 технологических стеков. База данных с поиском и рекомендациями на основе приоритетов.
Этот скилл следует использовать, когда задача связана со структурой UI, визуальными дизайн-решениями, паттернами взаимодействия или контролем качества UX.
Критерий решения: Если задача изменит, как функциональность выглядит, ощущается, движется или с ней взаимодействуют — этот скилл нужно использовать.
| Приоритет | Категория | Влияние | Ключевые проверки | Антипаттерны |
|---|---|---|---|---|
| 1 | Доступность | КРИТИЧНО | Контраст 4.5:1, Alt-текст, Навигация с клавиатуры, Aria-метки | Убирать кольца фокуса, Кнопки только с иконкой без меток |
| 2 | Касание и взаимодействие | КРИТИЧНО | Минимальный размер 44×44px, Отступ 8px+, Обратная связь при загрузке | Опора только на hover, Мгновенные смены состояния (0ms) |
| 3 | Производительность | ВЫСОКОЕ | WebP/AVIF, Ленивая загрузка, Резервирование пространства (CLS < 0.1) | Layout thrashing, Cumulative Layout Shift |
| 4 | Выбор стиля | ВЫСОКОЕ | Соответствие типу продукта, Согласованность, SVG-иконки (не эмодзи) | Смешивать flat и skeuomorphic произвольно, Эмодзи как иконки |
| 5 | Разметка и адаптивность | ВЫСОКОЕ | Mobile-first breakpoints, Viewport meta, Без горизонтального скролла | Горизонтальный скролл, Фиксированные px-ширины, Отключать zoom |
| 6 | Типографика и цвет | СРЕДНЕЕ | Base 16px, Line-height 1.5, Семантические цветовые токены | Текст < 12px для тела, Серый-на-сером, Raw hex в компонентах |
| 7 | Анимация | СРЕДНЕЕ | Длительность 150–300ms, Анимация передаёт смысл, Пространственная непрерывность | Только декоративная анимация, Анимация width/height, Без reduced-motion |
| 8 | Формы и обратная связь | СРЕДНЕЕ | Видимые метки, Ошибка рядом с полем, Вспомогательный текст | Только placeholder как метка, Ошибки только вверху |
| 9 | Паттерны навигации | ВЫСОКОЕ | Предсказуемое «назад», Bottom nav ≤5, Deep linking | Перегруженная навигация, Сломанная кнопка «назад» |
| 10 | Графики и данные | НИЗКОЕ | Легенды, Тултипы, Доступные цвета | Опора только на цвет для передачи смысла |
color-contrast — минимум 4.5:1 для обычного текста (крупный текст 3:1)focus-states — видимые кольца фокуса на интерактивных элементах (2–4px)alt-text — описательный alt-текст для значимых изображенийaria-labels — aria-label для кнопок только с иконкойkeyboard-nav — порядок Tab совпадает с визуальным порядком; полная поддержка клавиатурыform-labels — используйте label с атрибутом forskip-links — «Перейти к основному контенту» для пользователей клавиатурыheading-hierarchy — последовательные h1→h6, без пропуска уровнейcolor-not-only — не передавайте информацию только цветом (добавьте иконку/текст)reduced-motion — соблюдайте prefers-reduced-motion; уменьшайте/отключайте анимации по запросуtouch-target-size — минимум 44×44pt (Apple) / 48×48dp (Material); расширяйте область касания за визуальные границы при необходимостиtouch-spacing — минимум 8px/8dp между целевыми областями касанияhover-vs-tap — используйте click/tap для основных взаимодействий; не полагайтесь только на hoverloading-buttons — отключайте кнопку во время асинхронных операций; показывайте спиннер или прогрессtap-delay — используйте touch-action: manipulation для сокращения задержки 300ms (Web)press-feedback — визуальная обратная связь при нажатии (ripple/highlight)haptic-feedback — используйте тактильный отклик для подтверждений и важных действий; избегайте злоупотребленияsafe-area-awareness — держите основные элементы касания вдали от чёлки, Dynamic Island, панели жестов и краёв экранаimage-optimization — используйте WebP/AVIF, адаптивные изображения (srcset/sizes), ленивую загрузкуimage-dimension — объявляйте width/height или используйте aspect-ratio для предотвращения сдвигов разметкиfont-loading — используйте font-display: swap/optional для предотвращения FOITlazy-loading — ленивая загрузка некритичных компонентов через dynamic import / route-level splittingvirtualize-lists — виртуализируйте списки от 50+ элементовprogressive-loading — используйте скелетные экраны / shimmer вместо долгих блокирующих спиннеров для операций >1сinput-latency — задержка ввода менее ~100ms для нажатий/прокруткиdebounce-throttle — используйте debounce/throttle для высокочастотных событий (scroll, resize, input)style-match — подбирайте стиль под тип продуктаconsistency — используйте один стиль на всех страницахno-emoji-icons — используйте SVG-иконки (Heroicons, Lucide), не эмодзиplatform-adaptive — соблюдайте платформенные идиомы (iOS HIG vs Material)dark-mode-pairing — проектируйте светлый/тёмный варианты вместе для согласованностиprimary-action — каждый экран должен иметь только один основной CTAviewport-meta — width=device-width initial-scale=1 (никогда не отключать zoom)mobile-first — проектируйте сначала для мобильных, затем масштабируйте до планшета и десктопаbreakpoint-consistency — системные точки останова (например, 375 / 768 / 1024 / 1440)readable-font-size — минимум 16px основной текст на мобильных (избегает автозума iOS)line-length-control — мобильные 35–60 символов в строке; десктоп 60–75spacing-scale — используйте систему отступов с шагом 4pt/8dp (Material Design)viewport-units — предпочитайте min-h-dvh вместо 100vh на мобильныхline-height — используйте 1.5–1.75 для основного текстаfont-pairing — согласовывайте характер шрифтов заголовков и телаfont-scale — согласованная типографическая шкала (например, 12 14 16 18 24 32)color-semantic — определяйте семантические цветовые токены (primary, secondary, error, surface) вместо raw hex в компонентахcolor-dark-mode — тёмный режим использует десатурированные/более светлые тональные варианты, а не инвертированные цветаweight-hierarchy — используйте font-weight для иерархии: жирные заголовки (600–700), обычное тело (400)number-tabular — используйте tabular/monospaced цифры для столбцов данных, цен и таймеровduration-range — 150–300ms для стандартных переходов; 300–500ms для сложных (Material Motion)easing-curves — используйте ease-out для элементов входа, ease-in для выхода, ease-in-out для перемещения (Material Motion)spatial-continuity — сохраняйте пространственную непрерывность: элементы движутся к источнику/от источника (Apple HIG)no-width-height-animation — не анимируйте width/height; вместо этого используйте transform/opacitymotion-meaning — каждая анимация должна передавать состояние или причинно-следственную связь; избегайте только декоративных анимацийreduce-motion-required — ОБЯЗАТЕЛЬНО: реализуйте prefers-reduced-motion для всех анимацийvisible-labels — каждое поле формы должно иметь видимую постоянную метку; не используйте только placeholdererror-placement — размещайте сообщения об ошибках непосредственно под проблемным полем, а не только вверхуprogressive-disclosure — показывайте поля по мере необходимости; не перегружайте форму сразуloading-state — показывайте состояние загрузки для любого действия, занимающего более 100mssuccess-confirmation — давайте чёткую обратную связь после успешной отправкиinline-validation — валидируйте при unfocus (не при каждом нажатии), если возможноback-button-behavior — кнопка «Назад» всегда возвращает на один логический уровень вверх; никаких сюрпризовtab-bar-count — нижняя навигация должна иметь ≤5 элементов (Apple HIG, Material)deep-linking — каждый экран должен иметь уникальный URL или маршрут для навигации и обменаnav-hierarchy — максимум 3 уровня глубины навигации; более глубокие маршруты требуют хлебных крошекactive-state — текущий раздел должен быть чётко выделен в навигацииchart-legend — всегда включайте легенду или метки для многосерийных данныхchart-tooltips — используйте тултипы для отображения точных значений при наведении/касанииaccessible-colors — цвета графиков должны работать для дальтоников; используйте паттерны/формы в дополнение к цветуresponsive-charts — графики должны корректно изменять размер; на мобильных показывайте упрощённый видИнтегрируется с shadcn/ui MCP для поиска компонентов и получения примеров.