@rubix0270/arboris 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/README.md +151 -0
  2. package/cli/manifest.json +323 -0
  3. package/dist/cli.mjs +376 -0
  4. package/package.json +81 -0
  5. package/prisma/skills/accessibility/SKILL.md +147 -0
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  7. package/prisma/skills/agent-eval/SKILL.md +146 -0
  8. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  10. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  18. package/prisma/skills/agent-sort/SKILL.md +216 -0
  19. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  20. package/prisma/skills/agentic-os/SKILL.md +388 -0
  21. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  22. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  23. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  24. package/prisma/skills/angular-developer/SKILL.md +155 -0
  25. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  26. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  27. package/prisma/skills/angular-developer/references/cli.md +86 -0
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  29. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  30. package/prisma/skills/angular-developer/references/components.md +117 -0
  31. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  33. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  34. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  37. package/prisma/skills/angular-developer/references/effects.md +83 -0
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  39. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  40. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  41. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  42. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  44. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  46. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  49. package/prisma/skills/angular-developer/references/resource.md +77 -0
  50. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  51. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  53. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  55. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  56. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  60. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  61. package/prisma/skills/api-design/SKILL.md +524 -0
  62. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  63. package/prisma/skills/article-writing/SKILL.md +80 -0
  64. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  66. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  67. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  68. package/prisma/skills/benchmark/SKILL.md +94 -0
  69. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  72. package/prisma/skills/blueprint/SKILL.md +106 -0
  73. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  82. package/prisma/skills/brand-voice/SKILL.md +98 -0
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  84. package/prisma/skills/browser-qa/SKILL.md +105 -0
  85. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  86. package/prisma/skills/canary-watch/SKILL.md +108 -0
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  89. package/prisma/skills/ck/SKILL.md +148 -0
  90. package/prisma/skills/ck/commands/forget.mjs +44 -0
  91. package/prisma/skills/ck/commands/info.mjs +24 -0
  92. package/prisma/skills/ck/commands/init.mjs +143 -0
  93. package/prisma/skills/ck/commands/list.mjs +40 -0
  94. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  95. package/prisma/skills/ck/commands/resume.mjs +36 -0
  96. package/prisma/skills/ck/commands/save.mjs +210 -0
  97. package/prisma/skills/ck/commands/shared.mjs +387 -0
  98. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  99. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  100. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  101. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  102. package/prisma/skills/code-tour/SKILL.md +254 -0
  103. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  104. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  105. package/prisma/skills/coding-standards/SKILL.md +551 -0
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  107. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  109. package/prisma/skills/config-gc/SKILL.md +120 -0
  110. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  111. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  112. package/prisma/skills/content-engine/SKILL.md +132 -0
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  114. package/prisma/skills/context-budget/SKILL.md +136 -0
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  116. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  117. package/prisma/skills/continuous-learning/config.json +18 -0
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  124. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  132. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  133. package/prisma/skills/council/SKILL.md +204 -0
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  135. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  136. package/prisma/skills/crosspost/SKILL.md +112 -0
  137. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  138. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  141. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  142. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  144. package/prisma/skills/database-migrations/SKILL.md +430 -0
  145. package/prisma/skills/deep-research/SKILL.md +160 -0
  146. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  147. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  149. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  150. package/prisma/skills/design-system/SKILL.md +83 -0
  151. package/prisma/skills/django-celery/SKILL.md +458 -0
  152. package/prisma/skills/django-patterns/SKILL.md +735 -0
  153. package/prisma/skills/django-security/SKILL.md +644 -0
  154. package/prisma/skills/django-tdd/SKILL.md +730 -0
  155. package/prisma/skills/django-verification/SKILL.md +470 -0
  156. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  157. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  158. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  159. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  161. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  162. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  163. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  165. package/prisma/skills/email-ops/SKILL.md +122 -0
  166. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  168. package/prisma/skills/error-handling/SKILL.md +377 -0
  169. package/prisma/skills/eval-harness/SKILL.md +271 -0
  170. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  171. package/prisma/skills/exa-search/SKILL.md +108 -0
  172. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  173. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  174. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  175. package/prisma/skills/flox-environments/SKILL.md +497 -0
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  178. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  179. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  180. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  181. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  183. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  184. package/prisma/skills/frontend-slides/html-template.md +419 -0
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  187. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  188. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  189. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  190. package/prisma/skills/gateguard/SKILL.md +133 -0
  191. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  192. package/prisma/skills/git-workflow/SKILL.md +716 -0
  193. package/prisma/skills/github-ops/SKILL.md +145 -0
  194. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  195. package/prisma/skills/golang-testing/SKILL.md +721 -0
  196. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  197. package/prisma/skills/growth-log/SKILL.md +128 -0
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  202. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  204. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  206. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  210. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  212. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  214. package/prisma/skills/investor-materials/SKILL.md +97 -0
  215. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  216. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  219. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  220. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  223. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  224. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  225. package/prisma/skills/jira-integration/SKILL.md +303 -0
  226. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  227. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  231. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  232. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  234. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  236. package/prisma/skills/laravel-security/SKILL.md +948 -0
  237. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  238. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  239. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  240. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  245. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  247. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  248. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  251. package/prisma/skills/manim-video/SKILL.md +90 -0
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  253. package/prisma/skills/market-research/SKILL.md +76 -0
  254. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  256. package/prisma/skills/messages-ops/SKILL.md +105 -0
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  258. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  259. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  260. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  261. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  262. package/prisma/skills/motion-ui/SKILL.md +576 -0
  263. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  265. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  268. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  269. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  283. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  284. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  285. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  286. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  287. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  288. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  289. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  291. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  292. package/prisma/skills/perl-security/SKILL.md +504 -0
  293. package/prisma/skills/perl-testing/SKILL.md +476 -0
  294. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  295. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  296. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  299. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  300. package/prisma/skills/product-capability/SKILL.md +142 -0
  301. package/prisma/skills/product-lens/SKILL.md +93 -0
  302. package/prisma/skills/production-audit/SKILL.md +207 -0
  303. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  304. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  305. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  306. package/prisma/skills/python-patterns/SKILL.md +751 -0
  307. package/prisma/skills/python-testing/SKILL.md +817 -0
  308. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  309. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  310. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  311. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  312. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  313. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  315. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  316. package/prisma/skills/react-patterns/SKILL.md +342 -0
  317. package/prisma/skills/react-performance/SKILL.md +575 -0
  318. package/prisma/skills/react-testing/SKILL.md +424 -0
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  321. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  323. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  342. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  355. package/prisma/skills/repo-scan/SKILL.md +79 -0
  356. package/prisma/skills/research-ops/SKILL.md +113 -0
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  358. package/prisma/skills/rules-distill/SKILL.md +265 -0
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  361. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  362. package/prisma/skills/rust-testing/SKILL.md +501 -0
  363. package/prisma/skills/safety-guard/SKILL.md +76 -0
  364. package/prisma/skills/santa-method/SKILL.md +307 -0
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  370. package/prisma/skills/search-first/SKILL.md +183 -0
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  372. package/prisma/skills/security-review/SKILL.md +504 -0
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  374. package/prisma/skills/security-scan/SKILL.md +166 -0
  375. package/prisma/skills/seo/SKILL.md +155 -0
  376. package/prisma/skills/skill-comply/SKILL.md +59 -0
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  380. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  383. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  386. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  387. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  388. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  389. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  390. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  393. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  394. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  395. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  396. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  397. package/prisma/skills/skill-scout/SKILL.md +141 -0
  398. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  402. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  403. package/prisma/skills/social-publisher/SKILL.md +130 -0
  404. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  405. package/prisma/skills/springboot-security/SKILL.md +273 -0
  406. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  407. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  408. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  412. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  413. package/prisma/skills/taste/SKILL.md +264 -0
  414. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  415. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  417. package/prisma/skills/team-builder/SKILL.md +169 -0
  418. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  422. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  426. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  427. package/prisma/skills/ui-demo/SKILL.md +466 -0
  428. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  429. package/prisma/skills/uncloud/SKILL.md +344 -0
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  431. package/prisma/skills/verification-loop/SKILL.md +127 -0
  432. package/prisma/skills/video-editing/SKILL.md +311 -0
  433. package/prisma/skills/videodb/SKILL.md +375 -0
  434. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  435. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  436. package/prisma/skills/videodb/reference/capture.md +101 -0
  437. package/prisma/skills/videodb/reference/editor.md +443 -0
  438. package/prisma/skills/videodb/reference/generative.md +331 -0
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  440. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  441. package/prisma/skills/videodb/reference/search.md +230 -0
  442. package/prisma/skills/videodb/reference/streaming.md +406 -0
  443. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  444. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  445. package/prisma/skills/visa-doc-translate/README.md +86 -0
  446. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  447. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  448. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  451. package/prisma/skills/x-api/SKILL.md +235 -0
