Design Frontend Quickshell QML

VérifiéSûr

Créez des widgets QML de production sophistiqués pour Quickshell avec une esthétique distinctive. Spécialisé dans l'intégration thématique, la réutilisation de composants et le design sans généricité IA.

Spar Skills Guide Bot
DeveloppementIntermédiaire
3002/06/2026
Claude Code
#frontend#qml#quickshell#ui-design#widget

Recommandé pour

Notre avis

Ce guide aide à créer des widgets QML de haute qualité pour Quickshell, en combinant une expertise technique et un design esthétique poussé, spécifiquement pour la configuration '@quickshell'.

Points forts

  • Utilisation rigoureuse des composants et thèmes existants pour une intégration native.
  • Accent sur des principes de design forts (minimalisme brutal, luxe raffiné, etc.).
  • Support des animations et transitions fluides via Behavior et Easing.
  • Consignes claires pour éviter les designs génériques et adopter une identité visuelle cohérente.

Limites

  • Spécifique à l'environnement Quickshell et à la configuration 'Obelisk' ; non applicable directement à d'autres frameworks.
  • Nécessite une connaissance préalable de QML et du projet Quickshell.
  • Peut être restrictif si l'on souhaite sortir du cadre thématique défini.
Quand l'utiliser

Lors de la création de nouveaux widgets ou interfaces pour le shell Quickshell, en particulier dans le cadre d'une personnalisation avancée de l'environnement de bureau.

Quand l'éviter

Pour des projets UI génériques (web, mobile) ou des environnements ne reposant pas sur Quickshell et ses composants.

Analyse de sécurité

Sûr
Score qualité92/100

This skill provides design and coding guidance for QML interfaces using local tools. It does not execute any commands, access network resources, or handle sensitive data. No destructive or exfiltration risks are present.

Aucun point d'attention détecté

Exemples

System Monitor Widget
Create a system monitor widget showing CPU, RAM, and network usage for the Quickshell Obelisk shell. Use the Theme singleton for colors and components like OText and OPanel. Include animated bars with Behavior transitions.
Custom Clock Widget
Design a unique digital clock widget for Quickshell that displays the date and time with a retro-futuristic aesthetic. Use the Theme.fontFamily and animate the colon blink with QtQuick animations.
Weather Widget
Build a weather widget for Quickshell that fetches data from a service and displays the current temperature and conditions. Integrate with the existing Services singleton and use IconButton for a refresh button.

<!-- 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