codymaster 4.8.0 → 7.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 (416) hide show
  1. package/CHANGELOG.md +331 -7
  2. package/README.md +226 -296
  3. package/dist/advisory-handoff.js +89 -0
  4. package/dist/advisory-report.js +105 -0
  5. package/dist/agent/antigravity.js +152 -0
  6. package/dist/agent/backend.js +2 -0
  7. package/dist/agent/claude.js +196 -0
  8. package/dist/agent/codex.js +204 -0
  9. package/dist/agent/copilot.js +284 -0
  10. package/dist/agent/cursor.js +211 -0
  11. package/dist/agent/factory.js +30 -0
  12. package/dist/agent/gemini.js +142 -0
  13. package/dist/agent/opencode.js +205 -0
  14. package/dist/agent/spawn-helper.js +237 -0
  15. package/dist/agent/version.js +25 -0
  16. package/dist/browse/adapter-factory.js +69 -0
  17. package/dist/browse/adapters/agent-browser-adapter.js +305 -0
  18. package/dist/browse/adapters/playwright-adapter.js +309 -0
  19. package/dist/browse/adapters/types.js +6 -0
  20. package/dist/browse/error-collector.js +132 -0
  21. package/dist/browse/event-log.js +109 -0
  22. package/dist/browse/index.js +17 -0
  23. package/dist/browse-server.js +204 -120
  24. package/dist/cli/command-registry.js +20 -0
  25. package/dist/cli/commands/bench.js +69 -0
  26. package/dist/cli/commands/brain.js +108 -0
  27. package/dist/cli/commands/dashboard.js +76 -2
  28. package/dist/cli/commands/engineering.js +326 -4
  29. package/dist/cli/commands/evolve.js +123 -0
  30. package/dist/cli/commands/install.js +160 -0
  31. package/dist/cli/commands/learn.js +181 -0
  32. package/dist/cli/commands/mcp-serve.js +104 -0
  33. package/dist/cli/commands/parallel.js +138 -0
  34. package/dist/cli/commands/quality.js +105 -0
  35. package/dist/cli/commands/stack.js +49 -0
  36. package/dist/cli/commands/update.js +159 -0
  37. package/dist/cli/update-check.js +94 -10
  38. package/dist/cm-config.js +0 -18
  39. package/dist/codybench/judges/automated.js +31 -0
  40. package/dist/codybench/runners/claude-code.js +32 -0
  41. package/dist/codybench/suites/memory-retention.js +85 -0
  42. package/dist/codybench/suites/tdd-regression.js +35 -0
  43. package/dist/codybench/suites/token-efficiency.js +55 -0
  44. package/dist/codybench/types.js +2 -0
  45. package/dist/context-db.js +157 -0
  46. package/dist/continuity.js +5 -7
  47. package/dist/dashboard.js +47 -6
  48. package/dist/data.js +35 -0
  49. package/dist/execution/tdd-gate.js +113 -0
  50. package/dist/execution-analyzer.js +138 -0
  51. package/dist/executor/cancel.js +34 -0
  52. package/dist/executor/gc.js +74 -0
  53. package/dist/executor/index.js +14 -0
  54. package/dist/executor/runner.js +70 -0
  55. package/dist/executor/workdir.js +31 -0
  56. package/dist/handoff/contracts.js +22 -0
  57. package/dist/handoff/index.js +18 -0
  58. package/dist/handoff/io.js +121 -0
  59. package/dist/index.js +7 -3
  60. package/dist/indexer/skills-lib.js +533 -0
  61. package/dist/indexer/skills-map.js +1374 -0
  62. package/dist/indexer/skills.js +16 -0
  63. package/dist/indexer/stack-detect.js +219 -0
  64. package/dist/install/copy.js +98 -0
  65. package/dist/install/engine.js +42 -0
  66. package/dist/install/paths.js +70 -0
  67. package/dist/install/platforms/_simple.js +85 -0
  68. package/dist/install/platforms/antigravity.js +91 -0
  69. package/dist/install/platforms/claude-code.js +107 -0
  70. package/dist/install/platforms/cursor.js +77 -0
  71. package/dist/install/platforms/index.js +27 -0
  72. package/dist/install/platforms/simple.js +163 -0
  73. package/dist/install/profiles.js +75 -0
  74. package/dist/install/types.js +2 -0
  75. package/dist/learning-promoter.js +246 -0
  76. package/dist/learnings.js +208 -0
  77. package/dist/mcp-context-server.js +230 -1
  78. package/dist/middleware/metrics.js +30 -0
  79. package/dist/middleware/security-headers.js +14 -0
  80. package/dist/realtime/event-bus.js +29 -0
  81. package/dist/realtime/ws-hub.js +91 -0
  82. package/dist/schemas/task-schema.js +48 -0
  83. package/dist/schemas/validate.js +18 -0
  84. package/dist/skill-chain.js +63 -1
  85. package/dist/skill-evolver.js +456 -0
  86. package/dist/skill-execution-cache.js +254 -0
  87. package/dist/skills-lock.js +96 -0
  88. package/dist/smart-brain-router.js +184 -0
  89. package/dist/sprint-pipeline.js +26 -0
  90. package/dist/storage/index.js +21 -0
  91. package/dist/storage/repos/activity-repo.js +46 -0
  92. package/dist/storage/repos/message-repo.js +39 -0
  93. package/dist/storage/repos/project-repo.js +56 -0
  94. package/dist/storage/repos/task-repo.js +142 -0
  95. package/dist/storage/services/project-service.js +49 -0
  96. package/dist/storage/services/task-service.js +97 -0
  97. package/dist/storage/sqlite.js +113 -0
  98. package/dist/storage-backend.js +10 -8
  99. package/dist/tier-classify.js +131 -0
  100. package/dist/token-budget.js +88 -0
  101. package/dist/ui/onboarding.js +51 -15
  102. package/dist/utils/cli-utils.js +7 -2
  103. package/dist/utils/design-taste.js +108 -0
  104. package/dist/utils/output-compress.js +143 -0
  105. package/dist/vibecoding-index.js +126 -0
  106. package/package.json +20 -6
  107. package/public/dashboard/app.js +52 -1
  108. package/scripts/build-skills-lock.mjs +88 -0
  109. package/scripts/build-skills.mjs +187 -28
  110. package/scripts/compress-skill.mjs +73 -0
  111. package/scripts/deprecate-skill.mjs +72 -0
  112. package/scripts/install.sh +170 -0
  113. package/scripts/mcp-bridge.js +2 -2
  114. package/scripts/postinstall.js +53 -335
  115. package/scripts/update-changelog.sh +88 -0
  116. package/scripts/validate-skills.mjs +101 -4
  117. package/skills/CLAUDE.md +0 -5
  118. package/skills/_shared/SKILL_TEMPLATE.md +62 -0
  119. package/skills/_shared/helpers.md +2 -8
  120. package/skills/cm-autopilot/scripts/autopilot.py +19 -2
  121. package/skills/cm-brainstorm-idea/SKILL.md +9 -0
  122. package/skills/cm-browse/SKILL.md +6 -0
  123. package/skills/cm-clean-code/SKILL.md +20 -0
  124. package/skills/cm-code-review/SKILL.md +21 -0
  125. package/skills/cm-codeintell/SKILL.md +9 -0
  126. package/skills/cm-conductor-worktrees/SKILL.archive.md +28 -0
  127. package/skills/cm-conductor-worktrees/SKILL.md +20 -18
  128. package/skills/cm-continuity/SKILL.md +41 -33
  129. package/skills/cm-dashboard/SKILL.archive.md +15 -0
  130. package/skills/cm-dashboard/SKILL.md +20 -9
  131. package/skills/cm-dashboard/ui/app.js +9 -1
  132. package/skills/cm-debugging/SKILL.md +9 -0
  133. package/skills/cm-design-studio/SKILL.archive.md +34 -0
  134. package/skills/cm-design-studio/SKILL.md +20 -24
  135. package/skills/cm-design-system/SKILL.md +1 -0
  136. package/skills/cm-ecosystem-roadmap/SKILL.md +4 -0
  137. package/skills/cm-engineering-meta/SKILL.archive.md +73 -0
  138. package/skills/cm-engineering-meta/SKILL.md +19 -62
  139. package/skills/cm-execution/SKILL.md +98 -0
  140. package/skills/cm-git-worktrees/SKILL.archive.md +157 -0
  141. package/skills/cm-git-worktrees/SKILL.md +15 -146
  142. package/skills/cm-guardian-runtime/SKILL.md +5 -1
  143. package/skills/cm-identity-guard/SKILL.md +8 -0
  144. package/skills/cm-mcp-engineering/SKILL.md +4 -0
  145. package/skills/cm-planning/SKILL.md +63 -92
  146. package/skills/cm-post-deploy-canary/SKILL.archive.md +22 -0
  147. package/skills/cm-post-deploy-canary/SKILL.md +20 -12
  148. package/skills/cm-project-bootstrap/SKILL.md +11 -0
  149. package/skills/cm-qa-visual-cli/SKILL.archive.md +22 -0
  150. package/skills/cm-qa-visual-cli/SKILL.md +19 -11
  151. package/skills/cm-quality-gate/SKILL.md +38 -0
  152. package/skills/cm-retro-cli/SKILL.md +4 -0
  153. package/skills/cm-safe-deploy/SKILL.md +9 -0
  154. package/skills/cm-second-opinion-cli/SKILL.archive.md +23 -0
  155. package/skills/cm-second-opinion-cli/SKILL.md +20 -13
  156. package/skills/cm-secret-shield/SKILL.archive.md +580 -0
  157. package/skills/cm-secret-shield/SKILL.md +15 -569
  158. package/skills/cm-security-gate/SKILL.archive.md +239 -0
  159. package/skills/cm-security-gate/SKILL.md +16 -228
  160. package/skills/cm-skill-chain/SKILL.md +25 -4
  161. package/skills/cm-skill-evolution/SKILL.md +83 -0
  162. package/skills/cm-skill-health/SKILL.archive.md +83 -0
  163. package/skills/cm-skill-health/SKILL.md +26 -0
  164. package/skills/cm-skill-index/SKILL.md +19 -3
  165. package/skills/cm-skill-mastery/SKILL.archive.md +156 -0
  166. package/skills/cm-skill-mastery/SKILL.md +16 -146
  167. package/skills/cm-skill-search/SKILL.archive.md +49 -0
  168. package/skills/cm-skill-search/SKILL.md +26 -0
  169. package/skills/cm-skill-share/SKILL.archive.md +58 -0
  170. package/skills/cm-skill-share/SKILL.md +26 -0
  171. package/skills/cm-sprint-bus/SKILL.md +13 -0
  172. package/skills/cm-start/SKILL.md +17 -10
  173. package/skills/cm-tdd/SKILL.md +21 -2
  174. package/skills/cm-terminal/SKILL.md +15 -0
  175. package/skills/cm-test-gate/SKILL.archive.md +245 -0
  176. package/skills/cm-test-gate/SKILL.md +15 -234
  177. package/skills/cm-ui-preview/SKILL.archive.md +153 -0
  178. package/skills/cm-ui-preview/SKILL.md +16 -143
  179. package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +1 -1
  180. package/skills/cm-ux-master/mcp/mcp-config.json +1 -1
  181. package/skills/cm-ux-master/mcp/server.py +2 -2
  182. package/skills/profiles/design.txt +1 -1
  183. package/skills/profiles/full.txt +4 -10
  184. package/skills/profiles/growth.txt +8 -8
  185. package/skills/profiles/knowledge.txt +1 -1
  186. package/skills/profiles/top35.json +41 -0
  187. package/adapters/antigravity.js +0 -15
  188. package/adapters/claude-code.js +0 -17
  189. package/adapters/cursor.js +0 -16
  190. package/install.sh +0 -1125
  191. package/scripts/viking-demo.ts +0 -105
  192. package/skills/cm-ads-tracker/SKILL.md +0 -401
  193. package/skills/cm-ads-tracker/evals/evals.json +0 -55
  194. package/skills/cm-ads-tracker/references/gtm-architecture.md +0 -321
  195. package/skills/cm-ads-tracker/references/industry-events.md +0 -294
  196. package/skills/cm-ads-tracker/references/platforms-api.md +0 -238
  197. package/skills/cm-ads-tracker/templates/capi-payload.md +0 -79
  198. package/skills/cm-ads-tracker/templates/datalayer-push.js +0 -104
  199. package/skills/cm-ads-tracker/templates/gtm-variables.js +0 -56
  200. package/skills/cm-auto-publisher/SKILL.md +0 -81
  201. package/skills/cm-booking-calendar/SKILL.md +0 -521
  202. package/skills/cm-booking-calendar/references/industry-patterns.md +0 -527
  203. package/skills/cm-booking-calendar/templates/booking-form.css +0 -626
  204. package/skills/cm-booking-calendar/templates/booking-form.html +0 -477
  205. package/skills/cm-booking-calendar/templates/calendar-engine.js +0 -419
  206. package/skills/cm-booking-calendar/templates/calendar-export.js +0 -395
  207. package/skills/cm-booking-calendar/templates/reminder-config.js +0 -629
  208. package/skills/cm-content-factory/.content-factory-state.json +0 -132
  209. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +0 -1
  210. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +0 -1
  211. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  212. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  213. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  214. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  215. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  216. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  217. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  218. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  219. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  220. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  221. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  222. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  223. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  224. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  225. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  226. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  227. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  228. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  229. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  230. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  231. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  232. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  233. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  234. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  235. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  236. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  237. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  238. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  239. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  240. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  241. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  242. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  243. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  244. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  245. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  246. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  247. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  248. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  249. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  250. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  251. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  252. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  253. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  254. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +0 -5
  255. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  256. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  257. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  258. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  259. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  260. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  261. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  262. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  263. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  264. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  265. package/skills/cm-content-factory/.git 2/refs/heads/main +0 -1
  266. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +0 -1
  267. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +0 -76
  268. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +0 -1
  269. package/skills/cm-content-factory/AGENTS.md +0 -61
  270. package/skills/cm-content-factory/CLAUDE.md +0 -63
  271. package/skills/cm-content-factory/CURSOR.md +0 -43
  272. package/skills/cm-content-factory/Content Factory.zip +0 -0
  273. package/skills/cm-content-factory/SKILL.md +0 -416
  274. package/skills/cm-content-factory/cf +0 -313
  275. package/skills/cm-content-factory/config.schema.json +0 -397
  276. package/skills/cm-content-factory/dashboard/app.js +0 -556
  277. package/skills/cm-content-factory/dashboard/index.html +0 -397
  278. package/skills/cm-content-factory/dashboard/style.css +0 -1211
  279. package/skills/cm-content-factory/examples/01-real-estate.config.json +0 -146
  280. package/skills/cm-content-factory/examples/02-personal-finance.config.json +0 -146
  281. package/skills/cm-content-factory/examples/03-health-wellness.config.json +0 -147
  282. package/skills/cm-content-factory/examples/04-saas-software.config.json +0 -147
  283. package/skills/cm-content-factory/examples/05-legal-services.config.json +0 -147
  284. package/skills/cm-content-factory/examples/06-insurance.config.json +0 -146
  285. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +0 -146
  286. package/skills/cm-content-factory/examples/08-online-education.config.json +0 -147
  287. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +0 -147
  288. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +0 -147
  289. package/skills/cm-content-factory/examples/11-home-services.config.json +0 -146
  290. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +0 -147
  291. package/skills/cm-content-factory/examples/13-pet-care.config.json +0 -147
  292. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +0 -147
  293. package/skills/cm-content-factory/examples/15-ai-automation.config.json +0 -147
  294. package/skills/cm-content-factory/examples/16-wedding-events.config.json +0 -147
  295. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +0 -148
  296. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +0 -147
  297. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +0 -148
  298. package/skills/cm-content-factory/examples/20-solar-energy.config.json +0 -147
  299. package/skills/cm-content-factory/examples/fitness-blog.config.json +0 -116
  300. package/skills/cm-content-factory/examples/tech-blog.config.json +0 -107
  301. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +0 -72
  302. package/skills/cm-content-factory/extensions/hooks.py +0 -126
  303. package/skills/cm-content-factory/extensions/openclaw_adapter.py +0 -132
  304. package/skills/cm-content-factory/landing/docs/content/changelog.md +0 -36
  305. package/skills/cm-content-factory/landing/docs/content/deployment.md +0 -46
  306. package/skills/cm-content-factory/landing/docs/content/execution-flow.md +0 -67
  307. package/skills/cm-content-factory/landing/docs/content/openspace.md +0 -27
  308. package/skills/cm-content-factory/landing/docs/content/openviking.md +0 -33
  309. package/skills/cm-content-factory/landing/docs/content/use-cases.md +0 -26
  310. package/skills/cm-content-factory/landing/docs/content/v5-intro.md +0 -28
  311. package/skills/cm-content-factory/landing/docs/index.html +0 -240
  312. package/skills/cm-content-factory/landing/index.html +0 -680
  313. package/skills/cm-content-factory/landing/script.js +0 -143
  314. package/skills/cm-content-factory/landing/style.css +0 -1216
  315. package/skills/cm-content-factory/landing/translations.js +0 -508
  316. package/skills/cm-content-factory/logs/events.jsonl +0 -11
  317. package/skills/cm-content-factory/profiles/_template.profile.json +0 -231
  318. package/skills/cm-content-factory/profiles/finance.profile.json +0 -278
  319. package/skills/cm-content-factory/profiles/legal.profile.json +0 -263
  320. package/skills/cm-content-factory/profiles/medical-research.profile.json +0 -321
  321. package/skills/cm-content-factory/profiles/technology.profile.json +0 -275
  322. package/skills/cm-content-factory/scripts/agent_dispatcher.py +0 -266
  323. package/skills/cm-content-factory/scripts/audit.py +0 -106
  324. package/skills/cm-content-factory/scripts/dashboard_server.py +0 -225
  325. package/skills/cm-content-factory/scripts/deploy.py +0 -146
  326. package/skills/cm-content-factory/scripts/extract.py +0 -132
  327. package/skills/cm-content-factory/scripts/landing_generator.py +0 -459
  328. package/skills/cm-content-factory/scripts/memory.py +0 -521
  329. package/skills/cm-content-factory/scripts/monetize.py +0 -239
  330. package/skills/cm-content-factory/scripts/pipeline.py +0 -357
  331. package/skills/cm-content-factory/scripts/plan.py +0 -163
  332. package/skills/cm-content-factory/scripts/publish.py +0 -145
  333. package/skills/cm-content-factory/scripts/research.py +0 -337
  334. package/skills/cm-content-factory/scripts/scaffold.py +0 -464
  335. package/skills/cm-content-factory/scripts/scoreboard.py +0 -336
  336. package/skills/cm-content-factory/scripts/seo.py +0 -90
  337. package/skills/cm-content-factory/scripts/state_manager.py +0 -320
  338. package/skills/cm-content-factory/scripts/token_manager.py +0 -268
  339. package/skills/cm-content-factory/scripts/validate.py +0 -221
  340. package/skills/cm-content-factory/scripts/wizard.py +0 -329
  341. package/skills/cm-content-factory/scripts/write.py +0 -93
  342. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  343. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +0 -90
  344. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +0 -54
  345. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +0 -38
  346. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +0 -65
  347. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +0 -48
  348. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +0 -39
  349. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +0 -42
  350. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +0 -51
  351. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +0 -52
  352. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +0 -86
  353. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +0 -80
  354. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +0 -58
  355. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +0 -102
  356. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +0 -45
  357. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +0 -29
  358. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +0 -55
  359. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +0 -29
  360. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +0 -41
  361. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +0 -40
  362. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +0 -56
  363. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +0 -46
  364. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +0 -45
  365. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +0 -45
  366. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +0 -108
  367. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +0 -22
  368. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +0 -52
  369. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +0 -58
  370. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +0 -92
  371. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +0 -575
  372. package/skills/cm-content-factory/tests/conftest.py +0 -66
  373. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +0 -125
  374. package/skills/cm-content-factory/tests/test_memory.py +0 -128
  375. package/skills/cm-content-factory/tests/test_pipeline.py +0 -107
  376. package/skills/cm-content-factory/tests/test_research.py +0 -56
  377. package/skills/cm-content-factory/tests/test_state_manager.py +0 -131
  378. package/skills/cm-content-factory/tests/test_token_manager.py +0 -110
  379. package/skills/cm-content-factory/tests/test_wizard.py +0 -121
  380. package/skills/cm-cro-methodology/SKILL.md +0 -290
  381. package/skills/cm-cro-methodology/references/COPYWRITING.md +0 -178
  382. package/skills/cm-cro-methodology/references/OBJECTIONS.md +0 -135
  383. package/skills/cm-cro-methodology/references/PERSUASION.md +0 -158
  384. package/skills/cm-cro-methodology/references/RESEARCH.md +0 -220
  385. package/skills/cm-cro-methodology/references/funnel-analysis.md +0 -365
  386. package/skills/cm-cro-methodology/references/testing-methodology.md +0 -330
  387. package/skills/cm-google-form/SKILL.md +0 -266
  388. package/skills/cm-google-form/templates/apps-script.js +0 -55
  389. package/skills/cm-google-form/templates/form-markup.html +0 -110
  390. package/skills/cm-google-form/templates/form-submit.js +0 -201
  391. package/skills/cm-google-form/templates/toast.css +0 -152
  392. package/skills/cm-growth-hacking/SKILL.md +0 -282
  393. package/skills/cm-growth-hacking/bottom-sheet-engine.md +0 -261
  394. package/skills/cm-growth-hacking/calendar-integration.md +0 -264
  395. package/skills/cm-growth-hacking/references/engagement-patterns.md +0 -346
  396. package/skills/cm-growth-hacking/templates/bottom-sheet.css +0 -528
  397. package/skills/cm-growth-hacking/templates/bottom-sheet.js +0 -269
  398. package/skills/cm-growth-hacking/templates/calendar-cta.js +0 -213
  399. package/skills/cm-growth-hacking/templates/tracking-events.js +0 -211
  400. package/skills/cm-growth-hacking/templates/trigger-manager.js +0 -254
  401. package/skills/cm-growth-hacking/tracking-events.md +0 -246
  402. package/skills/cm-growth-hacking/trigger-system.md +0 -342
  403. package/skills/cm-jtbd/SKILL.md +0 -98
  404. package/skills/cm-notebooklm/SKILL.md +0 -156
  405. package/skills/cm-notebooklm/references/command_reference.md +0 -94
  406. package/skills/cm-notebooklm/references/workflows.md +0 -60
  407. package/skills/cm-notebooklm/resources/knowledge_sources.md +0 -106
  408. package/skills/cm-notebooklm/scripts/brain-sync.sh +0 -453
  409. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +0 -101
  410. package/skills/cm-readit/SKILL.md +0 -289
  411. package/skills/cm-readit/audio-player.md +0 -206
  412. package/skills/cm-readit/examples/blog-reader.js +0 -352
  413. package/skills/cm-readit/examples/voice-cro.js +0 -390
  414. package/skills/cm-readit/tts-engine.md +0 -262
  415. package/skills/cm-readit/ui-patterns.md +0 -362
  416. package/skills/cm-readit/voice-cro.md +0 -223
