@rubix0270/arboris 1.0.1 → 1.0.3

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/package.json +8 -19
  2. package/run.mjs +10 -0
  3. package/dist/cli.mjs +0 -382
  4. package/manifest.json +0 -323
  5. package/prisma/skills/accessibility/SKILL.md +0 -147
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +0 -257
  7. package/prisma/skills/agent-eval/SKILL.md +0 -146
  8. package/prisma/skills/agent-harness-construction/SKILL.md +0 -74
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +0 -154
  10. package/prisma/skills/agent-payment-x402/SKILL.md +0 -225
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +0 -182
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +0 -87
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +0 -86
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +0 -71
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +0 -64
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +0 -408
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +0 -86
  18. package/prisma/skills/agent-sort/SKILL.md +0 -216
  19. package/prisma/skills/agentic-engineering/SKILL.md +0 -64
  20. package/prisma/skills/agentic-os/SKILL.md +0 -388
  21. package/prisma/skills/ai-first-engineering/SKILL.md +0 -52
  22. package/prisma/skills/ai-regression-testing/SKILL.md +0 -386
  23. package/prisma/skills/android-clean-architecture/SKILL.md +0 -340
  24. package/prisma/skills/angular-developer/SKILL.md +0 -155
  25. package/prisma/skills/angular-developer/references/angular-animations.md +0 -160
  26. package/prisma/skills/angular-developer/references/angular-aria.md +0 -410
  27. package/prisma/skills/angular-developer/references/cli.md +0 -86
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +0 -59
  29. package/prisma/skills/angular-developer/references/component-styling.md +0 -91
  30. package/prisma/skills/angular-developer/references/components.md +0 -117
  31. package/prisma/skills/angular-developer/references/creating-services.md +0 -97
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +0 -69
  33. package/prisma/skills/angular-developer/references/define-routes.md +0 -67
  34. package/prisma/skills/angular-developer/references/defining-providers.md +0 -72
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +0 -120
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +0 -56
  37. package/prisma/skills/angular-developer/references/effects.md +0 -83
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +0 -43
  39. package/prisma/skills/angular-developer/references/host-elements.md +0 -80
  40. package/prisma/skills/angular-developer/references/injection-context.md +0 -63
  41. package/prisma/skills/angular-developer/references/inputs.md +0 -101
  42. package/prisma/skills/angular-developer/references/linked-signal.md +0 -59
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +0 -61
  44. package/prisma/skills/angular-developer/references/mcp.md +0 -108
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +0 -69
  46. package/prisma/skills/angular-developer/references/outputs.md +0 -86
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +0 -122
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +0 -44
  49. package/prisma/skills/angular-developer/references/resource.md +0 -77
  50. package/prisma/skills/angular-developer/references/route-animations.md +0 -56
  51. package/prisma/skills/angular-developer/references/route-guards.md +0 -52
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +0 -45
  53. package/prisma/skills/angular-developer/references/router-testing.md +0 -87
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +0 -68
  55. package/prisma/skills/angular-developer/references/signal-forms.md +0 -795
  56. package/prisma/skills/angular-developer/references/signals-overview.md +0 -94
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +0 -69
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +0 -114
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +0 -65
  60. package/prisma/skills/api-connector-builder/SKILL.md +0 -121
  61. package/prisma/skills/api-design/SKILL.md +0 -524
  62. package/prisma/skills/architecture-decision-records/SKILL.md +0 -180
  63. package/prisma/skills/article-writing/SKILL.md +0 -80
  64. package/prisma/skills/automation-audit-ops/SKILL.md +0 -143
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +0 -274
  66. package/prisma/skills/autonomous-loops/SKILL.md +0 -611
  67. package/prisma/skills/backend-patterns/SKILL.md +0 -562
  68. package/prisma/skills/benchmark/SKILL.md +0 -94
  69. package/prisma/skills/benchmark-methodology/SKILL.md +0 -190
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +0 -70
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +0 -165
  72. package/prisma/skills/blueprint/SKILL.md +0 -106
  73. package/prisma/skills/brand-discovery/SKILL.md +0 -145
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +0 -40
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +0 -44
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +0 -52
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +0 -57
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +0 -59
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +0 -50
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +0 -49
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +0 -133
  82. package/prisma/skills/brand-voice/SKILL.md +0 -98
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +0 -55
  84. package/prisma/skills/browser-qa/SKILL.md +0 -105
  85. package/prisma/skills/bun-runtime/SKILL.md +0 -85
  86. package/prisma/skills/canary-watch/SKILL.md +0 -108
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +0 -212
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +0 -164
  89. package/prisma/skills/ck/SKILL.md +0 -148
  90. package/prisma/skills/ck/commands/forget.mjs +0 -44
  91. package/prisma/skills/ck/commands/info.mjs +0 -24
  92. package/prisma/skills/ck/commands/init.mjs +0 -143
  93. package/prisma/skills/ck/commands/list.mjs +0 -40
  94. package/prisma/skills/ck/commands/migrate.mjs +0 -202
  95. package/prisma/skills/ck/commands/resume.mjs +0 -36
  96. package/prisma/skills/ck/commands/save.mjs +0 -210
  97. package/prisma/skills/ck/commands/shared.mjs +0 -387
  98. package/prisma/skills/ck/hooks/session-start.mjs +0 -224
  99. package/prisma/skills/claude-devfleet/SKILL.md +0 -112
  100. package/prisma/skills/click-path-audit/SKILL.md +0 -245
  101. package/prisma/skills/clickhouse-io/SKILL.md +0 -440
  102. package/prisma/skills/code-tour/SKILL.md +0 -254
  103. package/prisma/skills/codebase-onboarding/SKILL.md +0 -234
  104. package/prisma/skills/codehealth-mcp/SKILL.md +0 -167
  105. package/prisma/skills/coding-standards/SKILL.md +0 -551
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +0 -214
  107. package/prisma/skills/competitive-report-structure/SKILL.md +0 -162
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +0 -300
  109. package/prisma/skills/config-gc/SKILL.md +0 -120
  110. package/prisma/skills/configure-ecc/SKILL.md +0 -385
  111. package/prisma/skills/connections-optimizer/SKILL.md +0 -190
  112. package/prisma/skills/content-engine/SKILL.md +0 -132
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +0 -162
  114. package/prisma/skills/context-budget/SKILL.md +0 -136
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +0 -46
  116. package/prisma/skills/continuous-learning/SKILL.md +0 -132
  117. package/prisma/skills/continuous-learning/config.json +0 -18
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +0 -69
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +0 -361
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +0 -359
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +0 -189
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +0 -150
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +0 -248
  124. package/prisma/skills/continuous-learning-v2/config.json +0 -8
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +0 -585
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +0 -322
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -1956
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +0 -31
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +0 -68
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -1421
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +0 -184
  132. package/prisma/skills/cost-tracking/SKILL.md +0 -97
  133. package/prisma/skills/council/SKILL.md +0 -204
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +0 -724
  135. package/prisma/skills/cpp-testing/SKILL.md +0 -325
  136. package/prisma/skills/crosspost/SKILL.md +0 -112
  137. package/prisma/skills/csharp-testing/SKILL.md +0 -322
  138. package/prisma/skills/customer-billing-ops/SKILL.md +0 -141
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +0 -263
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +0 -564
  141. package/prisma/skills/dashboard-builder/SKILL.md +0 -109
  142. package/prisma/skills/data-scraper-agent/SKILL.md +0 -765
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +0 -73
  144. package/prisma/skills/database-migrations/SKILL.md +0 -430
  145. package/prisma/skills/deep-research/SKILL.md +0 -160
  146. package/prisma/skills/defi-amm-security/SKILL.md +0 -167
  147. package/prisma/skills/delivery-gate/SKILL.md +0 -126
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +0 -220
  149. package/prisma/skills/deployment-patterns/SKILL.md +0 -428
  150. package/prisma/skills/design-system/SKILL.md +0 -83
  151. package/prisma/skills/django-celery/SKILL.md +0 -458
  152. package/prisma/skills/django-patterns/SKILL.md +0 -735
  153. package/prisma/skills/django-security/SKILL.md +0 -644
  154. package/prisma/skills/django-tdd/SKILL.md +0 -730
  155. package/prisma/skills/django-verification/SKILL.md +0 -470
  156. package/prisma/skills/dmux-workflows/SKILL.md +0 -192
  157. package/prisma/skills/docker-patterns/SKILL.md +0 -365
  158. package/prisma/skills/documentation-lookup/SKILL.md +0 -91
  159. package/prisma/skills/dotnet-patterns/SKILL.md +0 -322
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +0 -124
  161. package/prisma/skills/e2e-testing/SKILL.md +0 -327
  162. package/prisma/skills/ecc-guide/SKILL.md +0 -190
  163. package/prisma/skills/ecc-recipes/SKILL.md +0 -149
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +0 -161
  165. package/prisma/skills/email-ops/SKILL.md +0 -122
  166. package/prisma/skills/energy-procurement/SKILL.md +0 -228
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +0 -51
  168. package/prisma/skills/error-handling/SKILL.md +0 -377
  169. package/prisma/skills/eval-harness/SKILL.md +0 -271
  170. package/prisma/skills/evm-token-decimals/SKILL.md +0 -131
  171. package/prisma/skills/exa-search/SKILL.md +0 -108
  172. package/prisma/skills/fal-ai-media/SKILL.md +0 -289
  173. package/prisma/skills/fastapi-patterns/SKILL.md +0 -514
  174. package/prisma/skills/finance-billing-ops/SKILL.md +0 -128
  175. package/prisma/skills/flox-environments/SKILL.md +0 -497
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +0 -436
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +0 -243
  178. package/prisma/skills/frontend-a11y/SKILL.md +0 -446
  179. package/prisma/skills/frontend-design-direction/SKILL.md +0 -93
  180. package/prisma/skills/frontend-patterns/SKILL.md +0 -657
  181. package/prisma/skills/frontend-slides/SKILL.md +0 -185
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +0 -330
  183. package/prisma/skills/frontend-slides/animation-patterns.md +0 -122
  184. package/prisma/skills/frontend-slides/html-template.md +0 -419
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +0 -418
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +0 -96
  187. package/prisma/skills/frontend-slides/viewport-base.css +0 -153
  188. package/prisma/skills/fsharp-testing/SKILL.md +0 -281
  189. package/prisma/skills/gan-style-harness/SKILL.md +0 -279
  190. package/prisma/skills/gateguard/SKILL.md +0 -133
  191. package/prisma/skills/generating-python-installer/SKILL.md +0 -820
  192. package/prisma/skills/git-workflow/SKILL.md +0 -716
  193. package/prisma/skills/github-ops/SKILL.md +0 -145
  194. package/prisma/skills/golang-patterns/SKILL.md +0 -675
  195. package/prisma/skills/golang-testing/SKILL.md +0 -721
  196. package/prisma/skills/google-workspace-ops/SKILL.md +0 -96
  197. package/prisma/skills/growth-log/SKILL.md +0 -128
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +0 -246
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +0 -160
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +0 -208
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +0 -146
  202. package/prisma/skills/hermes-imports/SKILL.md +0 -89
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +0 -277
  204. package/prisma/skills/hipaa-compliance/SKILL.md +0 -79
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +0 -170
  206. package/prisma/skills/homelab-network-setup/SKILL.md +0 -130
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +0 -275
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +0 -312
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +0 -306
  210. package/prisma/skills/hookify-rules/SKILL.md +0 -128
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +0 -157
  212. package/prisma/skills/intent-driven-development/SKILL.md +0 -360
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +0 -247
  214. package/prisma/skills/investor-materials/SKILL.md +0 -97
  215. package/prisma/skills/investor-outreach/SKILL.md +0 -92
  216. package/prisma/skills/ios-icon-gen/SKILL.md +0 -158
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +0 -258
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +0 -235
  219. package/prisma/skills/iterative-retrieval/SKILL.md +0 -212
  220. package/prisma/skills/ito-basket-compare/SKILL.md +0 -64
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +0 -64
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +0 -61
  223. package/prisma/skills/ito-trade-planner/SKILL.md +0 -68
  224. package/prisma/skills/java-coding-standards/SKILL.md +0 -384
  225. package/prisma/skills/jira-integration/SKILL.md +0 -303
  226. package/prisma/skills/jpa-patterns/SKILL.md +0 -152
  227. package/prisma/skills/knowledge-ops/SKILL.md +0 -155
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +0 -285
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +0 -720
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +0 -690
  231. package/prisma/skills/kotlin-patterns/SKILL.md +0 -712
  232. package/prisma/skills/kotlin-testing/SKILL.md +0 -825
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +0 -756
  234. package/prisma/skills/laravel-patterns/SKILL.md +0 -416
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +0 -230
  236. package/prisma/skills/laravel-security/SKILL.md +0 -948
  237. package/prisma/skills/laravel-tdd/SKILL.md +0 -675
  238. package/prisma/skills/laravel-verification/SKILL.md +0 -180
  239. package/prisma/skills/latency-critical-systems/SKILL.md +0 -74
  240. package/prisma/skills/lead-intelligence/SKILL.md +0 -322
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +0 -85
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +0 -75
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +0 -98
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +0 -60
  245. package/prisma/skills/liquid-glass-design/SKILL.md +0 -279
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +0 -147
  247. package/prisma/skills/logistics-exception-management/SKILL.md +0 -222
  248. package/prisma/skills/loop-design-check/SKILL.md +0 -143
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +0 -77
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +0 -152
  251. package/prisma/skills/manim-video/SKILL.md +0 -90
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +0 -52
  253. package/prisma/skills/market-research/SKILL.md +0 -76
  254. package/prisma/skills/marketing-campaign/SKILL.md +0 -114
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +0 -70
  256. package/prisma/skills/messages-ops/SKILL.md +0 -105
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +0 -57
  258. package/prisma/skills/mle-workflow/SKILL.md +0 -347
  259. package/prisma/skills/motion-advanced/SKILL.md +0 -596
  260. package/prisma/skills/motion-foundations/SKILL.md +0 -299
  261. package/prisma/skills/motion-patterns/SKILL.md +0 -434
  262. package/prisma/skills/motion-ui/SKILL.md +0 -576
  263. package/prisma/skills/mysql-patterns/SKILL.md +0 -413
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +0 -34
  265. package/prisma/skills/nestjs-patterns/SKILL.md +0 -231
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +0 -174
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +0 -168
  268. package/prisma/skills/network-config-validation/SKILL.md +0 -211
  269. package/prisma/skills/network-interface-health/SKILL.md +0 -153
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +0 -58
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +0 -103
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +0 -168
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +0 -101
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +0 -289
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +0 -224
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +0 -5
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +0 -124
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +0 -53
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +0 -53
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +0 -48
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +0 -39
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +0 -166
  283. package/prisma/skills/opensource-pipeline/SKILL.md +0 -256
  284. package/prisma/skills/orch-add-feature/SKILL.md +0 -45
  285. package/prisma/skills/orch-build-mvp/SKILL.md +0 -49
  286. package/prisma/skills/orch-change-feature/SKILL.md +0 -43
  287. package/prisma/skills/orch-fix-defect/SKILL.md +0 -43
  288. package/prisma/skills/orch-pipeline/SKILL.md +0 -121
  289. package/prisma/skills/orch-refine-code/SKILL.md +0 -44
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +0 -73
  291. package/prisma/skills/perl-patterns/SKILL.md +0 -505
  292. package/prisma/skills/perl-security/SKILL.md +0 -504
  293. package/prisma/skills/perl-testing/SKILL.md +0 -476
  294. package/prisma/skills/plan-orchestrate/SKILL.md +0 -263
  295. package/prisma/skills/plankton-code-quality/SKILL.md +0 -237
  296. package/prisma/skills/postgres-patterns/SKILL.md +0 -148
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +0 -64
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +0 -61
  299. package/prisma/skills/prisma-patterns/SKILL.md +0 -401
  300. package/prisma/skills/product-capability/SKILL.md +0 -142
  301. package/prisma/skills/product-lens/SKILL.md +0 -93
  302. package/prisma/skills/production-audit/SKILL.md +0 -207
  303. package/prisma/skills/production-scheduling/SKILL.md +0 -238
  304. package/prisma/skills/project-flow-ops/SKILL.md +0 -112
  305. package/prisma/skills/prompt-optimizer/SKILL.md +0 -398
  306. package/prisma/skills/python-patterns/SKILL.md +0 -751
  307. package/prisma/skills/python-testing/SKILL.md +0 -817
  308. package/prisma/skills/pytorch-patterns/SKILL.md +0 -397
  309. package/prisma/skills/quality-nonconformance/SKILL.md +0 -260
  310. package/prisma/skills/quarkus-patterns/SKILL.md +0 -723
  311. package/prisma/skills/quarkus-security/SKILL.md +0 -468
  312. package/prisma/skills/quarkus-tdd/SKILL.md +0 -812
  313. package/prisma/skills/quarkus-verification/SKILL.md +0 -480
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +0 -68
  315. package/prisma/skills/react-native-patterns/SKILL.md +0 -326
  316. package/prisma/skills/react-patterns/SKILL.md +0 -342
  317. package/prisma/skills/react-performance/SKILL.md +0 -575
  318. package/prisma/skills/react-testing/SKILL.md +0 -424
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +0 -115
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +0 -80
  321. package/prisma/skills/redis-patterns/SKILL.md +0 -404
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +0 -221
  323. package/prisma/skills/remotion-video-creation/SKILL.md +0 -43
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +0 -86
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +0 -29
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +0 -173
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +0 -100
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +0 -108
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +0 -78
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +0 -172
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +0 -104
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +0 -75
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +0 -58
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +0 -146
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +0 -126
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +0 -229
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +0 -152
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +0 -58
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +0 -68
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +0 -58
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +0 -138
  342. package/prisma/skills/remotion-video-creation/rules/images.md +0 -130
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +0 -67
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +0 -67
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +0 -34
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +0 -143
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +0 -106
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +0 -11
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +0 -20
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +0 -179
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +0 -19
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +0 -122
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +0 -52
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +0 -171
  355. package/prisma/skills/repo-scan/SKILL.md +0 -79
  356. package/prisma/skills/research-ops/SKILL.md +0 -113
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +0 -240
  358. package/prisma/skills/rules-distill/SKILL.md +0 -265
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +0 -58
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +0 -129
  361. package/prisma/skills/rust-patterns/SKILL.md +0 -500
  362. package/prisma/skills/rust-testing/SKILL.md +0 -501
  363. package/prisma/skills/safety-guard/SKILL.md +0 -76
  364. package/prisma/skills/santa-method/SKILL.md +0 -307
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +0 -176
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +0 -178
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +0 -167
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +0 -193
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +0 -161
  370. package/prisma/skills/search-first/SKILL.md +0 -183
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +0 -100
  372. package/prisma/skills/security-review/SKILL.md +0 -504
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +0 -361
  374. package/prisma/skills/security-scan/SKILL.md +0 -166
  375. package/prisma/skills/seo/SKILL.md +0 -155
  376. package/prisma/skills/skill-comply/SKILL.md +0 -59
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +0 -5
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +0 -3
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +0 -44
  380. package/prisma/skills/skill-comply/prompts/classifier.md +0 -24
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +0 -62
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +0 -42
  383. package/prisma/skills/skill-comply/pyproject.toml +0 -15
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +0 -85
  386. package/prisma/skills/skill-comply/scripts/grader.py +0 -124
  387. package/prisma/skills/skill-comply/scripts/parser.py +0 -107
  388. package/prisma/skills/skill-comply/scripts/report.py +0 -170
  389. package/prisma/skills/skill-comply/scripts/run.py +0 -127
  390. package/prisma/skills/skill-comply/scripts/runner.py +0 -194
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +0 -70
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +0 -72
  393. package/prisma/skills/skill-comply/scripts/utils.py +0 -13
  394. package/prisma/skills/skill-comply/tests/test_grader.py +0 -197
  395. package/prisma/skills/skill-comply/tests/test_parser.py +0 -90
  396. package/prisma/skills/skill-comply/tests/test_runner.py +0 -172
  397. package/prisma/skills/skill-scout/SKILL.md +0 -141
  398. package/prisma/skills/skill-stocktake/SKILL.md +0 -195
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +0 -87
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +0 -56
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +0 -170
  402. package/prisma/skills/social-graph-ranker/SKILL.md +0 -155
  403. package/prisma/skills/social-publisher/SKILL.md +0 -130
  404. package/prisma/skills/springboot-patterns/SKILL.md +0 -315
  405. package/prisma/skills/springboot-security/SKILL.md +0 -273
  406. package/prisma/skills/springboot-tdd/SKILL.md +0 -159
  407. package/prisma/skills/springboot-verification/SKILL.md +0 -232
  408. package/prisma/skills/strategic-compact/SKILL.md +0 -136
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +0 -144
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +0 -216
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +0 -191
  412. package/prisma/skills/swiftui-patterns/SKILL.md +0 -259
  413. package/prisma/skills/taste/SKILL.md +0 -264
  414. package/prisma/skills/taste/references/genre-taxonomy.md +0 -87
  415. package/prisma/skills/tdd-workflow/SKILL.md +0 -583
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +0 -111
  417. package/prisma/skills/team-builder/SKILL.md +0 -169
  418. package/prisma/skills/terminal-ops/SKILL.md +0 -110
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +0 -279
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +0 -90
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +0 -60
  422. package/prisma/skills/tinystruct-patterns/references/database.md +0 -99
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +0 -64
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +0 -97
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +0 -72
  426. package/prisma/skills/token-budget-advisor/SKILL.md +0 -134
  427. package/prisma/skills/ui-demo/SKILL.md +0 -466
  428. package/prisma/skills/ui-to-vue/SKILL.md +0 -135
  429. package/prisma/skills/uncloud/SKILL.md +0 -344
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +0 -188
  431. package/prisma/skills/verification-loop/SKILL.md +0 -127
  432. package/prisma/skills/video-editing/SKILL.md +0 -311
  433. package/prisma/skills/videodb/SKILL.md +0 -375
  434. package/prisma/skills/videodb/reference/api-reference.md +0 -550
  435. package/prisma/skills/videodb/reference/capture-reference.md +0 -407
  436. package/prisma/skills/videodb/reference/capture.md +0 -101
  437. package/prisma/skills/videodb/reference/editor.md +0 -443
  438. package/prisma/skills/videodb/reference/generative.md +0 -331
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +0 -564
  440. package/prisma/skills/videodb/reference/rtstream.md +0 -65
  441. package/prisma/skills/videodb/reference/search.md +0 -230
  442. package/prisma/skills/videodb/reference/streaming.md +0 -406
  443. package/prisma/skills/videodb/reference/use-cases.md +0 -118
  444. package/prisma/skills/videodb/scripts/ws_listener.py +0 -282
  445. package/prisma/skills/visa-doc-translate/README.md +0 -86
  446. package/prisma/skills/visa-doc-translate/SKILL.md +0 -117
  447. package/prisma/skills/vite-patterns/SKILL.md +0 -450
  448. package/prisma/skills/vue-patterns/SKILL.md +0 -471
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +0 -888
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +0 -126
  451. package/prisma/skills/x-api/SKILL.md +0 -235