@@ -0,0 +1,564 @@
1
+ ---
2
+ name: dart-flutter-patterns
3
+ description: Production-ready Dart and Flutter patterns covering null safety, immutable state, async composition, widget architecture, popular state management frameworks (BLoC, Riverpod, Provider), GoRouter navigation, Dio networking, Freezed code generation, and clean architecture.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Dart/Flutter Patterns
9
+
10
+ ## When to Use
11
+
12
+ Use this skill when:
13
+ - Starting a new Flutter feature and need idiomatic patterns for state management, navigation, or data access
14
+ - Reviewing or writing Dart code and need guidance on null safety, sealed types, or async composition
15
+ - Setting up a new Flutter project and choosing between BLoC, Riverpod, or Provider
16
+ - Implementing secure HTTP clients, WebView integration, or local storage
17
+ - Writing tests for Flutter widgets, Cubits, or Riverpod providers
18
+ - Wiring up GoRouter with authentication guards
19
+
20
+ ## How It Works
21
+
22
+ This skill provides copy-paste-ready Dart/Flutter code patterns organized by concern:
23
+ 1. **Null safety** — avoid `!`, prefer `?.`/`??`/pattern matching
24
+ 2. **Immutable state** — sealed classes, `freezed`, `copyWith`
25
+ 3. **Async composition** — concurrent `Future.wait`, safe `BuildContext` after `await`
26
+ 4. **Widget architecture** — extract to classes (not methods), `const` propagation, scoped rebuilds
27
+ 5. **State management** — BLoC/Cubit events, Riverpod notifiers and derived providers
28
+ 6. **Navigation** — GoRouter with reactive auth guards via `refreshListenable`
29
+ 7. **Networking** — Dio with interceptors, token refresh with one-time retry guard
30
+ 8. **Error handling** — global capture, `ErrorWidget.builder`, crashlytics wiring
31
+ 9. **Testing** — unit (BLoC test), widget (ProviderScope overrides), fakes over mocks
32
+
33
+ ## Examples
34
+
35
+ ```dart
36
+ // Sealed state — prevents impossible states
37
+ sealed class AsyncState<T> {}
38
+ final class Loading<T> extends AsyncState<T> {}
39
+ final class Success<T> extends AsyncState<T> { final T data; const Success(this.data); }
40
+ final class Failure<T> extends AsyncState<T> { final Object error; const Failure(this.error); }
41
+
42
+ // GoRouter with reactive auth redirect
43
+ final router = GoRouter(
44
+ refreshListenable: GoRouterRefreshStream(authCubit.stream),
45
+ redirect: (context, state) {
46
+ final authed = context.read<AuthCubit>().state is AuthAuthenticated;
47
+ if (!authed && !state.matchedLocation.startsWith('/login')) return '/login';
48
+ return null;
49
+ },
50
+ routes: [...],
51
+ );
52
+
53
+ // Riverpod derived provider with safe firstWhereOrNull
54
+ @riverpod
55
+ double cartTotal(Ref ref) {
56
+ final cart = ref.watch(cartNotifierProvider);
57
+ final products = ref.watch(productsProvider).valueOrNull ?? [];
58
+ return cart.fold(0.0, (total, item) {
59
+ final product = products.firstWhereOrNull((p) => p.id == item.productId);
60
+ return total + (product?.price ?? 0) * item.quantity;
61
+ });
62
+ }
63
+ ```
64
+
65
+ ---
66
+
67
+ Practical, production-ready patterns for Dart and Flutter applications. Library-agnostic where possible, with explicit coverage of the most common ecosystem packages.
68
+
69
+ ---
70
+
71
+ ## 1. Null Safety Fundamentals
72
+
73
+ ### Prefer Patterns Over Bang Operator
74
+
75
+ ```dart
76
+ // BAD — crashes at runtime if null
77
+ final name = user!.name;
78
+
79
+ // GOOD — provide fallback
80
+ final name = user?.name ?? 'Unknown';
81
+
82
+ // GOOD — Dart 3 pattern matching (preferred for complex cases)
83
+ final display = switch (user) {
84
+ User(:final name, :final email) => '$name <$email>',
85
+ null => 'Guest',
86
+ };
87
+
88
+ // GOOD — guard early return
89
+ String getUserName(User? user) {
90
+ if (user == null) return 'Unknown';
91
+ return user.name; // promoted to non-null after check
92
+ }
93
+ ```
94
+
95
+ ### Avoid `late` Overuse
96
+
97
+ ```dart
98
+ // BAD — defers null error to runtime
99
+ late String userId;
100
+
101
+ // GOOD — nullable with explicit initialization
102
+ String? userId;
103
+
104
+ // OK — use late only when initialization is guaranteed before first access
105
+ // (e.g., in initState() before any widget interaction)
106
+ late final AnimationController _controller;
107
+
108
+ @override
109
+ void initState() {
110
+ super.initState();
111
+ _controller = AnimationController(vsync: this, duration: const Duration(milliseconds: 300));
112
+ }
113
+ ```
114
+
115
+ ---
116
+
117
+ ## 2. Immutable State
118
+
119
+ ### Sealed Classes for State Hierarchies
120
+
121
+ ```dart
122
+ sealed class UserState {}
123
+
124
+ final class UserInitial extends UserState {}
125
+
126
+ final class UserLoading extends UserState {}
127
+
128
+ final class UserLoaded extends UserState {
129
+ const UserLoaded(this.user);
130
+ final User user;
131
+ }
132
+
133
+ final class UserError extends UserState {
134
+ const UserError(this.message);
135
+ final String message;
136
+ }
137
+
138
+ // Exhaustive switch — compiler enforces all branches
139
+ Widget buildFrom(UserState state) => switch (state) {
140
+ UserInitial() => const SizedBox.shrink(),
141
+ UserLoading() => const CircularProgressIndicator(),
142
+ UserLoaded(:final user) => UserCard(user: user),
143
+ UserError(:final message) => ErrorText(message),
144
+ };
145
+ ```
146
+
147
+ ### Freezed for Boilerplate-Free Immutability
148
+
149
+ ```dart
150
+ import 'package:freezed_annotation/freezed_annotation.dart';
151
+
152
+ part 'user.freezed.dart';
153
+ part 'user.g.dart';
154
+
155
+ @freezed
156
+ class User with _$User {
157
+ const factory User({
158
+ required String id,
159
+ required String name,
160
+ required String email,
161
+ @Default(false) bool isAdmin,
162
+ }) = _User;
163
+
164
+ factory User.fromJson(Map<String, dynamic> json) => _$UserFromJson(json);
165
+ }
166
+
167
+ // Usage
168
+ final user = User(id: '1', name: 'Alice', email: 'alice@example.com');
169
+ final updated = user.copyWith(name: 'Alice Smith'); // immutable update
170
+ final json = user.toJson();
171
+ final fromJson = User.fromJson(json);
172
+ ```
173
+
174
+ ---
175
+
176
+ ## 3. Async Composition
177
+
178
+ ### Structured Concurrency with Future.wait
179
+
180
+ ```dart
181
+ Future<DashboardData> loadDashboard(UserRepository users, OrderRepository orders) async {
182
+ // Run concurrently — don't await sequentially
183
+ final (userList, orderList) = await (
184
+ users.getAll(),
185
+ orders.getRecent(),
186
+ ).wait; // Dart 3 record destructuring + Future.wait extension
187
+
188
+ return DashboardData(users: userList, orders: orderList);
189
+ }
190
+ ```
191
+
192
+ ### Stream Patterns
193
+
194
+ ```dart
195
+ // Repository exposes reactive streams for live data
196
+ Stream<List<Item>> watchCartItems() => _db
197
+ .watchTable('cart_items')
198
+ .map((rows) => rows.map(Item.fromRow).toList());
199
+
200
+ // In widget layer — declarative, no manual subscription
201
+ StreamBuilder<List<Item>>(
202
+ stream: cartRepository.watchCartItems(),
203
+ builder: (context, snapshot) => switch (snapshot) {
204
+ AsyncSnapshot(connectionState: ConnectionState.waiting) =>
205
+ const CircularProgressIndicator(),
206
+ AsyncSnapshot(:final error?) => ErrorWidget(error.toString()),
207
+ AsyncSnapshot(:final data?) => CartList(items: data),
208
+ _ => const SizedBox.shrink(),
209
+ },
210
+ )
211
+ ```
212
+
213
+ ### BuildContext After Await
214
+
215
+ ```dart
216
+ // CRITICAL — always check mounted after any await in StatefulWidget
217
+ Future<void> _handleSubmit() async {
218
+ setState(() => _isLoading = true);
219
+ try {
220
+ await authService.login(_email, _password);
221
+ if (!mounted) return; // ← guard before using context
222
+ context.go('/home');
223
+ } on AuthException catch (e) {
224
+ if (!mounted) return;
225
+ ScaffoldMessenger.of(context).showSnackBar(SnackBar(content: Text(e.message)));
226
+ } finally {
227
+ if (mounted) setState(() => _isLoading = false);
228
+ }
229
+ }
230
+ ```
231
+
232
+ ---
233
+
234
+ ## 4. Widget Architecture
235
+
236
+ ### Extract to Classes, Not Methods
237
+
238
+ ```dart
239
+ // BAD — private method returning widget, prevents optimization
240
+ Widget _buildHeader() {
241
+ return Container(
242
+ padding: const EdgeInsets.all(16),
243
+ child: Text(title, style: Theme.of(context).textTheme.headlineMedium),
244
+ );
245
+ }
246
+
247
+ // GOOD — separate widget class, enables const, element reuse
248
+ class _PageHeader extends StatelessWidget {
249
+ const _PageHeader(this.title);
250
+ final String title;
251
+
252
+ @override
253
+ Widget build(BuildContext context) {
254
+ return Container(
255
+ padding: const EdgeInsets.all(16),
256
+ child: Text(title, style: Theme.of(context).textTheme.headlineMedium),
257
+ );
258
+ }
259
+ }
260
+ ```
261
+
262
+ ### const Propagation
263
+
264
+ ```dart
265
+ // BAD — new instances every rebuild
266
+ child: Padding(
267
+ padding: EdgeInsets.all(16.0), // not const
268
+ child: Icon(Icons.home, size: 24.0), // not const
269
+ )
270
+
271
+ // GOOD — const stops rebuild propagation
272
+ child: const Padding(
273
+ padding: EdgeInsets.all(16.0),
274
+ child: Icon(Icons.home, size: 24.0),
275
+ )
276
+ ```
277
+
278
+ ### Scoped Rebuilds
279
+
280
+ ```dart
281
+ // BAD — entire page rebuilds on every counter change
282
+ class CounterPage extends ConsumerWidget {
283
+ @override
284
+ Widget build(BuildContext context, WidgetRef ref) {
285
+ final count = ref.watch(counterProvider); // rebuilds everything
286
+ return Scaffold(
287
+ body: Column(children: [
288
+ const ExpensiveHeader(), // unnecessarily rebuilt
289
+ Text('$count'),
290
+ const ExpensiveFooter(), // unnecessarily rebuilt
291
+ ]),
292
+ );
293
+ }
294
+ }
295
+
296
+ // GOOD — isolate the rebuilding part
297
+ class CounterPage extends StatelessWidget {
298
+ const CounterPage({super.key});
299
+
300
+ @override
301
+ Widget build(BuildContext context) {
302
+ return const Scaffold(
303
+ body: Column(children: [
304
+ ExpensiveHeader(), // never rebuilt (const)
305
+ _CounterDisplay(), // only this rebuilds
306
+ ExpensiveFooter(), // never rebuilt (const)
307
+ ]),
308
+ );
309
+ }
310
+ }
311
+
312
+ class _CounterDisplay extends ConsumerWidget {
313
+ const _CounterDisplay();
314
+
315
+ @override
316
+ Widget build(BuildContext context, WidgetRef ref) {
317
+ final count = ref.watch(counterProvider);
318
+ return Text('$count');
319
+ }
320
+ }
321
+ ```
322
+
323
+ ---
324
+
325
+ ## 5. State Management: BLoC/Cubit
326
+
327
+ ```dart
328
+ // Cubit — synchronous or simple async state
329
+ class AuthCubit extends Cubit<AuthState> {
330
+ AuthCubit(this._authService) : super(const AuthState.initial());
331
+ final AuthService _authService;
332
+
333
+ Future<void> login(String email, String password) async {
334
+ emit(const AuthState.loading());
335
+ try {
336
+ final user = await _authService.login(email, password);
337
+ emit(AuthState.authenticated(user));
338
+ } on AuthException catch (e) {
339
+ emit(AuthState.error(e.message));
340
+ }
341
+ }
342
+
343
+ void logout() {
344
+ _authService.logout();
345
+ emit(const AuthState.initial());
346
+ }
347
+ }
348
+
349
+ // In widget
350
+ BlocBuilder<AuthCubit, AuthState>(
351
+ builder: (context, state) => switch (state) {
352
+ AuthInitial() => const LoginForm(),
353
+ AuthLoading() => const CircularProgressIndicator(),
354
+ AuthAuthenticated(:final user) => HomePage(user: user),
355
+ AuthError(:final message) => ErrorView(message: message),
356
+ },
357
+ )
358
+ ```
359
+
360
+ ---
361
+
362
+ ## 6. State Management: Riverpod
363
+
364
+ ```dart
365
+ // Auto-dispose async provider
366
+ @riverpod
367
+ Future<List<Product>> products(Ref ref) async {
368
+ final repo = ref.watch(productRepositoryProvider);
369
+ return repo.getAll();
370
+ }
371
+
372
+ // Notifier with complex mutations
373
+ @riverpod
374
+ class CartNotifier extends _$CartNotifier {
375
+ @override
376
+ List<CartItem> build() => [];
377
+
378
+ void add(Product product) {
379
+ final existing = state.where((i) => i.productId == product.id).firstOrNull;
380
+ if (existing != null) {
381
+ state = [
382
+ for (final item in state)
383
+ if (item.productId == product.id) item.copyWith(quantity: item.quantity + 1)
384
+ else item,
385
+ ];
386
+ } else {
387
+ state = [...state, CartItem(productId: product.id, quantity: 1)];
388
+ }
389
+ }
390
+
391
+ void remove(String productId) =>
392
+ state = state.where((i) => i.productId != productId).toList();
393
+
394
+ void clear() => state = [];
395
+ }
396
+
397
+ // Derived provider (selector pattern)
398
+ @riverpod
399
+ int cartCount(Ref ref) => ref.watch(cartNotifierProvider).length;
400
+
401
+ @riverpod
402
+ double cartTotal(Ref ref) {
403
+ final cart = ref.watch(cartNotifierProvider);
404
+ final products = ref.watch(productsProvider).valueOrNull ?? [];
405
+ return cart.fold(0.0, (total, item) {
406
+ // firstWhereOrNull (from collection package) avoids StateError when product is missing
407
+ final product = products.firstWhereOrNull((p) => p.id == item.productId);
408
+ return total + (product?.price ?? 0) * item.quantity;
409
+ });
410
+ }
411
+ ```
412
+
413
+ ---
414
+
415
+ ## 7. Navigation with GoRouter
416
+
417
+ ```dart
418
+ final router = GoRouter(
419
+ initialLocation: '/',
420
+ // refreshListenable re-evaluates redirect whenever auth state changes
421
+ refreshListenable: GoRouterRefreshStream(authCubit.stream),
422
+ redirect: (context, state) {
423
+ final isLoggedIn = context.read<AuthCubit>().state is AuthAuthenticated;
424
+ final isGoingToLogin = state.matchedLocation == '/login';
425
+ if (!isLoggedIn && !isGoingToLogin) return '/login';
426
+ if (isLoggedIn && isGoingToLogin) return '/';
427
+ return null;
428
+ },
429
+ routes: [
430
+ GoRoute(path: '/login', builder: (_, __) => const LoginPage()),
431
+ ShellRoute(
432
+ builder: (context, state, child) => AppShell(child: child),
433
+ routes: [
434
+ GoRoute(path: '/', builder: (_, __) => const HomePage()),
435
+ GoRoute(
436
+ path: '/products/:id',
437
+ builder: (context, state) =>
438
+ ProductDetailPage(id: state.pathParameters['id']!),
439
+ ),
440
+ ],
441
+ ),
442
+ ],
443
+ );
444
+ ```
445
+
446
+ ---
447
+
448
+ ## 8. HTTP with Dio
449
+
450
+ ```dart
451
+ final dio = Dio(BaseOptions(
452
+ baseUrl: const String.fromEnvironment('API_URL'),
453
+ connectTimeout: const Duration(seconds: 10),
454
+ receiveTimeout: const Duration(seconds: 30),
455
+ headers: {'Content-Type': 'application/json'},
456
+ ));
457
+
458
+ // Add auth interceptor
459
+ dio.interceptors.add(InterceptorsWrapper(
460
+ onRequest: (options, handler) async {
461
+ final token = await secureStorage.read(key: 'auth_token');
462
+ if (token != null) options.headers['Authorization'] = 'Bearer $token';
463
+ handler.next(options);
464
+ },
465
+ onError: (error, handler) async {
466
+ // Guard against infinite retry loops: only attempt refresh once per request
467
+ final isRetry = error.requestOptions.extra['_isRetry'] == true;
468
+ if (!isRetry && error.response?.statusCode == 401) {
469
+ final refreshed = await attemptTokenRefresh();
470
+ if (refreshed) {
471
+ error.requestOptions.extra['_isRetry'] = true;
472
+ return handler.resolve(await dio.fetch(error.requestOptions));
473
+ }
474
+ }
475
+ handler.next(error);
476
+ },
477
+ ));
478
+
479
+ // Repository using Dio
480
+ class UserApiDataSource {
481
+ const UserApiDataSource(this._dio);
482
+ final Dio _dio;
483
+
484
+ Future<User> getById(String id) async {
485
+ final response = await _dio.get<Map<String, dynamic>>('/users/$id');
486
+ return User.fromJson(response.data!);
487
+ }
488
+ }
489
+ ```
490
+
491
+ ---
492
+
493
+ ## 9. Error Handling Architecture
494
+
495
+ ```dart
496
+ // Global error capture — set up in main()
497
+ void main() {
498
+ FlutterError.onError = (details) {
499
+ FlutterError.presentError(details);
500
+ crashlytics.recordFlutterFatalError(details);
501
+ };
502
+
503
+ PlatformDispatcher.instance.onError = (error, stack) {
504
+ crashlytics.recordError(error, stack, fatal: true);
505
+ return true;
506
+ };
507
+
508
+ runApp(const App());
509
+ }
510
+
511
+ // Custom ErrorWidget for production
512
+ class App extends StatelessWidget {
513
+ @override
514
+ Widget build(BuildContext context) {
515
+ ErrorWidget.builder = (details) => ProductionErrorWidget(details);
516
+ return MaterialApp.router(routerConfig: router);
517
+ }
518
+ }
519
+ ```
520
+
521
+ ---
522
+
523
+ ## 10. Testing Quick Reference
524
+
525
+ ```dart
526
+ // Unit test — use case
527
+ test('GetUserUseCase returns null for missing user', () async {
528
+ final repo = FakeUserRepository();
529
+ final useCase = GetUserUseCase(repo);
530
+ expect(await useCase('missing-id'), isNull);
531
+ });
532
+
533
+ // BLoC test
534
+ blocTest<AuthCubit, AuthState>(
535
+ 'emits loading then error on failed login',
536
+ build: () => AuthCubit(FakeAuthService(throwsOn: 'login')),
537
+ act: (cubit) => cubit.login('user@test.com', 'wrong'),
538
+ expect: () => [const AuthState.loading(), isA<AuthError>()],
539
+ );
540
+
541
+ // Widget test
542
+ testWidgets('CartBadge shows item count', (tester) async {
543
+ await tester.pumpWidget(
544
+ ProviderScope(
545
+ overrides: [cartNotifierProvider.overrideWith(() => FakeCartNotifier(count: 3))],
546
+ child: const MaterialApp(home: CartBadge()),
547
+ ),
548
+ );
549
+ expect(find.text('3'), findsOneWidget);
550
+ });
551
+ ```
552
+
553
+ ---
554
+
555
+ ## References
556
+
557
+ - [Effective Dart: Design](https://dart.dev/effective-dart/design)
558
+ - [Flutter Performance Best Practices](https://docs.flutter.dev/perf/best-practices)
559
+ - [Riverpod Documentation](https://riverpod.dev/)
560
+ - [BLoC Library](https://bloclibrary.dev/)
561
+ - [GoRouter](https://pub.dev/packages/go_router)
562
+ - [Freezed](https://pub.dev/packages/freezed)
563
+ - Skill: `flutter-dart-code-review` — comprehensive review checklist
564
+ - Rules: `rules/dart/` — coding style, patterns, security, testing, hooks
@@ -0,0 +1,109 @@
1
+ ---
2
+ name: dashboard-builder
3
+ description: Build monitoring dashboards that answer real operator questions for Grafana, SigNoz, and similar platforms. Use when turning metrics into a working dashboard instead of a vanity board.
4
+ metadata:
5
+ origin: ECC direct-port adaptation
6
+ version: "1.0.0"
7
+ ---
8
+
9
+ # Dashboard Builder
10
+
11
+ Use this when the task is to build a dashboard people can operate from.
12
+
13
+ The goal is not "show every metric." The goal is to answer:
14
+
15
+ - is it healthy?
16
+ - where is the bottleneck?
17
+ - what changed?
18
+ - what action should someone take?
19
+
20
+ ## When to Use
21
+
22
+ - "Build a Kafka monitoring dashboard"
23
+ - "Create a Grafana dashboard for Elasticsearch"
24
+ - "Make a SigNoz dashboard for this service"
25
+ - "Turn this metrics list into a real operational dashboard"
26
+
27
+ ## Guardrails
28
+
29
+ - do not start from visual layout; start from operator questions
30
+ - do not include every available metric just because it exists
31
+ - do not mix health, throughput, and resource panels without structure
32
+ - do not ship panels without titles, units, and sane thresholds
33
+
34
+ ## Workflow
35
+
36
+ ### 1. Define the operating questions
37
+
38
+ Organize around:
39
+
40
+ - health / availability
41
+ - latency / performance
42
+ - throughput / volume
43
+ - saturation / resources
44
+ - service-specific risk
45
+
46
+ ### 2. Study the target platform schema
47
+
48
+ Inspect existing dashboards first:
49
+
50
+ - JSON structure
51
+ - query language
52
+ - variables
53
+ - threshold styling
54
+ - section layout
55
+
56
+ ### 3. Build the minimum useful board
57
+
58
+ Recommended structure:
59
+
60
+ 1. overview
61
+ 2. performance
62
+ 3. resources
63
+ 4. service-specific section
64
+
65
+ ### 4. Cut vanity panels
66
+
67
+ Every panel should answer a real question. If it does not, remove it.
68
+
69
+ ## Example Panel Sets
70
+
71
+ ### Elasticsearch
72
+
73
+ - cluster health
74
+ - shard allocation
75
+ - search latency
76
+ - indexing rate
77
+ - JVM heap / GC
78
+
79
+ ### Kafka
80
+
81
+ - broker count
82
+ - under-replicated partitions
83
+ - messages in / out
84
+ - consumer lag
85
+ - disk and network pressure
86
+
87
+ ### API gateway / ingress
88
+
89
+ - request rate
90
+ - p50 / p95 / p99 latency
91
+ - error rate
92
+ - upstream health
93
+ - active connections
94
+
95
+ ## Quality Checklist
96
+
97
+ - [ ] valid dashboard JSON
98
+ - [ ] clear section grouping
99
+ - [ ] titles and units are present
100
+ - [ ] thresholds/status colors are meaningful
101
+ - [ ] variables exist for common filters
102
+ - [ ] default time range and refresh are sensible
103
+ - [ ] no vanity panels with no operator value
104
+
105
+ ## Related Skills
106
+
107
+ - `research-ops`
108
+ - `backend-patterns`
109
+ - `terminal-ops`