Conception d'Interface Quickshell (QML)

VérifiéSûr

Créez des widgets QML haute qualité et distinctifs pour Quickshell. Maîtrisez l'intégration native, le thèming avancé et l'esthétique polished en évitant les designs génériques d'IA.

Spar Skills Guide Bot
DeveloppementIntermédiaire
2002/06/2026
Claude Code
#quickshell#qml#desktop-ui#theming#widget-design

Recommandé pour

Notre avis

Cette compétence guide la création d'interfaces QML de qualité professionnelle pour Quickshell, en mettant l'accent sur le design esthétique et le respect strict des tokens de thème et des composants du shell Obelisk.

Points forts

  • Fournit une direction esthétique audacieuse et intentionnelle pour éviter les interfaces génériques.
  • Impose l'utilisation rigoureuse des tokens de thème et des composants existants pour une cohérence parfaite.
  • Inclut des techniques avancées de motion, d'ombre et de dégradés pour un rendu soigné.
  • Offre des patrons de code concrets et une structure de module claire.

Limites

  • Fonctionne uniquement dans l'écosystème Quickshell/Obelisk, pas pour des projets génériques.
  • Nécessite une connaissance préalable de QML et du système de thème spécifique.
  • Certaines directions de design peuvent être subjectives et ne pas convenir à tous les cas d'usage.
Quand l'utiliser

Utilisez cette compétence lors de la création ou de la personnalisation de widgets pour un environnement de bureau Quickshell nécessitant une identité visuelle cohérente, soignée et distinctive.

Quand l'éviter

N'utilisez pas cette compétence pour le développement d'interfaces web ou mobiles génériques, ou lorsque le projet n'utilise pas Quickshell et son système de tokens de thème.

Analyse de sécurité

Sûr
Score qualité88/100

The skill is a design guide for QML interfaces with no executable code or dangerous instructions. It does not interact with system commands or external services.

Aucun point d'attention détecté

Exemples

System Monitor Widget
Create a new system monitor widget for my Quickshell desktop that shows CPU, memory, and network usage using the existing OPanel and OText components, styled with the Obelisk theme colors.
Music Player Control Panel
Design a stylish music player control panel for Quickshell that uses the Theme tokens and includes smooth animations for track changes.
Battery Indicator with Gradient Border
Add a battery indicator widget to the Quickshell bar that shows percentage and charging status, with a gradient border using Canvas and the Theme.critical color for low battery.

<!-- markdownlint-disable MD041 -->

name: frontend-design description: Create distinctive, production-grade Quickshell (QML) widgets and interfaces for the user's desktop environment. Specialized for the @quickshell configuration, using existing components, theme tokens, and services. Generates creative, polished code and UI design that avoids generic AI aesthetics. license: Complete terms in LICENSE.txt


Frontend Design Skill

This skill guides the creation of high-quality QML interfaces for Quickshell, specifically tailored to the @quickshell/.config/quickshell/ configuration. It combines technical Quickshell expertise with high-end aesthetic design thinking.

Design Thinking

Before coding, commit to a BOLD aesthetic direction that fits the "Obelisk" shell but pushes it further:

  • Tone: Pick a flavor: brutally minimal, retro-futuristic, refined luxury, industrial/utilitarian, or organic.
  • Differentiation: What is the one thing that makes this widget UNFORGETTABLE?
  • Intentionality: Bold maximalism and refined minimalism both work; the key is executing with precision.

Quickshell Design Principles

  • Native Integration: Widgets must look and feel like part of the existing "Obelisk" shell.
  • Theming: Rigorously use the Theme singleton (qs.Config) for all colors, sizes, radii, and fonts.
  • Reusability: Use existing components from qs.Components (OText, OButton, IconButton, OPanel) whenever possible.
  • Reactive: Bind properties to Services (qs.Services) for live data.

Technical Foundation

Always include necessary imports:

import QtQuick
import QtQuick.Layouts
import Quickshell
import Quickshell.Wayland
import qs.Config      // Theme, Settings
import qs.Components  // OText, OButton, OPanel, etc.
import qs.Services    // Core, SystemInfo, WM

Theming Guidelines (Theme.qml)

  • Backgrounds: Theme.bgColor, Theme.bgElevated, Theme.bgElevatedAlt
  • Accents: Theme.activeColor, Theme.onHoverColor, Theme.critical (red), Theme.warning (orange)
  • Text: Theme.textActiveColor, Theme.textInactiveColor
  • Spacing: Theme.spacingXs to Theme.spacingXl
  • Radii: Theme.itemRadius, Theme.radiusMd, Theme.radiusLg

Aesthetics & Polish

  • Typography: Stick to Theme.fontFamily (CaskaydiaCove) and Theme.iconFontFamily. Use OText variants for hierarchy.
  • Motion: Use Behavior on <property> with Theme.animationDuration and Easing.InOutQuad for all transitions. Focus on staggered reveals and smooth width/opacity changes.
  • Visual Details: Create depth. Use RectangularShadow or MultiEffect for subtle shadows. Use Canvas for custom gradient borders (see CardStyling.qml).
  • Avoid "AI Slop": No predictable layouts or generic "purple on white" color schemes. Stay true to the project's Catppuccin/Dracula/Obelisk color palettes.

Component Usage

  • OText: OText { text: "Label"; bold: true; muted: true }
  • IconButton: For circular icon-only buttons.
  • OPanel: For dropdowns/menus. Always provide a unique panelNamespace.
  • ExpandingPill: Use for collapsible groups of buttons (like PowerMenu or Workspaces).

New Modules

When creating a new widget:

  1. Place it in Modules/<Category>/<Name>.qml.
  2. Use pragma ComponentBehavior: Bound.
  3. Example Pattern:
pragma ComponentBehavior: Bound
import QtQuick
import QtQuick.Layouts
import qs.Config
import qs.Components

Rectangle {
    color: Theme.bgElevated
    radius: Theme.itemRadius
    border.color: Theme.borderLight
    border.width: 1

    ColumnLayout {
        anchors.fill: parent
        anchors.margins: Theme.spacingMd
        spacing: Theme.spacingSm

        OText {
            text: "Widget Title"
            bold: true
            size: "lg"
        }
        // ... content
    }
}
Skills similaires