@intentsolutionsio/tonone 0.9.7
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/.claude-plugin/CLAUDE.md +11 -0
- package/.claude-plugin/marketplace.json +2178 -0
- package/.claude-plugin/plugin.json +135 -0
- package/LICENSE +21 -0
- package/README.md +462 -0
- package/agents/apex.md +247 -0
- package/agents/atlas.md +181 -0
- package/agents/cortex.md +173 -0
- package/agents/crest.md +130 -0
- package/agents/draft.md +190 -0
- package/agents/echo.md +146 -0
- package/agents/flux.md +145 -0
- package/agents/forge.md +121 -0
- package/agents/form.md +244 -0
- package/agents/helm.md +180 -0
- package/agents/lens.md +145 -0
- package/agents/lumen.md +139 -0
- package/agents/pave.md +169 -0
- package/agents/pitch.md +177 -0
- package/agents/prism.md +181 -0
- package/agents/proof.md +205 -0
- package/agents/relay.md +147 -0
- package/agents/spine.md +207 -0
- package/agents/surge.md +127 -0
- package/agents/touch.md +185 -0
- package/agents/vigil.md +165 -0
- package/agents/volt.md +184 -0
- package/agents/warden.md +172 -0
- package/package.json +48 -0
- package/skills/apex/SKILL.md +32 -0
- package/skills/apex-plan/.claude-plugin/plugin.json +16 -0
- package/skills/apex-plan/SKILL.md +59 -0
- package/skills/apex-recon/.claude-plugin/plugin.json +16 -0
- package/skills/apex-recon/SKILL.md +91 -0
- package/skills/apex-review/.claude-plugin/plugin.json +16 -0
- package/skills/apex-review/SKILL.md +53 -0
- package/skills/apex-status/.claude-plugin/plugin.json +16 -0
- package/skills/apex-status/SKILL.md +42 -0
- package/skills/apex-takeover/.claude-plugin/plugin.json +16 -0
- package/skills/apex-takeover/SKILL.md +50 -0
- package/skills/atlas/SKILL.md +34 -0
- package/skills/atlas-adr/.claude-plugin/plugin.json +16 -0
- package/skills/atlas-adr/SKILL.md +147 -0
- package/skills/atlas-changelog/.claude-plugin/plugin.json +16 -0
- package/skills/atlas-changelog/SKILL.md +156 -0
- package/skills/atlas-map/.claude-plugin/plugin.json +16 -0
- package/skills/atlas-map/SKILL.md +183 -0
- package/skills/atlas-onboard/.claude-plugin/plugin.json +16 -0
- package/skills/atlas-onboard/SKILL.md +138 -0
- package/skills/atlas-present/.claude-plugin/plugin.json +16 -0
- package/skills/atlas-present/SKILL.md +214 -0
- package/skills/atlas-recon/.claude-plugin/plugin.json +16 -0
- package/skills/atlas-recon/SKILL.md +101 -0
- package/skills/atlas-report/.claude-plugin/plugin.json +16 -0
- package/skills/atlas-report/SKILL.md +304 -0
- package/skills/cortex/SKILL.md +32 -0
- package/skills/cortex-eval/.claude-plugin/plugin.json +16 -0
- package/skills/cortex-eval/SKILL.md +143 -0
- package/skills/cortex-integrate/.claude-plugin/plugin.json +16 -0
- package/skills/cortex-integrate/SKILL.md +218 -0
- package/skills/cortex-model/.claude-plugin/plugin.json +16 -0
- package/skills/cortex-model/SKILL.md +138 -0
- package/skills/cortex-prompt/.claude-plugin/plugin.json +16 -0
- package/skills/cortex-prompt/SKILL.md +246 -0
- package/skills/cortex-recon/.claude-plugin/plugin.json +16 -0
- package/skills/cortex-recon/SKILL.md +156 -0
- package/skills/crest/SKILL.md +32 -0
- package/skills/crest-compete/.claude-plugin/plugin.json +16 -0
- package/skills/crest-compete/SKILL.md +158 -0
- package/skills/crest-narrative/.claude-plugin/plugin.json +16 -0
- package/skills/crest-narrative/SKILL.md +124 -0
- package/skills/crest-okr/.claude-plugin/plugin.json +16 -0
- package/skills/crest-okr/SKILL.md +119 -0
- package/skills/crest-recon/.claude-plugin/plugin.json +16 -0
- package/skills/crest-recon/SKILL.md +91 -0
- package/skills/crest-roadmap/.claude-plugin/plugin.json +16 -0
- package/skills/crest-roadmap/SKILL.md +129 -0
- package/skills/draft/SKILL.md +34 -0
- package/skills/draft-flow/.claude-plugin/plugin.json +16 -0
- package/skills/draft-flow/SKILL.md +93 -0
- package/skills/draft-ia/.claude-plugin/plugin.json +16 -0
- package/skills/draft-ia/SKILL.md +204 -0
- package/skills/draft-landing/.claude-plugin/plugin.json +16 -0
- package/skills/draft-landing/SKILL.md +60 -0
- package/skills/draft-patterns/.claude-plugin/plugin.json +16 -0
- package/skills/draft-patterns/SKILL.md +55 -0
- package/skills/draft-recon/.claude-plugin/plugin.json +16 -0
- package/skills/draft-recon/SKILL.md +108 -0
- package/skills/draft-review/.claude-plugin/plugin.json +16 -0
- package/skills/draft-review/SKILL.md +131 -0
- package/skills/draft-wireframe/.claude-plugin/plugin.json +16 -0
- package/skills/draft-wireframe/SKILL.md +167 -0
- package/skills/echo/SKILL.md +32 -0
- package/skills/echo-feedback/.claude-plugin/plugin.json +16 -0
- package/skills/echo-feedback/SKILL.md +129 -0
- package/skills/echo-interview/.claude-plugin/plugin.json +16 -0
- package/skills/echo-interview/SKILL.md +189 -0
- package/skills/echo-jobs/.claude-plugin/plugin.json +16 -0
- package/skills/echo-jobs/SKILL.md +193 -0
- package/skills/echo-recon/.claude-plugin/plugin.json +16 -0
- package/skills/echo-recon/SKILL.md +96 -0
- package/skills/echo-segment/.claude-plugin/plugin.json +16 -0
- package/skills/echo-segment/SKILL.md +105 -0
- package/skills/flux/SKILL.md +33 -0
- package/skills/flux-health/.claude-plugin/plugin.json +16 -0
- package/skills/flux-health/SKILL.md +97 -0
- package/skills/flux-migrate/.claude-plugin/plugin.json +16 -0
- package/skills/flux-migrate/SKILL.md +176 -0
- package/skills/flux-pipeline/.claude-plugin/plugin.json +16 -0
- package/skills/flux-pipeline/SKILL.md +86 -0
- package/skills/flux-query/.claude-plugin/plugin.json +16 -0
- package/skills/flux-query/SKILL.md +87 -0
- package/skills/flux-recon/.claude-plugin/plugin.json +16 -0
- package/skills/flux-recon/SKILL.md +101 -0
- package/skills/flux-schema/.claude-plugin/plugin.json +16 -0
- package/skills/flux-schema/SKILL.md +125 -0
- package/skills/forge/SKILL.md +33 -0
- package/skills/forge-audit/.claude-plugin/plugin.json +16 -0
- package/skills/forge-audit/SKILL.md +117 -0
- package/skills/forge-cost/.claude-plugin/plugin.json +16 -0
- package/skills/forge-cost/SKILL.md +144 -0
- package/skills/forge-diagnose/.claude-plugin/plugin.json +16 -0
- package/skills/forge-diagnose/SKILL.md +122 -0
- package/skills/forge-infra/.claude-plugin/plugin.json +16 -0
- package/skills/forge-infra/SKILL.md +169 -0
- package/skills/forge-network/.claude-plugin/plugin.json +16 -0
- package/skills/forge-network/SKILL.md +106 -0
- package/skills/forge-recon/.claude-plugin/plugin.json +16 -0
- package/skills/forge-recon/SKILL.md +143 -0
- package/skills/form/SKILL.md +40 -0
- package/skills/form-audit/.claude-plugin/plugin.json +16 -0
- package/skills/form-audit/SKILL.md +290 -0
- package/skills/form-brand/.claude-plugin/plugin.json +16 -0
- package/skills/form-brand/SKILL.md +214 -0
- package/skills/form-component/.claude-plugin/plugin.json +16 -0
- package/skills/form-component/SKILL.md +336 -0
- package/skills/form-deck/.claude-plugin/plugin.json +16 -0
- package/skills/form-deck/SKILL.md +263 -0
- package/skills/form-email/.claude-plugin/plugin.json +16 -0
- package/skills/form-email/SKILL.md +304 -0
- package/skills/form-exam/.claude-plugin/plugin.json +16 -0
- package/skills/form-exam/SKILL.md +103 -0
- package/skills/form-logo/.claude-plugin/plugin.json +16 -0
- package/skills/form-logo/SKILL.md +231 -0
- package/skills/form-mobile/.claude-plugin/plugin.json +16 -0
- package/skills/form-mobile/SKILL.md +276 -0
- package/skills/form-palette/.claude-plugin/plugin.json +16 -0
- package/skills/form-palette/SKILL.md +68 -0
- package/skills/form-social/.claude-plugin/plugin.json +16 -0
- package/skills/form-social/SKILL.md +272 -0
- package/skills/form-style/.claude-plugin/plugin.json +16 -0
- package/skills/form-style/SKILL.md +63 -0
- package/skills/form-tokens/.claude-plugin/plugin.json +16 -0
- package/skills/form-tokens/SKILL.md +760 -0
- package/skills/form-web/.claude-plugin/plugin.json +16 -0
- package/skills/form-web/SKILL.md +254 -0
- package/skills/helm/SKILL.md +32 -0
- package/skills/helm-arbiter/.claude-plugin/plugin.json +16 -0
- package/skills/helm-arbiter/SKILL.md +104 -0
- package/skills/helm-brief/.claude-plugin/plugin.json +16 -0
- package/skills/helm-brief/SKILL.md +105 -0
- package/skills/helm-handoff/.claude-plugin/plugin.json +16 -0
- package/skills/helm-handoff/SKILL.md +102 -0
- package/skills/helm-plan/.claude-plugin/plugin.json +16 -0
- package/skills/helm-plan/SKILL.md +73 -0
- package/skills/helm-recon/.claude-plugin/plugin.json +16 -0
- package/skills/helm-recon/SKILL.md +99 -0
- package/skills/lens/SKILL.md +33 -0
- package/skills/lens-audit/.claude-plugin/plugin.json +16 -0
- package/skills/lens-audit/SKILL.md +101 -0
- package/skills/lens-chart/.claude-plugin/plugin.json +16 -0
- package/skills/lens-chart/SKILL.md +59 -0
- package/skills/lens-dashboard/.claude-plugin/plugin.json +16 -0
- package/skills/lens-dashboard/SKILL.md +212 -0
- package/skills/lens-metrics/.claude-plugin/plugin.json +16 -0
- package/skills/lens-metrics/SKILL.md +298 -0
- package/skills/lens-recon/.claude-plugin/plugin.json +16 -0
- package/skills/lens-recon/SKILL.md +106 -0
- package/skills/lens-report/.claude-plugin/plugin.json +16 -0
- package/skills/lens-report/SKILL.md +158 -0
- package/skills/lumen/SKILL.md +32 -0
- package/skills/lumen-abtest/.claude-plugin/plugin.json +16 -0
- package/skills/lumen-abtest/SKILL.md +217 -0
- package/skills/lumen-funnel/.claude-plugin/plugin.json +16 -0
- package/skills/lumen-funnel/SKILL.md +108 -0
- package/skills/lumen-instrument/.claude-plugin/plugin.json +16 -0
- package/skills/lumen-instrument/SKILL.md +130 -0
- package/skills/lumen-metrics/.claude-plugin/plugin.json +16 -0
- package/skills/lumen-metrics/SKILL.md +189 -0
- package/skills/lumen-recon/.claude-plugin/plugin.json +16 -0
- package/skills/lumen-recon/SKILL.md +108 -0
- package/skills/pave/SKILL.md +32 -0
- package/skills/pave-audit/.claude-plugin/plugin.json +16 -0
- package/skills/pave-audit/SKILL.md +109 -0
- package/skills/pave-catalog/.claude-plugin/plugin.json +16 -0
- package/skills/pave-catalog/SKILL.md +202 -0
- package/skills/pave-env/.claude-plugin/plugin.json +16 -0
- package/skills/pave-env/SKILL.md +102 -0
- package/skills/pave-golden/.claude-plugin/plugin.json +16 -0
- package/skills/pave-golden/SKILL.md +173 -0
- package/skills/pave-recon/.claude-plugin/plugin.json +16 -0
- package/skills/pave-recon/SKILL.md +118 -0
- package/skills/pitch/SKILL.md +33 -0
- package/skills/pitch-copy/.claude-plugin/plugin.json +16 -0
- package/skills/pitch-copy/SKILL.md +133 -0
- package/skills/pitch-landing/.claude-plugin/plugin.json +16 -0
- package/skills/pitch-landing/SKILL.md +62 -0
- package/skills/pitch-launch/.claude-plugin/plugin.json +16 -0
- package/skills/pitch-launch/SKILL.md +222 -0
- package/skills/pitch-message/.claude-plugin/plugin.json +16 -0
- package/skills/pitch-message/SKILL.md +98 -0
- package/skills/pitch-position/.claude-plugin/plugin.json +16 -0
- package/skills/pitch-position/SKILL.md +195 -0
- package/skills/pitch-recon/.claude-plugin/plugin.json +16 -0
- package/skills/pitch-recon/SKILL.md +102 -0
- package/skills/prism/SKILL.md +34 -0
- package/skills/prism-audit/.claude-plugin/plugin.json +16 -0
- package/skills/prism-audit/SKILL.md +129 -0
- package/skills/prism-chart/.claude-plugin/plugin.json +16 -0
- package/skills/prism-chart/SKILL.md +56 -0
- package/skills/prism-component/.claude-plugin/plugin.json +16 -0
- package/skills/prism-component/SKILL.md +270 -0
- package/skills/prism-dashboard/.claude-plugin/plugin.json +16 -0
- package/skills/prism-dashboard/SKILL.md +108 -0
- package/skills/prism-recon/.claude-plugin/plugin.json +16 -0
- package/skills/prism-recon/SKILL.md +109 -0
- package/skills/prism-stack/.claude-plugin/plugin.json +16 -0
- package/skills/prism-stack/SKILL.md +58 -0
- package/skills/prism-ui/.claude-plugin/plugin.json +16 -0
- package/skills/prism-ui/SKILL.md +247 -0
- package/skills/proof/SKILL.md +33 -0
- package/skills/proof-api/.claude-plugin/plugin.json +16 -0
- package/skills/proof-api/SKILL.md +86 -0
- package/skills/proof-audit/.claude-plugin/plugin.json +16 -0
- package/skills/proof-audit/SKILL.md +97 -0
- package/skills/proof-design/.claude-plugin/plugin.json +16 -0
- package/skills/proof-design/SKILL.md +133 -0
- package/skills/proof-e2e/.claude-plugin/plugin.json +16 -0
- package/skills/proof-e2e/SKILL.md +309 -0
- package/skills/proof-recon/.claude-plugin/plugin.json +16 -0
- package/skills/proof-recon/SKILL.md +98 -0
- package/skills/proof-strategy/.claude-plugin/plugin.json +16 -0
- package/skills/proof-strategy/SKILL.md +150 -0
- package/skills/relay/SKILL.md +33 -0
- package/skills/relay-audit/.claude-plugin/plugin.json +16 -0
- package/skills/relay-audit/SKILL.md +101 -0
- package/skills/relay-deploy/.claude-plugin/plugin.json +16 -0
- package/skills/relay-deploy/SKILL.md +404 -0
- package/skills/relay-docker/.claude-plugin/plugin.json +16 -0
- package/skills/relay-docker/SKILL.md +73 -0
- package/skills/relay-pipeline/.claude-plugin/plugin.json +16 -0
- package/skills/relay-pipeline/SKILL.md +267 -0
- package/skills/relay-recon/.claude-plugin/plugin.json +16 -0
- package/skills/relay-recon/SKILL.md +108 -0
- package/skills/relay-ship/.claude-plugin/plugin.json +16 -0
- package/skills/relay-ship/SKILL.md +253 -0
- package/skills/spine/SKILL.md +33 -0
- package/skills/spine-api/.claude-plugin/plugin.json +16 -0
- package/skills/spine-api/SKILL.md +184 -0
- package/skills/spine-design/.claude-plugin/plugin.json +16 -0
- package/skills/spine-design/SKILL.md +193 -0
- package/skills/spine-perf/.claude-plugin/plugin.json +16 -0
- package/skills/spine-perf/SKILL.md +120 -0
- package/skills/spine-recon/.claude-plugin/plugin.json +16 -0
- package/skills/spine-recon/SKILL.md +130 -0
- package/skills/spine-review/.claude-plugin/plugin.json +16 -0
- package/skills/spine-review/SKILL.md +122 -0
- package/skills/spine-service/.claude-plugin/plugin.json +16 -0
- package/skills/spine-service/SKILL.md +77 -0
- package/skills/surge/SKILL.md +33 -0
- package/skills/surge-activation/.claude-plugin/plugin.json +16 -0
- package/skills/surge-activation/SKILL.md +130 -0
- package/skills/surge-experiment/.claude-plugin/plugin.json +16 -0
- package/skills/surge-experiment/SKILL.md +134 -0
- package/skills/surge-landing/.claude-plugin/plugin.json +16 -0
- package/skills/surge-landing/SKILL.md +65 -0
- package/skills/surge-plg/.claude-plugin/plugin.json +16 -0
- package/skills/surge-plg/SKILL.md +243 -0
- package/skills/surge-recon/.claude-plugin/plugin.json +16 -0
- package/skills/surge-recon/SKILL.md +109 -0
- package/skills/surge-retention/.claude-plugin/plugin.json +16 -0
- package/skills/surge-retention/SKILL.md +222 -0
- package/skills/tonone-onboard/.claude-plugin/plugin.json +17 -0
- package/skills/tonone-onboard/SKILL.md +158 -0
- package/skills/touch/SKILL.md +33 -0
- package/skills/touch-app/.claude-plugin/plugin.json +16 -0
- package/skills/touch-app/SKILL.md +335 -0
- package/skills/touch-audit/.claude-plugin/plugin.json +16 -0
- package/skills/touch-audit/SKILL.md +190 -0
- package/skills/touch-feature/.claude-plugin/plugin.json +16 -0
- package/skills/touch-feature/SKILL.md +242 -0
- package/skills/touch-recon/.claude-plugin/plugin.json +16 -0
- package/skills/touch-recon/SKILL.md +194 -0
- package/skills/touch-release/.claude-plugin/plugin.json +16 -0
- package/skills/touch-release/SKILL.md +216 -0
- package/skills/touch-ui/.claude-plugin/plugin.json +16 -0
- package/skills/touch-ui/SKILL.md +58 -0
- package/skills/vigil/SKILL.md +32 -0
- package/skills/vigil-alert/.claude-plugin/plugin.json +16 -0
- package/skills/vigil-alert/SKILL.md +291 -0
- package/skills/vigil-check/.claude-plugin/plugin.json +16 -0
- package/skills/vigil-check/SKILL.md +108 -0
- package/skills/vigil-incident/.claude-plugin/plugin.json +16 -0
- package/skills/vigil-incident/SKILL.md +152 -0
- package/skills/vigil-instrument/.claude-plugin/plugin.json +16 -0
- package/skills/vigil-instrument/SKILL.md +324 -0
- package/skills/vigil-recon/.claude-plugin/plugin.json +16 -0
- package/skills/vigil-recon/SKILL.md +114 -0
- package/skills/volt/SKILL.md +32 -0
- package/skills/volt-driver/.claude-plugin/plugin.json +16 -0
- package/skills/volt-driver/SKILL.md +112 -0
- package/skills/volt-firmware/.claude-plugin/plugin.json +16 -0
- package/skills/volt-firmware/SKILL.md +271 -0
- package/skills/volt-ota/.claude-plugin/plugin.json +16 -0
- package/skills/volt-ota/SKILL.md +312 -0
- package/skills/volt-power/.claude-plugin/plugin.json +16 -0
- package/skills/volt-power/SKILL.md +112 -0
- package/skills/volt-recon/.claude-plugin/plugin.json +16 -0
- package/skills/volt-recon/SKILL.md +100 -0
- package/skills/warden/SKILL.md +32 -0
- package/skills/warden-audit/.claude-plugin/plugin.json +16 -0
- package/skills/warden-audit/SKILL.md +103 -0
- package/skills/warden-harden/.claude-plugin/plugin.json +16 -0
- package/skills/warden-harden/SKILL.md +245 -0
- package/skills/warden-iam/.claude-plugin/plugin.json +16 -0
- package/skills/warden-iam/SKILL.md +102 -0
- package/skills/warden-recon/.claude-plugin/plugin.json +16 -0
- package/skills/warden-recon/SKILL.md +115 -0
- package/skills/warden-threat/.claude-plugin/plugin.json +16 -0
- package/skills/warden-threat/SKILL.md +155 -0
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: touch-feature
|
|
3
|
+
description: Produce a mobile feature spec — user story, technical approach, component breakdown, platform-specific considerations, edge cases. Use when asked to "add a screen", "spec this feature", "mobile feature", "new tab", "push notifications", or "deep link".
|
|
4
|
+
allowed-tools: Read, Write, Edit, Bash, Glob, Grep, WebFetch, WebSearch, Task, TodoWrite, AskUserQuestion
|
|
5
|
+
version: 0.6.4
|
|
6
|
+
author: tonone-ai <hello@tonone.ai>
|
|
7
|
+
license: MIT
|
|
8
|
+
tags: ["ai-agency", "tonone"]
|
|
9
|
+
compatibility: "Designed for Claude Code"
|
|
10
|
+
---
|
|
11
|
+
|
|
12
|
+
# Mobile Feature Spec
|
|
13
|
+
|
|
14
|
+
You are Touch — the mobile engineer on the Engineering Team.
|
|
15
|
+
|
|
16
|
+
Follow the output format defined in docs/output-kit.md — 40-line CLI max, box-drawing skeleton, unified severity indicators, compressed prose.
|
|
17
|
+
|
|
18
|
+
Given a feature description, produce the implementation spec. Make the technical decisions. Don't present options and ask the human to choose — choose, with rationale.
|
|
19
|
+
|
|
20
|
+
## Step 0: Detect Stack
|
|
21
|
+
|
|
22
|
+
Scan the project to understand what you're building into:
|
|
23
|
+
|
|
24
|
+
```bash
|
|
25
|
+
# Platform + framework
|
|
26
|
+
ls -la *.xcodeproj *.xcworkspace 2>/dev/null
|
|
27
|
+
cat package.json 2>/dev/null | grep -E '"react-native"|"expo"|"@react-navigation"'
|
|
28
|
+
cat pubspec.yaml 2>/dev/null | head -20
|
|
29
|
+
find . -name "build.gradle" -maxdepth 3 2>/dev/null | head -3
|
|
30
|
+
|
|
31
|
+
# Architecture pattern in use
|
|
32
|
+
grep -rl "ViewModel\|@Observable\|@StateObject\|BLoC\|Riverpod\|Zustand\|useReducer" \
|
|
33
|
+
--include="*.swift" --include="*.kt" --include="*.ts" --include="*.tsx" --include="*.dart" \
|
|
34
|
+
. 2>/dev/null | head -8
|
|
35
|
+
|
|
36
|
+
# Navigation library
|
|
37
|
+
grep -rl "NavigationStack\|NavHost\|createNativeStackNavigator\|GoRouter\|auto_route" \
|
|
38
|
+
--include="*.swift" --include="*.kt" --include="*.ts" --include="*.tsx" --include="*.dart" \
|
|
39
|
+
. 2>/dev/null | head -5
|
|
40
|
+
|
|
41
|
+
# Existing screen/feature structure
|
|
42
|
+
ls src/screens/ lib/features/ App/Features/ 2>/dev/null | head -20
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
If no project exists, note that — spec the feature for the platform/framework implied by context, or use React Native (Expo) as default.
|
|
46
|
+
|
|
47
|
+
## Step 1: Understand the Feature
|
|
48
|
+
|
|
49
|
+
Read the feature description. If any of these are ambiguous, infer from context — only ask if genuinely blocked on a constraint that changes the architecture:
|
|
50
|
+
|
|
51
|
+
- What does this feature do for the user?
|
|
52
|
+
- Where does it live in the app (new tab, pushed screen, modal, bottom sheet)?
|
|
53
|
+
- Does it require API calls? (what data)
|
|
54
|
+
- Does it need to work offline?
|
|
55
|
+
- Is there any platform-specific behavior (iOS-only widget, Android back gesture, haptics)?
|
|
56
|
+
|
|
57
|
+
## Step 2: Write the Feature Spec
|
|
58
|
+
|
|
59
|
+
Output the spec in this structure:
|
|
60
|
+
|
|
61
|
+
---
|
|
62
|
+
|
|
63
|
+
## Feature Spec: [Feature Name]
|
|
64
|
+
|
|
65
|
+
**Platform:** [iOS / Android / Cross-platform (RN/Flutter)]
|
|
66
|
+
**Framework:** [SwiftUI / Jetpack Compose / React Native / Flutter]
|
|
67
|
+
**Navigation placement:** [Tab N / Pushed from [Screen] / Modal / Bottom sheet]
|
|
68
|
+
|
|
69
|
+
### User Story
|
|
70
|
+
|
|
71
|
+
As a [user type], I want to [action] so that [outcome].
|
|
72
|
+
|
|
73
|
+
**Acceptance criteria:**
|
|
74
|
+
|
|
75
|
+
- [ ] [Specific, testable behavior 1]
|
|
76
|
+
- [ ] [Specific, testable behavior 2]
|
|
77
|
+
- [ ] [Specific, testable behavior 3]
|
|
78
|
+
- [ ] Offline: [what happens with no connection]
|
|
79
|
+
- [ ] Error: [what happens on API failure]
|
|
80
|
+
- [ ] Empty: [what the screen shows with no data]
|
|
81
|
+
|
|
82
|
+
---
|
|
83
|
+
|
|
84
|
+
### Technical Approach
|
|
85
|
+
|
|
86
|
+
[2–4 sentences. The chosen architecture pattern, why it fits, any non-obvious decisions. State the decision, not the tradeoffs menu.]
|
|
87
|
+
|
|
88
|
+
**State management:** [chosen approach + why — e.g., "local ViewModel with StateFlow, no global store needed — feature is self-contained"]
|
|
89
|
+
|
|
90
|
+
**Data flow:** [where data comes from → how it moves → what the UI binds to]
|
|
91
|
+
|
|
92
|
+
**Offline strategy:** [cache-first / network-first / optimistic update / not needed — with rationale]
|
|
93
|
+
|
|
94
|
+
---
|
|
95
|
+
|
|
96
|
+
### Component Breakdown
|
|
97
|
+
|
|
98
|
+
| Component | Type | Responsibility |
|
|
99
|
+
| ------------------------- | --------- | ------------------------------------------- |
|
|
100
|
+
| `[ScreenName]Screen` | View | Layout, binds to ViewModel, no logic |
|
|
101
|
+
| `[ScreenName]ViewModel` | ViewModel | State management, API calls, business logic |
|
|
102
|
+
| `[FeatureName]Repository` | Service | Data fetching, cache coordination |
|
|
103
|
+
| `[ComponentName]` | Shared UI | [what it renders] |
|
|
104
|
+
|
|
105
|
+
**Files to create:**
|
|
106
|
+
|
|
107
|
+
```
|
|
108
|
+
[platform-appropriate file paths matching existing project structure]
|
|
109
|
+
```
|
|
110
|
+
|
|
111
|
+
**Files to modify:**
|
|
112
|
+
|
|
113
|
+
```
|
|
114
|
+
[navigation graph / router / tab config — wherever routing is registered]
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
---
|
|
118
|
+
|
|
119
|
+
### Key Screens / States
|
|
120
|
+
|
|
121
|
+
**Loading state:** [skeleton screen / spinner placement / what's visible]
|
|
122
|
+
|
|
123
|
+
**Loaded state:** [primary layout description — list/grid/form/detail]
|
|
124
|
+
|
|
125
|
+
**Empty state:** [illustration or icon + message + CTA if applicable]
|
|
126
|
+
|
|
127
|
+
**Error state:** [inline error or toast/snackbar + retry action]
|
|
128
|
+
|
|
129
|
+
**Offline state:** [show cached data with banner / block with message / transparent]
|
|
130
|
+
|
|
131
|
+
---
|
|
132
|
+
|
|
133
|
+
### Platform-Specific Considerations
|
|
134
|
+
|
|
135
|
+
**iOS:**
|
|
136
|
+
|
|
137
|
+
- [HIG compliance notes — navigation bar style, swipe-to-dismiss, SF Symbols to use]
|
|
138
|
+
- [iOS-specific APIs if any — haptics, Keychain, Share Sheet, Widgets]
|
|
139
|
+
- [Dynamic Type and Dark Mode: any non-obvious accommodations]
|
|
140
|
+
|
|
141
|
+
**Android:**
|
|
142
|
+
|
|
143
|
+
- [Material 3 component choices — which components to use]
|
|
144
|
+
- [Back gesture/hardware back behavior]
|
|
145
|
+
- [Android-specific behavior if any — deep link intent filters, widgets]
|
|
146
|
+
|
|
147
|
+
_(For cross-platform: note where Platform.select or platform conditionals are needed)_
|
|
148
|
+
|
|
149
|
+
---
|
|
150
|
+
|
|
151
|
+
### API Contract
|
|
152
|
+
|
|
153
|
+
**Endpoint:** `[METHOD] /[path]`
|
|
154
|
+
|
|
155
|
+
**Request:**
|
|
156
|
+
|
|
157
|
+
```json
|
|
158
|
+
{
|
|
159
|
+
"field": "type — description"
|
|
160
|
+
}
|
|
161
|
+
```
|
|
162
|
+
|
|
163
|
+
**Response:**
|
|
164
|
+
|
|
165
|
+
```json
|
|
166
|
+
{
|
|
167
|
+
"field": "type — description"
|
|
168
|
+
}
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
**Error cases to handle:**
|
|
172
|
+
|
|
173
|
+
- `401` → redirect to login, clear tokens
|
|
174
|
+
- `404` → show empty state with message
|
|
175
|
+
- `5xx` → show retry error state, cache last known data
|
|
176
|
+
|
|
177
|
+
_(If API doesn't exist yet: flag as "API TBD — Spine to spec" and describe the contract needed)_
|
|
178
|
+
|
|
179
|
+
---
|
|
180
|
+
|
|
181
|
+
### Navigation Wiring
|
|
182
|
+
|
|
183
|
+
**Route registration:**
|
|
184
|
+
|
|
185
|
+
```
|
|
186
|
+
[code snippet showing how to register the route in the existing navigation structure]
|
|
187
|
+
```
|
|
188
|
+
|
|
189
|
+
**Deep link pattern:** `[app-scheme://path/to/screen]` or "Not deep-linkable"
|
|
190
|
+
|
|
191
|
+
**Data passed via navigation:** `[params object shape]` or "None"
|
|
192
|
+
|
|
193
|
+
**Back navigation:** [Standard pop / custom back handler / modal dismiss gesture]
|
|
194
|
+
|
|
195
|
+
---
|
|
196
|
+
|
|
197
|
+
### Edge Cases
|
|
198
|
+
|
|
199
|
+
| Scenario | Behavior |
|
|
200
|
+
| -------------------------------------------------------------------- | ---------------------------------------------------------- |
|
|
201
|
+
| User taps [action] twice | Debounce — second tap ignored while first in flight |
|
|
202
|
+
| Network drops mid-load | Show cached data if available, else error state with retry |
|
|
203
|
+
| [Feature-specific edge case] | [Specified behavior] |
|
|
204
|
+
| App backgrounded during [operation] | [Continue / cancel / queue] |
|
|
205
|
+
| [Permission denied — if feature needs camera/location/notifications] | Explain why, link to Settings |
|
|
206
|
+
|
|
207
|
+
---
|
|
208
|
+
|
|
209
|
+
### Tests
|
|
210
|
+
|
|
211
|
+
**Unit tests (ViewModel/logic):**
|
|
212
|
+
|
|
213
|
+
- `test_[featureName]_loadsData_success` — mocked API returns data, state transitions to loaded
|
|
214
|
+
- `test_[featureName]_loadsData_networkError` — API throws, state transitions to error
|
|
215
|
+
- `test_[featureName]_[coreBusinessLogic]` — [what it validates]
|
|
216
|
+
|
|
217
|
+
**UI/Widget tests:**
|
|
218
|
+
|
|
219
|
+
- Loading state renders skeleton
|
|
220
|
+
- Error state renders retry button
|
|
221
|
+
- [Core interaction] triggers correct state change
|
|
222
|
+
|
|
223
|
+
**Integration test (if complex flow):**
|
|
224
|
+
|
|
225
|
+
- Full happy path: load → interact → result
|
|
226
|
+
|
|
227
|
+
---
|
|
228
|
+
|
|
229
|
+
### Done Criteria
|
|
230
|
+
|
|
231
|
+
This feature is done when:
|
|
232
|
+
|
|
233
|
+
- [ ] All acceptance criteria pass on a real device (not just simulator)
|
|
234
|
+
- [ ] Tested on a low-end device (Android) or iPhone SE (iOS)
|
|
235
|
+
- [ ] Offline behavior verified by toggling airplane mode
|
|
236
|
+
- [ ] Deep link opens correct screen from a cold start (if deep-linkable)
|
|
237
|
+
- [ ] ViewModel unit tests pass
|
|
238
|
+
- [ ] No new crashes in the crash reporter after 1 session of dogfooding
|
|
239
|
+
|
|
240
|
+
## Delivery
|
|
241
|
+
|
|
242
|
+
If output exceeds the 40-line CLI budget, invoke `/atlas-report` with the full findings. The HTML report is the output. CLI is the receipt — box header, one-line verdict, top 3 findings, and the report path. Never dump analysis to CLI.
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "touch-recon",
|
|
3
|
+
"version": "0.9.7",
|
|
4
|
+
"description": "Mobile reconnaissance \u2014 understand the app's tech stack, architecture, dependencies, and health for takeover. Use when asked to \"understand this app\", \"mobile assessment\", or \"app health\".",
|
|
5
|
+
"author": {
|
|
6
|
+
"name": "tonone-ai",
|
|
7
|
+
"url": "https://tonone.ai"
|
|
8
|
+
},
|
|
9
|
+
"repository": "https://github.com/tonone-ai/tonone",
|
|
10
|
+
"license": "MIT",
|
|
11
|
+
"type": "skill",
|
|
12
|
+
"keywords": [
|
|
13
|
+
"touch",
|
|
14
|
+
"skill"
|
|
15
|
+
]
|
|
16
|
+
}
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: touch-recon
|
|
3
|
+
description: Mobile reconnaissance — understand the app's tech stack, architecture, dependencies, and health for takeover. Use when asked to "understand this app", "mobile assessment", or "app health".
|
|
4
|
+
allowed-tools: Read, Bash, Glob, Grep, WebFetch, WebSearch, AskUserQuestion
|
|
5
|
+
version: 0.6.4
|
|
6
|
+
author: tonone-ai <hello@tonone.ai>
|
|
7
|
+
license: MIT
|
|
8
|
+
tags: ["ai-agency", "tonone"]
|
|
9
|
+
compatibility: "Designed for Claude Code"
|
|
10
|
+
---
|
|
11
|
+
|
|
12
|
+
# Mobile Reconnaissance
|
|
13
|
+
|
|
14
|
+
You are Touch — the mobile engineer on the Engineering Team.
|
|
15
|
+
|
|
16
|
+
## Steps
|
|
17
|
+
|
|
18
|
+
### Step 0: Detect Environment
|
|
19
|
+
|
|
20
|
+
Scan the project broadly to understand everything about the mobile app:
|
|
21
|
+
|
|
22
|
+
```bash
|
|
23
|
+
# Platform detection
|
|
24
|
+
ls -la *.xcodeproj *.xcworkspace 2>/dev/null
|
|
25
|
+
ls -la android/ ios/ 2>/dev/null
|
|
26
|
+
ls -la build.gradle* settings.gradle* 2>/dev/null
|
|
27
|
+
cat package.json 2>/dev/null | grep -iE "react-native|expo|capacitor"
|
|
28
|
+
cat pubspec.yaml 2>/dev/null
|
|
29
|
+
|
|
30
|
+
# Project structure
|
|
31
|
+
find . -maxdepth 3 -type d -not -path "*/node_modules/*" -not -path "*/.git/*" -not -path "*/build/*" -not -path "*/Pods/*" 2>/dev/null | head -40
|
|
32
|
+
|
|
33
|
+
# Dependencies
|
|
34
|
+
cat Podfile 2>/dev/null
|
|
35
|
+
cat android/app/build.gradle 2>/dev/null
|
|
36
|
+
cat package.json 2>/dev/null
|
|
37
|
+
cat pubspec.yaml 2>/dev/null
|
|
38
|
+
|
|
39
|
+
# CI/CD
|
|
40
|
+
ls -la fastlane/ .github/workflows/ bitrise.yml .circleci/ 2>/dev/null
|
|
41
|
+
|
|
42
|
+
# Tests
|
|
43
|
+
find . -type f \( -name "*Test*" -o -name "*test*" -o -name "*spec*" -o -name "*Spec*" \) -not -path "*/node_modules/*" -not -path "*/Pods/*" 2>/dev/null | head -20
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
### Step 1: Tech Stack
|
|
47
|
+
|
|
48
|
+
Identify the complete tech stack:
|
|
49
|
+
|
|
50
|
+
- **Platform:** iOS, Android, both, cross-platform
|
|
51
|
+
- **Language:** Swift, Objective-C, Kotlin, Java, TypeScript, Dart
|
|
52
|
+
- **UI framework:** SwiftUI, UIKit, Jetpack Compose, XML Views, React Native, Flutter
|
|
53
|
+
- **State management:** Combine, Redux, MobX, BLoC, Riverpod, Provider
|
|
54
|
+
- **Networking:** URLSession, Alamofire, Retrofit, Ktor, Axios, Dio
|
|
55
|
+
- **Storage:** Core Data, Room, Realm, SQLite, AsyncStorage, Hive
|
|
56
|
+
- **Dependency injection:** Hilt, Koin, Swinject, Provider
|
|
57
|
+
|
|
58
|
+
### Step 2: Architecture Pattern
|
|
59
|
+
|
|
60
|
+
Understand how the app is structured:
|
|
61
|
+
|
|
62
|
+
- **Pattern:** MVC, MVVM, MVI, Clean Architecture, VIPER, Redux
|
|
63
|
+
- **Module structure:** monolith, feature modules, packages
|
|
64
|
+
- **Navigation:** how screens connect (coordinator, router, navigation graph)
|
|
65
|
+
- **API layer:** centralized client or scattered fetch calls
|
|
66
|
+
- **Error handling:** consistent strategy or ad-hoc
|
|
67
|
+
|
|
68
|
+
Assess: is the architecture consistent, or does it shift between features (common in apps with multiple contributors over time)?
|
|
69
|
+
|
|
70
|
+
### Step 3: API Integration Patterns
|
|
71
|
+
|
|
72
|
+
Map how the app talks to backends:
|
|
73
|
+
|
|
74
|
+
- **Base URL(s)** — how many backends does it talk to?
|
|
75
|
+
- **Authentication** — token type, refresh flow, storage
|
|
76
|
+
- **Request/response models** — typed or stringly-typed?
|
|
77
|
+
- **Error handling** — unified error model or per-endpoint?
|
|
78
|
+
- **Caching** — any response caching? Cache invalidation strategy?
|
|
79
|
+
- **Offline support** — does the app work without network?
|
|
80
|
+
|
|
81
|
+
### Step 4: Third-Party SDKs
|
|
82
|
+
|
|
83
|
+
Inventory all third-party dependencies:
|
|
84
|
+
|
|
85
|
+
- **Analytics:** Firebase Analytics, Mixpanel, Amplitude, PostHog
|
|
86
|
+
- **Crash reporting:** Crashlytics, Sentry, BugSnag
|
|
87
|
+
- **Auth:** Firebase Auth, Auth0, custom
|
|
88
|
+
- **Push:** FCM, APNs, OneSignal
|
|
89
|
+
- **Payments:** Stripe, RevenueCat, StoreKit 2
|
|
90
|
+
- **Maps:** Google Maps, MapKit, Mapbox
|
|
91
|
+
- **Ads:** AdMob, Meta Audience Network
|
|
92
|
+
- **Other:** feature flags, A/B testing, remote config
|
|
93
|
+
|
|
94
|
+
Flag any deprecated, abandoned, or duplicate SDKs.
|
|
95
|
+
|
|
96
|
+
### Step 5: CI/CD Status
|
|
97
|
+
|
|
98
|
+
Assess the build and release pipeline:
|
|
99
|
+
|
|
100
|
+
- **CI provider:** GitHub Actions, Bitrise, CircleCI, Codemagic, none
|
|
101
|
+
- **Build automation:** Fastlane, Gradle tasks, Xcode Cloud, manual
|
|
102
|
+
- **Test automation:** tests run on CI? Coverage tracked?
|
|
103
|
+
- **Beta distribution:** TestFlight, Firebase App Distribution, manual IPA/APK sharing
|
|
104
|
+
- **Release process:** automated or manual? Who triggers releases?
|
|
105
|
+
- **Code signing:** managed (match) or manual? Certificates expiring soon?
|
|
106
|
+
|
|
107
|
+
### Step 6: App Store Listing Status
|
|
108
|
+
|
|
109
|
+
Check the app's store presence:
|
|
110
|
+
|
|
111
|
+
- **Store listing:** is it live? Both platforms?
|
|
112
|
+
- **Recent updates:** when was the last release? (stale apps get deprioritized)
|
|
113
|
+
- **Reviews and ratings:** current rating, recent review sentiment
|
|
114
|
+
- **Version history:** how frequently does the app ship?
|
|
115
|
+
- **Store compliance:** any known rejections or policy issues?
|
|
116
|
+
|
|
117
|
+
### Step 7: Code Quality Assessment
|
|
118
|
+
|
|
119
|
+
Evaluate code health:
|
|
120
|
+
|
|
121
|
+
- **Test coverage:** percentage and quality (meaningful tests vs boilerplate)
|
|
122
|
+
- **Linting:** is a linter configured and enforced?
|
|
123
|
+
- **Code style:** consistent formatting, naming conventions
|
|
124
|
+
- **Documentation:** inline docs, architecture docs, onboarding guide
|
|
125
|
+
- **Dead code:** unused files, unreachable screens, commented-out blocks
|
|
126
|
+
- **TODO/FIXME count:** how much acknowledged debt?
|
|
127
|
+
|
|
128
|
+
### Step 8: Dependency Freshness
|
|
129
|
+
|
|
130
|
+
Follow the output format defined in docs/output-kit.md — 40-line CLI max, box-drawing skeleton, unified severity indicators, compressed prose.
|
|
131
|
+
|
|
132
|
+
Check dependency health:
|
|
133
|
+
|
|
134
|
+
- **Major version behind:** any dependencies 2+ major versions behind?
|
|
135
|
+
- **Security vulnerabilities:** known CVEs in current dependency versions?
|
|
136
|
+
- **Deprecated dependencies:** any libraries that are no longer maintained?
|
|
137
|
+
- **Lock file present:** is the dependency graph deterministic?
|
|
138
|
+
- **Minimum platform version:** are dependencies forcing an old or new minimum target?
|
|
139
|
+
|
|
140
|
+
Present the full assessment:
|
|
141
|
+
|
|
142
|
+
```
|
|
143
|
+
## Mobile Reconnaissance Report
|
|
144
|
+
|
|
145
|
+
**App:** [name] | **Platform:** [platform]
|
|
146
|
+
**Framework:** [framework] | **Architecture:** [pattern]
|
|
147
|
+
|
|
148
|
+
### Tech Stack Summary
|
|
149
|
+
| Layer | Technology |
|
|
150
|
+
|-------|-----------|
|
|
151
|
+
| Language | [lang] |
|
|
152
|
+
| UI | [framework] |
|
|
153
|
+
| State | [management] |
|
|
154
|
+
| Network | [library] |
|
|
155
|
+
| Storage | [solution] |
|
|
156
|
+
| DI | [framework] |
|
|
157
|
+
|
|
158
|
+
### Third-Party SDKs ([count] total)
|
|
159
|
+
| Category | SDK | Version | Status |
|
|
160
|
+
|----------|-----|---------|--------|
|
|
161
|
+
| Analytics | [name] | [ver] | [current/outdated/deprecated] |
|
|
162
|
+
| Crash | [name] | [ver] | [current/outdated/deprecated] |
|
|
163
|
+
| [etc] | | | |
|
|
164
|
+
|
|
165
|
+
### CI/CD
|
|
166
|
+
- Provider: [name or "none"]
|
|
167
|
+
- Automation: [Fastlane/manual/etc]
|
|
168
|
+
- Beta: [TestFlight/Firebase/manual]
|
|
169
|
+
- Last release: [date]
|
|
170
|
+
|
|
171
|
+
### Health Scores
|
|
172
|
+
| Area | Score | Notes |
|
|
173
|
+
|------|-------|-------|
|
|
174
|
+
| Code quality | [1-10] | [note] |
|
|
175
|
+
| Test coverage | [1-10] | [note] |
|
|
176
|
+
| Dependency health | [1-10] | [note] |
|
|
177
|
+
| CI/CD maturity | [1-10] | [note] |
|
|
178
|
+
| Store compliance | [1-10] | [note] |
|
|
179
|
+
| Architecture | [1-10] | [note] |
|
|
180
|
+
|
|
181
|
+
### Top Risks
|
|
182
|
+
1. [risk] — [impact and urgency]
|
|
183
|
+
2. [risk] — [impact and urgency]
|
|
184
|
+
3. [risk] — [impact and urgency]
|
|
185
|
+
|
|
186
|
+
### Quick Wins
|
|
187
|
+
1. [action] — [effort: low/medium] — [impact: high/medium]
|
|
188
|
+
2. [action] — [effort: low/medium] — [impact: high/medium]
|
|
189
|
+
3. [action] — [effort: low/medium] — [impact: high/medium]
|
|
190
|
+
```
|
|
191
|
+
|
|
192
|
+
## Delivery
|
|
193
|
+
|
|
194
|
+
If output exceeds the 40-line CLI budget, invoke `/atlas-report` with the full findings. The HTML report is the output. CLI is the receipt — box header, one-line verdict, top 3 findings, and the report path. Never dump analysis to CLI.
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "touch-release",
|
|
3
|
+
"version": "0.9.7",
|
|
4
|
+
"description": "Set up mobile release pipeline \u2014 Fastlane, code signing, CI, beta distribution, versioning. Use when asked about \"app store setup\", \"release pipeline\", \"fastlane\", \"beta distribution\", or \"signing\".",
|
|
5
|
+
"author": {
|
|
6
|
+
"name": "tonone-ai",
|
|
7
|
+
"url": "https://tonone.ai"
|
|
8
|
+
},
|
|
9
|
+
"repository": "https://github.com/tonone-ai/tonone",
|
|
10
|
+
"license": "MIT",
|
|
11
|
+
"type": "skill",
|
|
12
|
+
"keywords": [
|
|
13
|
+
"touch",
|
|
14
|
+
"skill"
|
|
15
|
+
]
|
|
16
|
+
}
|
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: touch-release
|
|
3
|
+
description: Set up mobile release pipeline — Fastlane, code signing, CI, beta distribution, versioning. Use when asked about "app store setup", "release pipeline", "fastlane", "beta distribution", or "signing".
|
|
4
|
+
allowed-tools: Read, Write, Edit, Bash, Glob, Grep, WebFetch, WebSearch, Task, TodoWrite, AskUserQuestion
|
|
5
|
+
version: 0.6.4
|
|
6
|
+
author: tonone-ai <hello@tonone.ai>
|
|
7
|
+
license: MIT
|
|
8
|
+
tags: ["ai-agency", "tonone"]
|
|
9
|
+
compatibility: "Designed for Claude Code"
|
|
10
|
+
---
|
|
11
|
+
|
|
12
|
+
# Set Up Mobile Release Pipeline
|
|
13
|
+
|
|
14
|
+
You are Touch — the mobile engineer on the Engineering Team.
|
|
15
|
+
|
|
16
|
+
## Steps
|
|
17
|
+
|
|
18
|
+
### Step 0: Detect Environment
|
|
19
|
+
|
|
20
|
+
Scan the project to understand the mobile platform and existing CI/CD:
|
|
21
|
+
|
|
22
|
+
```bash
|
|
23
|
+
# Platform detection
|
|
24
|
+
ls -la *.xcodeproj *.xcworkspace 2>/dev/null
|
|
25
|
+
ls -la android/ build.gradle* 2>/dev/null
|
|
26
|
+
cat package.json 2>/dev/null | grep -iE "react-native|expo"
|
|
27
|
+
cat pubspec.yaml 2>/dev/null
|
|
28
|
+
|
|
29
|
+
# Existing CI/CD
|
|
30
|
+
ls -la fastlane/ 2>/dev/null
|
|
31
|
+
cat fastlane/Fastfile 2>/dev/null | head -40
|
|
32
|
+
ls -la .github/workflows/ 2>/dev/null
|
|
33
|
+
cat bitrise.yml 2>/dev/null | head -20
|
|
34
|
+
ls -la .circleci/ 2>/dev/null
|
|
35
|
+
|
|
36
|
+
# Code signing
|
|
37
|
+
ls -la *.mobileprovision 2>/dev/null
|
|
38
|
+
ls -la fastlane/Matchfile 2>/dev/null
|
|
39
|
+
grep -r "signingConfig\|keystore\|KEYSTORE" --include="*.gradle" --include="*.gradle.kts" . 2>/dev/null | head -5
|
|
40
|
+
|
|
41
|
+
# Current version
|
|
42
|
+
grep -r "CFBundleShortVersionString\|versionName\|version\":" --include="*.plist" --include="*.gradle" --include="*.gradle.kts" --include="package.json" --include="pubspec.yaml" . 2>/dev/null | head -5
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
Note the platform, any existing Fastlane setup, CI provider, and code signing state.
|
|
46
|
+
|
|
47
|
+
### Step 1: Fastlane Setup
|
|
48
|
+
|
|
49
|
+
Create or update Fastlane configuration:
|
|
50
|
+
|
|
51
|
+
**Fastfile lanes:**
|
|
52
|
+
|
|
53
|
+
- **`beta`** — build and distribute to testers
|
|
54
|
+
- Increment build number
|
|
55
|
+
- Build the app (release configuration)
|
|
56
|
+
- Upload to TestFlight (iOS) or Firebase App Distribution (Android)
|
|
57
|
+
- Post to Slack/notification channel
|
|
58
|
+
|
|
59
|
+
- **`release`** — build and submit to app store
|
|
60
|
+
- Increment version number (semantic versioning)
|
|
61
|
+
- Build the app (release configuration)
|
|
62
|
+
- Upload to App Store Connect (iOS) or Google Play Console (Android)
|
|
63
|
+
- Create git tag
|
|
64
|
+
- Post release notes
|
|
65
|
+
|
|
66
|
+
- **`test`** — run test suite
|
|
67
|
+
- Run unit tests
|
|
68
|
+
- Run UI tests (if applicable)
|
|
69
|
+
- Generate coverage report
|
|
70
|
+
|
|
71
|
+
**Supporting files:**
|
|
72
|
+
|
|
73
|
+
```
|
|
74
|
+
fastlane/
|
|
75
|
+
Fastfile — lane definitions
|
|
76
|
+
Appfile — app identifier, team ID
|
|
77
|
+
Matchfile — code signing config (iOS)
|
|
78
|
+
Pluginfile — Fastlane plugins
|
|
79
|
+
.env.default — shared environment variables
|
|
80
|
+
.env.beta — beta-specific config
|
|
81
|
+
.env.production — production-specific config
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
### Step 2: Code Signing
|
|
85
|
+
|
|
86
|
+
Set up code signing properly:
|
|
87
|
+
|
|
88
|
+
**iOS (using Match):**
|
|
89
|
+
|
|
90
|
+
- Configure `fastlane match` for certificate and provisioning profile management
|
|
91
|
+
- Set up a private git repo or cloud storage for certificates
|
|
92
|
+
- Generate profiles for: development, ad-hoc (beta), app-store (production)
|
|
93
|
+
- Document the match passphrase storage (do not commit it)
|
|
94
|
+
|
|
95
|
+
**Android:**
|
|
96
|
+
|
|
97
|
+
- Create or locate the release keystore
|
|
98
|
+
- Store keystore password securely (not in the repo)
|
|
99
|
+
- Configure signing in `build.gradle`
|
|
100
|
+
- Set up Play App Signing (let Google manage the release key)
|
|
101
|
+
|
|
102
|
+
### Step 3: App Store Metadata Structure
|
|
103
|
+
|
|
104
|
+
Set up metadata management:
|
|
105
|
+
|
|
106
|
+
```
|
|
107
|
+
fastlane/metadata/
|
|
108
|
+
[locale]/
|
|
109
|
+
name.txt — app name
|
|
110
|
+
subtitle.txt — short description
|
|
111
|
+
description.txt — full description
|
|
112
|
+
keywords.txt — search keywords (iOS)
|
|
113
|
+
release_notes.txt — what's new
|
|
114
|
+
privacy_url.txt — privacy policy URL
|
|
115
|
+
screenshots/
|
|
116
|
+
[device]/ — organized by device type
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
- Use `fastlane deliver` (iOS) or `fastlane supply` (Android) for metadata sync
|
|
120
|
+
- Screenshots organized by device type and locale
|
|
121
|
+
- Privacy policy URL and support URL configured
|
|
122
|
+
|
|
123
|
+
### Step 4: CI Integration
|
|
124
|
+
|
|
125
|
+
Set up CI to build, test, and deploy:
|
|
126
|
+
|
|
127
|
+
**GitHub Actions example:**
|
|
128
|
+
|
|
129
|
+
- **On every PR:** run tests, lint, build (debug)
|
|
130
|
+
- **On merge to main:** run tests, build beta, deploy to testers
|
|
131
|
+
- **On tag/release:** build production, submit to store
|
|
132
|
+
|
|
133
|
+
CI configuration includes:
|
|
134
|
+
|
|
135
|
+
- Caching (CocoaPods, Gradle, node_modules, pub cache)
|
|
136
|
+
- Secrets management (signing keys, API keys, match passphrase)
|
|
137
|
+
- macOS runner for iOS builds
|
|
138
|
+
- Artifact upload (build logs, test results, IPA/APK)
|
|
139
|
+
|
|
140
|
+
### Step 5: Beta Distribution
|
|
141
|
+
|
|
142
|
+
Set up beta testing distribution:
|
|
143
|
+
|
|
144
|
+
**iOS:**
|
|
145
|
+
|
|
146
|
+
- TestFlight via `fastlane pilot`
|
|
147
|
+
- Internal testers (team) — immediate distribution
|
|
148
|
+
- External testers — requires brief review (~24h)
|
|
149
|
+
|
|
150
|
+
**Android:**
|
|
151
|
+
|
|
152
|
+
- Firebase App Distribution via `fastlane firebase_app_distribution`
|
|
153
|
+
- Or Google Play Internal Testing track
|
|
154
|
+
- Tester groups configured
|
|
155
|
+
|
|
156
|
+
**Both:**
|
|
157
|
+
|
|
158
|
+
- Tester group management
|
|
159
|
+
- Build notes auto-generated from commits
|
|
160
|
+
- Notification to testers on new build
|
|
161
|
+
|
|
162
|
+
### Step 6: Version Bumping
|
|
163
|
+
|
|
164
|
+
Automate version management:
|
|
165
|
+
|
|
166
|
+
- **Version number:** semantic versioning (major.minor.patch)
|
|
167
|
+
- **Build number:** auto-incrementing (CI build number or timestamp)
|
|
168
|
+
- **Bump script:** `fastlane bump_patch`, `bump_minor`, `bump_major`
|
|
169
|
+
- **Single source of truth** — version defined in one place, not scattered across files
|
|
170
|
+
- **Git tag on release** — tag format: `v1.2.3`
|
|
171
|
+
|
|
172
|
+
### Step 7: Changelog Generation
|
|
173
|
+
|
|
174
|
+
Follow the output format defined in docs/output-kit.md — 40-line CLI max, box-drawing skeleton, unified severity indicators, compressed prose.
|
|
175
|
+
|
|
176
|
+
Automate changelog from git history:
|
|
177
|
+
|
|
178
|
+
- Generate from conventional commits or PR titles since last tag
|
|
179
|
+
- Format for app store release notes (character limits: 4000 for iOS, 500 for Play Store)
|
|
180
|
+
- Include in build metadata
|
|
181
|
+
- Store in `CHANGELOG.md` for the team
|
|
182
|
+
|
|
183
|
+
Present a summary:
|
|
184
|
+
|
|
185
|
+
```
|
|
186
|
+
## Release Pipeline Configured
|
|
187
|
+
|
|
188
|
+
**Platform:** [iOS/Android/Both]
|
|
189
|
+
|
|
190
|
+
### Lanes
|
|
191
|
+
- `fastlane beta` — build + TestFlight/Firebase App Distribution
|
|
192
|
+
- `fastlane release` — build + App Store/Play Store submission
|
|
193
|
+
- `fastlane test` — test suite
|
|
194
|
+
|
|
195
|
+
### Code Signing
|
|
196
|
+
- iOS: [match/manual] — profiles in [location]
|
|
197
|
+
- Android: [keystore location] — Play App Signing [enabled/disabled]
|
|
198
|
+
|
|
199
|
+
### CI
|
|
200
|
+
- Provider: [GitHub Actions/Bitrise/etc]
|
|
201
|
+
- PR: test + build
|
|
202
|
+
- Main: test + beta deploy
|
|
203
|
+
- Tag: production release
|
|
204
|
+
|
|
205
|
+
### Files Created
|
|
206
|
+
[List key files]
|
|
207
|
+
|
|
208
|
+
### Next Steps
|
|
209
|
+
- [ ] Add signing credentials to CI secrets
|
|
210
|
+
- [ ] Configure tester groups
|
|
211
|
+
- [ ] First beta build: `fastlane beta`
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
## Delivery
|
|
215
|
+
|
|
216
|
+
If output exceeds the 40-line CLI budget, invoke `/atlas-report` with the full findings. The HTML report is the output. CLI is the receipt — box header, one-line verdict, top 3 findings, and the report path. Never dump analysis to CLI.
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "touch-ui",
|
|
3
|
+
"version": "0.9.7",
|
|
4
|
+
"description": "|",
|
|
5
|
+
"author": {
|
|
6
|
+
"name": "tonone-ai",
|
|
7
|
+
"url": "https://tonone.ai"
|
|
8
|
+
},
|
|
9
|
+
"repository": "https://github.com/tonone-ai/tonone",
|
|
10
|
+
"license": "MIT",
|
|
11
|
+
"type": "skill",
|
|
12
|
+
"keywords": [
|
|
13
|
+
"touch",
|
|
14
|
+
"skill"
|
|
15
|
+
]
|
|
16
|
+
}
|