@@ -1,466 +0,0 @@
1
- ---
2
- name: ui-demo
3
- description: Record polished UI demo videos using Playwright. Use when the user asks to create a demo, walkthrough, screen recording, or tutorial video of a web application. Produces WebM videos with visible cursor, natural pacing, and professional feel.
4
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # UI Demo Video Recorder
9
-
10
- Record polished demo videos of web applications using Playwright's video recording with an injected cursor overlay, natural pacing, and storytelling flow.
11
-
12
- ## When to Use
13
-
14
- - User asks for a "demo video", "screen recording", "walkthrough", or "tutorial"
15
- - User wants to showcase a feature or workflow visually
16
- - User needs a video for documentation, onboarding, or stakeholder presentation
17
-
18
- ## Three-Phase Process
19
-
20
- Every demo goes through three phases: **Discover -> Rehearse -> Record**. Never skip straight to recording.
21
-
22
- ---
23
-
24
- ## Phase 1: Discover
25
-
26
- Before writing any script, explore the target pages to understand what is actually there.
27
-
28
- ### Why
29
-
30
- You cannot script what you have not seen. Fields may be `<input>` not `<textarea>`, dropdowns may be custom components not `<select>`, and comment boxes may support `@mentions` or `#tags`. Assumptions break recordings silently.
31
-
32
- ### How
33
-
34
- Navigate to each page in the flow and dump its interactive elements:
35
-
36
- ```javascript
37
- // Run this for each page in the flow BEFORE writing the demo script
38
- const fields = await page.evaluate(() => {
39
- const els = [];
40
- document.querySelectorAll('input, select, textarea, button, [contenteditable]').forEach(el => {
41
- if (el.offsetParent !== null) {
42
- els.push({
43
- tag: el.tagName,
44
- type: el.type || '',
45
- name: el.name || '',
46
- placeholder: el.placeholder || '',
47
- text: el.textContent?.trim().substring(0, 40) || '',
48
- contentEditable: el.contentEditable === 'true',
49
- role: el.getAttribute('role') || '',
50
- });
51
- }
52
- });
53
- return els;
54
- });
55
- console.log(JSON.stringify(fields, null, 2));
56
- ```
57
-
58
- ### What to look for
59
-
60
- - **Form fields**: Are they `<select>`, `<input>`, custom dropdowns, or comboboxes?
61
- - **Select options**: Dump option values AND text. Placeholders often have `value="0"` or `value=""` which looks non-empty. Use `Array.from(el.options).map(o => ({ value: o.value, text: o.text }))`. Skip options where text includes "Select" or value is `"0"`.
62
- - **Rich text**: Does the comment box support `@mentions`, `#tags`, markdown, or emoji? Check placeholder text.
63
- - **Required fields**: Which fields block form submission? Check `required`, `*` in labels, and try submitting empty to see validation errors.
64
- - **Dynamic content**: Do fields appear after other fields are filled?
65
- - **Button labels**: Exact text such as `"Submit"`, `"Submit Request"`, or `"Send"`.
66
- - **Table column headers**: For table-driven modals, map each `input[type="number"]` to its column header instead of assuming all numeric inputs mean the same thing.
67
-
68
- ### Output
69
-
70
- A field map for each page, used to write correct selectors in the script. Example:
71
-
72
- ```text
73
- /purchase-requests/new:
74
- - Budget Code: <select> (first select on page, 4 options)
75
- - Desired Delivery: <input type="date">
76
- - Context: <textarea> (not input)
77
- - BOM table: inline-editable cells with span.cursor-pointer -> input pattern
78
- - Submit: <button> text="Submit"
79
-
80
- /purchase-requests/N (detail):
81
- - Comment: <input placeholder="Type a message..."> supports @user and #PR tags
82
- - Send: <button> text="Send" (disabled until input has content)
83
- ```
84
-
85
- ---
86
-
87
- ## Phase 2: Rehearse
88
-
89
- Run through all steps without recording. Verify every selector resolves.
90
-
91
- ### Why
92
-
93
- Silent selector failures are the main reason demo recordings break. Rehearsal catches them before you waste a recording.
94
-
95
- ### How
96
-
97
- Use `ensureVisible`, a wrapper that logs and fails loudly:
98
-
99
- ```javascript
100
- async function ensureVisible(page, locator, label) {
101
- const el = typeof locator === 'string' ? page.locator(locator).first() : locator;
102
- const visible = await el.isVisible().catch(() => false);
103
- if (!visible) {
104
- const msg = `REHEARSAL FAIL: "${label}" not found - selector: ${typeof locator === 'string' ? locator : '(locator object)'}`;
105
- console.error(msg);
106
- const found = await page.evaluate(() => {
107
- return Array.from(document.querySelectorAll('button, input, select, textarea, a'))
108
- .filter(el => el.offsetParent !== null)
109
- .map(el => `${el.tagName}[${el.type || ''}] "${el.textContent?.trim().substring(0, 30)}"`)
110
- .join('\n ');
111
- });
112
- console.error(' Visible elements:\n ' + found);
113
- return false;
114
- }
115
- console.log(`REHEARSAL OK: "${label}"`);
116
- return true;
117
- }
118
- ```
119
-
120
- ### Rehearsal script structure
121
-
122
- ```javascript
123
- const steps = [
124
- { label: 'Login email field', selector: '#email' },
125
- { label: 'Login submit', selector: 'button[type="submit"]' },
126
- { label: 'New Request button', selector: 'button:has-text("New Request")' },
127
- { label: 'Budget Code select', selector: 'select' },
128
- { label: 'Delivery date', selector: 'input[type="date"]:visible' },
129
- { label: 'Description field', selector: 'textarea:visible' },
130
- { label: 'Add Item button', selector: 'button:has-text("Add Item")' },
131
- { label: 'Submit button', selector: 'button:has-text("Submit")' },
132
- ];
133
-
134
- let allOk = true;
135
- for (const step of steps) {
136
- if (!await ensureVisible(page, step.selector, step.label)) {
137
- allOk = false;
138
- }
139
- }
140
- if (!allOk) {
141
- console.error('REHEARSAL FAILED - fix selectors before recording');
142
- process.exit(1);
143
- }
144
- console.log('REHEARSAL PASSED - all selectors verified');
145
- ```
146
-
147
- ### When rehearsal fails
148
-
149
- 1. Read the visible-element dump.
150
- 2. Find the correct selector.
151
- 3. Update the script.
152
- 4. Re-run rehearsal.
153
- 5. Only proceed when every selector passes.
154
-
155
- ---
156
-
157
- ## Phase 3: Record
158
-
159
- Only after discovery and rehearsal pass should you create the recording.
160
-
161
- ### Recording Principles
162
-
163
- #### 1. Storytelling Flow
164
-
165
- Plan the video as a story. Follow user-specified order, or use this default:
166
-
167
- - **Entry**: Login or navigate to the starting point
168
- - **Context**: Pan the surroundings so viewers orient themselves
169
- - **Action**: Perform the main workflow steps
170
- - **Variation**: Show a secondary feature such as settings, theme, or localization
171
- - **Result**: Show the outcome, confirmation, or new state
172
-
173
- #### 2. Pacing
174
-
175
- - After login: `4s`
176
- - After navigation: `3s`
177
- - After clicking a button: `2s`
178
- - Between major steps: `1.5-2s`
179
- - After the final action: `3s`
180
- - Typing delay: `25-40ms` per character
181
-
182
- #### 3. Cursor Overlay
183
-
184
- Inject an SVG arrow cursor that follows mouse movements:
185
-
186
- ```javascript
187
- async function injectCursor(page) {
188
- await page.evaluate(() => {
189
- if (document.getElementById('demo-cursor')) return;
190
- const cursor = document.createElement('div');
191
- cursor.id = 'demo-cursor';
192
- cursor.innerHTML = `<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
193
- <path d="M5 3L19 12L12 13L9 20L5 3Z" fill="white" stroke="black" stroke-width="1.5" stroke-linejoin="round"/>
194
- </svg>`;
195
- cursor.style.cssText = `
196
- position: fixed; z-index: 999999; pointer-events: none;
197
- width: 24px; height: 24px;
198
- transition: left 0.1s, top 0.1s;
199
- filter: drop-shadow(1px 1px 2px rgba(0,0,0,0.3));
200
- `;
201
- cursor.style.left = '0px';
202
- cursor.style.top = '0px';
203
- document.body.appendChild(cursor);
204
- document.addEventListener('mousemove', (e) => {
205
- cursor.style.left = e.clientX + 'px';
206
- cursor.style.top = e.clientY + 'px';
207
- });
208
- });
209
- }
210
- ```
211
-
212
- Call `injectCursor(page)` after every page navigation because the overlay is destroyed on navigate.
213
-
214
- #### 4. Mouse Movement
215
-
216
- Never teleport the cursor. Move to the target before clicking:
217
-
218
- ```javascript
219
- async function moveAndClick(page, locator, label, opts = {}) {
220
- const { postClickDelay = 800, ...clickOpts } = opts;
221
- const el = typeof locator === 'string' ? page.locator(locator).first() : locator;
222
- const visible = await el.isVisible().catch(() => false);
223
- if (!visible) {
224
- console.error(`WARNING: moveAndClick skipped - "${label}" not visible`);
225
- return false;
226
- }
227
- try {
228
- await el.scrollIntoViewIfNeeded();
229
- await page.waitForTimeout(300);
230
- const box = await el.boundingBox();
231
- if (box) {
232
- await page.mouse.move(box.x + box.width / 2, box.y + box.height / 2, { steps: 10 });
233
- await page.waitForTimeout(400);
234
- }
235
- await el.click(clickOpts);
236
- } catch (e) {
237
- console.error(`WARNING: moveAndClick failed on "${label}": ${e.message}`);
238
- return false;
239
- }
240
- await page.waitForTimeout(postClickDelay);
241
- return true;
242
- }
243
- ```
244
-
245
- Every call should include a descriptive `label` for debugging.
246
-
247
- #### 5. Typing
248
-
249
- Type visibly, not instant-fill:
250
-
251
- ```javascript
252
- async function typeSlowly(page, locator, text, label, charDelay = 35) {
253
- const el = typeof locator === 'string' ? page.locator(locator).first() : locator;
254
- const visible = await el.isVisible().catch(() => false);
255
- if (!visible) {
256
- console.error(`WARNING: typeSlowly skipped - "${label}" not visible`);
257
- return false;
258
- }
259
- await moveAndClick(page, el, label);
260
- await el.fill('');
261
- await el.pressSequentially(text, { delay: charDelay });
262
- await page.waitForTimeout(500);
263
- return true;
264
- }
265
- ```
266
-
267
- #### 6. Scrolling
268
-
269
- Use smooth scroll instead of jumps:
270
-
271
- ```javascript
272
- await page.evaluate(() => window.scrollTo({ top: 400, behavior: 'smooth' }));
273
- await page.waitForTimeout(1500);
274
- ```
275
-
276
- #### 7. Dashboard Panning
277
-
278
- When showing a dashboard or overview page, move the cursor across key elements:
279
-
280
- ```javascript
281
- async function panElements(page, selector, maxCount = 6) {
282
- const elements = await page.locator(selector).all();
283
- for (let i = 0; i < Math.min(elements.length, maxCount); i++) {
284
- try {
285
- const box = await elements[i].boundingBox();
286
- if (box && box.y < 700) {
287
- await page.mouse.move(box.x + box.width / 2, box.y + box.height / 2, { steps: 8 });
288
- await page.waitForTimeout(600);
289
- }
290
- } catch (e) {
291
- console.warn(`WARNING: panElements skipped element ${i} (selector: "${selector}"): ${e.message}`);
292
- }
293
- }
294
- }
295
- ```
296
-
297
- #### 8. Subtitles
298
-
299
- Inject a subtitle bar at the bottom of the viewport:
300
-
301
- ```javascript
302
- async function injectSubtitleBar(page) {
303
- await page.evaluate(() => {
304
- if (document.getElementById('demo-subtitle')) return;
305
- const bar = document.createElement('div');
306
- bar.id = 'demo-subtitle';
307
- bar.style.cssText = `
308
- position: fixed; bottom: 0; left: 0; right: 0; z-index: 999998;
309
- text-align: center; padding: 12px 24px;
310
- background: rgba(0, 0, 0, 0.75);
311
- color: white; font-family: -apple-system, "Segoe UI", sans-serif;
312
- font-size: 16px; font-weight: 500; letter-spacing: 0.3px;
313
- transition: opacity 0.3s;
314
- pointer-events: none;
315
- `;
316
- bar.textContent = '';
317
- bar.style.opacity = '0';
318
- document.body.appendChild(bar);
319
- });
320
- }
321
-
322
- async function showSubtitle(page, text) {
323
- await page.evaluate((t) => {
324
- const bar = document.getElementById('demo-subtitle');
325
- if (!bar) return;
326
- if (t) {
327
- bar.textContent = t;
328
- bar.style.opacity = '1';
329
- } else {
330
- bar.style.opacity = '0';
331
- }
332
- }, text);
333
- if (text) await page.waitForTimeout(800);
334
- }
335
- ```
336
-
337
- Call `injectSubtitleBar(page)` alongside `injectCursor(page)` after every navigation.
338
-
339
- Usage pattern:
340
-
341
- ```javascript
342
- await showSubtitle(page, 'Step 1 - Logging in');
343
- await showSubtitle(page, 'Step 2 - Dashboard overview');
344
- await showSubtitle(page, '');
345
- ```
346
-
347
- Guidelines:
348
-
349
- - Keep subtitle text short, ideally under 60 characters.
350
- - Use `Step N - Action` format for consistency.
351
- - Clear the subtitle during long pauses where the UI can speak for itself.
352
-
353
- ## Script Template
354
-
355
- ```javascript
356
- 'use strict';
357
- const { chromium } = require('playwright');
358
- const path = require('path');
359
- const fs = require('fs');
360
-
361
- const BASE_URL = process.env.QA_BASE_URL || 'http://localhost:3000';
362
- const VIDEO_DIR = path.join(__dirname, 'screenshots');
363
- const OUTPUT_NAME = 'demo-FEATURE.webm';
364
- const REHEARSAL = process.argv.includes('--rehearse');
365
-
366
- // Paste injectCursor, injectSubtitleBar, showSubtitle, moveAndClick,
367
- // typeSlowly, ensureVisible, and panElements here.
368
-
369
- (async () => {
370
- const browser = await chromium.launch({ headless: true });
371
-
372
- if (REHEARSAL) {
373
- const context = await browser.newContext({ viewport: { width: 1280, height: 720 } });
374
- const page = await context.newPage();
375
- // Navigate through the flow and run ensureVisible for each selector.
376
- await browser.close();
377
- return;
378
- }
379
-
380
- const context = await browser.newContext({
381
- recordVideo: { dir: VIDEO_DIR, size: { width: 1280, height: 720 } },
382
- viewport: { width: 1280, height: 720 }
383
- });
384
- const page = await context.newPage();
385
-
386
- try {
387
- await injectCursor(page);
388
- await injectSubtitleBar(page);
389
-
390
- await showSubtitle(page, 'Step 1 - Logging in');
391
- // login actions
392
-
393
- await page.goto(`${BASE_URL}/dashboard`);
394
- await injectCursor(page);
395
- await injectSubtitleBar(page);
396
- await showSubtitle(page, 'Step 2 - Dashboard overview');
397
- // pan dashboard
398
-
399
- await showSubtitle(page, 'Step 3 - Main workflow');
400
- // action sequence
401
-
402
- await showSubtitle(page, 'Step 4 - Result');
403
- // final reveal
404
- await showSubtitle(page, '');
405
- } catch (err) {
406
- console.error('DEMO ERROR:', err.message);
407
- } finally {
408
- await context.close();
409
- const video = page.video();
410
- if (video) {
411
- const src = await video.path();
412
- const dest = path.join(VIDEO_DIR, OUTPUT_NAME);
413
- try {
414
- fs.copyFileSync(src, dest);
415
- console.log('Video saved:', dest);
416
- } catch (e) {
417
- console.error('ERROR: Failed to copy video:', e.message);
418
- console.error(' Source:', src);
419
- console.error(' Destination:', dest);
420
- }
421
- }
422
- await browser.close();
423
- }
424
- })();
425
- ```
426
-
427
- Usage:
428
-
429
- ```bash
430
- # Phase 2: Rehearse
431
- node demo-script.cjs --rehearse
432
-
433
- # Phase 3: Record
434
- node demo-script.cjs
435
- ```
436
-
437
- ## Checklist Before Recording
438
-
439
- - [ ] Discovery phase completed
440
- - [ ] Rehearsal passes with all selectors OK
441
- - [ ] Headless mode enabled
442
- - [ ] Resolution set to `1280x720`
443
- - [ ] Cursor and subtitle overlays re-injected after every navigation
444
- - [ ] `showSubtitle(page, 'Step N - ...')` used at major transitions
445
- - [ ] `moveAndClick` used for all clicks with descriptive labels
446
- - [ ] `typeSlowly` used for visible input
447
- - [ ] No silent catches; helpers log warnings
448
- - [ ] Smooth scrolling used for content reveal
449
- - [ ] Key pauses are visible to a human viewer
450
- - [ ] Flow matches the requested story order
451
- - [ ] Script reflects the actual UI discovered in phase 1
452
-
453
- ## Common Pitfalls
454
-
455
- 1. Cursor disappears after navigation - re-inject it.
456
- 2. Video is too fast - add pauses.
457
- 3. Cursor is a dot instead of an arrow - use the SVG overlay.
458
- 4. Cursor teleports - move before clicking.
459
- 5. Select dropdowns look wrong - show the move, then pick the option.
460
- 6. Modals feel abrupt - add a read pause before confirming.
461
- 7. Video file path is random - copy it to a stable output name.
462
- 8. Selector failures are swallowed - never use silent catch blocks.
463
- 9. Field types were assumed - discover them first.
464
- 10. Features were assumed - inspect the actual UI before scripting.
465
- 11. Placeholder select values look real - watch for `"0"` and `"Select..."`.
466
- 12. Popups create separate videos - capture popup pages explicitly and merge later if needed.
@@ -1,135 +0,0 @@
1
- ---
2
- name: ui-to-vue
3
- description: Use when the user has UI screenshots or design exports that need batch conversion into Vue 3 components, especially with Vant, Element Plus, or Ant Design Vue.
4
- metadata:
5
- origin: community
6
- ---
7
-
8
- # UI To Vue
9
-
10
- Batch-convert UI design screenshots into Vue 3 Composition API component code.
11
-
12
- ## When to Use
13
-
14
- - The user provides a directory of design screenshots or design-export images.
15
- - The target application is Vue 3.
16
- - The user wants a first pass of page components, shared components, and router wiring.
17
- - The user specifies Vant, Element Plus, or Ant Design Vue as the component library.
18
-
19
- ## When Not to Use
20
-
21
- - The user has only one screenshot and wants a bespoke component.
22
- - The target project is not Vue.
23
- - The design requires detailed interaction logic, data flow, or accessibility review.
24
- - The screenshots contain private customer data that cannot be sent to an external model API.
25
-
26
- ## Inputs
27
-
28
- Use an input directory that groups screenshots by module and page state:
29
-
30
- ```text
31
- screenshots/
32
- |-- HomePage/
33
- | |-- List/
34
- | | |-- HomePage-List-Default@3x.png
35
- | | `-- cut-images/
36
- | |-- cut-images/
37
- | `-- HomePage-Default@3x.png
38
- `-- cut-images/
39
- ```
40
-
41
- Supported cut-image directory names include `assets`, `icons`, `sprites`, `cut`, `images`, and `cut-images`.
42
-
43
- ## Conversion Model
44
-
45
- - Page grouping: combine related screenshots into one page component when they represent list, detail, form, loading, or empty states.
46
- - UI library mapping: map native visual elements to Vant, Element Plus, or Ant Design Vue components where practical.
47
- - Cut-image priority: prefer page-level assets, then module-level assets, then global shared assets.
48
- - Component extraction: extract repeated UI regions into shared components when they appear more than once.
49
-
50
- ## CLI Usage
51
-
52
- Run the converter with `npx` so the documented command works without relying on a global binary:
53
-
54
- ```bash
55
- export DASHSCOPE_API_KEY=your_key
56
- npx ui-to-vue-converter@1.0.2 --input ./screenshots --ui vant --output ./src
57
- ```
58
-
59
- For desktop UI libraries:
60
-
61
- ```bash
62
- npx ui-to-vue-converter@1.0.2 --input ./designs --ui element-plus --output ./src
63
- npx ui-to-vue-converter@1.0.2 --input ./designs --ui antd-vue --output ./src
64
- ```
65
-
66
- If the package is installed globally, the `ui-to-vue` binary can be used directly:
67
-
68
- ```bash
69
- npm install -g ui-to-vue-converter@1.0.2
70
- ui-to-vue --input ./screenshots --ui vant --output ./src
71
- ```
72
-
73
- ## Options
74
-
75
- | Option | Description | Default |
76
- | --- | --- | --- |
77
- | `--input` | Design image directory | `./screenshots` |
78
- | `--ui` | UI library: `vant`, `element-plus`, or `antd-vue` | `vant` |
79
- | `--output` | Output directory | `./src` |
80
- | `--config` | Config file path | `./.ui-to-vue.config.json` |
81
-
82
- ## API Key Handling
83
-
84
- The converter can read DashScope credentials from a config file or from the environment. Prefer an environment variable in repositories:
85
-
86
- ```bash
87
- export DASHSCOPE_API_KEY=your_key
88
- ```
89
-
90
- If a local config file is required, keep it out of version control:
91
-
92
- ```json
93
- {
94
- "apiKey": "your_dashscope_key",
95
- "input": "./designs",
96
- "ui": "vant",
97
- "output": "./src"
98
- }
99
- ```
100
-
101
- ```gitignore
102
- .ui-to-vue.config.json
103
- ```
104
-
105
- ## Security and Privacy
106
-
107
- - Treat design screenshots as source material that may be sent to an external model API.
108
- - Do not run this flow on private customer designs without permission.
109
- - Pin the converter version in repeatable workflows instead of using `@latest`.
110
- - Review generated Vue code before committing it.
111
- - Do not commit `.ui-to-vue.config.json`, API keys, generated secrets, or customer screenshots.
112
-
113
- ## Output Review Checklist
114
-
115
- - [ ] Page components were generated under `views/` or the chosen output directory.
116
- - [ ] Repeated UI regions were extracted into `components/` only when reuse is clear.
117
- - [ ] Router output is compatible with the target project's router style.
118
- - [ ] Generated components use the requested UI library consistently.
119
- - [ ] Generated CSS units match the design baseline.
120
- - [ ] The code passes the project's formatter, linter, type checker, and build.
121
- - [ ] Placeholder copy, mock data, and generated assets were reviewed before commit.
122
-
123
- ## Troubleshooting
124
-
125
- | Issue | Check |
126
- | --- | --- |
127
- | `401` or authentication error | Confirm `DASHSCOPE_API_KEY` is set in the shell running the command. |
128
- | `command not found: ui-to-vue` | Use the `npx ui-to-vue-converter@1.0.2` form or install the package globally. |
129
- | Cut images are ignored | Confirm the asset directory name is supported and nested under the matching page or module. |
130
- | Components ignore the requested UI library | Re-run with an explicit `--ui` value and inspect the generated imports. |
131
- | Generated layout dimensions look wrong | Confirm the screenshot export width matches the target library baseline. |
132
-
133
- ## References
134
-
135
- - npm package: `ui-to-vue-converter`