Smithery Logo
MCPsSkillsDocsPricing
Login
Smithery Logo

Accelerating the Agent Economy

Resources

DocumentationPrivacy PolicySystem Status

Company

PricingAboutBlog

Connect

© 2026 Smithery. All rights reserved.

    dagba

    swiftui-liquid-glass

    dagba/swiftui-liquid-glass
    Design
    3

    About

    SKILL.md

    Install

    Install via Skills CLI

    or add to your agent
    • Claude Code
      Claude Code
    • Codex
      Codex
    • OpenClaw
      OpenClaw
    • Cursor
      Cursor
    • Amp
      Amp
    • GitHub Copilot
      GitHub Copilot
    • Gemini CLI
      Gemini CLI
    • Kilo Code
      Kilo Code
    • Junie
      Junie
    • Replit
      Replit
    • Windsurf
      Windsurf
    • Cline
      Cline
    • Continue
      Continue
    • OpenCode
      OpenCode
    • OpenHands
      OpenHands
    • Roo Code
      Roo Code
    • Augment
      Augment
    • Goose
      Goose
    • Trae
      Trae
    • Zencoder
      Zencoder
    • Antigravity
      Antigravity
    ├─
    ├─
    └─

    About

    Implement, review, or improve SwiftUI features using the iOS 26+ Liquid Glass API...

    SKILL.md

    SwiftUI Liquid Glass

    Overview

    Use this skill to build or review SwiftUI features that fully align with the iOS 26+ Liquid Glass API. Prioritize native APIs (glassEffect, GlassEffectContainer, glass button styles) and Apple design guidance. Keep usage consistent, interactive where needed, and performance aware.

    Workflow Decision Tree

    Choose the path that matches the request:

    1) Review an existing feature

    • Inspect where Liquid Glass should be used and where it should not.
    • Verify correct modifier order, shape usage, and container placement.
    • Check for iOS 26+ availability handling and sensible fallbacks.

    2) Improve a feature using Liquid Glass

    • Identify target components for glass treatment (surfaces, chips, buttons, cards).
    • Refactor to use GlassEffectContainer where multiple glass elements appear.
    • Introduce interactive glass only for tappable or focusable elements.

    3) Implement a new feature using Liquid Glass

    • Design the glass surfaces and interactions first (shape, prominence, grouping).
    • Add glass modifiers after layout/appearance modifiers.
    • Add morphing transitions only when the view hierarchy changes with animation.

    Core Guidelines

    • Prefer native Liquid Glass APIs over custom blurs.
    • Use GlassEffectContainer when multiple glass elements coexist.
    • Apply .glassEffect(...) after layout and visual modifiers.
    • Use .interactive() for elements that respond to touch/pointer.
    • Keep shapes consistent across related elements for a cohesive look.
    • Gate with #available(iOS 26, *) and provide a non-glass fallback.

    Review Checklist

    • Availability: #available(iOS 26, *) present with fallback UI.
    • Composition: Multiple glass views wrapped in GlassEffectContainer.
    • Modifier order: glassEffect applied after layout/appearance modifiers.
    • Interactivity: interactive() only where user interaction exists.
    • Transitions: glassEffectID used with @Namespace for morphing.
    • Consistency: Shapes, tinting, and spacing align across the feature.

    Implementation Checklist

    • Define target elements and desired glass prominence.
    • Wrap grouped glass elements in GlassEffectContainer and tune spacing.
    • Use .glassEffect(.regular.tint(...).interactive(), in: .rect(cornerRadius: ...)) as needed.
    • Use .buttonStyle(.glass) / .buttonStyle(.glassProminent) for actions.
    • Add morphing transitions with glassEffectID when hierarchy changes.
    • Provide fallback materials and visuals for earlier iOS versions.

    Quick Snippets

    Use these patterns directly and tailor shapes/tints/spacing.

    if #available(iOS 26, *) {
        Text("Hello")
            .padding()
            .glassEffect(.regular.interactive(), in: .rect(cornerRadius: 16))
    } else {
        Text("Hello")
            .padding()
            .background(.ultraThinMaterial, in: RoundedRectangle(cornerRadius: 16))
    }
    
    GlassEffectContainer(spacing: 24) {
        HStack(spacing: 24) {
            Image(systemName: "scribble.variable")
                .frame(width: 72, height: 72)
                .font(.system(size: 32))
                .glassEffect()
            Image(systemName: "eraser.fill")
                .frame(width: 72, height: 72)
                .font(.system(size: 32))
                .glassEffect()
        }
    }
    
    Button("Confirm") { }
        .buttonStyle(.glassProminent)
    

    Resources

    Official Apple Documentation:

    • references/SwiftUI-Implementing-Liquid-Glass-Design.md - Official SwiftUI Liquid Glass implementation guide
    • references/AppKit-Implementing-Liquid-Glass-Design.md - AppKit Liquid Glass patterns
    • references/UIKit-Implementing-Liquid-Glass-Design.md - UIKit Liquid Glass patterns
    • references/WidgetKit-Implementing-Liquid-Glass-Design.md - WidgetKit Liquid Glass integration

    Community References:

    • Reference guide: references/liquid-glass.md - Community patterns and examples

    Prefer official Apple docs for the most up-to-date API details and design guidance.

    Recommended Servers
    Vercel Grep
    Vercel Grep
    WorkOS
    WorkOS
    Gemini
    Gemini
    Repository
    dagba/ios-mcp
    Files