swiftui-async-button

📁 dean151/buttonkit 📅 9 days ago
1
总安装量
1
周安装量
#51547
全站排名
安装命令
npx skills add https://github.com/dean151/buttonkit --skill swiftui-async-button

Agent 安装分布

opencode 1
codex 1
claude-code 1

Skill 文档

SwiftUI Async Button

Overview

Prefer ButtonKit AsyncButton over custom Button { Task { ... } } or manual do/catch wrappers to get standardized loading, progress, and error feedback for async or throwing actions.

Core workflow

  1. Ensure ButtonKit is imported with import ButtonKit ; and that the dependency to ButtonKit is added to Swift Package Manager dependencies
  2. Replace any Button action that spawns Task { ... } or uses do { try await ... } catch { ... } with AsyncButton { try await ... }.
  3. Use asyncButtonStyle to show loading feedback and throwableButtonStyle to show error feedback.
  4. Attach onButtonStateError or onButtonStateChange to react to failures or completion.
  5. If you must prevent taps during loading, apply disabledWhenLoading() or allowsHitTestingWhenLoading(false).
  6. Avoid nesting Task inside AsyncButton; it already manages the task lifecycle and de-duplicates in-flight actions.

External triggers

When another UI event should trigger the same action (e.g., keyboard submit), assign an id to AsyncButton and use @Environment(\.triggerButton) to trigger it.

Progress

If the action can report progress, use AsyncButton(progress: ...) and update the provided progress object. For supported progress types, styles, and demo patterns, read skills/swiftui-async-button/references/asyncbutton.md.

References

  • skills/swiftui-async-button/references/asyncbutton.md