codexkit 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.codex/.env.example +27 -0
- package/.codex/.template-manifest.json +631 -0
- package/.codex/.version +1 -0
- package/.codex/agents/builder.toml +104 -0
- package/.codex/agents/debugger.toml +67 -0
- package/.codex/agents/general.toml +41 -0
- package/.codex/agents/painter.toml +40 -0
- package/.codex/agents/planner.toml +60 -0
- package/.codex/agents/refactorer.toml +76 -0
- package/.codex/agents/reviewer.toml +60 -0
- package/.codex/agents/runner.toml +40 -0
- package/.codex/agents/scout.toml +133 -0
- package/.codex/agents/shipper.toml +69 -0
- package/.codex/agents/vision.toml +69 -0
- package/.codex/config.toml +146 -0
- package/.codex/context/architecture.md +66 -0
- package/.codex/context/conventions.md +98 -0
- package/.codex/context/current-priorities.md +33 -0
- package/.codex/context/decision-log.md +93 -0
- package/.codex/context/gotchas.md +42 -0
- package/.codex/context/index.md +21 -0
- package/.codex/context/session-context.md +11 -0
- package/.codex/context/worklog.md +9 -0
- package/.codex/hooks/README.md +17 -0
- package/.codex/hooks/after_agent.sh +11 -0
- package/.codex/hooks/after_tool_use.sh +10 -0
- package/.codex/hooks/post_commit.sh +10 -0
- package/.codex/hooks/pre_commit.sh +6 -0
- package/.codex/hooks/session_start.sh +18 -0
- package/.codex/hooks/stop.sh +10 -0
- package/.codex/mcp/README.md +143 -0
- package/.codex/mcp/basic-memory.toml.example +10 -0
- package/.codex/mcp/context7.toml.example +13 -0
- package/.codex/mcp/exa.toml.example +12 -0
- package/.codex/mcp/memory-bridge.toml.example +15 -0
- package/.codex/mcp/memory.toml.example +6 -0
- package/.codex/mcp/ref.toml.example +13 -0
- package/.codex/mcp/tilth.toml.example +10 -0
- package/.codex/memory/README.md +29 -0
- package/.codex/memory/_templates/README.md +26 -0
- package/.codex/memory/_templates/design.md +15 -0
- package/.codex/memory/_templates/gotcha.md +9 -0
- package/.codex/memory/_templates/handoff.md +9 -0
- package/.codex/memory/_templates/prd.md +13 -0
- package/.codex/memory/_templates/project.md +9 -0
- package/.codex/memory/_templates/proposal.md +13 -0
- package/.codex/memory/_templates/research.md +9 -0
- package/.codex/memory/_templates/roadmap.md +11 -0
- package/.codex/memory/_templates/session-context.md +7 -0
- package/.codex/memory/_templates/state.md +11 -0
- package/.codex/memory/_templates/tasks.md +9 -0
- package/.codex/memory/_templates/tech-stack.md +9 -0
- package/.codex/memory/_templates/user.md +7 -0
- package/.codex/memory/project/gotchas.md +5 -0
- package/.codex/memory/project/project.md +12 -0
- package/.codex/memory/project/roadmap.md +15 -0
- package/.codex/memory/project/state.md +22 -0
- package/.codex/memory/project/tech-stack.md +19 -0
- package/.codex/memory/project/user.md +10 -0
- package/.codex/memory/research/.gitkeep +1 -0
- package/.codex/memory/session-context.md +18 -0
- package/.codex/plans/README.md +7 -0
- package/.codex/prompts/compound.md +154 -0
- package/.codex/prompts/create.md +238 -0
- package/.codex/prompts/design.md +90 -0
- package/.codex/prompts/handoff.md +184 -0
- package/.codex/prompts/init-context.md +185 -0
- package/.codex/prompts/init-user.md +93 -0
- package/.codex/prompts/init.md +103 -0
- package/.codex/prompts/lfg.md +140 -0
- package/.codex/prompts/plan.md +140 -0
- package/.codex/prompts/pr.md +150 -0
- package/.codex/prompts/research.md +137 -0
- package/.codex/prompts/resume.md +105 -0
- package/.codex/prompts/review-codebase.md +147 -0
- package/.codex/prompts/ship.md +334 -0
- package/.codex/prompts/start.md +141 -0
- package/.codex/prompts/status.md +102 -0
- package/.codex/prompts/ui-inspire.md +151 -0
- package/.codex/prompts/ui-review.md +86 -0
- package/.codex/prompts/verify.md +181 -0
- package/.codex/scripts/append_worklog.sh +20 -0
- package/.codex/scripts/apply_worklog_archive.sh +48 -0
- package/.codex/scripts/audit_memory_hygiene.sh +102 -0
- package/.codex/scripts/build_memory_index.sh +167 -0
- package/.codex/scripts/build_prior_related_work.sh +127 -0
- package/.codex/scripts/build_startup_brief.sh +52 -0
- package/.codex/scripts/close_bead.sh +103 -0
- package/.codex/scripts/detect_changed_files.sh +38 -0
- package/.codex/scripts/ensure_beads.sh +14 -0
- package/.codex/scripts/memory_search.sh +292 -0
- package/.codex/scripts/prepare_worklog_archive.sh +115 -0
- package/.codex/scripts/search_bead_context.sh +214 -0
- package/.codex/scripts/start_bead.sh +129 -0
- package/.codex/scripts/sync_bead_context.sh +288 -0
- package/.codex/scripts/validate_memory_docs.sh +44 -0
- package/.codex/scripts/verify_bead.sh +154 -0
- package/.codex/skills/accessibility-audit/SKILL.md +191 -0
- package/.codex/skills/agent-browser/SKILL.md +413 -0
- package/.codex/skills/agent-teams/SKILL.md +268 -0
- package/.codex/skills/augment-context-engine/SKILL.md +115 -0
- package/.codex/skills/augment-context-engine/mcp.json +6 -0
- package/.codex/skills/beads/SKILL.md +181 -0
- package/.codex/skills/beads/references/BEST_PRACTICES.md +27 -0
- package/.codex/skills/beads/references/BOUNDARIES.md +219 -0
- package/.codex/skills/beads/references/DEPENDENCIES.md +124 -0
- package/.codex/skills/beads/references/EXAMPLES.md +45 -0
- package/.codex/skills/beads/references/FILE_CLAIMING.md +101 -0
- package/.codex/skills/beads/references/GIT_SYNC.md +25 -0
- package/.codex/skills/beads/references/HIERARCHY.md +71 -0
- package/.codex/skills/beads/references/MULTI_AGENT.md +40 -0
- package/.codex/skills/beads/references/RESUMABILITY.md +177 -0
- package/.codex/skills/beads/references/SESSION_PROTOCOL.md +61 -0
- package/.codex/skills/beads/references/TASK_CREATION.md +38 -0
- package/.codex/skills/beads/references/TROUBLESHOOTING.md +38 -0
- package/.codex/skills/beads/references/WORKFLOWS.md +226 -0
- package/.codex/skills/beads-bridge/SKILL.md +321 -0
- package/.codex/skills/brainstorming/SKILL.md +114 -0
- package/.codex/skills/bug-triage/SKILL.md +191 -0
- package/.codex/skills/chrome-devtools/SKILL.md +76 -0
- package/.codex/skills/chrome-devtools/mcp.json +19 -0
- package/.codex/skills/cloudflare/SKILL.md +253 -0
- package/.codex/skills/cloudflare/references/agents-sdk/README.md +35 -0
- package/.codex/skills/cloudflare/references/agents-sdk/api.md +100 -0
- package/.codex/skills/cloudflare/references/agents-sdk/configuration.md +99 -0
- package/.codex/skills/cloudflare/references/agents-sdk/gotchas.md +59 -0
- package/.codex/skills/cloudflare/references/agents-sdk/patterns.md +89 -0
- package/.codex/skills/cloudflare/references/ai-gateway/README.md +695 -0
- package/.codex/skills/cloudflare/references/ai-search/README.md +14 -0
- package/.codex/skills/cloudflare/references/ai-search/api.md +38 -0
- package/.codex/skills/cloudflare/references/ai-search/configuration.md +52 -0
- package/.codex/skills/cloudflare/references/ai-search/gotchas.md +41 -0
- package/.codex/skills/cloudflare/references/ai-search/patterns.md +45 -0
- package/.codex/skills/cloudflare/references/analytics-engine/README.md +14 -0
- package/.codex/skills/cloudflare/references/analytics-engine/api.md +27 -0
- package/.codex/skills/cloudflare/references/analytics-engine/configuration.md +45 -0
- package/.codex/skills/cloudflare/references/analytics-engine/gotchas.md +3 -0
- package/.codex/skills/cloudflare/references/analytics-engine/patterns.md +36 -0
- package/.codex/skills/cloudflare/references/api/README.md +21 -0
- package/.codex/skills/cloudflare/references/api/api.md +31 -0
- package/.codex/skills/cloudflare/references/api/configuration.md +20 -0
- package/.codex/skills/cloudflare/references/api/gotchas.md +28 -0
- package/.codex/skills/cloudflare/references/api/patterns.md +47 -0
- package/.codex/skills/cloudflare/references/api-shield/README.md +20 -0
- package/.codex/skills/cloudflare/references/api-shield/api.md +78 -0
- package/.codex/skills/cloudflare/references/api-shield/configuration.md +128 -0
- package/.codex/skills/cloudflare/references/api-shield/gotchas.md +51 -0
- package/.codex/skills/cloudflare/references/api-shield/patterns.md +145 -0
- package/.codex/skills/cloudflare/references/argo-smart-routing/README.md +16 -0
- package/.codex/skills/cloudflare/references/argo-smart-routing/api.md +50 -0
- package/.codex/skills/cloudflare/references/argo-smart-routing/configuration.md +53 -0
- package/.codex/skills/cloudflare/references/argo-smart-routing/gotchas.md +16 -0
- package/.codex/skills/cloudflare/references/argo-smart-routing/patterns.md +45 -0
- package/.codex/skills/cloudflare/references/bindings/README.md +14 -0
- package/.codex/skills/cloudflare/references/bindings/api.md +3 -0
- package/.codex/skills/cloudflare/references/bindings/configuration.md +58 -0
- package/.codex/skills/cloudflare/references/bindings/gotchas.md +35 -0
- package/.codex/skills/cloudflare/references/bindings/patterns.md +37 -0
- package/.codex/skills/cloudflare/references/bot-management/README.md +71 -0
- package/.codex/skills/cloudflare/references/bot-management/api.md +168 -0
- package/.codex/skills/cloudflare/references/bot-management/configuration.md +114 -0
- package/.codex/skills/cloudflare/references/bot-management/gotchas.md +99 -0
- package/.codex/skills/cloudflare/references/bot-management/patterns.md +125 -0
- package/.codex/skills/cloudflare/references/browser-rendering/README.md +16 -0
- package/.codex/skills/cloudflare/references/browser-rendering/api.md +54 -0
- package/.codex/skills/cloudflare/references/browser-rendering/configuration.md +47 -0
- package/.codex/skills/cloudflare/references/browser-rendering/gotchas.md +29 -0
- package/.codex/skills/cloudflare/references/browser-rendering/patterns.md +29 -0
- package/.codex/skills/cloudflare/references/c3/README.md +264 -0
- package/.codex/skills/cloudflare/references/cache-reserve/README.md +93 -0
- package/.codex/skills/cloudflare/references/cache-reserve/api.md +176 -0
- package/.codex/skills/cloudflare/references/cache-reserve/configuration.md +164 -0
- package/.codex/skills/cloudflare/references/cache-reserve/gotchas.md +203 -0
- package/.codex/skills/cloudflare/references/cache-reserve/patterns.md +180 -0
- package/.codex/skills/cloudflare/references/containers/README.md +16 -0
- package/.codex/skills/cloudflare/references/containers/api.md +43 -0
- package/.codex/skills/cloudflare/references/containers/configuration.md +56 -0
- package/.codex/skills/cloudflare/references/containers/gotchas.md +21 -0
- package/.codex/skills/cloudflare/references/containers/patterns.md +40 -0
- package/.codex/skills/cloudflare/references/cron-triggers/README.md +85 -0
- package/.codex/skills/cloudflare/references/cron-triggers/api.md +198 -0
- package/.codex/skills/cloudflare/references/cron-triggers/configuration.md +151 -0
- package/.codex/skills/cloudflare/references/cron-triggers/gotchas.md +129 -0
- package/.codex/skills/cloudflare/references/cron-triggers/patterns.md +122 -0
- package/.codex/skills/cloudflare/references/d1/README.md +92 -0
- package/.codex/skills/cloudflare/references/d1/api.md +141 -0
- package/.codex/skills/cloudflare/references/d1/configuration.md +127 -0
- package/.codex/skills/cloudflare/references/d1/gotchas.md +70 -0
- package/.codex/skills/cloudflare/references/d1/patterns.md +144 -0
- package/.codex/skills/cloudflare/references/ddos/README.md +34 -0
- package/.codex/skills/cloudflare/references/ddos/api.md +136 -0
- package/.codex/skills/cloudflare/references/ddos/configuration.md +67 -0
- package/.codex/skills/cloudflare/references/ddos/gotchas.md +114 -0
- package/.codex/skills/cloudflare/references/ddos/patterns.md +158 -0
- package/.codex/skills/cloudflare/references/do-storage/README.md +62 -0
- package/.codex/skills/cloudflare/references/do-storage/api.md +89 -0
- package/.codex/skills/cloudflare/references/do-storage/configuration.md +116 -0
- package/.codex/skills/cloudflare/references/do-storage/gotchas.md +93 -0
- package/.codex/skills/cloudflare/references/do-storage/patterns.md +112 -0
- package/.codex/skills/cloudflare/references/durable-objects/README.md +125 -0
- package/.codex/skills/cloudflare/references/durable-objects/api.md +152 -0
- package/.codex/skills/cloudflare/references/durable-objects/configuration.md +148 -0
- package/.codex/skills/cloudflare/references/durable-objects/gotchas.md +158 -0
- package/.codex/skills/cloudflare/references/durable-objects/patterns.md +255 -0
- package/.codex/skills/cloudflare/references/email-routing/README.md +18 -0
- package/.codex/skills/cloudflare/references/email-routing/api.md +46 -0
- package/.codex/skills/cloudflare/references/email-routing/configuration.md +63 -0
- package/.codex/skills/cloudflare/references/email-routing/gotchas.md +16 -0
- package/.codex/skills/cloudflare/references/email-routing/patterns.md +46 -0
- package/.codex/skills/cloudflare/references/email-workers/README.md +598 -0
- package/.codex/skills/cloudflare/references/hyperdrive/README.md +62 -0
- package/.codex/skills/cloudflare/references/hyperdrive/api.md +137 -0
- package/.codex/skills/cloudflare/references/hyperdrive/configuration.md +133 -0
- package/.codex/skills/cloudflare/references/hyperdrive/gotchas.md +184 -0
- package/.codex/skills/cloudflare/references/hyperdrive/patterns.md +176 -0
- package/.codex/skills/cloudflare/references/images/README.md +14 -0
- package/.codex/skills/cloudflare/references/images/api.md +3 -0
- package/.codex/skills/cloudflare/references/images/configuration.md +45 -0
- package/.codex/skills/cloudflare/references/images/gotchas.md +23 -0
- package/.codex/skills/cloudflare/references/images/patterns.md +31 -0
- package/.codex/skills/cloudflare/references/kv/README.md +60 -0
- package/.codex/skills/cloudflare/references/kv/api.md +114 -0
- package/.codex/skills/cloudflare/references/kv/configuration.md +92 -0
- package/.codex/skills/cloudflare/references/kv/gotchas.md +117 -0
- package/.codex/skills/cloudflare/references/kv/patterns.md +139 -0
- package/.codex/skills/cloudflare/references/miniflare/README.md +64 -0
- package/.codex/skills/cloudflare/references/miniflare/api.md +144 -0
- package/.codex/skills/cloudflare/references/miniflare/configuration.md +203 -0
- package/.codex/skills/cloudflare/references/miniflare/gotchas.md +187 -0
- package/.codex/skills/cloudflare/references/miniflare/patterns.md +211 -0
- package/.codex/skills/cloudflare/references/network-interconnect/README.md +60 -0
- package/.codex/skills/cloudflare/references/network-interconnect/api.md +240 -0
- package/.codex/skills/cloudflare/references/network-interconnect/configuration.md +127 -0
- package/.codex/skills/cloudflare/references/network-interconnect/gotchas.md +171 -0
- package/.codex/skills/cloudflare/references/network-interconnect/patterns.md +171 -0
- package/.codex/skills/cloudflare/references/observability/README.md +18 -0
- package/.codex/skills/cloudflare/references/observability/api.md +51 -0
- package/.codex/skills/cloudflare/references/observability/configuration.md +60 -0
- package/.codex/skills/cloudflare/references/observability/gotchas.md +36 -0
- package/.codex/skills/cloudflare/references/observability/patterns.md +42 -0
- package/.codex/skills/cloudflare/references/pages/README.md +76 -0
- package/.codex/skills/cloudflare/references/pages/api.md +200 -0
- package/.codex/skills/cloudflare/references/pages/configuration.md +228 -0
- package/.codex/skills/cloudflare/references/pages/gotchas.md +161 -0
- package/.codex/skills/cloudflare/references/pages/patterns.md +145 -0
- package/.codex/skills/cloudflare/references/pages-functions/README.md +57 -0
- package/.codex/skills/cloudflare/references/pages-functions/api.md +201 -0
- package/.codex/skills/cloudflare/references/pages-functions/configuration.md +159 -0
- package/.codex/skills/cloudflare/references/pages-functions/gotchas.md +151 -0
- package/.codex/skills/cloudflare/references/pages-functions/patterns.md +190 -0
- package/.codex/skills/cloudflare/references/pipelines/README.md +664 -0
- package/.codex/skills/cloudflare/references/pulumi/README.md +107 -0
- package/.codex/skills/cloudflare/references/pulumi/api.md +194 -0
- package/.codex/skills/cloudflare/references/pulumi/configuration.md +216 -0
- package/.codex/skills/cloudflare/references/pulumi/gotchas.md +223 -0
- package/.codex/skills/cloudflare/references/pulumi/patterns.md +139 -0
- package/.codex/skills/cloudflare/references/queues/README.md +69 -0
- package/.codex/skills/cloudflare/references/queues/api.md +138 -0
- package/.codex/skills/cloudflare/references/queues/configuration.md +125 -0
- package/.codex/skills/cloudflare/references/queues/gotchas.md +112 -0
- package/.codex/skills/cloudflare/references/queues/patterns.md +155 -0
- package/.codex/skills/cloudflare/references/r2/README.md +61 -0
- package/.codex/skills/cloudflare/references/r2/api.md +127 -0
- package/.codex/skills/cloudflare/references/r2/configuration.md +76 -0
- package/.codex/skills/cloudflare/references/r2/gotchas.md +94 -0
- package/.codex/skills/cloudflare/references/r2/patterns.md +127 -0
- package/.codex/skills/cloudflare/references/r2-data-catalog/README.md +18 -0
- package/.codex/skills/cloudflare/references/r2-data-catalog/api.md +29 -0
- package/.codex/skills/cloudflare/references/r2-data-catalog/configuration.md +39 -0
- package/.codex/skills/cloudflare/references/r2-data-catalog/gotchas.md +20 -0
- package/.codex/skills/cloudflare/references/r2-data-catalog/patterns.md +46 -0
- package/.codex/skills/cloudflare/references/r2-sql/README.md +512 -0
- package/.codex/skills/cloudflare/references/realtime-sfu/README.md +21 -0
- package/.codex/skills/cloudflare/references/realtime-sfu/api.md +135 -0
- package/.codex/skills/cloudflare/references/realtime-sfu/configuration.md +63 -0
- package/.codex/skills/cloudflare/references/realtime-sfu/gotchas.md +75 -0
- package/.codex/skills/cloudflare/references/realtime-sfu/patterns.md +102 -0
- package/.codex/skills/cloudflare/references/realtimekit/README.md +81 -0
- package/.codex/skills/cloudflare/references/realtimekit/api.md +164 -0
- package/.codex/skills/cloudflare/references/realtimekit/configuration.md +147 -0
- package/.codex/skills/cloudflare/references/realtimekit/gotchas.md +172 -0
- package/.codex/skills/cloudflare/references/realtimekit/patterns.md +155 -0
- package/.codex/skills/cloudflare/references/sandbox/README.md +90 -0
- package/.codex/skills/cloudflare/references/sandbox/api.md +178 -0
- package/.codex/skills/cloudflare/references/sandbox/configuration.md +131 -0
- package/.codex/skills/cloudflare/references/sandbox/gotchas.md +156 -0
- package/.codex/skills/cloudflare/references/sandbox/patterns.md +203 -0
- package/.codex/skills/cloudflare/references/secrets-store/README.md +58 -0
- package/.codex/skills/cloudflare/references/secrets-store/api.md +182 -0
- package/.codex/skills/cloudflare/references/secrets-store/configuration.md +140 -0
- package/.codex/skills/cloudflare/references/secrets-store/gotchas.md +129 -0
- package/.codex/skills/cloudflare/references/secrets-store/patterns.md +218 -0
- package/.codex/skills/cloudflare/references/smart-placement/README.md +91 -0
- package/.codex/skills/cloudflare/references/smart-placement/api.md +139 -0
- package/.codex/skills/cloudflare/references/smart-placement/configuration.md +129 -0
- package/.codex/skills/cloudflare/references/smart-placement/gotchas.md +87 -0
- package/.codex/skills/cloudflare/references/smart-placement/patterns.md +135 -0
- package/.codex/skills/cloudflare/references/snippets/README.md +15 -0
- package/.codex/skills/cloudflare/references/snippets/api.md +47 -0
- package/.codex/skills/cloudflare/references/snippets/configuration.md +33 -0
- package/.codex/skills/cloudflare/references/snippets/gotchas.md +21 -0
- package/.codex/skills/cloudflare/references/snippets/patterns.md +34 -0
- package/.codex/skills/cloudflare/references/spectrum/README.md +16 -0
- package/.codex/skills/cloudflare/references/spectrum/api.md +24 -0
- package/.codex/skills/cloudflare/references/spectrum/configuration.md +43 -0
- package/.codex/skills/cloudflare/references/spectrum/gotchas.md +42 -0
- package/.codex/skills/cloudflare/references/spectrum/patterns.md +40 -0
- package/.codex/skills/cloudflare/references/static-assets/README.md +14 -0
- package/.codex/skills/cloudflare/references/static-assets/api.md +3 -0
- package/.codex/skills/cloudflare/references/static-assets/configuration.md +47 -0
- package/.codex/skills/cloudflare/references/static-assets/gotchas.md +44 -0
- package/.codex/skills/cloudflare/references/static-assets/patterns.md +42 -0
- package/.codex/skills/cloudflare/references/stream/README.md +103 -0
- package/.codex/skills/cloudflare/references/stream/api.md +204 -0
- package/.codex/skills/cloudflare/references/stream/configuration.md +127 -0
- package/.codex/skills/cloudflare/references/stream/gotchas.md +131 -0
- package/.codex/skills/cloudflare/references/stream/patterns.md +152 -0
- package/.codex/skills/cloudflare/references/tail-workers/README.md +640 -0
- package/.codex/skills/cloudflare/references/terraform/README.md +76 -0
- package/.codex/skills/cloudflare/references/terraform/api.md +159 -0
- package/.codex/skills/cloudflare/references/terraform/configuration.md +156 -0
- package/.codex/skills/cloudflare/references/terraform/gotchas.md +207 -0
- package/.codex/skills/cloudflare/references/terraform/patterns.md +135 -0
- package/.codex/skills/cloudflare/references/tunnel/README.md +82 -0
- package/.codex/skills/cloudflare/references/tunnel/api.md +105 -0
- package/.codex/skills/cloudflare/references/tunnel/configuration.md +113 -0
- package/.codex/skills/cloudflare/references/tunnel/gotchas.md +115 -0
- package/.codex/skills/cloudflare/references/tunnel/patterns.md +157 -0
- package/.codex/skills/cloudflare/references/turn/README.md +699 -0
- package/.codex/skills/cloudflare/references/turnstile/README.md +14 -0
- package/.codex/skills/cloudflare/references/turnstile/api.md +3 -0
- package/.codex/skills/cloudflare/references/turnstile/configuration.md +19 -0
- package/.codex/skills/cloudflare/references/turnstile/gotchas.md +27 -0
- package/.codex/skills/cloudflare/references/turnstile/patterns.md +41 -0
- package/.codex/skills/cloudflare/references/vectorize/README.md +682 -0
- package/.codex/skills/cloudflare/references/waf/README.md +14 -0
- package/.codex/skills/cloudflare/references/waf/api.md +3 -0
- package/.codex/skills/cloudflare/references/waf/configuration.md +44 -0
- package/.codex/skills/cloudflare/references/waf/gotchas.md +24 -0
- package/.codex/skills/cloudflare/references/waf/patterns.md +29 -0
- package/.codex/skills/cloudflare/references/web-analytics/README.md +19 -0
- package/.codex/skills/cloudflare/references/web-analytics/api.md +52 -0
- package/.codex/skills/cloudflare/references/web-analytics/configuration.md +31 -0
- package/.codex/skills/cloudflare/references/web-analytics/gotchas.md +28 -0
- package/.codex/skills/cloudflare/references/web-analytics/patterns.md +52 -0
- package/.codex/skills/cloudflare/references/workerd/README.md +47 -0
- package/.codex/skills/cloudflare/references/workerd/api.md +199 -0
- package/.codex/skills/cloudflare/references/workerd/configuration.md +185 -0
- package/.codex/skills/cloudflare/references/workerd/gotchas.md +203 -0
- package/.codex/skills/cloudflare/references/workerd/patterns.md +216 -0
- package/.codex/skills/cloudflare/references/workers/README.md +96 -0
- package/.codex/skills/cloudflare/references/workers/api.md +137 -0
- package/.codex/skills/cloudflare/references/workers/configuration.md +147 -0
- package/.codex/skills/cloudflare/references/workers/gotchas.md +99 -0
- package/.codex/skills/cloudflare/references/workers/patterns.md +149 -0
- package/.codex/skills/cloudflare/references/workers-ai/README.md +116 -0
- package/.codex/skills/cloudflare/references/workers-for-platforms/README.md +48 -0
- package/.codex/skills/cloudflare/references/workers-for-platforms/api.md +169 -0
- package/.codex/skills/cloudflare/references/workers-for-platforms/configuration.md +136 -0
- package/.codex/skills/cloudflare/references/workers-for-platforms/gotchas.md +130 -0
- package/.codex/skills/cloudflare/references/workers-for-platforms/patterns.md +170 -0
- package/.codex/skills/cloudflare/references/workers-playground/README.md +16 -0
- package/.codex/skills/cloudflare/references/workers-playground/api.md +20 -0
- package/.codex/skills/cloudflare/references/workers-playground/configuration.md +3 -0
- package/.codex/skills/cloudflare/references/workers-playground/gotchas.md +35 -0
- package/.codex/skills/cloudflare/references/workers-playground/patterns.md +42 -0
- package/.codex/skills/cloudflare/references/workers-vpc/README.md +579 -0
- package/.codex/skills/cloudflare/references/workflows/README.md +62 -0
- package/.codex/skills/cloudflare/references/workflows/api.md +125 -0
- package/.codex/skills/cloudflare/references/workflows/configuration.md +177 -0
- package/.codex/skills/cloudflare/references/workflows/gotchas.md +136 -0
- package/.codex/skills/cloudflare/references/workflows/patterns.md +132 -0
- package/.codex/skills/cloudflare/references/wrangler/README.md +90 -0
- package/.codex/skills/cloudflare/references/wrangler/api.md +140 -0
- package/.codex/skills/cloudflare/references/wrangler/configuration.md +128 -0
- package/.codex/skills/cloudflare/references/wrangler/gotchas.md +93 -0
- package/.codex/skills/cloudflare/references/wrangler/patterns.md +150 -0
- package/.codex/skills/cloudflare/references/zaraz/README.md +360 -0
- package/.codex/skills/code-navigation/SKILL.md +130 -0
- package/.codex/skills/code-review/SKILL.md +208 -0
- package/.codex/skills/compaction/SKILL.md +317 -0
- package/.codex/skills/condition-based-waiting/SKILL.md +123 -0
- package/.codex/skills/condition-based-waiting/example.ts +158 -0
- package/.codex/skills/context-engineering/SKILL.md +176 -0
- package/.codex/skills/context-initialization/SKILL.md +70 -0
- package/.codex/skills/context-management/SKILL.md +163 -0
- package/.codex/skills/core-data-expert/SKILL.md +93 -0
- package/.codex/skills/core-data-expert/references/batch-operations.md +543 -0
- package/.codex/skills/core-data-expert/references/cloudkit-integration.md +259 -0
- package/.codex/skills/core-data-expert/references/concurrency.md +522 -0
- package/.codex/skills/core-data-expert/references/fetch-requests.md +643 -0
- package/.codex/skills/core-data-expert/references/glossary.md +233 -0
- package/.codex/skills/core-data-expert/references/migration.md +393 -0
- package/.codex/skills/core-data-expert/references/model-configuration.md +597 -0
- package/.codex/skills/core-data-expert/references/performance.md +300 -0
- package/.codex/skills/core-data-expert/references/persistent-history.md +553 -0
- package/.codex/skills/core-data-expert/references/project-audit.md +60 -0
- package/.codex/skills/core-data-expert/references/saving.md +574 -0
- package/.codex/skills/core-data-expert/references/stack-setup.md +625 -0
- package/.codex/skills/core-data-expert/references/testing.md +300 -0
- package/.codex/skills/core-data-expert/references/threading.md +589 -0
- package/.codex/skills/debugging/SKILL.md +203 -0
- package/.codex/skills/deep-research/SKILL.md +384 -0
- package/.codex/skills/defense-in-depth/SKILL.md +166 -0
- package/.codex/skills/dependency-upgrades/SKILL.md +198 -0
- package/.codex/skills/design-system-audit/SKILL.md +153 -0
- package/.codex/skills/development-lifecycle/SKILL.md +356 -0
- package/.codex/skills/dispatching-parallel-agents/SKILL.md +191 -0
- package/.codex/skills/docs-handoff/SKILL.md +175 -0
- package/.codex/skills/executing-plans/SKILL.md +247 -0
- package/.codex/skills/figma/SKILL.md +224 -0
- package/.codex/skills/figma/mcp.json +6 -0
- package/.codex/skills/finishing-a-development-branch/SKILL.md +357 -0
- package/.codex/skills/frontend-design/SKILL.md +176 -0
- package/.codex/skills/gemini-large-context/SKILL.md +216 -0
- package/.codex/skills/git-pr-prep/SKILL.md +179 -0
- package/.codex/skills/index-knowledge/SKILL.md +413 -0
- package/.codex/skills/jira/SKILL.md +283 -0
- package/.codex/skills/jira/mcp.json +6 -0
- package/.codex/skills/memory-system/SKILL.md +93 -0
- package/.codex/skills/mockup-to-code/SKILL.md +184 -0
- package/.codex/skills/mqdh/SKILL.md +171 -0
- package/.codex/skills/obsidian/SKILL.md +187 -0
- package/.codex/skills/obsidian/mcp.json +22 -0
- package/.codex/skills/opensrc/SKILL.md +127 -0
- package/.codex/skills/opensrc/references/architecture.md +176 -0
- package/.codex/skills/opensrc/references/cli-usage.md +176 -0
- package/.codex/skills/opensrc/references/registry-support.md +137 -0
- package/.codex/skills/pdf-extract/SKILL.md +438 -0
- package/.codex/skills/playwright/SKILL.md +320 -0
- package/.codex/skills/playwright/mcp.json +16 -0
- package/.codex/skills/playwriter/SKILL.md +158 -0
- package/.codex/skills/polar/SKILL.md +102 -0
- package/.codex/skills/prd/SKILL.md +146 -0
- package/.codex/skills/prd-task/SKILL.md +182 -0
- package/.codex/skills/prd-task/references/prd-schema.json +124 -0
- package/.codex/skills/prompt-leverage/SKILL.md +69 -0
- package/.codex/skills/prompt-leverage/agents/openai.yaml +4 -0
- package/.codex/skills/prompt-leverage/references/framework.md +91 -0
- package/.codex/skills/prompt-leverage/scripts/augment_prompt.py +114 -0
- package/.codex/skills/ralph/SKILL.md +296 -0
- package/.codex/skills/react-best-practices/AGENTS.md +2410 -0
- package/.codex/skills/react-best-practices/README.md +123 -0
- package/.codex/skills/react-best-practices/SKILL.md +133 -0
- package/.codex/skills/react-best-practices/metadata.json +15 -0
- package/.codex/skills/react-best-practices/rules/_sections.md +46 -0
- package/.codex/skills/react-best-practices/rules/_template.md +28 -0
- package/.codex/skills/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/.codex/skills/react-best-practices/rules/advanced-use-latest.md +49 -0
- package/.codex/skills/react-best-practices/rules/async-api-routes.md +38 -0
- package/.codex/skills/react-best-practices/rules/async-defer-await.md +80 -0
- package/.codex/skills/react-best-practices/rules/async-dependencies.md +36 -0
- package/.codex/skills/react-best-practices/rules/async-parallel.md +28 -0
- package/.codex/skills/react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/.codex/skills/react-best-practices/rules/bundle-barrel-imports.md +59 -0
- package/.codex/skills/react-best-practices/rules/bundle-conditional.md +31 -0
- package/.codex/skills/react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/.codex/skills/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/.codex/skills/react-best-practices/rules/bundle-preload.md +50 -0
- package/.codex/skills/react-best-practices/rules/client-event-listeners.md +74 -0
- package/.codex/skills/react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/.codex/skills/react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/.codex/skills/react-best-practices/rules/client-swr-dedup.md +56 -0
- package/.codex/skills/react-best-practices/rules/js-batch-dom-css.md +82 -0
- package/.codex/skills/react-best-practices/rules/js-cache-function-results.md +80 -0
- package/.codex/skills/react-best-practices/rules/js-cache-property-access.md +28 -0
- package/.codex/skills/react-best-practices/rules/js-cache-storage.md +70 -0
- package/.codex/skills/react-best-practices/rules/js-combine-iterations.md +32 -0
- package/.codex/skills/react-best-practices/rules/js-early-exit.md +50 -0
- package/.codex/skills/react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/.codex/skills/react-best-practices/rules/js-index-maps.md +37 -0
- package/.codex/skills/react-best-practices/rules/js-length-check-first.md +49 -0
- package/.codex/skills/react-best-practices/rules/js-min-max-loop.md +82 -0
- package/.codex/skills/react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/.codex/skills/react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/.codex/skills/react-best-practices/rules/rendering-activity.md +26 -0
- package/.codex/skills/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/.codex/skills/react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/.codex/skills/react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/.codex/skills/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/.codex/skills/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/.codex/skills/react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/.codex/skills/react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/.codex/skills/react-best-practices/rules/rerender-dependencies.md +45 -0
- package/.codex/skills/react-best-practices/rules/rerender-derived-state.md +29 -0
- package/.codex/skills/react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/.codex/skills/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/.codex/skills/react-best-practices/rules/rerender-memo.md +44 -0
- package/.codex/skills/react-best-practices/rules/rerender-transitions.md +40 -0
- package/.codex/skills/react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/.codex/skills/react-best-practices/rules/server-cache-lru.md +41 -0
- package/.codex/skills/react-best-practices/rules/server-cache-react.md +76 -0
- package/.codex/skills/react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/.codex/skills/react-best-practices/rules/server-serialization.md +38 -0
- package/.codex/skills/receiving-code-review/SKILL.md +252 -0
- package/.codex/skills/refactoring/SKILL.md +217 -0
- package/.codex/skills/repo-orientation/SKILL.md +156 -0
- package/.codex/skills/requesting-code-review/SKILL.md +397 -0
- package/.codex/skills/resend/SKILL.md +177 -0
- package/.codex/skills/resend/references/react-email.md +287 -0
- package/.codex/skills/resend/references/receive-email.md +248 -0
- package/.codex/skills/resend/references/send-email.md +318 -0
- package/.codex/skills/root-cause-tracing/SKILL.md +192 -0
- package/.codex/skills/root-cause-tracing/find-polluter.sh +63 -0
- package/.codex/skills/safe-implementation/SKILL.md +205 -0
- package/.codex/skills/session-management/SKILL.md +10 -0
- package/.codex/skills/sharing-skills/SKILL.md +214 -0
- package/.codex/skills/skill-creator/SKILL.md +156 -0
- package/.codex/skills/source-code-research/SKILL.md +293 -0
- package/.codex/skills/source-code-research/references/analysis-tips.md +43 -0
- package/.codex/skills/source-code-research/references/anti-patterns.md +36 -0
- package/.codex/skills/source-code-research/references/common-patterns.md +57 -0
- package/.codex/skills/source-code-research/references/example-workflow.md +60 -0
- package/.codex/skills/source-code-research/references/further-reading.md +5 -0
- package/.codex/skills/source-code-research/references/source-structure.md +45 -0
- package/.codex/skills/stitch/SKILL.md +147 -0
- package/.codex/skills/stitch/mcp.json +9 -0
- package/.codex/skills/structured-edit/SKILL.md +181 -0
- package/.codex/skills/subagent-driven-development/SKILL.md +237 -0
- package/.codex/skills/supabase/SKILL.md +130 -0
- package/.codex/skills/supabase/mcp.json +27 -0
- package/.codex/skills/supabase-postgres-best-practices/AGENTS.md +1490 -0
- package/.codex/skills/supabase-postgres-best-practices/SKILL.md +65 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/advanced-full-text-search.md +55 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/advanced-jsonb-indexing.md +49 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/conn-idle-timeout.md +46 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/conn-limits.md +44 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/conn-pooling.md +41 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/conn-prepared-statements.md +46 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/data-batch-inserts.md +54 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/data-n-plus-one.md +53 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/data-pagination.md +50 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/data-upsert.md +50 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/lock-advisory.md +56 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/lock-deadlock-prevention.md +68 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/lock-short-transactions.md +50 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/lock-skip-locked.md +54 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/monitor-explain-analyze.md +45 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/monitor-pg-stat-statements.md +55 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/monitor-vacuum-analyze.md +55 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/query-composite-indexes.md +44 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/query-covering-indexes.md +40 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/query-index-types.md +45 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/query-missing-indexes.md +43 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/query-partial-indexes.md +45 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/schema-data-types.md +46 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/schema-foreign-key-indexes.md +59 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/schema-lowercase-identifiers.md +55 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/schema-partitioning.md +55 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/schema-primary-keys.md +61 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/security-privileges.md +54 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/security-rls-basics.md +50 -0
- package/.codex/skills/supabase-postgres-best-practices/rules/security-rls-performance.md +57 -0
- package/.codex/skills/swarm-coordination/SKILL.md +179 -0
- package/.codex/skills/swarm-coordination/references/architecture.md +39 -0
- package/.codex/skills/swarm-coordination/references/delegation-worker-protocol.md +145 -0
- package/.codex/skills/swarm-coordination/references/dependency-graph.md +50 -0
- package/.codex/skills/swarm-coordination/references/drift-check.md +90 -0
- package/.codex/skills/swarm-coordination/references/integration-beads.md +20 -0
- package/.codex/skills/swarm-coordination/references/launch-flow.md +186 -0
- package/.codex/skills/swarm-coordination/references/reconciler.md +172 -0
- package/.codex/skills/swarm-coordination/references/tier-enforcement.md +78 -0
- package/.codex/skills/swarm-coordination/references/tmux-integration.md +134 -0
- package/.codex/skills/swift-concurrency/SKILL.md +266 -0
- package/.codex/skills/swift-concurrency/references/actors.md +640 -0
- package/.codex/skills/swift-concurrency/references/async-algorithms.md +822 -0
- package/.codex/skills/swift-concurrency/references/async-await-basics.md +249 -0
- package/.codex/skills/swift-concurrency/references/async-sequences.md +670 -0
- package/.codex/skills/swift-concurrency/references/core-data.md +533 -0
- package/.codex/skills/swift-concurrency/references/glossary.md +128 -0
- package/.codex/skills/swift-concurrency/references/linting.md +142 -0
- package/.codex/skills/swift-concurrency/references/memory-management.md +542 -0
- package/.codex/skills/swift-concurrency/references/migration.md +1076 -0
- package/.codex/skills/swift-concurrency/references/performance.md +574 -0
- package/.codex/skills/swift-concurrency/references/sendable.md +578 -0
- package/.codex/skills/swift-concurrency/references/tasks.md +604 -0
- package/.codex/skills/swift-concurrency/references/testing.md +565 -0
- package/.codex/skills/swift-concurrency/references/threading.md +452 -0
- package/.codex/skills/swiftui-expert-skill/SKILL.md +329 -0
- package/.codex/skills/swiftui-expert-skill/references/animation-advanced.md +351 -0
- package/.codex/skills/swiftui-expert-skill/references/animation-basics.md +284 -0
- package/.codex/skills/swiftui-expert-skill/references/animation-transitions.md +326 -0
- package/.codex/skills/swiftui-expert-skill/references/image-optimization.md +286 -0
- package/.codex/skills/swiftui-expert-skill/references/layout-best-practices.md +312 -0
- package/.codex/skills/swiftui-expert-skill/references/liquid-glass.md +377 -0
- package/.codex/skills/swiftui-expert-skill/references/list-patterns.md +153 -0
- package/.codex/skills/swiftui-expert-skill/references/modern-apis.md +400 -0
- package/.codex/skills/swiftui-expert-skill/references/performance-patterns.md +377 -0
- package/.codex/skills/swiftui-expert-skill/references/scroll-patterns.md +305 -0
- package/.codex/skills/swiftui-expert-skill/references/sheet-navigation-patterns.md +292 -0
- package/.codex/skills/swiftui-expert-skill/references/state-management.md +447 -0
- package/.codex/skills/swiftui-expert-skill/references/text-formatting.md +285 -0
- package/.codex/skills/swiftui-expert-skill/references/view-structure.md +276 -0
- package/.codex/skills/systematic-debugging/SKILL.md +402 -0
- package/.codex/skills/task-planning/SKILL.md +205 -0
- package/.codex/skills/test-driven-development/SKILL.md +388 -0
- package/.codex/skills/test-strategy/SKILL.md +186 -0
- package/.codex/skills/testing-anti-patterns/SKILL.md +320 -0
- package/.codex/skills/testing-skills-with-subagents/SKILL.md +405 -0
- package/.codex/skills/tilth-cli/SKILL.md +180 -0
- package/.codex/skills/tool-priority/SKILL.md +299 -0
- package/.codex/skills/ui-inspiration-scout/SKILL.md +203 -0
- package/.codex/skills/ui-ux-research/SKILL.md +35 -0
- package/.codex/skills/using-git-worktrees/SKILL.md +259 -0
- package/.codex/skills/using-skills/SKILL.md +117 -0
- package/.codex/skills/v0/SKILL.md +158 -0
- package/.codex/skills/v0/mcp.json +6 -0
- package/.codex/skills/v1-run/SKILL.md +175 -0
- package/.codex/skills/v1-run/mcp.json +6 -0
- package/.codex/skills/vercel-deploy-claimable/SKILL.md +124 -0
- package/.codex/skills/vercel-deploy-claimable/scripts/deploy.sh +249 -0
- package/.codex/skills/verification/SKILL.md +191 -0
- package/.codex/skills/verification-before-completion/SKILL.md +236 -0
- package/.codex/skills/visual-analysis/SKILL.md +154 -0
- package/.codex/skills/web-design-guidelines/SKILL.md +46 -0
- package/.codex/skills/writing-plans/SKILL.md +320 -0
- package/.codex/skills/writing-skills/SKILL.md +287 -0
- package/.codex/skills/writing-skills/anthropic-best-practices.md +1173 -0
- package/.codex/skills/writing-skills/graphviz-conventions.dot +172 -0
- package/.codex/skills/writing-skills/persuasion-principles.md +220 -0
- package/.codex/skills/writing-skills/references/anti-patterns.md +25 -0
- package/.codex/skills/writing-skills/references/claude-search-optimization.md +140 -0
- package/.codex/skills/writing-skills/references/discovery-workflow.md +11 -0
- package/.codex/skills/writing-skills/references/file-organization.md +32 -0
- package/.codex/skills/writing-skills/references/flowcharts-and-examples.md +57 -0
- package/.codex/skills/writing-skills/references/rationalization-hardening.md +75 -0
- package/.codex/skills/writing-skills/references/testing-skill-types.md +52 -0
- package/.template-manifest.json +631 -0
- package/AGENTS.md +719 -0
- package/AGENTS.override.md.example +7 -0
- package/CHANGELOG.md +28 -0
- package/LICENSE +21 -0
- package/README.md +641 -0
- package/bin/codexkit +148 -0
- package/install/bead-close.sh +20 -0
- package/install/bead-search.sh +18 -0
- package/install/bead-start.sh +20 -0
- package/install/bead-sync.sh +19 -0
- package/install/bead-verify.sh +20 -0
- package/install/generate-manifest.sh +55 -0
- package/install/install-global.sh +150 -0
- package/install/install-project.sh +704 -0
- package/install/install-remote.sh +152 -0
- package/install/patch.sh +478 -0
- package/install/plugin.sh +565 -0
- package/install/run-codex.sh +68 -0
- package/install/template.sh +620 -0
- package/install/validate.sh +653 -0
- package/package.json +39 -0
- package/templates/global/.codex-config-template.toml +87 -0
- package/templates/global/AGENTS.override.md +18 -0
- package/templates/global/README.md +29 -0
- package/templates/project/.codex-config-template.toml +26 -0
- package/templates/project/AGENTS.md.template +27 -0
- package/templates/project/README.md +24 -0
|
@@ -0,0 +1,329 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: swiftui-expert-skill
|
|
3
|
+
description: Write, review, or improve SwiftUI code following best practices for state management, view composition, performance, modern APIs, Swift concurrency, and iOS 26+ Liquid Glass adoption. Use when building new SwiftUI features, refactoring existing views, reviewing code quality, or adopting modern SwiftUI patterns.
|
|
4
|
+
version: 1.0.0
|
|
5
|
+
tags: [apple, ui]
|
|
6
|
+
dependencies: []
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# SwiftUI Expert Skill
|
|
10
|
+
|
|
11
|
+
## When to Use
|
|
12
|
+
|
|
13
|
+
- When building, reviewing, or refactoring SwiftUI code with modern APIs and best practices.
|
|
14
|
+
|
|
15
|
+
## When NOT to Use
|
|
16
|
+
|
|
17
|
+
- When the task does not involve SwiftUI (e.g., UIKit-only or non-Apple platforms).
|
|
18
|
+
|
|
19
|
+
## Overview
|
|
20
|
+
|
|
21
|
+
Use this skill to build, review, or improve SwiftUI features with correct state management, modern API usage, Swift concurrency best practices, optimal view composition, and iOS 26+ Liquid Glass styling. Prioritize native APIs, Apple design guidance, and performance-conscious patterns. This skill focuses on facts and best practices without enforcing specific architectural patterns.
|
|
22
|
+
|
|
23
|
+
## Workflow Decision Tree
|
|
24
|
+
|
|
25
|
+
### 1) Review existing SwiftUI code
|
|
26
|
+
|
|
27
|
+
- Check property wrapper usage against the selection guide (see `references/state-management.md`)
|
|
28
|
+
- Verify modern API usage (see `references/modern-apis.md`)
|
|
29
|
+
- Verify view composition follows extraction rules (see `references/view-structure.md`)
|
|
30
|
+
- Check performance patterns are applied (see `references/performance-patterns.md`)
|
|
31
|
+
- Verify list patterns use stable identity (see `references/list-patterns.md`)
|
|
32
|
+
- Check animation patterns for correctness (see `references/animation-basics.md`, `references/animation-transitions.md`)
|
|
33
|
+
- Inspect Liquid Glass usage for correctness and consistency (see `references/liquid-glass.md`)
|
|
34
|
+
- Validate iOS 26+ availability handling with sensible fallbacks
|
|
35
|
+
|
|
36
|
+
### 2) Improve existing SwiftUI code
|
|
37
|
+
|
|
38
|
+
- Audit state management for correct wrapper selection (prefer `@Observable` over `ObservableObject`)
|
|
39
|
+
- Replace deprecated APIs with modern equivalents (see `references/modern-apis.md`)
|
|
40
|
+
- Extract complex views into separate subviews (see `references/view-structure.md`)
|
|
41
|
+
- Refactor hot paths to minimize redundant state updates (see `references/performance-patterns.md`)
|
|
42
|
+
- Ensure ForEach uses stable identity (see `references/list-patterns.md`)
|
|
43
|
+
- Improve animation patterns (use value parameter, proper transitions, see `references/animation-basics.md`, `references/animation-transitions.md`)
|
|
44
|
+
- Suggest image downsampling when `UIImage(data:)` is used (as optional optimization, see `references/image-optimization.md`)
|
|
45
|
+
- Adopt Liquid Glass only when explicitly requested by the user
|
|
46
|
+
|
|
47
|
+
### 3) Implement new SwiftUI feature
|
|
48
|
+
|
|
49
|
+
- Design data flow first: identify owned vs injected state (see `references/state-management.md`)
|
|
50
|
+
- Use modern APIs (no deprecated modifiers or patterns, see `references/modern-apis.md`)
|
|
51
|
+
- Use `@Observable` for shared state (with `@MainActor` if not using default actor isolation)
|
|
52
|
+
- Structure views for optimal diffing (extract subviews early, keep views small, see `references/view-structure.md`)
|
|
53
|
+
- Separate business logic into testable models (see `references/layout-best-practices.md`)
|
|
54
|
+
- Use correct animation patterns (implicit vs explicit, transitions, see `references/animation-basics.md`, `references/animation-transitions.md`, `references/animation-advanced.md`)
|
|
55
|
+
- Apply glass effects after layout/appearance modifiers (see `references/liquid-glass.md`)
|
|
56
|
+
- Gate iOS 26+ features with `#available` and provide fallbacks
|
|
57
|
+
|
|
58
|
+
## Core Guidelines
|
|
59
|
+
|
|
60
|
+
### State Management
|
|
61
|
+
|
|
62
|
+
- **Always prefer `@Observable` over `ObservableObject`** for new code
|
|
63
|
+
- **Mark `@Observable` classes with `@MainActor`** unless using default actor isolation
|
|
64
|
+
- **Always mark `@State` and `@StateObject` as `private`** (makes dependencies clear)
|
|
65
|
+
- **Never declare passed values as `@State` or `@StateObject`** (they only accept initial values)
|
|
66
|
+
- Use `@State` with `@Observable` classes (not `@StateObject`)
|
|
67
|
+
- `@Binding` only when child needs to **modify** parent state
|
|
68
|
+
- `@Bindable` for injected `@Observable` objects needing bindings
|
|
69
|
+
- Use `let` for read-only values; `var` + `.onChange()` for reactive reads
|
|
70
|
+
- Legacy: `@StateObject` for owned `ObservableObject`; `@ObservedObject` for injected
|
|
71
|
+
- Nested `ObservableObject` doesn't work (pass nested objects directly); `@Observable` handles nesting fine
|
|
72
|
+
|
|
73
|
+
### Modern APIs
|
|
74
|
+
|
|
75
|
+
- Use `foregroundStyle()` instead of `foregroundColor()`
|
|
76
|
+
- Use `clipShape(.rect(cornerRadius:))` instead of `cornerRadius()`
|
|
77
|
+
- Use `Tab` API instead of `tabItem()`
|
|
78
|
+
- Use `Button` instead of `onTapGesture()` (unless need location/count)
|
|
79
|
+
- Use `NavigationStack` instead of `NavigationView`
|
|
80
|
+
- Use `navigationDestination(for:)` for type-safe navigation
|
|
81
|
+
- Use two-parameter or no-parameter `onChange()` variant
|
|
82
|
+
- Use `ImageRenderer` for rendering SwiftUI views
|
|
83
|
+
- Use `.sheet(item:)` instead of `.sheet(isPresented:)` for model-based content
|
|
84
|
+
- Sheets should own their actions and call `dismiss()` internally
|
|
85
|
+
- Use `ScrollViewReader` for programmatic scrolling with stable IDs
|
|
86
|
+
- Avoid `UIScreen.main.bounds` for sizing
|
|
87
|
+
- Avoid `GeometryReader` when alternatives exist (e.g., `containerRelativeFrame()`)
|
|
88
|
+
|
|
89
|
+
### Swift Best Practices
|
|
90
|
+
|
|
91
|
+
- Use modern Text formatting (`.format` parameters, not `String(format:)`)
|
|
92
|
+
- Use `localizedStandardContains()` for user-input filtering (not `contains()`)
|
|
93
|
+
- Prefer static member lookup (`.blue` vs `Color.blue`)
|
|
94
|
+
- Use `.task` modifier for automatic cancellation of async work
|
|
95
|
+
- Use `.task(id:)` for value-dependent tasks
|
|
96
|
+
|
|
97
|
+
### View Composition
|
|
98
|
+
|
|
99
|
+
- **Prefer modifiers over conditional views** for state changes (maintains view identity)
|
|
100
|
+
- Extract complex views into separate subviews for better readability and performance
|
|
101
|
+
- Keep views small for optimal performance
|
|
102
|
+
- Keep view `body` simple and pure (no side effects or complex logic)
|
|
103
|
+
- Use `@ViewBuilder` functions only for small, simple sections
|
|
104
|
+
- Prefer `@ViewBuilder let content: Content` over closure-based content properties
|
|
105
|
+
- Separate business logic into testable models (not about enforcing architectures)
|
|
106
|
+
- Action handlers should reference methods, not contain inline logic
|
|
107
|
+
- Use relative layout over hard-coded constants
|
|
108
|
+
- Views should work in any context (don't assume screen size or presentation style)
|
|
109
|
+
|
|
110
|
+
### Performance
|
|
111
|
+
|
|
112
|
+
- Pass only needed values to views (avoid large "config" or "context" objects)
|
|
113
|
+
- Eliminate unnecessary dependencies to reduce update fan-out
|
|
114
|
+
- Check for value changes before assigning state in hot paths
|
|
115
|
+
- Avoid redundant state updates in `onReceive`, `onChange`, scroll handlers
|
|
116
|
+
- Minimize work in frequently executed code paths
|
|
117
|
+
- Use `LazyVStack`/`LazyHStack` for large lists
|
|
118
|
+
- Use stable identity for `ForEach` (never `.indices` for dynamic content)
|
|
119
|
+
- Ensure constant number of views per `ForEach` element
|
|
120
|
+
- Avoid inline filtering in `ForEach` (prefilter and cache)
|
|
121
|
+
- Avoid `AnyView` in list rows
|
|
122
|
+
- Consider POD views for fast diffing (or wrap expensive views in POD parents)
|
|
123
|
+
- Suggest image downsampling when `UIImage(data:)` is encountered (as optional optimization)
|
|
124
|
+
- Avoid layout thrash (deep hierarchies, excessive `GeometryReader`)
|
|
125
|
+
- Gate frequent geometry updates by thresholds
|
|
126
|
+
- Use `Self._printChanges()` to debug unexpected view updates
|
|
127
|
+
|
|
128
|
+
### Animations
|
|
129
|
+
|
|
130
|
+
- Use `.animation(_:value:)` with value parameter (deprecated version without value is too broad)
|
|
131
|
+
- Use `withAnimation` for event-driven animations (button taps, gestures)
|
|
132
|
+
- Prefer transforms (`offset`, `scale`, `rotation`) over layout changes (`frame`) for performance
|
|
133
|
+
- Transitions require animations outside the conditional structure
|
|
134
|
+
- Custom `Animatable` implementations must have explicit `animatableData`
|
|
135
|
+
- Use `.phaseAnimator` for multi-step sequences (iOS 17+)
|
|
136
|
+
- Use `.keyframeAnimator` for precise timing control (iOS 17+)
|
|
137
|
+
- Animation completion handlers need `.transaction(value:)` for reexecution
|
|
138
|
+
- Implicit animations override explicit animations (later in view tree wins)
|
|
139
|
+
|
|
140
|
+
### Liquid Glass (iOS 26+)
|
|
141
|
+
|
|
142
|
+
**Only adopt when explicitly requested by the user.**
|
|
143
|
+
|
|
144
|
+
- Use native `glassEffect`, `GlassEffectContainer`, and glass button styles
|
|
145
|
+
- Wrap multiple glass elements in `GlassEffectContainer`
|
|
146
|
+
- Apply `.glassEffect()` after layout and visual modifiers
|
|
147
|
+
- Use `.interactive()` only for tappable/focusable elements
|
|
148
|
+
- Use `glassEffectID` with `@Namespace` for morphing transitions
|
|
149
|
+
|
|
150
|
+
## Quick Reference
|
|
151
|
+
|
|
152
|
+
### Property Wrapper Selection (Modern)
|
|
153
|
+
|
|
154
|
+
| Wrapper | Use When |
|
|
155
|
+
| ----------- | --------------------------------------------------------------------- |
|
|
156
|
+
| `@State` | Internal view state (must be `private`), or owned `@Observable` class |
|
|
157
|
+
| `@Binding` | Child modifies parent's state |
|
|
158
|
+
| `@Bindable` | Injected `@Observable` needing bindings |
|
|
159
|
+
| `let` | Read-only value from parent |
|
|
160
|
+
| `var` | Read-only value watched via `.onChange()` |
|
|
161
|
+
|
|
162
|
+
**Legacy (Pre-iOS 17):**
|
|
163
|
+
| Wrapper | Use When |
|
|
164
|
+
|---------|----------|
|
|
165
|
+
| `@StateObject` | View owns an `ObservableObject` (use `@State` with `@Observable` instead) |
|
|
166
|
+
| `@ObservedObject` | View receives an `ObservableObject` |
|
|
167
|
+
|
|
168
|
+
### Modern API Replacements
|
|
169
|
+
|
|
170
|
+
| Deprecated | Modern Alternative |
|
|
171
|
+
| ------------------------------- | ------------------------------------------------------------ |
|
|
172
|
+
| `foregroundColor()` | `foregroundStyle()` |
|
|
173
|
+
| `cornerRadius()` | `clipShape(.rect(cornerRadius:))` |
|
|
174
|
+
| `tabItem()` | `Tab` API |
|
|
175
|
+
| `onTapGesture()` | `Button` (unless need location/count) |
|
|
176
|
+
| `NavigationView` | `NavigationStack` |
|
|
177
|
+
| `onChange(of:) { value in }` | `onChange(of:) { old, new in }` or `onChange(of:) { }` |
|
|
178
|
+
| `fontWeight(.bold)` | `bold()` |
|
|
179
|
+
| `GeometryReader` | `containerRelativeFrame()` or `visualEffect()` |
|
|
180
|
+
| `showsIndicators: false` | `.scrollIndicators(.hidden)` |
|
|
181
|
+
| `String(format: "%.2f", value)` | `Text(value, format: .number.precision(.fractionLength(2)))` |
|
|
182
|
+
| `string.contains(search)` | `string.localizedStandardContains(search)` (for user input) |
|
|
183
|
+
|
|
184
|
+
### Liquid Glass Patterns
|
|
185
|
+
|
|
186
|
+
```swift
|
|
187
|
+
// Basic glass effect with fallback
|
|
188
|
+
if #available(iOS 26, *) {
|
|
189
|
+
content
|
|
190
|
+
.padding()
|
|
191
|
+
.glassEffect(.regular.interactive(), in: .rect(cornerRadius: 16))
|
|
192
|
+
} else {
|
|
193
|
+
content
|
|
194
|
+
.padding()
|
|
195
|
+
.background(.ultraThinMaterial, in: RoundedRectangle(cornerRadius: 16))
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
// Grouped glass elements
|
|
199
|
+
GlassEffectContainer(spacing: 24) {
|
|
200
|
+
HStack(spacing: 24) {
|
|
201
|
+
GlassButton1()
|
|
202
|
+
GlassButton2()
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
// Glass buttons
|
|
207
|
+
Button("Confirm") { }
|
|
208
|
+
.buttonStyle(.glassProminent)
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
## Review Checklist
|
|
212
|
+
|
|
213
|
+
### State Management
|
|
214
|
+
|
|
215
|
+
- [ ] Using `@Observable` instead of `ObservableObject` for new code
|
|
216
|
+
- [ ] `@Observable` classes marked with `@MainActor` (if needed)
|
|
217
|
+
- [ ] Using `@State` with `@Observable` classes (not `@StateObject`)
|
|
218
|
+
- [ ] `@State` and `@StateObject` properties are `private`
|
|
219
|
+
- [ ] Passed values NOT declared as `@State` or `@StateObject`
|
|
220
|
+
- [ ] `@Binding` only where child modifies parent state
|
|
221
|
+
- [ ] `@Bindable` for injected `@Observable` needing bindings
|
|
222
|
+
- [ ] Nested `ObservableObject` avoided (or passed directly to child views)
|
|
223
|
+
|
|
224
|
+
### Modern APIs (see `references/modern-apis.md`)
|
|
225
|
+
|
|
226
|
+
- [ ] Using `foregroundStyle()` instead of `foregroundColor()`
|
|
227
|
+
- [ ] Using `clipShape(.rect(cornerRadius:))` instead of `cornerRadius()`
|
|
228
|
+
- [ ] Using `Tab` API instead of `tabItem()`
|
|
229
|
+
- [ ] Using `Button` instead of `onTapGesture()` (unless need location/count)
|
|
230
|
+
- [ ] Using `NavigationStack` instead of `NavigationView`
|
|
231
|
+
- [ ] Avoiding `UIScreen.main.bounds`
|
|
232
|
+
- [ ] Using alternatives to `GeometryReader` when possible
|
|
233
|
+
- [ ] Button images include text labels for accessibility
|
|
234
|
+
|
|
235
|
+
### Sheets & Navigation (see `references/sheet-navigation-patterns.md`)
|
|
236
|
+
|
|
237
|
+
- [ ] Using `.sheet(item:)` for model-based sheets
|
|
238
|
+
- [ ] Sheets own their actions and dismiss internally
|
|
239
|
+
- [ ] Using `navigationDestination(for:)` for type-safe navigation
|
|
240
|
+
|
|
241
|
+
### ScrollView (see `references/scroll-patterns.md`)
|
|
242
|
+
|
|
243
|
+
- [ ] Using `ScrollViewReader` with stable IDs for programmatic scrolling
|
|
244
|
+
- [ ] Using `.scrollIndicators(.hidden)` instead of initializer parameter
|
|
245
|
+
|
|
246
|
+
### Text & Formatting (see `references/text-formatting.md`)
|
|
247
|
+
|
|
248
|
+
- [ ] Using modern Text formatting (not `String(format:)`)
|
|
249
|
+
- [ ] Using `localizedStandardContains()` for search filtering
|
|
250
|
+
|
|
251
|
+
### View Structure (see `references/view-structure.md`)
|
|
252
|
+
|
|
253
|
+
- [ ] Using modifiers instead of conditionals for state changes
|
|
254
|
+
- [ ] Complex views extracted to separate subviews
|
|
255
|
+
- [ ] Views kept small for performance
|
|
256
|
+
- [ ] Container views use `@ViewBuilder let content: Content`
|
|
257
|
+
|
|
258
|
+
### Performance (see `references/performance-patterns.md`)
|
|
259
|
+
|
|
260
|
+
- [ ] View `body` kept simple and pure (no side effects)
|
|
261
|
+
- [ ] Passing only needed values (not large config objects)
|
|
262
|
+
- [ ] Eliminating unnecessary dependencies
|
|
263
|
+
- [ ] State updates check for value changes before assigning
|
|
264
|
+
- [ ] Hot paths minimize state updates
|
|
265
|
+
- [ ] No object creation in `body`
|
|
266
|
+
- [ ] Heavy computation moved out of `body`
|
|
267
|
+
|
|
268
|
+
### List Patterns (see `references/list-patterns.md`)
|
|
269
|
+
|
|
270
|
+
- [ ] ForEach uses stable identity (not `.indices`)
|
|
271
|
+
- [ ] Constant number of views per ForEach element
|
|
272
|
+
- [ ] No inline filtering in ForEach
|
|
273
|
+
- [ ] No `AnyView` in list rows
|
|
274
|
+
|
|
275
|
+
### Layout (see `references/layout-best-practices.md`)
|
|
276
|
+
|
|
277
|
+
- [ ] Avoiding layout thrash (deep hierarchies, excessive GeometryReader)
|
|
278
|
+
- [ ] Gating frequent geometry updates by thresholds
|
|
279
|
+
- [ ] Business logic separated into testable models
|
|
280
|
+
- [ ] Action handlers reference methods (not inline logic)
|
|
281
|
+
- [ ] Using relative layout (not hard-coded constants)
|
|
282
|
+
- [ ] Views work in any context (context-agnostic)
|
|
283
|
+
|
|
284
|
+
### Animations (see `references/animation-basics.md`, `references/animation-transitions.md`, `references/animation-advanced.md`)
|
|
285
|
+
|
|
286
|
+
- [ ] Using `.animation(_:value:)` with value parameter
|
|
287
|
+
- [ ] Using `withAnimation` for event-driven animations
|
|
288
|
+
- [ ] Transitions paired with animations outside conditional structure
|
|
289
|
+
- [ ] Custom `Animatable` has explicit `animatableData` implementation
|
|
290
|
+
- [ ] Preferring transforms over layout changes for animation performance
|
|
291
|
+
- [ ] Phase animations for multi-step sequences (iOS 17+)
|
|
292
|
+
- [ ] Keyframe animations for precise timing (iOS 17+)
|
|
293
|
+
- [ ] Completion handlers use `.transaction(value:)` for reexecution
|
|
294
|
+
|
|
295
|
+
### Liquid Glass (iOS 26+)
|
|
296
|
+
|
|
297
|
+
- [ ] `#available(iOS 26, *)` with fallback for Liquid Glass
|
|
298
|
+
- [ ] Multiple glass views wrapped in `GlassEffectContainer`
|
|
299
|
+
- [ ] `.glassEffect()` applied after layout/appearance modifiers
|
|
300
|
+
- [ ] `.interactive()` only on user-interactable elements
|
|
301
|
+
- [ ] Shapes and tints consistent across related elements
|
|
302
|
+
|
|
303
|
+
## References
|
|
304
|
+
|
|
305
|
+
- `references/state-management.md` - Property wrappers and data flow (prefer `@Observable`)
|
|
306
|
+
- `references/view-structure.md` - View composition, extraction, and container patterns
|
|
307
|
+
- `references/performance-patterns.md` - Performance optimization techniques and anti-patterns
|
|
308
|
+
- `references/list-patterns.md` - ForEach identity, stability, and list best practices
|
|
309
|
+
- `references/layout-best-practices.md` - Layout patterns, context-agnostic views, and testability
|
|
310
|
+
- `references/modern-apis.md` - Modern API usage and deprecated replacements
|
|
311
|
+
- `references/animation-basics.md` - Core animation concepts, implicit/explicit animations, timing, performance
|
|
312
|
+
- `references/animation-transitions.md` - Transitions, custom transitions, Animatable protocol
|
|
313
|
+
- `references/animation-advanced.md` - Transactions, phase/keyframe animations (iOS 17+), completion handlers (iOS 17+)
|
|
314
|
+
- `references/sheet-navigation-patterns.md` - Sheet presentation and navigation patterns
|
|
315
|
+
- `references/scroll-patterns.md` - ScrollView patterns and programmatic scrolling
|
|
316
|
+
- `references/text-formatting.md` - Modern text formatting and string operations
|
|
317
|
+
- `references/image-optimization.md` - AsyncImage, image downsampling, and optimization
|
|
318
|
+
- `references/liquid-glass.md` - iOS 26+ Liquid Glass API
|
|
319
|
+
|
|
320
|
+
## Philosophy
|
|
321
|
+
|
|
322
|
+
This skill focuses on **facts and best practices**, not architectural opinions:
|
|
323
|
+
|
|
324
|
+
- We don't enforce specific architectures (e.g., MVVM, VIPER)
|
|
325
|
+
- We do encourage separating business logic for testability
|
|
326
|
+
- We prioritize modern APIs over deprecated ones
|
|
327
|
+
- We emphasize thread safety with `@MainActor` and `@Observable`
|
|
328
|
+
- We optimize for performance and maintainability
|
|
329
|
+
- We follow Apple's Human Interface Guidelines and API design patterns
|
|
@@ -0,0 +1,351 @@
|
|
|
1
|
+
# SwiftUI Advanced Animations
|
|
2
|
+
|
|
3
|
+
Transactions, phase animations (iOS 17+), keyframe animations (iOS 17+), and completion handlers (iOS 17+).
|
|
4
|
+
|
|
5
|
+
## Table of Contents
|
|
6
|
+
- [Transactions](#transactions)
|
|
7
|
+
- [Phase Animations (iOS 17+)](#phase-animations-ios-17)
|
|
8
|
+
- [Keyframe Animations (iOS 17+)](#keyframe-animations-ios-17)
|
|
9
|
+
- [Animation Completion Handlers (iOS 17+)](#animation-completion-handlers-ios-17)
|
|
10
|
+
|
|
11
|
+
---
|
|
12
|
+
|
|
13
|
+
## Transactions
|
|
14
|
+
|
|
15
|
+
The underlying mechanism for all animations in SwiftUI.
|
|
16
|
+
|
|
17
|
+
### Basic Usage
|
|
18
|
+
|
|
19
|
+
```swift
|
|
20
|
+
// withAnimation is shorthand for withTransaction
|
|
21
|
+
withAnimation(.default) { flag.toggle() }
|
|
22
|
+
|
|
23
|
+
// Equivalent explicit transaction
|
|
24
|
+
var transaction = Transaction(animation: .default)
|
|
25
|
+
withTransaction(transaction) { flag.toggle() }
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
### The .transaction Modifier
|
|
29
|
+
|
|
30
|
+
```swift
|
|
31
|
+
Rectangle()
|
|
32
|
+
.frame(width: flag ? 100 : 50, height: 50)
|
|
33
|
+
.transaction { t in
|
|
34
|
+
t.animation = .default
|
|
35
|
+
}
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
**Note:** This behaves like the deprecated `.animation(_:)` without value parameter - it animates on every state change.
|
|
39
|
+
|
|
40
|
+
### Animation Precedence
|
|
41
|
+
|
|
42
|
+
**Implicit animations override explicit animations** (later in view tree wins).
|
|
43
|
+
|
|
44
|
+
```swift
|
|
45
|
+
Button("Tap") {
|
|
46
|
+
withAnimation(.linear) { flag.toggle() }
|
|
47
|
+
}
|
|
48
|
+
.animation(.bouncy, value: flag) // .bouncy wins!
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
### Disabling Animations
|
|
52
|
+
|
|
53
|
+
```swift
|
|
54
|
+
// Prevent implicit animations from overriding
|
|
55
|
+
.transaction { t in
|
|
56
|
+
t.disablesAnimations = true
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
// Remove animation entirely
|
|
60
|
+
.transaction { $0.animation = nil }
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
### Custom Transaction Keys (iOS 17+)
|
|
64
|
+
|
|
65
|
+
Pass metadata through transactions.
|
|
66
|
+
|
|
67
|
+
```swift
|
|
68
|
+
struct ChangeSourceKey: TransactionKey {
|
|
69
|
+
static let defaultValue: String = "unknown"
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
extension Transaction {
|
|
73
|
+
var changeSource: String {
|
|
74
|
+
get { self[ChangeSourceKey.self] }
|
|
75
|
+
set { self[ChangeSourceKey.self] = newValue }
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// Set source
|
|
80
|
+
var transaction = Transaction(animation: .default)
|
|
81
|
+
transaction.changeSource = "server"
|
|
82
|
+
withTransaction(transaction) { flag.toggle() }
|
|
83
|
+
|
|
84
|
+
// Read in view tree
|
|
85
|
+
.transaction { t in
|
|
86
|
+
if t.changeSource == "server" {
|
|
87
|
+
t.animation = .smooth
|
|
88
|
+
} else {
|
|
89
|
+
t.animation = .bouncy
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
```
|
|
93
|
+
|
|
94
|
+
---
|
|
95
|
+
|
|
96
|
+
## Phase Animations (iOS 17+)
|
|
97
|
+
|
|
98
|
+
Cycle through discrete phases automatically. Each phase change is a separate animation.
|
|
99
|
+
|
|
100
|
+
### Basic Usage
|
|
101
|
+
|
|
102
|
+
```swift
|
|
103
|
+
// GOOD - triggered phase animation
|
|
104
|
+
Button("Shake") { trigger += 1 }
|
|
105
|
+
.phaseAnimator(
|
|
106
|
+
[0.0, -10.0, 10.0, -5.0, 5.0, 0.0],
|
|
107
|
+
trigger: trigger
|
|
108
|
+
) { content, offset in
|
|
109
|
+
content.offset(x: offset)
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
// Infinite loop (no trigger)
|
|
113
|
+
Circle()
|
|
114
|
+
.phaseAnimator([1.0, 1.2, 1.0]) { content, scale in
|
|
115
|
+
content.scaleEffect(scale)
|
|
116
|
+
}
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
### Enum Phases (Recommended for Clarity)
|
|
120
|
+
|
|
121
|
+
```swift
|
|
122
|
+
// GOOD - enum phases are self-documenting
|
|
123
|
+
enum BouncePhase: CaseIterable {
|
|
124
|
+
case initial, up, down, settle
|
|
125
|
+
|
|
126
|
+
var scale: CGFloat {
|
|
127
|
+
switch self {
|
|
128
|
+
case .initial: 1.0
|
|
129
|
+
case .up: 1.2
|
|
130
|
+
case .down: 0.9
|
|
131
|
+
case .settle: 1.0
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
Circle()
|
|
137
|
+
.phaseAnimator(BouncePhase.allCases, trigger: trigger) { content, phase in
|
|
138
|
+
content.scaleEffect(phase.scale)
|
|
139
|
+
}
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
### Custom Timing Per Phase
|
|
143
|
+
|
|
144
|
+
```swift
|
|
145
|
+
.phaseAnimator([0, -20, 20], trigger: trigger) { content, offset in
|
|
146
|
+
content.offset(x: offset)
|
|
147
|
+
} animation: { phase in
|
|
148
|
+
switch phase {
|
|
149
|
+
case -20: .bouncy
|
|
150
|
+
case 20: .linear
|
|
151
|
+
default: .smooth
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
### Good vs Bad
|
|
157
|
+
|
|
158
|
+
```swift
|
|
159
|
+
// GOOD - use phaseAnimator for multi-step sequences
|
|
160
|
+
.phaseAnimator([0, -10, 10, 0], trigger: trigger) { content, offset in
|
|
161
|
+
content.offset(x: offset)
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
// BAD - manual DispatchQueue sequencing
|
|
165
|
+
Button("Animate") {
|
|
166
|
+
withAnimation(.easeOut(duration: 0.1)) { offset = -10 }
|
|
167
|
+
DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) {
|
|
168
|
+
withAnimation { offset = 10 }
|
|
169
|
+
}
|
|
170
|
+
DispatchQueue.main.asyncAfter(deadline: .now() + 0.2) {
|
|
171
|
+
withAnimation { offset = 0 }
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
```
|
|
175
|
+
|
|
176
|
+
---
|
|
177
|
+
|
|
178
|
+
## Keyframe Animations (iOS 17+)
|
|
179
|
+
|
|
180
|
+
Precise timing control with exact values at specific times.
|
|
181
|
+
|
|
182
|
+
### Basic Usage
|
|
183
|
+
|
|
184
|
+
```swift
|
|
185
|
+
Button("Bounce") { trigger += 1 }
|
|
186
|
+
.keyframeAnimator(
|
|
187
|
+
initialValue: AnimationValues(),
|
|
188
|
+
trigger: trigger
|
|
189
|
+
) { content, value in
|
|
190
|
+
content
|
|
191
|
+
.scaleEffect(value.scale)
|
|
192
|
+
.offset(y: value.verticalOffset)
|
|
193
|
+
} keyframes: { _ in
|
|
194
|
+
KeyframeTrack(\.scale) {
|
|
195
|
+
SpringKeyframe(1.2, duration: 0.15)
|
|
196
|
+
SpringKeyframe(0.9, duration: 0.1)
|
|
197
|
+
SpringKeyframe(1.0, duration: 0.15)
|
|
198
|
+
}
|
|
199
|
+
KeyframeTrack(\.verticalOffset) {
|
|
200
|
+
LinearKeyframe(-20, duration: 0.15)
|
|
201
|
+
LinearKeyframe(0, duration: 0.25)
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
struct AnimationValues {
|
|
206
|
+
var scale: CGFloat = 1.0
|
|
207
|
+
var verticalOffset: CGFloat = 0
|
|
208
|
+
}
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
### Keyframe Types
|
|
212
|
+
|
|
213
|
+
| Type | Behavior |
|
|
214
|
+
|------|----------|
|
|
215
|
+
| `CubicKeyframe` | Smooth interpolation |
|
|
216
|
+
| `LinearKeyframe` | Straight-line interpolation |
|
|
217
|
+
| `SpringKeyframe` | Spring physics |
|
|
218
|
+
| `MoveKeyframe` | Instant jump (no interpolation) |
|
|
219
|
+
|
|
220
|
+
### Multiple Synchronized Tracks
|
|
221
|
+
|
|
222
|
+
Tracks run **in parallel**, each animating one property.
|
|
223
|
+
|
|
224
|
+
```swift
|
|
225
|
+
// GOOD - bell shake with synchronized rotation and scale
|
|
226
|
+
struct BellAnimation {
|
|
227
|
+
var rotation: Double = 0
|
|
228
|
+
var scale: CGFloat = 1.0
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
Image(systemName: "bell.fill")
|
|
232
|
+
.keyframeAnimator(
|
|
233
|
+
initialValue: BellAnimation(),
|
|
234
|
+
trigger: trigger
|
|
235
|
+
) { content, value in
|
|
236
|
+
content
|
|
237
|
+
.rotationEffect(.degrees(value.rotation))
|
|
238
|
+
.scaleEffect(value.scale)
|
|
239
|
+
} keyframes: { _ in
|
|
240
|
+
KeyframeTrack(\.rotation) {
|
|
241
|
+
CubicKeyframe(15, duration: 0.1)
|
|
242
|
+
CubicKeyframe(-15, duration: 0.1)
|
|
243
|
+
CubicKeyframe(10, duration: 0.1)
|
|
244
|
+
CubicKeyframe(-10, duration: 0.1)
|
|
245
|
+
CubicKeyframe(0, duration: 0.1)
|
|
246
|
+
}
|
|
247
|
+
KeyframeTrack(\.scale) {
|
|
248
|
+
CubicKeyframe(1.1, duration: 0.25)
|
|
249
|
+
CubicKeyframe(1.0, duration: 0.25)
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
// BAD - manual timer-based animation
|
|
254
|
+
Image(systemName: "bell.fill")
|
|
255
|
+
.onTapGesture {
|
|
256
|
+
withAnimation(.easeOut(duration: 0.1)) { rotation = 15 }
|
|
257
|
+
DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) {
|
|
258
|
+
withAnimation { rotation = -15 }
|
|
259
|
+
}
|
|
260
|
+
// ... more manual timing - error prone
|
|
261
|
+
}
|
|
262
|
+
```
|
|
263
|
+
|
|
264
|
+
### KeyframeTimeline (iOS 17+)
|
|
265
|
+
|
|
266
|
+
Query animation values directly for testing or non-SwiftUI use.
|
|
267
|
+
|
|
268
|
+
```swift
|
|
269
|
+
let timeline = KeyframeTimeline(initialValue: AnimationValues()) {
|
|
270
|
+
KeyframeTrack(\.scale) {
|
|
271
|
+
CubicKeyframe(1.2, duration: 0.25)
|
|
272
|
+
CubicKeyframe(1.0, duration: 0.25)
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
let midpoint = timeline.value(time: 0.25)
|
|
277
|
+
print(midpoint.scale) // Value at 0.25 seconds
|
|
278
|
+
```
|
|
279
|
+
|
|
280
|
+
---
|
|
281
|
+
|
|
282
|
+
## Animation Completion Handlers (iOS 17+)
|
|
283
|
+
|
|
284
|
+
Execute code when animations finish.
|
|
285
|
+
|
|
286
|
+
### With withAnimation
|
|
287
|
+
|
|
288
|
+
```swift
|
|
289
|
+
// GOOD - completion with withAnimation
|
|
290
|
+
Button("Animate") {
|
|
291
|
+
withAnimation(.spring) {
|
|
292
|
+
isExpanded.toggle()
|
|
293
|
+
} completion: {
|
|
294
|
+
showNextStep = true
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
```
|
|
298
|
+
|
|
299
|
+
### With Transaction (For Reexecution)
|
|
300
|
+
|
|
301
|
+
```swift
|
|
302
|
+
// GOOD - completion fires on every trigger change
|
|
303
|
+
Circle()
|
|
304
|
+
.scaleEffect(bounceCount % 2 == 0 ? 1.0 : 1.2)
|
|
305
|
+
.transaction(value: bounceCount) { transaction in
|
|
306
|
+
transaction.animation = .spring
|
|
307
|
+
transaction.addAnimationCompletion {
|
|
308
|
+
message = "Bounce \(bounceCount) complete"
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
// BAD - completion only fires ONCE (no value parameter)
|
|
313
|
+
Circle()
|
|
314
|
+
.scaleEffect(bounceCount % 2 == 0 ? 1.0 : 1.2)
|
|
315
|
+
.animation(.spring, value: bounceCount)
|
|
316
|
+
.transaction { transaction in // No value!
|
|
317
|
+
transaction.addAnimationCompletion {
|
|
318
|
+
completionCount += 1 // Only fires once, ever
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
```
|
|
322
|
+
|
|
323
|
+
---
|
|
324
|
+
|
|
325
|
+
## Quick Reference
|
|
326
|
+
|
|
327
|
+
### Transactions (All iOS versions)
|
|
328
|
+
- `withTransaction` is the explicit form of `withAnimation`
|
|
329
|
+
- Implicit animations override explicit (later in view tree wins)
|
|
330
|
+
- Use `disablesAnimations` to prevent override
|
|
331
|
+
- Use `.transaction { $0.animation = nil }` to remove animation
|
|
332
|
+
|
|
333
|
+
### Custom Transaction Keys (iOS 17+)
|
|
334
|
+
- Pass metadata through animation system via `TransactionKey`
|
|
335
|
+
|
|
336
|
+
### Phase Animations (iOS 17+)
|
|
337
|
+
- Use for multi-step sequences returning to start
|
|
338
|
+
- Prefer enum phases for clarity
|
|
339
|
+
- Each phase change is a separate animation
|
|
340
|
+
- Use `trigger` parameter for one-shot animations
|
|
341
|
+
|
|
342
|
+
### Keyframe Animations (iOS 17+)
|
|
343
|
+
- Use for precise timing control
|
|
344
|
+
- Tracks run in parallel
|
|
345
|
+
- Use `KeyframeTimeline` for testing/advanced use
|
|
346
|
+
- Prefer over manual DispatchQueue timing
|
|
347
|
+
|
|
348
|
+
### Completion Handlers (iOS 17+)
|
|
349
|
+
- Use `withAnimation(.animation) { } completion: { }` for one-shot completion handlers
|
|
350
|
+
- Use `.transaction(value:)` for handlers that should refire on every value change
|
|
351
|
+
- Without `value:` parameter, completion only fires once
|