@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.
Files changed (330) hide show
  1. package/.claude-plugin/CLAUDE.md +11 -0
  2. package/.claude-plugin/marketplace.json +2178 -0
  3. package/.claude-plugin/plugin.json +135 -0
  4. package/LICENSE +21 -0
  5. package/README.md +462 -0
  6. package/agents/apex.md +247 -0
  7. package/agents/atlas.md +181 -0
  8. package/agents/cortex.md +173 -0
  9. package/agents/crest.md +130 -0
  10. package/agents/draft.md +190 -0
  11. package/agents/echo.md +146 -0
  12. package/agents/flux.md +145 -0
  13. package/agents/forge.md +121 -0
  14. package/agents/form.md +244 -0
  15. package/agents/helm.md +180 -0
  16. package/agents/lens.md +145 -0
  17. package/agents/lumen.md +139 -0
  18. package/agents/pave.md +169 -0
  19. package/agents/pitch.md +177 -0
  20. package/agents/prism.md +181 -0
  21. package/agents/proof.md +205 -0
  22. package/agents/relay.md +147 -0
  23. package/agents/spine.md +207 -0
  24. package/agents/surge.md +127 -0
  25. package/agents/touch.md +185 -0
  26. package/agents/vigil.md +165 -0
  27. package/agents/volt.md +184 -0
  28. package/agents/warden.md +172 -0
  29. package/package.json +48 -0
  30. package/skills/apex/SKILL.md +32 -0
  31. package/skills/apex-plan/.claude-plugin/plugin.json +16 -0
  32. package/skills/apex-plan/SKILL.md +59 -0
  33. package/skills/apex-recon/.claude-plugin/plugin.json +16 -0
  34. package/skills/apex-recon/SKILL.md +91 -0
  35. package/skills/apex-review/.claude-plugin/plugin.json +16 -0
  36. package/skills/apex-review/SKILL.md +53 -0
  37. package/skills/apex-status/.claude-plugin/plugin.json +16 -0
  38. package/skills/apex-status/SKILL.md +42 -0
  39. package/skills/apex-takeover/.claude-plugin/plugin.json +16 -0
  40. package/skills/apex-takeover/SKILL.md +50 -0
  41. package/skills/atlas/SKILL.md +34 -0
  42. package/skills/atlas-adr/.claude-plugin/plugin.json +16 -0
  43. package/skills/atlas-adr/SKILL.md +147 -0
  44. package/skills/atlas-changelog/.claude-plugin/plugin.json +16 -0
  45. package/skills/atlas-changelog/SKILL.md +156 -0
  46. package/skills/atlas-map/.claude-plugin/plugin.json +16 -0
  47. package/skills/atlas-map/SKILL.md +183 -0
  48. package/skills/atlas-onboard/.claude-plugin/plugin.json +16 -0
  49. package/skills/atlas-onboard/SKILL.md +138 -0
  50. package/skills/atlas-present/.claude-plugin/plugin.json +16 -0
  51. package/skills/atlas-present/SKILL.md +214 -0
  52. package/skills/atlas-recon/.claude-plugin/plugin.json +16 -0
  53. package/skills/atlas-recon/SKILL.md +101 -0
  54. package/skills/atlas-report/.claude-plugin/plugin.json +16 -0
  55. package/skills/atlas-report/SKILL.md +304 -0
  56. package/skills/cortex/SKILL.md +32 -0
  57. package/skills/cortex-eval/.claude-plugin/plugin.json +16 -0
  58. package/skills/cortex-eval/SKILL.md +143 -0
  59. package/skills/cortex-integrate/.claude-plugin/plugin.json +16 -0
  60. package/skills/cortex-integrate/SKILL.md +218 -0
  61. package/skills/cortex-model/.claude-plugin/plugin.json +16 -0
  62. package/skills/cortex-model/SKILL.md +138 -0
  63. package/skills/cortex-prompt/.claude-plugin/plugin.json +16 -0
  64. package/skills/cortex-prompt/SKILL.md +246 -0
  65. package/skills/cortex-recon/.claude-plugin/plugin.json +16 -0
  66. package/skills/cortex-recon/SKILL.md +156 -0
  67. package/skills/crest/SKILL.md +32 -0
  68. package/skills/crest-compete/.claude-plugin/plugin.json +16 -0
  69. package/skills/crest-compete/SKILL.md +158 -0
  70. package/skills/crest-narrative/.claude-plugin/plugin.json +16 -0
  71. package/skills/crest-narrative/SKILL.md +124 -0
  72. package/skills/crest-okr/.claude-plugin/plugin.json +16 -0
  73. package/skills/crest-okr/SKILL.md +119 -0
  74. package/skills/crest-recon/.claude-plugin/plugin.json +16 -0
  75. package/skills/crest-recon/SKILL.md +91 -0
  76. package/skills/crest-roadmap/.claude-plugin/plugin.json +16 -0
  77. package/skills/crest-roadmap/SKILL.md +129 -0
  78. package/skills/draft/SKILL.md +34 -0
  79. package/skills/draft-flow/.claude-plugin/plugin.json +16 -0
  80. package/skills/draft-flow/SKILL.md +93 -0
  81. package/skills/draft-ia/.claude-plugin/plugin.json +16 -0
  82. package/skills/draft-ia/SKILL.md +204 -0
  83. package/skills/draft-landing/.claude-plugin/plugin.json +16 -0
  84. package/skills/draft-landing/SKILL.md +60 -0
  85. package/skills/draft-patterns/.claude-plugin/plugin.json +16 -0
  86. package/skills/draft-patterns/SKILL.md +55 -0
  87. package/skills/draft-recon/.claude-plugin/plugin.json +16 -0
  88. package/skills/draft-recon/SKILL.md +108 -0
  89. package/skills/draft-review/.claude-plugin/plugin.json +16 -0
  90. package/skills/draft-review/SKILL.md +131 -0
  91. package/skills/draft-wireframe/.claude-plugin/plugin.json +16 -0
  92. package/skills/draft-wireframe/SKILL.md +167 -0
  93. package/skills/echo/SKILL.md +32 -0
  94. package/skills/echo-feedback/.claude-plugin/plugin.json +16 -0
  95. package/skills/echo-feedback/SKILL.md +129 -0
  96. package/skills/echo-interview/.claude-plugin/plugin.json +16 -0
  97. package/skills/echo-interview/SKILL.md +189 -0
  98. package/skills/echo-jobs/.claude-plugin/plugin.json +16 -0
  99. package/skills/echo-jobs/SKILL.md +193 -0
  100. package/skills/echo-recon/.claude-plugin/plugin.json +16 -0
  101. package/skills/echo-recon/SKILL.md +96 -0
  102. package/skills/echo-segment/.claude-plugin/plugin.json +16 -0
  103. package/skills/echo-segment/SKILL.md +105 -0
  104. package/skills/flux/SKILL.md +33 -0
  105. package/skills/flux-health/.claude-plugin/plugin.json +16 -0
  106. package/skills/flux-health/SKILL.md +97 -0
  107. package/skills/flux-migrate/.claude-plugin/plugin.json +16 -0
  108. package/skills/flux-migrate/SKILL.md +176 -0
  109. package/skills/flux-pipeline/.claude-plugin/plugin.json +16 -0
  110. package/skills/flux-pipeline/SKILL.md +86 -0
  111. package/skills/flux-query/.claude-plugin/plugin.json +16 -0
  112. package/skills/flux-query/SKILL.md +87 -0
  113. package/skills/flux-recon/.claude-plugin/plugin.json +16 -0
  114. package/skills/flux-recon/SKILL.md +101 -0
  115. package/skills/flux-schema/.claude-plugin/plugin.json +16 -0
  116. package/skills/flux-schema/SKILL.md +125 -0
  117. package/skills/forge/SKILL.md +33 -0
  118. package/skills/forge-audit/.claude-plugin/plugin.json +16 -0
  119. package/skills/forge-audit/SKILL.md +117 -0
  120. package/skills/forge-cost/.claude-plugin/plugin.json +16 -0
  121. package/skills/forge-cost/SKILL.md +144 -0
  122. package/skills/forge-diagnose/.claude-plugin/plugin.json +16 -0
  123. package/skills/forge-diagnose/SKILL.md +122 -0
  124. package/skills/forge-infra/.claude-plugin/plugin.json +16 -0
  125. package/skills/forge-infra/SKILL.md +169 -0
  126. package/skills/forge-network/.claude-plugin/plugin.json +16 -0
  127. package/skills/forge-network/SKILL.md +106 -0
  128. package/skills/forge-recon/.claude-plugin/plugin.json +16 -0
  129. package/skills/forge-recon/SKILL.md +143 -0
  130. package/skills/form/SKILL.md +40 -0
  131. package/skills/form-audit/.claude-plugin/plugin.json +16 -0
  132. package/skills/form-audit/SKILL.md +290 -0
  133. package/skills/form-brand/.claude-plugin/plugin.json +16 -0
  134. package/skills/form-brand/SKILL.md +214 -0
  135. package/skills/form-component/.claude-plugin/plugin.json +16 -0
  136. package/skills/form-component/SKILL.md +336 -0
  137. package/skills/form-deck/.claude-plugin/plugin.json +16 -0
  138. package/skills/form-deck/SKILL.md +263 -0
  139. package/skills/form-email/.claude-plugin/plugin.json +16 -0
  140. package/skills/form-email/SKILL.md +304 -0
  141. package/skills/form-exam/.claude-plugin/plugin.json +16 -0
  142. package/skills/form-exam/SKILL.md +103 -0
  143. package/skills/form-logo/.claude-plugin/plugin.json +16 -0
  144. package/skills/form-logo/SKILL.md +231 -0
  145. package/skills/form-mobile/.claude-plugin/plugin.json +16 -0
  146. package/skills/form-mobile/SKILL.md +276 -0
  147. package/skills/form-palette/.claude-plugin/plugin.json +16 -0
  148. package/skills/form-palette/SKILL.md +68 -0
  149. package/skills/form-social/.claude-plugin/plugin.json +16 -0
  150. package/skills/form-social/SKILL.md +272 -0
  151. package/skills/form-style/.claude-plugin/plugin.json +16 -0
  152. package/skills/form-style/SKILL.md +63 -0
  153. package/skills/form-tokens/.claude-plugin/plugin.json +16 -0
  154. package/skills/form-tokens/SKILL.md +760 -0
  155. package/skills/form-web/.claude-plugin/plugin.json +16 -0
  156. package/skills/form-web/SKILL.md +254 -0
  157. package/skills/helm/SKILL.md +32 -0
  158. package/skills/helm-arbiter/.claude-plugin/plugin.json +16 -0
  159. package/skills/helm-arbiter/SKILL.md +104 -0
  160. package/skills/helm-brief/.claude-plugin/plugin.json +16 -0
  161. package/skills/helm-brief/SKILL.md +105 -0
  162. package/skills/helm-handoff/.claude-plugin/plugin.json +16 -0
  163. package/skills/helm-handoff/SKILL.md +102 -0
  164. package/skills/helm-plan/.claude-plugin/plugin.json +16 -0
  165. package/skills/helm-plan/SKILL.md +73 -0
  166. package/skills/helm-recon/.claude-plugin/plugin.json +16 -0
  167. package/skills/helm-recon/SKILL.md +99 -0
  168. package/skills/lens/SKILL.md +33 -0
  169. package/skills/lens-audit/.claude-plugin/plugin.json +16 -0
  170. package/skills/lens-audit/SKILL.md +101 -0
  171. package/skills/lens-chart/.claude-plugin/plugin.json +16 -0
  172. package/skills/lens-chart/SKILL.md +59 -0
  173. package/skills/lens-dashboard/.claude-plugin/plugin.json +16 -0
  174. package/skills/lens-dashboard/SKILL.md +212 -0
  175. package/skills/lens-metrics/.claude-plugin/plugin.json +16 -0
  176. package/skills/lens-metrics/SKILL.md +298 -0
  177. package/skills/lens-recon/.claude-plugin/plugin.json +16 -0
  178. package/skills/lens-recon/SKILL.md +106 -0
  179. package/skills/lens-report/.claude-plugin/plugin.json +16 -0
  180. package/skills/lens-report/SKILL.md +158 -0
  181. package/skills/lumen/SKILL.md +32 -0
  182. package/skills/lumen-abtest/.claude-plugin/plugin.json +16 -0
  183. package/skills/lumen-abtest/SKILL.md +217 -0
  184. package/skills/lumen-funnel/.claude-plugin/plugin.json +16 -0
  185. package/skills/lumen-funnel/SKILL.md +108 -0
  186. package/skills/lumen-instrument/.claude-plugin/plugin.json +16 -0
  187. package/skills/lumen-instrument/SKILL.md +130 -0
  188. package/skills/lumen-metrics/.claude-plugin/plugin.json +16 -0
  189. package/skills/lumen-metrics/SKILL.md +189 -0
  190. package/skills/lumen-recon/.claude-plugin/plugin.json +16 -0
  191. package/skills/lumen-recon/SKILL.md +108 -0
  192. package/skills/pave/SKILL.md +32 -0
  193. package/skills/pave-audit/.claude-plugin/plugin.json +16 -0
  194. package/skills/pave-audit/SKILL.md +109 -0
  195. package/skills/pave-catalog/.claude-plugin/plugin.json +16 -0
  196. package/skills/pave-catalog/SKILL.md +202 -0
  197. package/skills/pave-env/.claude-plugin/plugin.json +16 -0
  198. package/skills/pave-env/SKILL.md +102 -0
  199. package/skills/pave-golden/.claude-plugin/plugin.json +16 -0
  200. package/skills/pave-golden/SKILL.md +173 -0
  201. package/skills/pave-recon/.claude-plugin/plugin.json +16 -0
  202. package/skills/pave-recon/SKILL.md +118 -0
  203. package/skills/pitch/SKILL.md +33 -0
  204. package/skills/pitch-copy/.claude-plugin/plugin.json +16 -0
  205. package/skills/pitch-copy/SKILL.md +133 -0
  206. package/skills/pitch-landing/.claude-plugin/plugin.json +16 -0
  207. package/skills/pitch-landing/SKILL.md +62 -0
  208. package/skills/pitch-launch/.claude-plugin/plugin.json +16 -0
  209. package/skills/pitch-launch/SKILL.md +222 -0
  210. package/skills/pitch-message/.claude-plugin/plugin.json +16 -0
  211. package/skills/pitch-message/SKILL.md +98 -0
  212. package/skills/pitch-position/.claude-plugin/plugin.json +16 -0
  213. package/skills/pitch-position/SKILL.md +195 -0
  214. package/skills/pitch-recon/.claude-plugin/plugin.json +16 -0
  215. package/skills/pitch-recon/SKILL.md +102 -0
  216. package/skills/prism/SKILL.md +34 -0
  217. package/skills/prism-audit/.claude-plugin/plugin.json +16 -0
  218. package/skills/prism-audit/SKILL.md +129 -0
  219. package/skills/prism-chart/.claude-plugin/plugin.json +16 -0
  220. package/skills/prism-chart/SKILL.md +56 -0
  221. package/skills/prism-component/.claude-plugin/plugin.json +16 -0
  222. package/skills/prism-component/SKILL.md +270 -0
  223. package/skills/prism-dashboard/.claude-plugin/plugin.json +16 -0
  224. package/skills/prism-dashboard/SKILL.md +108 -0
  225. package/skills/prism-recon/.claude-plugin/plugin.json +16 -0
  226. package/skills/prism-recon/SKILL.md +109 -0
  227. package/skills/prism-stack/.claude-plugin/plugin.json +16 -0
  228. package/skills/prism-stack/SKILL.md +58 -0
  229. package/skills/prism-ui/.claude-plugin/plugin.json +16 -0
  230. package/skills/prism-ui/SKILL.md +247 -0
  231. package/skills/proof/SKILL.md +33 -0
  232. package/skills/proof-api/.claude-plugin/plugin.json +16 -0
  233. package/skills/proof-api/SKILL.md +86 -0
  234. package/skills/proof-audit/.claude-plugin/plugin.json +16 -0
  235. package/skills/proof-audit/SKILL.md +97 -0
  236. package/skills/proof-design/.claude-plugin/plugin.json +16 -0
  237. package/skills/proof-design/SKILL.md +133 -0
  238. package/skills/proof-e2e/.claude-plugin/plugin.json +16 -0
  239. package/skills/proof-e2e/SKILL.md +309 -0
  240. package/skills/proof-recon/.claude-plugin/plugin.json +16 -0
  241. package/skills/proof-recon/SKILL.md +98 -0
  242. package/skills/proof-strategy/.claude-plugin/plugin.json +16 -0
  243. package/skills/proof-strategy/SKILL.md +150 -0
  244. package/skills/relay/SKILL.md +33 -0
  245. package/skills/relay-audit/.claude-plugin/plugin.json +16 -0
  246. package/skills/relay-audit/SKILL.md +101 -0
  247. package/skills/relay-deploy/.claude-plugin/plugin.json +16 -0
  248. package/skills/relay-deploy/SKILL.md +404 -0
  249. package/skills/relay-docker/.claude-plugin/plugin.json +16 -0
  250. package/skills/relay-docker/SKILL.md +73 -0
  251. package/skills/relay-pipeline/.claude-plugin/plugin.json +16 -0
  252. package/skills/relay-pipeline/SKILL.md +267 -0
  253. package/skills/relay-recon/.claude-plugin/plugin.json +16 -0
  254. package/skills/relay-recon/SKILL.md +108 -0
  255. package/skills/relay-ship/.claude-plugin/plugin.json +16 -0
  256. package/skills/relay-ship/SKILL.md +253 -0
  257. package/skills/spine/SKILL.md +33 -0
  258. package/skills/spine-api/.claude-plugin/plugin.json +16 -0
  259. package/skills/spine-api/SKILL.md +184 -0
  260. package/skills/spine-design/.claude-plugin/plugin.json +16 -0
  261. package/skills/spine-design/SKILL.md +193 -0
  262. package/skills/spine-perf/.claude-plugin/plugin.json +16 -0
  263. package/skills/spine-perf/SKILL.md +120 -0
  264. package/skills/spine-recon/.claude-plugin/plugin.json +16 -0
  265. package/skills/spine-recon/SKILL.md +130 -0
  266. package/skills/spine-review/.claude-plugin/plugin.json +16 -0
  267. package/skills/spine-review/SKILL.md +122 -0
  268. package/skills/spine-service/.claude-plugin/plugin.json +16 -0
  269. package/skills/spine-service/SKILL.md +77 -0
  270. package/skills/surge/SKILL.md +33 -0
  271. package/skills/surge-activation/.claude-plugin/plugin.json +16 -0
  272. package/skills/surge-activation/SKILL.md +130 -0
  273. package/skills/surge-experiment/.claude-plugin/plugin.json +16 -0
  274. package/skills/surge-experiment/SKILL.md +134 -0
  275. package/skills/surge-landing/.claude-plugin/plugin.json +16 -0
  276. package/skills/surge-landing/SKILL.md +65 -0
  277. package/skills/surge-plg/.claude-plugin/plugin.json +16 -0
  278. package/skills/surge-plg/SKILL.md +243 -0
  279. package/skills/surge-recon/.claude-plugin/plugin.json +16 -0
  280. package/skills/surge-recon/SKILL.md +109 -0
  281. package/skills/surge-retention/.claude-plugin/plugin.json +16 -0
  282. package/skills/surge-retention/SKILL.md +222 -0
  283. package/skills/tonone-onboard/.claude-plugin/plugin.json +17 -0
  284. package/skills/tonone-onboard/SKILL.md +158 -0
  285. package/skills/touch/SKILL.md +33 -0
  286. package/skills/touch-app/.claude-plugin/plugin.json +16 -0
  287. package/skills/touch-app/SKILL.md +335 -0
  288. package/skills/touch-audit/.claude-plugin/plugin.json +16 -0
  289. package/skills/touch-audit/SKILL.md +190 -0
  290. package/skills/touch-feature/.claude-plugin/plugin.json +16 -0
  291. package/skills/touch-feature/SKILL.md +242 -0
  292. package/skills/touch-recon/.claude-plugin/plugin.json +16 -0
  293. package/skills/touch-recon/SKILL.md +194 -0
  294. package/skills/touch-release/.claude-plugin/plugin.json +16 -0
  295. package/skills/touch-release/SKILL.md +216 -0
  296. package/skills/touch-ui/.claude-plugin/plugin.json +16 -0
  297. package/skills/touch-ui/SKILL.md +58 -0
  298. package/skills/vigil/SKILL.md +32 -0
  299. package/skills/vigil-alert/.claude-plugin/plugin.json +16 -0
  300. package/skills/vigil-alert/SKILL.md +291 -0
  301. package/skills/vigil-check/.claude-plugin/plugin.json +16 -0
  302. package/skills/vigil-check/SKILL.md +108 -0
  303. package/skills/vigil-incident/.claude-plugin/plugin.json +16 -0
  304. package/skills/vigil-incident/SKILL.md +152 -0
  305. package/skills/vigil-instrument/.claude-plugin/plugin.json +16 -0
  306. package/skills/vigil-instrument/SKILL.md +324 -0
  307. package/skills/vigil-recon/.claude-plugin/plugin.json +16 -0
  308. package/skills/vigil-recon/SKILL.md +114 -0
  309. package/skills/volt/SKILL.md +32 -0
  310. package/skills/volt-driver/.claude-plugin/plugin.json +16 -0
  311. package/skills/volt-driver/SKILL.md +112 -0
  312. package/skills/volt-firmware/.claude-plugin/plugin.json +16 -0
  313. package/skills/volt-firmware/SKILL.md +271 -0
  314. package/skills/volt-ota/.claude-plugin/plugin.json +16 -0
  315. package/skills/volt-ota/SKILL.md +312 -0
  316. package/skills/volt-power/.claude-plugin/plugin.json +16 -0
  317. package/skills/volt-power/SKILL.md +112 -0
  318. package/skills/volt-recon/.claude-plugin/plugin.json +16 -0
  319. package/skills/volt-recon/SKILL.md +100 -0
  320. package/skills/warden/SKILL.md +32 -0
  321. package/skills/warden-audit/.claude-plugin/plugin.json +16 -0
  322. package/skills/warden-audit/SKILL.md +103 -0
  323. package/skills/warden-harden/.claude-plugin/plugin.json +16 -0
  324. package/skills/warden-harden/SKILL.md +245 -0
  325. package/skills/warden-iam/.claude-plugin/plugin.json +16 -0
  326. package/skills/warden-iam/SKILL.md +102 -0
  327. package/skills/warden-recon/.claude-plugin/plugin.json +16 -0
  328. package/skills/warden-recon/SKILL.md +115 -0
  329. package/skills/warden-threat/.claude-plugin/plugin.json +16 -0
  330. 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
+ }