@@ -1,152 +0,0 @@
1
- /* ============================================
2
- FORM TOAST NOTIFICATION
3
- ============================================
4
-
5
- Copy this into your main CSS file.
6
-
7
- Dependencies: none
8
- CSS Variables used (override if needed):
9
- - --space-2 through --space-8
10
- - --radius-lg, --radius-full
11
- - --text-sm
12
- - --transition-fast
13
- - --white
14
-
15
- If your project doesn't use CSS variables,
16
- replace them with fixed values:
17
- - --space-2: 8px, --space-3: 12px, --space-4: 16px, --space-5: 20px
18
- - --radius-lg: 12px, --radius-full: 9999px
19
- - --text-sm: 14px
20
- - --transition-fast: 150ms ease
21
- */
22
-
23
- .form-toast-container {
24
- position: fixed;
25
- bottom: 100px;
26
- left: 50%;
27
- transform: translateX(-50%);
28
- z-index: 10000;
29
- display: flex;
30
- flex-direction: column;
31
- gap: 12px;
32
- width: calc(100% - 32px);
33
- max-width: 440px;
34
- pointer-events: none;
35
- }
36
-
37
- .form-toast {
38
- pointer-events: auto;
39
- display: flex;
40
- align-items: flex-start;
41
- gap: 12px;
42
- padding: 16px 20px;
43
- border-radius: 12px;
44
- box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18), 0 2px 8px rgba(0, 0, 0, 0.1);
45
- animation: toastSlideUp 0.35s cubic-bezier(0.16, 1, 0.3, 1) forwards;
46
- opacity: 0;
47
- transform: translateY(20px);
48
- font-size: 14px;
49
- line-height: 1.5;
50
- }
51
-
52
- .form-toast.hiding {
53
- animation: toastSlideDown 0.25s ease-in forwards;
54
- }
55
-
56
- /* Variants */
57
- .form-toast--success {
58
- background: #ECFDF5;
59
- border: 1px solid #A7F3D0;
60
- color: #065F46;
61
- }
62
-
63
- .form-toast--error {
64
- background: #FEF2F2;
65
- border: 1px solid #FECACA;
66
- color: #991B1B;
67
- }
68
-
69
- .form-toast--retrying {
70
- background: #FFFBEB;
71
- border: 1px solid #FDE68A;
72
- color: #92400E;
73
- }
74
-
75
- /* Elements */
76
- .form-toast-icon {
77
- font-size: 20px;
78
- flex-shrink: 0;
79
- line-height: 1;
80
- margin-top: 1px;
81
- }
82
-
83
- .form-toast-body {
84
- flex: 1;
85
- min-width: 0;
86
- }
87
-
88
- .form-toast-title {
89
- font-weight: 700;
90
- margin-bottom: 2px;
91
- }
92
-
93
- .form-toast-msg {
94
- opacity: 0.85;
95
- }
96
-
97
- .form-toast-close {
98
- flex-shrink: 0;
99
- background: none;
100
- border: none;
101
- cursor: pointer;
102
- font-size: 18px;
103
- line-height: 1;
104
- opacity: 0.5;
105
- padding: 4px;
106
- color: inherit;
107
- transition: opacity 150ms ease;
108
- }
109
-
110
- .form-toast-close:hover {
111
- opacity: 1;
112
- }
113
-
114
- /* Fallback contact button (Zalo, Messenger, etc.) */
115
- .form-toast-zalo {
116
- display: inline-flex;
117
- align-items: center;
118
- gap: 6px;
119
- margin-top: 8px;
120
- padding: 8px 16px;
121
- background: #0068FF;
122
- color: #fff !important;
123
- border-radius: 9999px;
124
- font-size: 14px;
125
- font-weight: 600;
126
- text-decoration: none;
127
- transition: background 150ms ease, transform 150ms ease;
128
- }
129
-
130
- .form-toast-zalo:hover {
131
- background: #0054cc;
132
- transform: translateY(-1px);
133
- }
134
-
135
- /* Animations */
136
- @keyframes toastSlideUp {
137
- from { opacity: 0; transform: translateY(20px); }
138
- to { opacity: 1; transform: translateY(0); }
139
- }
140
-
141
- @keyframes toastSlideDown {
142
- from { opacity: 1; transform: translateY(0); }
143
- to { opacity: 0; transform: translateY(20px); }
144
- }
145
-
146
- /* Mobile: push toast above sticky CTAs */
147
- @media (max-width: 768px) {
148
- .form-toast-container {
149
- bottom: 80px;
150
- width: calc(100% - 24px);
151
- }
152
- }
@@ -1,282 +0,0 @@
1
- ---
2
- name: cm-growth-hacking
3
- description: "Bottom-sheet and popup growth system: booking CTAs, calendars, lead capture, surveys, re-engagement, with CRO tracking hooks. Zero-deps; works static or dynamic sites. Works with cm-booking-calendar, cm-ads-tracker, cm-google-form, cm-readit, cm-ux-master."
4
- allowed-tools: Read, Write, Edit, Glob, Grep, Browser
5
- version: 1.0
6
- priority: HIGH
7
- skills:
8
- - cm-booking-calendar
9
- - cm-ads-tracker
10
- - cm-google-form
11
- - cm-readit
12
- - cm-ux-master
13
- ---
14
-
15
- # CM Growth Hacking
16
-
17
- > **Bottom Sheet + Calendar + Trigger + Tracking = Growth Hacking Engine.**
18
- > Đa ngành, đa mục đích, zero dependencies.
19
- > 1 skill = mọi growth hacking pattern bạn cần.
20
-
21
- ---
22
-
23
- ## 🎯 When to Use
24
-
25
- | Trigger | Action |
26
- |---------|--------|
27
- | User says "bottom sheet", "popup" | Activate — start Phase 1 |
28
- | User says "đặt lịch popup", "booking bottom sheet" | Activate — focus booking sheet |
29
- | User says "lead capture", "exit intent" | Activate — focus lead capture |
30
- | User says "nhắc lịch", "google calendar", "apple calendar" | Activate — focus calendar CTA |
31
- | User says "flash sale popup", "countdown" | Activate — focus promo sheet |
32
- | User says "survey", "đánh giá", "feedback" | Activate — focus survey sheet |
33
- | User says "tăng conversion", "giảm bounce" | Activate — explain + build |
34
-
35
- ---
36
-
37
- ## 📖 Selective Reading Rule (MANDATORY)
38
-
39
- | File | Status | When to Read |
40
- |------|--------|--------------|
41
- | [bottom-sheet-engine.md](bottom-sheet-engine.md) | 🔴 REQUIRED | Any bottom sheet implementation |
42
- | [trigger-system.md](trigger-system.md) | 🔴 REQUIRED | Setting up when/how sheets appear |
43
- | [calendar-integration.md](calendar-integration.md) | ⚪ Optional | When sheet includes calendar CTA |
44
- | [tracking-events.md](tracking-events.md) | ⚪ Optional | When tracking engagement events |
45
-
46
- > 🔴 **Always read `bottom-sheet-engine.md` + `trigger-system.md` first.**
47
-
48
- ---
49
-
50
- ## 🧭 Quick Decision Tree
51
-
52
- ```
53
- "I need an engagement popup"
54
-
55
- ├─ Booking / Appointment
56
- │ └─ bottom-sheet-engine + calendar-integration + cm-booking-calendar
57
- │ └─ Form → Sheet: cm-google-form
58
- │ └─ Post-submit: Calendar CTA (GCal + ICS)
59
-
60
- ├─ Lead Capture / Exit Intent
61
- │ └─ bottom-sheet-engine + trigger-system (exit-intent)
62
- │ └─ Form → Sheet: cm-google-form
63
- │ └─ Tracking: cro_lead_capture
64
-
65
- ├─ Flash Sale / Promo
66
- │ └─ bottom-sheet-engine + trigger-system (timer)
67
- │ └─ Countdown timer + CTA
68
- │ └─ Optional: Calendar deadline
69
-
70
- ├─ Survey / Feedback
71
- │ └─ bottom-sheet-engine + trigger-system (post-interaction)
72
- │ └─ Star rating or NPS
73
- │ └─ Form → Sheet: cm-google-form
74
-
75
- ├─ Event / Webinar Registration
76
- │ └─ bottom-sheet-engine + calendar-integration
77
- │ └─ Register → Add to Calendar
78
- │ └─ Tracking: cro_event_register
79
-
80
- ├─ Re-engagement (Return Visitor)
81
- │ └─ bottom-sheet-engine + trigger-system (return-visitor)
82
- │ └─ "Welcome back" + personalized CTA
83
-
84
- └─ Chat / Contact CTA
85
- └─ bottom-sheet-engine + trigger-system (scroll)
86
- └─ Zalo / Messenger / Hotline buttons
87
- ```
88
-
89
- ---
90
-
91
- ## 📋 6-Phase Workflow
92
-
93
- ```
94
- Phase 1: DISCOVER → Scan site, detect industry, identify existing popups/forms
95
- Phase 2: SOCRATIC GATE → Ask strategic questions (max 5)
96
- Phase 3: CONFIGURE → Select engagement pattern + customize
97
- Phase 4: BUILD → Generate bottom sheet + triggers + calendar + tracking
98
- Phase 5: INTEGRATE → Wire to site + link skills
99
- Phase 6: VERIFY → Test all interactions + tracking events
100
- ```
101
-
102
- > 🔴 **Rule:** NEVER skip Phase 1 & 2. Always scan first, ask second.
103
-
104
- ---
105
-
106
- ## Phase 1: DISCOVER
107
-
108
- Scan the website to understand:
109
-
110
- ```bash
111
- # Find existing popups/modals/sheets
112
- grep -ri "modal\|popup\|bottom-sheet\|overlay\|dialog" --include="*.html" --include="*.astro" --include="*.css" .
113
-
114
- # Find existing forms
115
- grep -ri "data-form-type\|onsubmit\|<form" --include="*.html" --include="*.astro" .
116
-
117
- # Find existing calendar code
118
- grep -ri "VCALENDAR\|google.com/calendar\|\.ics\|VEVENT" --include="*.js" --include="*.html" .
119
-
120
- # Find existing tracking
121
- grep -ri "dataLayer\|fbq\|ttq\|gtag" --include="*.js" --include="*.html" .
122
- ```
123
-
124
- **Output:** Discovery Report with detected industry, existing UI, and recommended pattern.
125
-
126
- ---
127
-
128
- ## Phase 2: SOCRATIC GATE
129
-
130
- > 🔴 **MANDATORY.** Ask ALL in ONE message. Max 5 questions.
131
-
132
- 1. **Mục tiêu chính** — Bạn muốn popup/bottom sheet để làm gì? (đặt lịch / thu lead / khuyến mãi / survey / khác)
133
- 2. **Trigger** — Khi nào hiện? (ngay khi vào trang / scroll X% / sau X giây / khi sắp thoát / click nút)
134
- 3. **Nội dung** — Trong popup cần gì? (form / calendar CTA / countdown / rating / nút chat)
135
- 4. **Calendar** — Có cần thêm Google Calendar / Apple Calendar không? Nhắc trước bao lâu?
136
- 5. **Tracking** — Đang chạy ads platform nào? (Facebook / TikTok / Google / không)
137
-
138
- ---
139
-
140
- ## Phase 3: CONFIGURE
141
-
142
- Based on answers, select from `references/engagement-patterns.md` and build config:
143
-
144
- ```javascript
145
- const ENGAGEMENT_CONFIG = {
146
- type: 'booking', // booking | lead | promo | survey | event | chat | reengagement
147
- trigger: {
148
- type: 'scroll', // scroll | time | exit | click | return | interaction
149
- value: 0.3, // scroll % or ms or selector
150
- delay: 0, // additional delay after trigger
151
- },
152
- sheet: {
153
- size: 'standard', // compact | standard | full
154
- title: 'Đặt Lịch Khám',
155
- icon: '📅',
156
- dismissible: true,
157
- swipeToDismiss: true,
158
- },
159
- calendar: {
160
- enabled: true,
161
- providers: ['gcal', 'ics'], // gcal | ics | outlook
162
- reminderMinutes: [1440, 120], // 1 day + 2 hours before
163
- location: 'Google Maps URL',
164
- },
165
- tracking: {
166
- events: ['cro_sheet_shown', 'cro_booking_submit', 'cro_calendar_add'],
167
- conversionValue: 500000,
168
- currency: 'VND',
169
- },
170
- session: {
171
- dismissKey: 'eng_booking_dismissed',
172
- storage: 'sessionStorage', // sessionStorage | localStorage
173
- maxShowPerSession: 1,
174
- }
175
- };
176
- ```
177
-
178
- ---
179
-
180
- ## Phase 4: BUILD
181
-
182
- Read and use templates from `templates/` directory:
183
-
184
- | Template | Purpose |
185
- |----------|---------|
186
- | `templates/bottom-sheet.css` | Universal responsive bottom sheet CSS |
187
- | `templates/bottom-sheet.js` | `BottomSheetEngine` class — create, show, hide, swipe, stack |
188
- | `templates/calendar-cta.js` | Calendar button generators (GCal + ICS + device detection) |
189
- | `templates/trigger-manager.js` | `TriggerManager` class — scroll, time, exit, click triggers |
190
- | `templates/tracking-events.js` | DataLayer push helpers for engagement events |
191
-
192
- ---
193
-
194
- ## Phase 5: INTEGRATE
195
-
196
- ### Wire to Existing Skills
197
-
198
- ```
199
- cm-growth-hacking (this skill)
200
-
201
- ├── UI Layer ──────────── templates/bottom-sheet.css + .js
202
-
203
- ├── Form Submit ───────── @skills/cm-google-form
204
- │ └── submitToGoogleSheet() → success callback → show calendar CTA
205
-
206
- ├── Calendar Logic ────── @skills/cm-booking-calendar
207
- │ └── calendar-engine.js (scheduling)
208
- │ └── calendar-export.js (ICS + GCal deep link)
209
- │ └── reminder-config.js (VALARM + industry patterns)
210
-
211
- ├── CRO Tracking ──────── @skills/cm-ads-tracker
212
- │ └── dataLayer.push() → GTM → FB/TikTok/Google
213
-
214
- └── Design Principles ─── @skills/cm-ux-master
215
- └── Color, typography, animation standards
216
- ```
217
-
218
- ---
219
-
220
- ## Phase 6: VERIFY
221
-
222
- | # | Test Case | Expected |
223
- |---|-----------|----------|
224
- | 1 | Bottom sheet opens | Slides up with animation |
225
- | 2 | Swipe down to dismiss | Sheet closes + state saved |
226
- | 3 | Trigger fires correctly | Sheet appears at configured trigger |
227
- | 4 | Form submit (if applicable) | Toast success → Calendar CTA appears |
228
- | 5 | Google Calendar click | New tab with pre-filled event |
229
- | 6 | ICS download click | .ics file downloads |
230
- | 7 | .ics on iOS | Opens Apple Calendar with reminders |
231
- | 8 | Tracking events fire | dataLayer shows correct events |
232
- | 9 | Session dismiss works | Sheet doesn't reappear after dismiss |
233
- | 10 | Mobile responsive | Sheet adapts to viewport |
234
- | 11 | Accessibility | aria-labels, focus trap, Escape key |
235
- | 12 | No conflict with existing UI | Doesn't break page layout |
236
-
237
- ---
238
-
239
- ## ❌ Anti-Patterns
240
-
241
- | ❌ Don't | ✅ Do |
242
- |----------|------|
243
- | Hardcode content in sheet | Use config object |
244
- | Show popup immediately on page load | Use trigger system with delay |
245
- | No dismiss option | Always allow close + swipe |
246
- | Forget mobile safe-area | Pad for notched devices |
247
- | Skip tracking | Track every interaction |
248
- | One-size-fits-all sheet | Use compact/standard/full variants |
249
- | Autoplay anything | Require user interaction |
250
- | Show on every page visit | Respect session/localStorage dismiss |
251
- | Build calendar logic from scratch | Inherit from `cm-booking-calendar` |
252
- | Build tracking from scratch | Inherit from `cm-ads-tracker` |
253
-
254
- ---
255
-
256
- ## 📑 Templates
257
-
258
- | File | Purpose |
259
- |------|---------|
260
- | `templates/bottom-sheet.css` | Universal bottom sheet CSS (3 sizes) |
261
- | `templates/bottom-sheet.js` | BottomSheetEngine class |
262
- | `templates/calendar-cta.js` | Calendar CTA buttons + auto device route |
263
- | `templates/trigger-manager.js` | TriggerManager class |
264
- | `templates/tracking-events.js` | Engagement tracking helpers |
265
-
266
- ## 📚 References
267
-
268
- | File | Purpose |
269
- |------|---------|
270
- | `references/engagement-patterns.md` | 10+ engagement patterns by industry |
271
-
272
- ---
273
-
274
- ## 🔗 Related Skills
275
-
276
- | Need | Skill |
277
- |------|-------|
278
- | Calendar scheduling + export | `@[skills/cm-booking-calendar]` |
279
- | Form → Google Sheet | `@[skills/cm-google-form]` |
280
- | Full CRO tracking setup | `@[skills/cm-ads-tracker]` |
281
- | Audio engagement | `@[skills/cm-readit]` |
282
- | UI/UX design principles | `@[skills/cm-ux-master]` |
@@ -1,261 +0,0 @@
1
- # Bottom Sheet Engine
2
-
3
- > Core module cho mọi engagement UI. Modular, responsive, accessible.
4
- > Một engine — nhiều content types.
5
-
6
- ---
7
-
8
- ## 🏗️ Architecture
9
-
10
- ```
11
- BottomSheetEngine
12
- ├── create(config) → Build DOM + attach events
13
- ├── show() → Slide up animation
14
- ├── hide() → Slide down + cleanup
15
- ├── destroy() → Remove from DOM entirely
16
- ├── setContent(html) → Swap inner content dynamically
17
- ├── setSize(size) → Switch compact/standard/full
18
- └── onDismiss(callback) → Hook for tracking/state
19
- ```
20
-
21
- ### 3 Size Variants
22
-
23
- | Size | Height | Use Case |
24
- |------|--------|----------|
25
- | `compact` | ~120px | Simple CTA, chat buttons, promo banner |
26
- | `standard` | ~320px | Booking form, lead capture, calendar CTA |
27
- | `full` | ~80vh | Survey, multi-step form, detailed content |
28
-
29
- ### DOM Structure
30
-
31
- ```html
32
- <!-- Backdrop (optional, for full-size sheets) -->
33
- <div class="eng-backdrop" data-sheet-id="booking"></div>
34
-
35
- <!-- Bottom Sheet -->
36
- <div class="eng-sheet eng-sheet--standard" data-sheet-id="booking" role="dialog" aria-modal="true" aria-label="Đặt Lịch Khám">
37
- <!-- Drag handle -->
38
- <div class="eng-sheet__handle" aria-hidden="true">
39
- <div class="eng-sheet__handle-bar"></div>
40
- </div>
41
-
42
- <!-- Close button -->
43
- <button class="eng-sheet__close" aria-label="Đóng">✕</button>
44
-
45
- <!-- Content area (swappable) -->
46
- <div class="eng-sheet__content">
47
- <!-- Dynamic content injected here -->
48
- </div>
49
- </div>
50
- ```
51
-
52
- ---
53
-
54
- ## 🎨 Styling Principles
55
-
56
- ### Must-Have CSS Features
57
-
58
- | Feature | Why |
59
- |---------|-----|
60
- | `position: fixed; bottom: 0` | Anchored to viewport bottom |
61
- | `transform: translateY(100%)` → `translateY(0)` | Smooth slide-up animation |
62
- | `backdrop-filter: blur(24px)` | Glassmorphism, premium feel |
63
- | `border-radius: 20px 20px 0 0` | iOS-style rounded top corners |
64
- | `padding-bottom: env(safe-area-inset-bottom)` | Safe area for notched devices |
65
- | `z-index: 1100` | Above nav bars but below modals |
66
- | Drag handle pseudo-element | Visual signal "this is draggable" |
67
-
68
- ### Animation Timing
69
-
70
- ```css
71
- /* Open: slightly bouncy, feels natural */
72
- transition: transform 0.4s cubic-bezier(0.32, 0.72, 0, 1);
73
-
74
- /* Close: quick, decisive */
75
- transition: transform 0.25s cubic-bezier(0.4, 0, 1, 1);
76
- ```
77
-
78
- ### Responsive Rules
79
-
80
- | Viewport | Behavior |
81
- |----------|----------|
82
- | Mobile (< 768px) | Full-width, touch-optimized, swipe dismiss |
83
- | Tablet (768-1024px) | Max-width 480px, centered |
84
- | Desktop (> 1024px) | Max-width 480px, right-aligned or centered |
85
-
86
- ---
87
-
88
- ## 👆 Touch Interactions
89
-
90
- ### Swipe-to-Dismiss
91
-
92
- ```
93
- touchstart → record startY
94
- touchmove → calculate deltaY
95
- if deltaY > 0 → sheet follows finger (translateY)
96
- if deltaY > threshold (80px) → dismiss
97
- touchend → snap back or dismiss based on velocity
98
- ```
99
-
100
- **Key Rules:**
101
- - Only allow downward swipe (deltaY > 0)
102
- - Apply `will-change: transform` during drag for perf
103
- - Use velocity calculation: fast swipe = dismiss even if < 80px
104
- - Add `touch-action: none` on the drag handle only
105
-
106
- ### Focus Trap (Accessibility)
107
-
108
- ```
109
- When sheet opens:
110
- 1. Save currently focused element
111
- 2. Move focus to sheet
112
- 3. Trap Tab/Shift+Tab within sheet
113
- 4. On close: restore focus to saved element
114
- ```
115
-
116
- ---
117
-
118
- ## 📦 Content Type Patterns
119
-
120
- ### 1. Booking Form Content
121
-
122
- ```html
123
- <div class="eng-sheet__content">
124
- <div class="eng-content-booking">
125
- <h3 class="eng-content__title">📅 Đặt Lịch Khám</h3>
126
- <form data-form-type="booking" onsubmit="window.submitToGoogleSheet(event)">
127
- <input type="hidden" name="url" value="">
128
- <input type="text" name="name" placeholder="Họ tên" required>
129
- <input type="tel" name="phone" placeholder="Số điện thoại" required>
130
- <div class="eng-date-chips" id="dateChips"><!-- JS generated --></div>
131
- <div class="eng-time-slots" id="timeSlots"><!-- JS generated --></div>
132
- <select name="service"><!-- Industry-specific options --></select>
133
- <textarea name="note" placeholder="Ghi chú (tùy chọn)"></textarea>
134
- <button type="submit" class="eng-btn eng-btn--primary">Xác Nhận Đặt Lịch</button>
135
- </form>
136
- </div>
137
- </div>
138
- ```
139
-
140
- ### 2. Calendar CTA Content (Post-Submit)
141
-
142
- ```html
143
- <div class="eng-content-calendar">
144
- <div class="eng-content__icon">✅</div>
145
- <h3 class="eng-content__title">Đặt lịch thành công!</h3>
146
- <p class="eng-content__subtitle">Thêm vào lịch để không quên nhé</p>
147
- <div class="eng-calendar-buttons">
148
- <button onclick="addToGoogleCal()" class="eng-btn eng-btn--gcal">
149
- <img src="gcal-icon.svg" alt="" width="20"> Google Calendar
150
- </button>
151
- <button onclick="downloadICS()" class="eng-btn eng-btn--ics">
152
- 📥 Apple Calendar / Khác
153
- </button>
154
- </div>
155
- <p class="eng-content__benefit">💡 Lịch sẽ tự nhắc bạn — hoàn toàn miễn phí</p>
156
- </div>
157
- ```
158
-
159
- ### 3. Lead Capture Content
160
-
161
- ```html
162
- <div class="eng-content-lead">
163
- <div class="eng-content__icon">🎁</div>
164
- <h3 class="eng-content__title">Nhận tài liệu miễn phí</h3>
165
- <p class="eng-content__subtitle">Để lại SĐT, chúng tôi gửi ngay</p>
166
- <form data-form-type="lead" onsubmit="window.submitToGoogleSheet(event)">
167
- <input type="hidden" name="url" value="">
168
- <input type="tel" name="phone" placeholder="Số điện thoại" required>
169
- <button type="submit" class="eng-btn eng-btn--primary">Gửi Cho Tôi</button>
170
- </form>
171
- </div>
172
- ```
173
-
174
- ### 4. Flash Sale Content
175
-
176
- ```html
177
- <div class="eng-content-promo">
178
- <div class="eng-content__icon">🔥</div>
179
- <h3 class="eng-content__title">Ưu đãi đặc biệt!</h3>
180
- <div class="eng-countdown" id="countdown">
181
- <span class="eng-countdown__unit"><span id="hours">00</span>h</span>
182
- <span class="eng-countdown__unit"><span id="minutes">00</span>m</span>
183
- <span class="eng-countdown__unit"><span id="seconds">00</span>s</span>
184
- </div>
185
- <p class="eng-content__subtitle">Giảm 30% khi đặt lịch hôm nay</p>
186
- <a href="#booking" class="eng-btn eng-btn--primary">Đặt Ngay →</a>
187
- <button class="eng-btn eng-btn--outline" onclick="addDeadlineToCalendar()">
188
- 📅 Nhắc tôi trước khi hết hạn
189
- </button>
190
- </div>
191
- ```
192
-
193
- ### 5. Survey / Feedback Content
194
-
195
- ```html
196
- <div class="eng-content-survey">
197
- <h3 class="eng-content__title">⭐ Đánh giá trải nghiệm</h3>
198
- <div class="eng-rating" id="starRating">
199
- <button data-rating="1" aria-label="1 sao">⭐</button>
200
- <button data-rating="2" aria-label="2 sao">⭐</button>
201
- <button data-rating="3" aria-label="3 sao">⭐</button>
202
- <button data-rating="4" aria-label="4 sao">⭐</button>
203
- <button data-rating="5" aria-label="5 sao">⭐</button>
204
- </div>
205
- <textarea name="feedback" placeholder="Chia sẻ thêm (tùy chọn)"></textarea>
206
- <button class="eng-btn eng-btn--primary" onclick="submitSurvey()">Gửi Đánh Giá</button>
207
- </div>
208
- ```
209
-
210
- ### 6. Chat / Contact CTA
211
-
212
- ```html
213
- <div class="eng-content-chat">
214
- <p class="eng-content__title">💬 Cần tư vấn?</p>
215
- <div class="eng-chat-buttons">
216
- <a href="https://zalo.me/PHONE" class="eng-btn eng-btn--zalo">Zalo</a>
217
- <a href="tel:PHONE" class="eng-btn eng-btn--phone">📞 Gọi ngay</a>
218
- <a href="https://m.me/PAGE" class="eng-btn eng-btn--messenger">Messenger</a>
219
- </div>
220
- </div>
221
- ```
222
-
223
- ---
224
-
225
- ## 🔄 Multi-Step Flow
226
-
227
- For complex interactions (e.g., booking → success → calendar CTA):
228
-
229
- ```javascript
230
- // Step 1: Show booking form
231
- sheet.setContent(bookingFormHTML);
232
- sheet.show();
233
-
234
- // Step 2: On form success → swap to calendar CTA
235
- onFormSuccess(() => {
236
- sheet.setContent(calendarCTAHTML);
237
- // Track transition
238
- trackEngagement('cro_booking_submit', { service: formData.service });
239
- });
240
-
241
- // Step 3: On calendar add → show thank you + close
242
- onCalendarAdd(() => {
243
- trackEngagement('cro_calendar_add', { type: 'gcal' });
244
- sheet.hide();
245
- showToast('success', 'Đã thêm vào lịch! 🎉');
246
- });
247
- ```
248
-
249
- ---
250
-
251
- ## ❌ Anti-Patterns
252
-
253
- | ❌ Don't | ✅ Do |
254
- |----------|------|
255
- | Nest sheets inside sheets | One sheet at a time, swap content |
256
- | Hardcode content | Use setContent() for flexibility |
257
- | Forget backdrop for full sheets | Add backdrop + blur for full-size |
258
- | Skip keyboard navigation | Trap Tab key, close on Escape |
259
- | Ignore safe-area-inset | Always pad for notched phones |
260
- | Use `overflow: hidden` on body | Use `overscroll-behavior: contain` on sheet |
261
- | Animate with JS | Use CSS transitions + `requestAnimationFrame` |