codymaster 4.1.4 → 4.3.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 (657) hide show
  1. package/CHANGELOG.md +22 -2
  2. package/README.md +54 -84
  3. package/dist/index.js +118 -4
  4. package/install.sh +2 -2
  5. package/package.json +3 -8
  6. package/skills/AGENTS.md +61 -0
  7. package/skills/CLAUDE.md +158 -0
  8. package/skills/boxme-git-config/SKILL.md +56 -0
  9. package/skills/boxme-local-dev/SKILL.md +66 -0
  10. package/skills/build.sh +30 -0
  11. package/skills/cf +314 -0
  12. package/skills/cf 2 +313 -0
  13. package/skills/cm-ads-tracker/SKILL.md +364 -69
  14. package/skills/cm-auto-publisher/SKILL.md +81 -0
  15. package/skills/cm-booking-calendar/SKILL.md +521 -0
  16. package/skills/cm-booking-calendar/references/industry-patterns.md +527 -0
  17. package/skills/cm-booking-calendar/templates/booking-form.css +626 -0
  18. package/skills/cm-booking-calendar/templates/booking-form.html +477 -0
  19. package/skills/cm-booking-calendar/templates/calendar-engine.js +419 -0
  20. package/skills/cm-booking-calendar/templates/calendar-export.js +395 -0
  21. package/skills/cm-booking-calendar/templates/reminder-config.js +629 -0
  22. package/skills/cm-brainstorm-idea/SKILL.md +15 -24
  23. package/skills/cm-clean-code/SKILL.md +300 -0
  24. package/skills/cm-code-review/SKILL.md +0 -27
  25. package/skills/cm-codeintell/SKILL.md +598 -0
  26. package/skills/cm-content-factory/.content-factory-state.json +132 -0
  27. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +1 -0
  28. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +1 -0
  29. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  30. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  31. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  32. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  33. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  34. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  35. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  36. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  37. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  38. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  39. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  40. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  41. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  42. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  43. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  44. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  45. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  46. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  47. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  48. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  49. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  50. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  51. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  52. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  53. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  54. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  55. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  56. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  57. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  58. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  59. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  60. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  61. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  62. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  63. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  64. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  65. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  66. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  67. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  68. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  69. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  70. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  71. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  72. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +5 -0
  73. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  74. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  75. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  76. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  77. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  78. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  79. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  80. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  81. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  82. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  83. package/skills/cm-content-factory/.git 2/refs/heads/main +1 -0
  84. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +1 -0
  85. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +76 -0
  86. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +1 -0
  87. package/skills/cm-content-factory/AGENTS.md +61 -0
  88. package/skills/cm-content-factory/CLAUDE.md +63 -0
  89. package/skills/cm-content-factory/CURSOR.md +43 -0
  90. package/skills/cm-content-factory/Content Factory.zip +0 -0
  91. package/skills/cm-content-factory/cf +313 -0
  92. package/skills/cm-content-factory/config.schema.json +397 -0
  93. package/skills/cm-content-factory/dashboard/app.js +556 -0
  94. package/skills/cm-content-factory/dashboard/index.html +397 -0
  95. package/skills/cm-content-factory/dashboard/style.css +1211 -0
  96. package/skills/cm-content-factory/examples/01-real-estate.config.json +146 -0
  97. package/skills/cm-content-factory/examples/02-personal-finance.config.json +146 -0
  98. package/skills/cm-content-factory/examples/03-health-wellness.config.json +147 -0
  99. package/skills/cm-content-factory/examples/04-saas-software.config.json +147 -0
  100. package/skills/cm-content-factory/examples/05-legal-services.config.json +147 -0
  101. package/skills/cm-content-factory/examples/06-insurance.config.json +146 -0
  102. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +146 -0
  103. package/skills/cm-content-factory/examples/08-online-education.config.json +147 -0
  104. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +147 -0
  105. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +147 -0
  106. package/skills/cm-content-factory/examples/11-home-services.config.json +146 -0
  107. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +147 -0
  108. package/skills/cm-content-factory/examples/13-pet-care.config.json +147 -0
  109. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +147 -0
  110. package/skills/cm-content-factory/examples/15-ai-automation.config.json +147 -0
  111. package/skills/cm-content-factory/examples/16-wedding-events.config.json +147 -0
  112. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +148 -0
  113. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +147 -0
  114. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +148 -0
  115. package/skills/cm-content-factory/examples/20-solar-energy.config.json +147 -0
  116. package/skills/cm-content-factory/examples/fitness-blog.config.json +116 -0
  117. package/skills/cm-content-factory/examples/tech-blog.config.json +107 -0
  118. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +72 -0
  119. package/skills/cm-content-factory/extensions/hooks.py +126 -0
  120. package/skills/cm-content-factory/extensions/openclaw_adapter.py +132 -0
  121. package/skills/cm-content-factory/landing/index.html +680 -0
  122. package/skills/cm-content-factory/landing/script.js +101 -0
  123. package/skills/cm-content-factory/landing/style.css +1216 -0
  124. package/skills/cm-content-factory/landing/translations.js +508 -0
  125. package/skills/cm-content-factory/logs/events.jsonl +11 -0
  126. package/skills/cm-content-factory/profiles/_template.profile.json +231 -0
  127. package/skills/cm-content-factory/profiles/finance.profile.json +278 -0
  128. package/skills/cm-content-factory/profiles/legal.profile.json +263 -0
  129. package/skills/cm-content-factory/profiles/medical-research.profile.json +321 -0
  130. package/skills/cm-content-factory/profiles/technology.profile.json +275 -0
  131. package/skills/cm-content-factory/scripts/agent_dispatcher.py +266 -0
  132. package/skills/cm-content-factory/scripts/audit.py +106 -0
  133. package/skills/cm-content-factory/scripts/dashboard_server.py +225 -0
  134. package/skills/cm-content-factory/scripts/deploy.py +146 -0
  135. package/skills/cm-content-factory/scripts/extract.py +132 -0
  136. package/skills/cm-content-factory/scripts/landing_generator.py +459 -0
  137. package/skills/cm-content-factory/scripts/memory.py +521 -0
  138. package/skills/cm-content-factory/scripts/monetize.py +239 -0
  139. package/skills/cm-content-factory/scripts/pipeline.py +357 -0
  140. package/skills/cm-content-factory/scripts/plan.py +163 -0
  141. package/skills/cm-content-factory/scripts/publish.py +145 -0
  142. package/skills/cm-content-factory/scripts/research.py +337 -0
  143. package/skills/cm-content-factory/scripts/scaffold.py +464 -0
  144. package/skills/cm-content-factory/scripts/scoreboard.py +336 -0
  145. package/skills/cm-content-factory/scripts/seo.py +90 -0
  146. package/skills/cm-content-factory/scripts/state_manager.py +320 -0
  147. package/skills/cm-content-factory/scripts/token_manager.py +268 -0
  148. package/skills/cm-content-factory/scripts/validate.py +221 -0
  149. package/skills/cm-content-factory/scripts/wizard.py +329 -0
  150. package/skills/cm-content-factory/scripts/write.py +93 -0
  151. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  152. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +90 -0
  153. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +54 -0
  154. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +38 -0
  155. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +65 -0
  156. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +48 -0
  157. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +39 -0
  158. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +42 -0
  159. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +51 -0
  160. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +52 -0
  161. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +86 -0
  162. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +80 -0
  163. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +58 -0
  164. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +102 -0
  165. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +45 -0
  166. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +29 -0
  167. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +55 -0
  168. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +29 -0
  169. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +41 -0
  170. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +40 -0
  171. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +56 -0
  172. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +46 -0
  173. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +45 -0
  174. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +45 -0
  175. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +108 -0
  176. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +22 -0
  177. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +52 -0
  178. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +58 -0
  179. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +92 -0
  180. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +575 -0
  181. package/skills/cm-content-factory/tests/conftest.py +66 -0
  182. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +125 -0
  183. package/skills/cm-content-factory/tests/test_memory.py +128 -0
  184. package/skills/cm-content-factory/tests/test_pipeline.py +107 -0
  185. package/skills/cm-content-factory/tests/test_research.py +56 -0
  186. package/skills/cm-content-factory/tests/test_state_manager.py +131 -0
  187. package/skills/cm-content-factory/tests/test_token_manager.py +110 -0
  188. package/skills/cm-content-factory/tests/test_wizard.py +121 -0
  189. package/skills/cm-continuity/SKILL.md +7 -0
  190. package/skills/cm-cro-methodology/SKILL.md +290 -0
  191. package/skills/cm-dashboard/SKILL.md +7 -525
  192. package/skills/cm-debugging/SKILL.md +7 -116
  193. package/skills/cm-deep-search/SKILL.md +5 -1
  194. package/skills/cm-dockit/README.md +6 -15
  195. package/skills/cm-dockit/SKILL.md +20 -37
  196. package/skills/cm-execution/SKILL.md +6 -1
  197. package/skills/cm-frappe-agent/SKILL.md +134 -0
  198. package/skills/cm-frappe-agent/agents/doctype-architect.md +596 -0
  199. package/skills/cm-frappe-agent/agents/erpnext-customizer.md +643 -0
  200. package/skills/cm-frappe-agent/agents/frappe-backend.md +814 -0
  201. package/skills/cm-frappe-agent/agents/frappe-custom-frontend.md +557 -0
  202. package/skills/cm-frappe-agent/agents/frappe-debugger.md +625 -0
  203. package/skills/cm-frappe-agent/agents/frappe-fixer.md +275 -0
  204. package/skills/cm-frappe-agent/agents/frappe-frontend.md +660 -0
  205. package/skills/cm-frappe-agent/agents/frappe-installer.md +158 -0
  206. package/skills/cm-frappe-agent/agents/frappe-performance.md +307 -0
  207. package/skills/cm-frappe-agent/agents/frappe-planner.md +419 -0
  208. package/skills/cm-frappe-agent/agents/frappe-remote-ops.md +153 -0
  209. package/skills/cm-frappe-agent/agents/github-workflow.md +286 -0
  210. package/skills/cm-frappe-agent/commands/frappe-app.md +351 -0
  211. package/skills/cm-frappe-agent/commands/frappe-backend.md +162 -0
  212. package/skills/cm-frappe-agent/commands/frappe-bench.md +254 -0
  213. package/skills/cm-frappe-agent/commands/frappe-debug.md +263 -0
  214. package/skills/cm-frappe-agent/commands/frappe-doctype-create.md +272 -0
  215. package/skills/cm-frappe-agent/commands/frappe-doctype-field.md +310 -0
  216. package/skills/cm-frappe-agent/commands/frappe-erpnext.md +210 -0
  217. package/skills/cm-frappe-agent/commands/frappe-fix.md +59 -0
  218. package/skills/cm-frappe-agent/commands/frappe-frontend.md +210 -0
  219. package/skills/cm-frappe-agent/commands/frappe-fullstack.md +243 -0
  220. package/skills/cm-frappe-agent/commands/frappe-github.md +57 -0
  221. package/skills/cm-frappe-agent/commands/frappe-install.md +52 -0
  222. package/skills/cm-frappe-agent/commands/frappe-plan.md +442 -0
  223. package/skills/cm-frappe-agent/commands/frappe-remote.md +58 -0
  224. package/skills/cm-frappe-agent/commands/frappe-test.md +356 -0
  225. package/skills/cm-frappe-agent/docs/README.md +51 -0
  226. package/skills/cm-frappe-agent/docs/agents-catalog.md +113 -0
  227. package/skills/cm-frappe-agent/docs/architecture.md +149 -0
  228. package/skills/cm-frappe-agent/docs/commands-catalog.md +82 -0
  229. package/skills/cm-frappe-agent/docs/resources-catalog.md +66 -0
  230. package/skills/cm-frappe-agent/docs/sitemap-urls.txt +52 -0
  231. package/skills/cm-frappe-agent/docs/sitemap.md +81 -0
  232. package/skills/cm-frappe-agent/docs/sop/user-guide.md +178 -0
  233. package/skills/cm-frappe-agent/docs/sop/vibe-coding-guide.md +122 -0
  234. package/skills/cm-frappe-agent/resources/7-layer-architecture.md +985 -0
  235. package/skills/cm-frappe-agent/resources/bench_commands.md +73 -0
  236. package/skills/cm-frappe-agent/resources/code-patterns-guide.md +948 -0
  237. package/skills/cm-frappe-agent/resources/common_pitfalls.md +266 -0
  238. package/skills/cm-frappe-agent/resources/doctype-registry.md +158 -0
  239. package/skills/cm-frappe-agent/resources/installation-guide.md +289 -0
  240. package/skills/cm-frappe-agent/resources/rest-api-patterns.md +182 -0
  241. package/skills/cm-frappe-agent/resources/scaffold_checklist.md +82 -0
  242. package/skills/cm-frappe-agent/resources/upgrade_patterns.md +113 -0
  243. package/skills/cm-frappe-agent/resources/web-form-patterns.md +252 -0
  244. package/skills/cm-frappe-agent/skills/bench-commands/SKILL.md +621 -0
  245. package/skills/cm-frappe-agent/skills/client-scripts/SKILL.md +642 -0
  246. package/skills/cm-frappe-agent/skills/doctype-patterns/SKILL.md +576 -0
  247. package/skills/cm-frappe-agent/skills/frappe-api/SKILL.md +740 -0
  248. package/skills/cm-frappe-agent/skills/remote-operations/SKILL.md +47 -0
  249. package/skills/cm-frappe-agent/skills/server-scripts/SKILL.md +608 -0
  250. package/skills/cm-frappe-agent/skills/web-forms/SKILL.md +46 -0
  251. package/skills/cm-git-worktrees/SKILL.md +0 -7
  252. package/skills/cm-google-form/SKILL.md +266 -0
  253. package/skills/cm-google-form/templates/apps-script.js +55 -0
  254. package/skills/cm-google-form/templates/form-markup.html +110 -0
  255. package/skills/cm-google-form/templates/form-submit.js +201 -0
  256. package/skills/cm-google-form/templates/toast.css +152 -0
  257. package/skills/cm-growth-hacking/SKILL.md +293 -0
  258. package/skills/cm-growth-hacking/bottom-sheet-engine.md +261 -0
  259. package/skills/cm-growth-hacking/calendar-integration.md +264 -0
  260. package/skills/cm-growth-hacking/references/engagement-patterns.md +346 -0
  261. package/skills/cm-growth-hacking/templates/bottom-sheet.css +528 -0
  262. package/skills/cm-growth-hacking/templates/bottom-sheet.js +269 -0
  263. package/skills/cm-growth-hacking/templates/calendar-cta.js +213 -0
  264. package/skills/cm-growth-hacking/templates/tracking-events.js +211 -0
  265. package/skills/cm-growth-hacking/templates/trigger-manager.js +254 -0
  266. package/skills/cm-growth-hacking/tracking-events.md +246 -0
  267. package/skills/cm-growth-hacking/trigger-system.md +342 -0
  268. package/skills/cm-how-it-work/SKILL.md +20 -4
  269. package/skills/cm-identity-guard/SKILL.md +0 -11
  270. package/skills/cm-jtbd/SKILL.md +1 -1
  271. package/skills/cm-notebooklm/SKILL.md +172 -0
  272. package/skills/cm-notebooklm/references/command_reference.md +94 -0
  273. package/skills/cm-notebooklm/references/workflows.md +60 -0
  274. package/skills/cm-notebooklm/resources/knowledge_sources.md +106 -0
  275. package/skills/cm-notebooklm/scripts/brain-sync.sh +453 -0
  276. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +101 -0
  277. package/skills/cm-planning/SKILL.md +39 -52
  278. package/skills/cm-project-bootstrap/SKILL.md +1307 -99
  279. package/skills/cm-quality-gate/SKILL.md +13 -106
  280. package/skills/cm-reactor/SKILL.md +274 -0
  281. package/skills/cm-safe-deploy/SKILL.md +415 -52
  282. package/skills/cm-safe-i18n/SKILL.md +1 -22
  283. package/skills/cm-secret-shield/SKILL.md +2 -2
  284. package/skills/cm-security-gate/SKILL.md +114 -0
  285. package/skills/cm-skill-chain/SKILL.md +2 -2
  286. package/skills/cm-skill-index/SKILL.md +9 -6
  287. package/skills/cm-skill-mastery/SKILL.md +2 -15
  288. package/skills/cm-start/SKILL.md +9 -0
  289. package/skills/cm-tdd/SKILL.md +16 -49
  290. package/skills/cm-ui-preview/SKILL.md +35 -173
  291. package/skills/cm-ux-master/FEATURES-v4.md +305 -0
  292. package/skills/cm-ux-master/README-ru.md +135 -0
  293. package/skills/cm-ux-master/README-vi.md +135 -0
  294. package/skills/cm-ux-master/README-zh.md +135 -0
  295. package/skills/cm-ux-master/README.md +489 -0
  296. package/skills/cm-ux-master/SKILL.md +773 -62
  297. package/skills/cm-ux-master/cli/README.md +180 -0
  298. package/skills/cm-ux-master/cli/pyproject.toml +106 -0
  299. package/skills/cm-ux-master/cli/requirements.txt +21 -0
  300. package/skills/cm-ux-master/cli/templates/base/skill-core.md +262 -0
  301. package/skills/cm-ux-master/cli/templates/platforms/claude.yaml +21 -0
  302. package/skills/cm-ux-master/cli/templates/platforms/cursor.yaml +21 -0
  303. package/skills/cm-ux-master/cli/templates/platforms/figma.yaml +24 -0
  304. package/skills/cm-ux-master/cli/templates/platforms/vscode-mcp.yaml +28 -0
  305. package/skills/cm-ux-master/cli/templates/platforms/windsurf.yaml +21 -0
  306. package/skills/cm-ux-master/cli/uxmaster/__init__.py +10 -0
  307. package/skills/cm-ux-master/cli/uxmaster/__main__.py +19 -0
  308. package/skills/cm-ux-master/cli/uxmaster/cli.py +349 -0
  309. package/skills/cm-ux-master/cli/uxmaster/commands/__init__.py +8 -0
  310. package/skills/cm-ux-master/cli/uxmaster/commands/extract.py +18 -0
  311. package/skills/cm-ux-master/cli/uxmaster/commands/init.py +58 -0
  312. package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +194 -0
  313. package/skills/cm-ux-master/cli/uxmaster/commands/search.py +23 -0
  314. package/skills/cm-ux-master/cli/uxmaster/commands/validate.py +270 -0
  315. package/skills/cm-ux-master/cli/uxmaster/search_engine.py +532 -0
  316. package/skills/cm-ux-master/cli/uxmaster/template_engine.py +458 -0
  317. package/skills/cm-ux-master/cli/uxmaster/utils/__init__.py +9 -0
  318. package/skills/cm-ux-master/cli/uxmaster/utils/console.py +42 -0
  319. package/skills/cm-ux-master/cli/uxmaster/utils/detect.py +83 -0
  320. package/skills/cm-ux-master/data/accessibility-advanced.csv +26 -0
  321. package/skills/cm-ux-master/data/animation.csv +31 -0
  322. package/skills/cm-ux-master/data/charts.csv +26 -0
  323. package/skills/cm-ux-master/data/colors.csv +97 -0
  324. package/skills/cm-ux-master/data/design-tests.csv +37 -0
  325. package/skills/cm-ux-master/data/devices.csv +21 -0
  326. package/skills/cm-ux-master/data/icons.csv +101 -0
  327. package/skills/cm-ux-master/data/landing.csv +31 -0
  328. package/skills/cm-ux-master/data/products.csv +97 -0
  329. package/skills/cm-ux-master/data/react-performance.csv +45 -0
  330. package/skills/cm-ux-master/data/responsive.csv +26 -0
  331. package/skills/cm-ux-master/data/semi-tokens.csv +52 -0
  332. package/skills/cm-ux-master/data/stacks/angular.csv +34 -0
  333. package/skills/cm-ux-master/data/stacks/astro.csv +54 -0
  334. package/skills/cm-ux-master/data/stacks/electron.csv +32 -0
  335. package/skills/cm-ux-master/data/stacks/flutter.csv +53 -0
  336. package/skills/cm-ux-master/data/stacks/html-tailwind.csv +56 -0
  337. package/skills/cm-ux-master/data/stacks/htmx.csv +28 -0
  338. package/skills/cm-ux-master/data/stacks/jetpack-compose.csv +53 -0
  339. package/skills/cm-ux-master/data/stacks/nextjs.csv +53 -0
  340. package/skills/cm-ux-master/data/stacks/nuxt-ui.csv +51 -0
  341. package/skills/cm-ux-master/data/stacks/nuxtjs.csv +59 -0
  342. package/skills/cm-ux-master/data/stacks/react-native.csv +52 -0
  343. package/skills/cm-ux-master/data/stacks/react.csv +54 -0
  344. package/skills/cm-ux-master/data/stacks/shadcn.csv +61 -0
  345. package/skills/cm-ux-master/data/stacks/svelte.csv +54 -0
  346. package/skills/cm-ux-master/data/stacks/swiftui.csv +51 -0
  347. package/skills/cm-ux-master/data/stacks/tauri.csv +29 -0
  348. package/skills/cm-ux-master/data/stacks/vue.csv +50 -0
  349. package/skills/cm-ux-master/data/styles.csv +68 -0
  350. package/skills/cm-ux-master/data/typography.csv +58 -0
  351. package/skills/cm-ux-master/data/ui-reasoning.csv +101 -0
  352. package/skills/cm-ux-master/data/ux-guidelines.csv +100 -0
  353. package/skills/cm-ux-master/data/ux-laws.csv +49 -0
  354. package/skills/cm-ux-master/data/web-interface.csv +31 -0
  355. package/skills/cm-ux-master/docs/LANDING-PAGE.html +377 -0
  356. package/skills/cm-ux-master/docs/README.md +108 -0
  357. package/skills/cm-ux-master/docs/css/styles.css +573 -0
  358. package/skills/cm-ux-master/docs/examples/demo-script.md +319 -0
  359. package/skills/cm-ux-master/docs/guides/for-designers.md +692 -0
  360. package/skills/cm-ux-master/docs/guides/for-developers.md +778 -0
  361. package/skills/cm-ux-master/docs/guides/for-product-managers.md +693 -0
  362. package/skills/cm-ux-master/docs/guides/react-guide-vi.md +50 -0
  363. package/skills/cm-ux-master/docs/index.html +1062 -0
  364. package/skills/cm-ux-master/docs/js/i18n.js +84 -0
  365. package/skills/cm-ux-master/docs/js/lang/de.js +145 -0
  366. package/skills/cm-ux-master/docs/js/lang/en.js +145 -0
  367. package/skills/cm-ux-master/docs/js/lang/fr.js +145 -0
  368. package/skills/cm-ux-master/docs/js/lang/hi.js +145 -0
  369. package/skills/cm-ux-master/docs/js/lang/id.js +145 -0
  370. package/skills/cm-ux-master/docs/js/lang/ja.js +145 -0
  371. package/skills/cm-ux-master/docs/js/lang/ko.js +145 -0
  372. package/skills/cm-ux-master/docs/js/lang/ru.js +145 -0
  373. package/skills/cm-ux-master/docs/js/lang/vi.js +145 -0
  374. package/skills/cm-ux-master/docs/js/lang/zh.js +145 -0
  375. package/skills/cm-ux-master/docs/js/main.js +117 -0
  376. package/skills/cm-ux-master/docs/plan/PHASE1-COMPLETION.md +217 -0
  377. package/skills/cm-ux-master/docs/plan/PHASE2-COMPLETION.md +199 -0
  378. package/skills/cm-ux-master/docs/plan/PHASE2-ENHANCED-COMPLETION.md +352 -0
  379. package/skills/cm-ux-master/docs/plan/PHASE3-VALIDATION-COMPLETION.md +499 -0
  380. package/skills/cm-ux-master/docs/plan/PHASE4-TESTING-POLISH-COMPLETION.md +483 -0
  381. package/skills/cm-ux-master/docs/plan/UXM-2.0-ROADMAP.md +681 -0
  382. package/skills/cm-ux-master/docs/plan/WOW-PITCH.md +410 -0
  383. package/skills/cm-ux-master/docs/technical/api-reference.md +824 -0
  384. package/skills/cm-ux-master/docs/technical/harvester-v4.md +328 -0
  385. package/skills/cm-ux-master/docs/technical/how-it-works.md +1128 -0
  386. package/skills/cm-ux-master/docs/tutorials/quickstart.md +339 -0
  387. package/skills/cm-ux-master/docs/tutorials/tutorials.md +939 -0
  388. package/skills/cm-ux-master/docs/tutorials/user-guide.md +716 -0
  389. package/skills/cm-ux-master/examples/README.md +63 -0
  390. package/skills/cm-ux-master/mcp/__init__.py +3 -0
  391. package/skills/cm-ux-master/mcp/integrations/__init__.py +11 -0
  392. package/skills/cm-ux-master/mcp/integrations/figma/__init__.py +6 -0
  393. package/skills/cm-ux-master/mcp/integrations/figma/client.py +293 -0
  394. package/skills/cm-ux-master/mcp/integrations/figma/plugin/code.js +561 -0
  395. package/skills/cm-ux-master/mcp/integrations/figma/plugin/ui.html +334 -0
  396. package/skills/cm-ux-master/mcp/integrations/stitch/__init__.py +5 -0
  397. package/skills/cm-ux-master/mcp/integrations/stitch/client.py +410 -0
  398. package/skills/cm-ux-master/mcp/integrations/vscode/package.json +167 -0
  399. package/skills/cm-ux-master/mcp/integrations/vscode/src/extension.ts +81 -0
  400. package/skills/cm-ux-master/mcp/mcp-config.json +274 -0
  401. package/skills/cm-ux-master/mcp/server.py +771 -0
  402. package/skills/cm-ux-master/mcp/tools/__init__.py +13 -0
  403. package/skills/cm-ux-master/mcp-server/server.py +595 -0
  404. package/skills/cm-ux-master/output/fila/FilaDashboard.tsx +47 -0
  405. package/skills/cm-ux-master/output/fila/components/badge/component.tsx +35 -0
  406. package/skills/cm-ux-master/output/fila/components/badge/index.ts +1 -0
  407. package/skills/cm-ux-master/output/fila/components/button/component.tsx +53 -0
  408. package/skills/cm-ux-master/output/fila/components/button/index.ts +1 -0
  409. package/skills/cm-ux-master/output/fila/components/card/component.tsx +35 -0
  410. package/skills/cm-ux-master/output/fila/components/card/index.ts +1 -0
  411. package/skills/cm-ux-master/output/fila/components/input/component.tsx +41 -0
  412. package/skills/cm-ux-master/output/fila/components/input/index.ts +1 -0
  413. package/skills/cm-ux-master/output/fila/design-system.css +151 -0
  414. package/skills/cm-ux-master/output/fila/design-system.html +1596 -0
  415. package/skills/cm-ux-master/output/fila/design-system.json +168 -0
  416. package/skills/cm-ux-master/output/fila/figma-tokens.json +523 -0
  417. package/skills/cm-ux-master/output/fila/harvest-v4-raw.json +406 -0
  418. package/skills/cm-ux-master/output/fila/semi-theme-override.css +95 -0
  419. package/skills/cm-ux-master/output/haravan/HaravanDashboard.tsx +103 -0
  420. package/skills/cm-ux-master/output/haravan/design-system-v3-live.html +2716 -0
  421. package/skills/cm-ux-master/output/haravan/design-system-v3.html +1770 -0
  422. package/skills/cm-ux-master/output/haravan/design-system.html +914 -0
  423. package/skills/cm-ux-master/output/haravan/figma-tokens.json +84 -0
  424. package/skills/cm-ux-master/output/haravan/haravan-harvest.json +33 -0
  425. package/skills/cm-ux-master/output/haravan/harvest-v3-raw.json +167 -0
  426. package/skills/cm-ux-master/output/haravan/semi-theme-override.css +39 -0
  427. package/skills/cm-ux-master/references/audit-template.md +257 -0
  428. package/skills/cm-ux-master/references/cultural-ux.md +346 -0
  429. package/skills/cm-ux-master/references/dark-patterns.md +362 -0
  430. package/skills/cm-ux-master/references/heuristic-conflicts.md +296 -0
  431. package/skills/cm-ux-master/references/krug-principles.md +289 -0
  432. package/skills/cm-ux-master/references/nielsen-heuristics.md +360 -0
  433. package/skills/cm-ux-master/references/wcag-checklist.md +306 -0
  434. package/skills/cm-ux-master/scripts/component_generator.py +631 -0
  435. package/skills/cm-ux-master/scripts/core.py +305 -0
  436. package/skills/cm-ux-master/scripts/demo_validation.py +452 -0
  437. package/skills/cm-ux-master/scripts/design_doc_generator.py +1325 -0
  438. package/skills/cm-ux-master/scripts/design_system.py +1141 -0
  439. package/skills/cm-ux-master/scripts/design_system_indexer.py +889 -0
  440. package/skills/cm-ux-master/scripts/extract_i18n.py +251 -0
  441. package/skills/cm-ux-master/scripts/extractor.py +1437 -0
  442. package/skills/cm-ux-master/scripts/figma_bridge.py +406 -0
  443. package/skills/cm-ux-master/scripts/generate.py +147 -0
  444. package/skills/cm-ux-master/scripts/harvest_session.py +207 -0
  445. package/skills/cm-ux-master/scripts/harvester.js +240 -0
  446. package/skills/cm-ux-master/scripts/harvester_browser.py +717 -0
  447. package/skills/cm-ux-master/scripts/harvester_cli.py +431 -0
  448. package/skills/cm-ux-master/scripts/harvester_v1.js +275 -0
  449. package/skills/cm-ux-master/scripts/harvester_v3.js +620 -0
  450. package/skills/cm-ux-master/scripts/harvester_v4.js +1003 -0
  451. package/skills/cm-ux-master/scripts/install.py +528 -0
  452. package/skills/cm-ux-master/scripts/license.py +81 -0
  453. package/skills/cm-ux-master/scripts/media/qrpayment.png +0 -0
  454. package/skills/cm-ux-master/scripts/pro_stubs.py +120 -0
  455. package/skills/cm-ux-master/scripts/project_registry.py +217 -0
  456. package/skills/cm-ux-master/scripts/search.py +114 -0
  457. package/skills/cm-ux-master/scripts/semi_mcp_bridge.py +425 -0
  458. package/skills/cm-ux-master/scripts/stitch_integration.py +583 -0
  459. package/skills/cm-ux-master/scripts/test_harvester_v4.py +335 -0
  460. package/skills/cm-ux-master/scripts/token_mapper.py +626 -0
  461. package/skills/cm-ux-master/scripts/validation_engine.py +1571 -0
  462. package/skills/cm-ux-master/scripts/wizard.py +653 -0
  463. package/skills/cm-ux-master/setup.py +93 -0
  464. package/skills/cm-ux-master/templates/base/flutter-widget.dart +69 -0
  465. package/skills/cm-ux-master/templates/base/html-page.html +152 -0
  466. package/skills/cm-ux-master/templates/base/react-component.tsx +47 -0
  467. package/skills/cm-ux-master/templates/base/swiftui-view.swift +62 -0
  468. package/skills/cm-ux-master/templates/quick-start.sh +176 -0
  469. package/skills/cm-ux-master/tests/automation/batch-validate.sh +250 -0
  470. package/skills/cm-ux-master/tests/automation/generate-test-projects.sh +561 -0
  471. package/skills/cm-ux-master/tests/automation/run-all-tests.sh +315 -0
  472. package/skills/cm-ux-master/tests/test_design_doc.py +145 -0
  473. package/skills/cm-ux-master/tests/test_devices.py +74 -0
  474. package/skills/cm-ux-master/tests/test_generator.py +116 -0
  475. package/skills/cm-ux-master/tests/test_harvest_session.py +131 -0
  476. package/skills/cm-ux-master/tests/test_harvester.py +127 -0
  477. package/skills/cm-ux-master/tests/test_harvester_v3.py +324 -0
  478. package/skills/cm-ux-master/tests/test_mcp_server.py +496 -0
  479. package/skills/cm-ux-master/tests/test_new_domains.py +108 -0
  480. package/skills/cm-ux-master/tests/test_new_stacks.py +103 -0
  481. package/skills/cm-ux-master/tests/test_project_registry.py +146 -0
  482. package/skills/cm-ux-master/tests/test_semi_mcp_bridge.py +207 -0
  483. package/skills/cm-ux-master/tests/test_token_mapper.py +247 -0
  484. package/skills/cm-ux-master/tests/test_validation_engine.py +617 -0
  485. package/skills/config.schema.json +397 -0
  486. package/skills/frappe-app-builder.zip +0 -0
  487. package/skills/jobs-to-be-done/SKILL.md +266 -0
  488. package/skills/jobs-to-be-done/references/case-studies.md +154 -0
  489. package/skills/jobs-to-be-done/references/competitive-strategy.md +280 -0
  490. package/skills/jobs-to-be-done/references/diagnostics.md +158 -0
  491. package/skills/jobs-to-be-done/references/innovation-process.md +392 -0
  492. package/skills/jobs-to-be-done/references/organizational-change.md +328 -0
  493. package/skills/marketplace-report-crawler/SKILL.md +176 -0
  494. package/skills/marketplace-report-crawler/config/accounts.json +41 -0
  495. package/skills/marketplace-report-crawler/config/report-types.json +422 -0
  496. package/skills/marketplace-report-crawler/config/sessions.json +3 -0
  497. package/skills/marketplace-report-crawler/scripts/ab-wrapper.sh +102 -0
  498. package/skills/marketplace-report-crawler/scripts/browser-actions/lazada/lazada-actions.js +114 -0
  499. package/skills/marketplace-report-crawler/scripts/browser-actions/shopee/shopee-actions.js +94 -0
  500. package/skills/marketplace-report-crawler/scripts/browser-actions/tiktok/tiktok-actions.js +272 -0
  501. package/skills/marketplace-report-crawler/scripts/crawl-runner.js +281 -0
  502. package/skills/marketplace-report-crawler/scripts/session-check.sh +72 -0
  503. package/skills/marketplace-report-crawler/scripts/session-manager.sh +349 -0
  504. package/skills/marketplace-report-crawler/scripts/setup-folders.sh +83 -0
  505. package/skills/medical-research/SKILL.md +194 -0
  506. package/skills/medical-research/scripts/evidence_checker.py +288 -0
  507. package/skills/mom-test/SKILL.md +267 -0
  508. package/skills/mom-test/references/avoiding-bad-data.md +221 -0
  509. package/skills/mom-test/references/case-studies.md +306 -0
  510. package/skills/mom-test/references/commitment-advancement.md +219 -0
  511. package/skills/mom-test/references/finding-conversations.md +251 -0
  512. package/skills/mom-test/references/processing-learning.md +256 -0
  513. package/skills/mom-test/references/question-patterns.md +198 -0
  514. package/skills/pandasai-analytics/SKILL.md +251 -0
  515. package/skills/release-it/SKILL.md +235 -0
  516. package/skills/release-it/references/anti-patterns.md +279 -0
  517. package/skills/release-it/references/capacity-planning.md +285 -0
  518. package/skills/release-it/references/chaos-engineering.md +325 -0
  519. package/skills/release-it/references/deployment-strategies.md +331 -0
  520. package/skills/release-it/references/observability.md +301 -0
  521. package/skills/release-it/references/stability-patterns.md +355 -0
  522. package/skills/scripts/sync-ide-skills.sh +61 -0
  523. package/skills/skill-creator-ultra/.agents/workflows/skill-audit.md +37 -0
  524. package/skills/skill-creator-ultra/.agents/workflows/skill-compare.md +34 -0
  525. package/skills/skill-creator-ultra/.agents/workflows/skill-export.md +51 -0
  526. package/skills/skill-creator-ultra/.agents/workflows/skill-generate.md +39 -0
  527. package/skills/skill-creator-ultra/.agents/workflows/skill-scaffold.md +52 -0
  528. package/skills/skill-creator-ultra/.agents/workflows/skill-simulate.md +25 -0
  529. package/skills/skill-creator-ultra/.agents/workflows/skill-stats.md +31 -0
  530. package/skills/skill-creator-ultra/.agents/workflows/skill-validate.md +25 -0
  531. package/skills/skill-creator-ultra/README.md +1242 -0
  532. package/skills/skill-creator-ultra/SKILL.md +388 -0
  533. package/skills/skill-creator-ultra/agents/analyzer.md +274 -0
  534. package/skills/skill-creator-ultra/agents/comparator.md +202 -0
  535. package/skills/skill-creator-ultra/agents/grader.md +223 -0
  536. package/skills/skill-creator-ultra/assets/eval_review.html +146 -0
  537. package/skills/skill-creator-ultra/eval-viewer/generate_review.py +471 -0
  538. package/skills/skill-creator-ultra/eval-viewer/viewer.html +1325 -0
  539. package/skills/skill-creator-ultra/examples/example_anthropic_frontend.md +109 -0
  540. package/skills/skill-creator-ultra/examples/example_anthropic_pdf.md +116 -0
  541. package/skills/skill-creator-ultra/examples/example_api_docs.md +189 -0
  542. package/skills/skill-creator-ultra/examples/example_db_migration.md +253 -0
  543. package/skills/skill-creator-ultra/examples/example_git_commit.md +111 -0
  544. package/skills/skill-creator-ultra/install.ps1 +289 -0
  545. package/skills/skill-creator-ultra/install.sh +313 -0
  546. package/skills/skill-creator-ultra/phases/phase1_interview.md +202 -0
  547. package/skills/skill-creator-ultra/phases/phase2_extract.md +55 -0
  548. package/skills/skill-creator-ultra/phases/phase3_detect.md +57 -0
  549. package/skills/skill-creator-ultra/phases/phase4_generate.md +543 -0
  550. package/skills/skill-creator-ultra/phases/phase5_test.md +319 -0
  551. package/skills/skill-creator-ultra/phases/phase6_eval.md +301 -0
  552. package/skills/skill-creator-ultra/phases/phase7_iterate.md +103 -0
  553. package/skills/skill-creator-ultra/phases/phase8_optimize.md +113 -0
  554. package/skills/skill-creator-ultra/resources/advanced_patterns.md +499 -0
  555. package/skills/skill-creator-ultra/resources/anti_patterns.md +376 -0
  556. package/skills/skill-creator-ultra/resources/blueprints.md +498 -0
  557. package/skills/skill-creator-ultra/resources/checklist.md +243 -0
  558. package/skills/skill-creator-ultra/resources/composition_cookbook.md +291 -0
  559. package/skills/skill-creator-ultra/resources/description_optimization.md +90 -0
  560. package/skills/skill-creator-ultra/resources/eval_guide.md +133 -0
  561. package/skills/skill-creator-ultra/resources/industry_questions.md +189 -0
  562. package/skills/skill-creator-ultra/resources/interview_questions.md +200 -0
  563. package/skills/skill-creator-ultra/resources/pattern_detection.md +200 -0
  564. package/skills/skill-creator-ultra/resources/prompt_engineering.md +531 -0
  565. package/skills/skill-creator-ultra/resources/schemas.md +430 -0
  566. package/skills/skill-creator-ultra/resources/script_integration.md +593 -0
  567. package/skills/skill-creator-ultra/resources/scripts_guide.md +339 -0
  568. package/skills/skill-creator-ultra/resources/skill_template.md +124 -0
  569. package/skills/skill-creator-ultra/resources/skill_writing_guide.md +634 -0
  570. package/skills/skill-creator-ultra/resources/versioning_guide.md +193 -0
  571. package/skills/skill-creator-ultra/scripts/ci_eval.py +200 -0
  572. package/skills/skill-creator-ultra/scripts/package_skill.py +165 -0
  573. package/skills/skill-creator-ultra/scripts/simulate_skill.py +398 -0
  574. package/skills/skill-creator-ultra/scripts/skill_audit.py +611 -0
  575. package/skills/skill-creator-ultra/scripts/skill_compare.py +265 -0
  576. package/skills/skill-creator-ultra/scripts/skill_export.py +334 -0
  577. package/skills/skill-creator-ultra/scripts/skill_scaffold.py +403 -0
  578. package/skills/skill-creator-ultra/scripts/skill_stats.py +339 -0
  579. package/skills/skill-creator-ultra/scripts/validate_skill.py +411 -0
  580. package/skills/tailwind-mastery/SKILL.md +229 -0
  581. package/skills/vercel-react-best-practices/AGENTS.md +3373 -0
  582. package/skills/vercel-react-best-practices/README.md +123 -0
  583. package/skills/vercel-react-best-practices/SKILL.md +143 -0
  584. package/skills/vercel-react-best-practices/rules/_sections.md +46 -0
  585. package/skills/vercel-react-best-practices/rules/_template.md +28 -0
  586. package/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  587. package/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
  588. package/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
  589. package/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
  590. package/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
  591. package/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
  592. package/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
  593. package/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
  594. package/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
  595. package/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
  596. package/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
  597. package/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  598. package/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
  599. package/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
  600. package/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
  601. package/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
  602. package/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
  603. package/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
  604. package/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
  605. package/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
  606. package/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
  607. package/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
  608. package/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
  609. package/skills/vercel-react-best-practices/rules/js-flatmap-filter.md +60 -0
  610. package/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
  611. package/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
  612. package/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
  613. package/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
  614. package/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
  615. package/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
  616. package/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
  617. package/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  618. package/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
  619. package/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
  620. package/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  621. package/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  622. package/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
  623. package/skills/vercel-react-best-practices/rules/rendering-resource-hints.md +85 -0
  624. package/skills/vercel-react-best-practices/rules/rendering-script-defer-async.md +68 -0
  625. package/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
  626. package/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
  627. package/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
  628. package/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
  629. package/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
  630. package/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
  631. package/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
  632. package/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  633. package/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
  634. package/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
  635. package/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
  636. package/skills/vercel-react-best-practices/rules/rerender-no-inline-components.md +82 -0
  637. package/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
  638. package/skills/vercel-react-best-practices/rules/rerender-split-combined-hooks.md +64 -0
  639. package/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
  640. package/skills/vercel-react-best-practices/rules/rerender-use-deferred-value.md +59 -0
  641. package/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
  642. package/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
  643. package/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
  644. package/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
  645. package/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
  646. package/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
  647. package/skills/vercel-react-best-practices/rules/server-hoist-static-io.md +142 -0
  648. package/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
  649. package/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
  650. package/skills/web-design-guidelines/SKILL.md +39 -0
  651. package/skills/cro-methodology/SKILL.md +0 -98
  652. /package/skills/{cro-methodology → cm-cro-methodology}/references/COPYWRITING.md +0 -0
  653. /package/skills/{cro-methodology → cm-cro-methodology}/references/OBJECTIONS.md +0 -0
  654. /package/skills/{cro-methodology → cm-cro-methodology}/references/PERSUASION.md +0 -0
  655. /package/skills/{cro-methodology → cm-cro-methodology}/references/RESEARCH.md +0 -0
  656. /package/skills/{cro-methodology → cm-cro-methodology}/references/funnel-analysis.md +0 -0
  657. /package/skills/{cro-methodology → cm-cro-methodology}/references/testing-methodology.md +0 -0
@@ -0,0 +1,266 @@
1
+ ---
2
+ name: cm-google-form
3
+ description: Google App Script form-to-sheet integration with auto-retry, toast notifications, and Zalo/contact fallback. Reusable across any static website.
4
+ allowed-tools: Read, Write, Edit, Glob, Grep, Browser
5
+ version: 1.0
6
+ priority: HIGH
7
+ ---
8
+
9
+ # Google Forms → Sheet Integration Skill
10
+
11
+ > **Connect HTML forms → Google Sheets via Google Apps Script.**
12
+ > Auto-retry, toast UI, contact fallback on errors. Zero dependencies, works on any static site.
13
+
14
+ ---
15
+
16
+ ## 🎯 When to Use
17
+
18
+ | Trigger | Action |
19
+ |---------|--------|
20
+ | User says "create form", "connect Google Sheet" | Activate this skill |
21
+ | User says "form broken", "submit not working" | Debug using Phase 4-5 |
22
+ | User says "add new form to page" | Start from Phase 2 |
23
+ | User says "form for another website" | Start from Phase 1 |
24
+
25
+ ---
26
+
27
+ ## 📋 5-Phase Workflow
28
+
29
+ ```
30
+ Phase 1: DISCOVER → Scan forms, identify fields, determine sheet structure
31
+ Phase 2: PLAN → Design sheet columns, map form fields, create deployment plan
32
+ Phase 3: BUILD → Generate Apps Script + Frontend JS + Toast CSS
33
+ Phase 4: INTEGRATE → Wire forms to JS, add CSS, deploy Apps Script
34
+ Phase 5: VERIFY → Test submit, test retry, test error fallback
35
+ ```
36
+
37
+ > 🔴 **Rule:** NEVER skip Phase 1. Always read existing forms first.
38
+
39
+ ---
40
+
41
+ ## Phase 1: DISCOVER (Scan & Analyze)
42
+
43
+ **Goal:** Understand what forms exist and what fields they have.
44
+
45
+ ### Actions:
46
+
47
+ 1. **Search for forms** in the project:
48
+ ```
49
+ grep -r "data-form-type\|onsubmit\|<form" --include="*.html" .
50
+ ```
51
+
52
+ 2. **For each form found, extract:**
53
+
54
+ | Info | How to Find |
55
+ |------|-------------|
56
+ | Form type | `data-form-type` attribute |
57
+ | Fields | `<input name="...">`, `<select name="...">` |
58
+ | Submit handler | `onsubmit` attribute |
59
+ | Page URL | File path |
60
+
61
+ 3. **Ask user** (Socratic Gate):
62
+ - How many separate Google Sheets? (1 shared sheet or separate?)
63
+ - What columns does each sheet need?
64
+ - Is there a fallback contact channel? (WhatsApp, Messenger, Hotline?)
65
+ - Fallback contact URL (e.g., `https://wa.me/15551234567`)
66
+
67
+ ### Output: Form Inventory Table
68
+
69
+ ```markdown
70
+ | # | Form Type | Pages | Fields | Target Sheet |
71
+ |---|-----------|-------|--------|-------------|
72
+ | 1 | massage | 7 | name, phone, branch, problem, time, package | Sheet Massage |
73
+ | 2 | course | 1 | name, phone, goal | Course Sheet |
74
+ ```
75
+
76
+ ---
77
+
78
+ ## Phase 2: PLAN (Design & Map)
79
+
80
+ **Goal:** Map form fields → Sheet columns → Apps Script params.
81
+
82
+ ### Sheet Column Design
83
+
84
+ For each sheet, define columns in order:
85
+
86
+ | Column | Source | Always Include |
87
+ |--------|--------|---------------|
88
+ | Timestamp | `new Date()` — auto | ✅ Yes |
89
+ | (form fields) | `e.parameter.xxx` | From inventory |
90
+ | Page Source | `e.parameter.url` | ✅ Yes |
91
+
92
+ ### Naming Convention
93
+
94
+ | Element | Convention |
95
+ |---------|-----------|
96
+ | Sheet tab name | `Data` |
97
+ | Form attribute | `data-form-type="<type>"` |
98
+ | Hidden URL field | `<input type="hidden" name="url" value="">` |
99
+ | JS global function | `window.submitToGoogleSheet` |
100
+
101
+ ### Deliverables Checklist
102
+
103
+ - [ ] Apps Script code per sheet
104
+ - [ ] Frontend JS with retry + toast
105
+ - [ ] Toast CSS component
106
+ - [ ] HTML form markup template
107
+ - [ ] Deploy instructions
108
+ - [ ] Verification test plan
109
+
110
+ ---
111
+
112
+ ## Phase 3: BUILD (Generate Code)
113
+
114
+ ### 3A. Google Apps Script Template
115
+
116
+ > See `templates/apps-script.js` for the full template.
117
+
118
+ **Key rules:**
119
+ - Always use `doPost(e)` — NOT `doGet`
120
+ - Always wrap in `try/catch`
121
+ - Always return JSON with `{status: "success"}` or `{status: "error", message: "..."}`
122
+ - Column order MUST match `sheet.appendRow([...])` order
123
+ - Tab name MUST match `SHEET_NAME` constant
124
+
125
+ ### 3B. Frontend JavaScript
126
+
127
+ > See `templates/form-submit.js` for the full template.
128
+
129
+ **Key features:**
130
+
131
+ | Feature | Detail |
132
+ |---------|--------|
133
+ | Auto-retry | 3 attempts, exponential backoff (1s → 2s → 4s) |
134
+ | Toast UI | Success (green), Error (red), Retrying (amber) |
135
+ | Phone validation | Vietnamese format: `/^0\d{8,10}$/` |
136
+ | Button states | "Submitting..." → "Retrying (X/3)..." → reset |
137
+ | CORS handling | Handles opaque responses from Apps Script |
138
+ | Fallback | Zalo button in error toast |
139
+ | Auto-dismiss | Success: 6s, Error: 15s, Retrying: 10s |
140
+
141
+ ### 3C. Toast CSS
142
+
143
+ > See `templates/toast.css` for the full template.
144
+
145
+ **3 variants:** `--success`, `--error`, `--retrying`
146
+
147
+ ### 3D. HTML Form Markup
148
+
149
+ > See `templates/form-markup.html` for examples.
150
+
151
+ **Required attributes:**
152
+ ```html
153
+ <form data-form-type="TYPE" onsubmit="window.submitToGoogleSheet(event)">
154
+ <input type="hidden" name="url" value="">
155
+ <!-- form fields with name="..." -->
156
+ <button type="submit">Submit Text</button>
157
+ </form>
158
+ ```
159
+
160
+ ---
161
+
162
+ ## Phase 4: INTEGRATE (Wire Everything)
163
+
164
+ ### Step-by-step:
165
+
166
+ 1. **Add Toast CSS** → Append to main CSS file (e.g., `design-system.css`)
167
+ 2. **Add Form JS** → Add to shared JS file or create `js/form-handler.js`
168
+ 3. **Update HTML forms:**
169
+ - Add `data-form-type="..."` attribute
170
+ - Add `onsubmit="window.submitToGoogleSheet(event)"`
171
+ - Add `<input type="hidden" name="url" value="">`
172
+ - Ensure all inputs have `name="..."` matching Apps Script params
173
+ 4. **Configure URLs:**
174
+ - Replace placeholder URLs in JS with deployed Apps Script URLs
175
+ 5. **Configure fallback contact:**
176
+ - Replace Zalo URL in JS toast with project's contact URL
177
+
178
+ ### Customization Points
179
+
180
+ | Setting | Location | Default |
181
+ |---------|----------|---------|
182
+ | Apps Script URLs | JS `URLS` object | placeholder |
183
+ | Fallback contact | Toast Zalo link | `https://zalo.me/...` |
184
+ | Max retries | `fetchWithRetry` arg | 3 |
185
+ | Phone regex | Validation block | `/^0\d{8,10}$/` |
186
+ | Toast auto-dismiss | `showFormToast` timeouts | 6s/15s/10s |
187
+ | Success message | `.then()` block | Customizable |
188
+ | Error message | `.catch()` block | Customizable |
189
+
190
+ ---
191
+
192
+ ## Phase 5: VERIFY (Test & Report)
193
+
194
+ ### Test Checklist
195
+
196
+ | # | Test Case | Expected | Status |
197
+ |---|-----------|----------|--------|
198
+ | 1 | Submit valid form | Toast success (green) + Zalo opens | |
199
+ | 2 | Submit invalid phone | Toast error "Invalid phone number" | |
200
+ | 3 | Network offline | 3 retries → Toast error with Zalo button | |
201
+ | 4 | Check Google Sheet | New row appears with correct data | |
202
+ | 5 | Button states | Disabled during submit, resets after | |
203
+ | 6 | Toast close button | Toast disappears on click | |
204
+ | 7 | Mobile responsive | Toast visible above sticky CTA | |
205
+ | 8 | Multiple forms same page | Each form submits independently | |
206
+
207
+ ### How to Test Retry
208
+
209
+ 1. Open DevTools → Network tab
210
+ 2. Block domain `script.google.com`
211
+ 3. Submit form → Should see 3 retry attempts
212
+ 4. Unblock → Submit again → Should succeed
213
+
214
+ ### Report Template
215
+
216
+ ```markdown
217
+ ## Form Integration Test Report
218
+
219
+ **Date:** YYYY-MM-DD
220
+ **Pages tested:** X/Y
221
+
222
+ | Page | Form Type | Submit | Retry | Fallback | Sheet |
223
+ |------|-----------|--------|-------|----------|-------|
224
+ | index.html | massage | ✅ | ✅ | ✅ | ✅ |
225
+ | khoa-hoc.html | course | ✅ | ✅ | ✅ | ✅ |
226
+
227
+ **Issues found:** None / [list issues]
228
+ **Resolution:** [fixes applied]
229
+ ```
230
+
231
+ ---
232
+
233
+ ## ❌ Anti-Patterns
234
+
235
+ | ❌ Don't | ✅ Do |
236
+ |----------|------|
237
+ | Use `alert()` for feedback | Use toast notifications |
238
+ | No retry on failure | Auto-retry 3x with backoff |
239
+ | Silently fail | Show error + contact fallback |
240
+ | Hardcode form URLs | Use config object (`URLS`) |
241
+ | Skip phone validation | Validate before submit |
242
+ | Forget `name` attribute | Every input MUST have `name` |
243
+ | Use `doGet` for form submit | Use `doPost` only |
244
+ | Multiple submit handlers | One shared `submitToGoogleSheet` |
245
+
246
+ ---
247
+
248
+ ## 📑 Templates
249
+
250
+ | File | Purpose |
251
+ |------|---------|
252
+ | `templates/apps-script.js` | Google Apps Script doPost handler |
253
+ | `templates/form-submit.js` | Frontend JS with retry + toast |
254
+ | `templates/toast.css` | Toast notification CSS component |
255
+ | `templates/form-markup.html` | HTML form examples |
256
+
257
+ ---
258
+
259
+ ## 🔗 Related Skills
260
+
261
+ | Need | Skill |
262
+ |------|-------|
263
+ | Form UI/UX design | `@[skills/cm-ux-master]` |
264
+ | SEO for forms | `@[skills/cm-dockit]` |
265
+ | Form security | `@[skills/vulnerability-scanner]` |
266
+ | Deployment | `@[skills/deployment-procedures]` |
@@ -0,0 +1,55 @@
1
+ /**
2
+ * Google Apps Script — Form to Sheet Handler
3
+ *
4
+ * SETUP:
5
+ * 1. Create Google Sheet with headers matching appendRow columns
6
+ * 2. Extensions > Apps Script > paste this code
7
+ * 3. Deploy > New deployment > Web app
8
+ * - Execute as: Me
9
+ * - Who has access: Anyone
10
+ * 4. Copy the deployment URL → use in frontend URLS config
11
+ *
12
+ * CUSTOMIZATION:
13
+ * - Change SHEET_NAME if tab is not "Data"
14
+ * - Modify appendRow columns to match your form fields
15
+ * - Add more e.parameter.xxx for additional fields
16
+ */
17
+
18
+ const SHEET_NAME = 'Data';
19
+
20
+ function doPost(e) {
21
+ try {
22
+ const sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName(SHEET_NAME);
23
+ if (!e || !e.parameter) {
24
+ return ContentService.createTextOutput(JSON.stringify({ status: 'error', message: 'No data received' }))
25
+ .setMimeType(ContentService.MimeType.JSON);
26
+ }
27
+
28
+ const p = e.parameter;
29
+
30
+ // ═══════════════════════════════════════
31
+ // CUSTOMIZE: Change columns below to match your form
32
+ // Column order MUST match Sheet header row
33
+ // ═══════════════════════════════════════
34
+ sheet.appendRow([
35
+ new Date(), // A: Thời gian (auto)
36
+ p.name || '', // B: Họ tên
37
+ p.phone || '', // C: SĐT
38
+ // --- Add your custom fields below ---
39
+ // p.email || '', // D: Email
40
+ // p.branch || '', // E: Chi nhánh
41
+ // p.problem || '', // F: Vấn đề
42
+ // p.time || '', // G: Khung giờ
43
+ // p.package || '', // H: Gói dịch vụ
44
+ // p.goal || '', // I: Mục tiêu
45
+ // --- End custom fields ---
46
+ p.url || '' // Last: Nguồn trang (auto)
47
+ ]);
48
+
49
+ return ContentService.createTextOutput(JSON.stringify({ status: 'success' }))
50
+ .setMimeType(ContentService.MimeType.JSON);
51
+ } catch (err) {
52
+ return ContentService.createTextOutput(JSON.stringify({ status: 'error', message: err.toString() }))
53
+ .setMimeType(ContentService.MimeType.JSON);
54
+ }
55
+ }
@@ -0,0 +1,110 @@
1
+ <!--
2
+ Form Markup Templates — Google Apps Script Integration
3
+
4
+ RULES:
5
+ 1. Every form MUST have data-form-type="TYPE"
6
+ 2. Every form MUST have onsubmit="window.submitToGoogleSheet(event)"
7
+ 3. Every form MUST include <input type="hidden" name="url" value="">
8
+ 4. Every input/select MUST have name="..." matching Apps Script params
9
+ 5. One submit button with type="submit"
10
+ -->
11
+
12
+ <!-- ═══════════════════════════════════════ -->
13
+ <!-- EXAMPLE 1: Service Booking (Massage) -->
14
+ <!-- ═══════════════════════════════════════ -->
15
+ <form data-form-type="massage" onsubmit="window.submitToGoogleSheet(event)">
16
+ <input type="hidden" name="url" value="">
17
+
18
+ <div class="form-group">
19
+ <label class="form-label">Họ và tên</label>
20
+ <input type="text" class="form-input" name="name" placeholder="Nhập họ tên" required>
21
+ </div>
22
+
23
+ <div class="form-group">
24
+ <label class="form-label">Số điện thoại</label>
25
+ <input type="tel" class="form-input" name="phone" placeholder="0xxx xxx xxx" required>
26
+ </div>
27
+
28
+ <div class="form-group">
29
+ <label class="form-label">Chi nhánh</label>
30
+ <select class="form-input" name="branch">
31
+ <option>Chi nhánh 1</option>
32
+ <option>Chi nhánh 2</option>
33
+ </select>
34
+ </div>
35
+
36
+ <div class="form-group">
37
+ <label class="form-label">Vấn đề quan tâm</label>
38
+ <select class="form-input" name="problem">
39
+ <option>Đau cổ vai gáy</option>
40
+ <option>Mất ngủ</option>
41
+ <option>Đau lưng</option>
42
+ <option>Khác</option>
43
+ </select>
44
+ </div>
45
+
46
+ <button type="submit" class="btn btn-primary btn-lg" style="width:100%;">Đặt Lịch Ngay</button>
47
+
48
+ <p style="text-align:center;margin-top:12px;font-size:14px;color:#666;">
49
+ Hoặc gọi: <a href="tel:0559669663" style="color:#C9A84C;font-weight:600;">0559.669.663</a>
50
+ </p>
51
+ </form>
52
+
53
+
54
+ <!-- ═══════════════════════════════════════ -->
55
+ <!-- EXAMPLE 2: Course Registration -->
56
+ <!-- ═══════════════════════════════════════ -->
57
+ <form data-form-type="course" onsubmit="window.submitToGoogleSheet(event)">
58
+ <input type="hidden" name="url" value="">
59
+
60
+ <div class="form-group">
61
+ <label class="form-label">Họ và tên</label>
62
+ <input type="text" class="form-input" name="name" placeholder="Nhập họ tên" required>
63
+ </div>
64
+
65
+ <div class="form-group">
66
+ <label class="form-label">Số điện thoại</label>
67
+ <input type="tel" class="form-input" name="phone" placeholder="0xxx xxx xxx" required>
68
+ </div>
69
+
70
+ <div class="form-group">
71
+ <label class="form-label">Mục tiêu học</label>
72
+ <select class="form-input" name="goal">
73
+ <option>Chuyển nghề</option>
74
+ <option>Nâng cấp kỹ năng</option>
75
+ <option>Chăm sóc gia đình</option>
76
+ </select>
77
+ </div>
78
+
79
+ <button type="submit" class="btn btn-primary btn-lg" style="width:100%;">Đăng Ký Tư Vấn</button>
80
+ </form>
81
+
82
+
83
+ <!-- ═══════════════════════════════════════ -->
84
+ <!-- EXAMPLE 3: Simple Contact/Lead Form -->
85
+ <!-- ═══════════════════════════════════════ -->
86
+ <form data-form-type="contact" onsubmit="window.submitToGoogleSheet(event)">
87
+ <input type="hidden" name="url" value="">
88
+
89
+ <div class="form-group">
90
+ <label class="form-label">Họ và tên</label>
91
+ <input type="text" class="form-input" name="name" placeholder="Nhập họ tên" required>
92
+ </div>
93
+
94
+ <div class="form-group">
95
+ <label class="form-label">Số điện thoại</label>
96
+ <input type="tel" class="form-input" name="phone" placeholder="0xxx xxx xxx" required>
97
+ </div>
98
+
99
+ <div class="form-group">
100
+ <label class="form-label">Email (tùy chọn)</label>
101
+ <input type="email" class="form-input" name="email" placeholder="email@example.com">
102
+ </div>
103
+
104
+ <div class="form-group">
105
+ <label class="form-label">Nội dung</label>
106
+ <textarea class="form-input" name="message" rows="3" placeholder="Bạn cần hỗ trợ gì?"></textarea>
107
+ </div>
108
+
109
+ <button type="submit" class="btn btn-primary btn-lg" style="width:100%;">Gửi Yêu Cầu</button>
110
+ </form>
@@ -0,0 +1,201 @@
1
+ /**
2
+ * Form Submission Handler — Auto Retry + Toast UI + Fallback
3
+ *
4
+ * Features:
5
+ * - Auto retry 3x with exponential backoff (1s → 2s → 4s)
6
+ * - Toast notifications (success/error/retrying) — no alert()
7
+ * - Phone validation (Vietnamese format)
8
+ * - Zalo/contact fallback on total failure
9
+ * - CORS-safe: handles opaque responses from Google Apps Script
10
+ *
11
+ * USAGE:
12
+ * 1. Include this script in your page (or append to shared.js)
13
+ * 2. Add toast.css to your stylesheet
14
+ * 3. Configure URLS object with your Apps Script deployment URLs
15
+ * 4. Configure FALLBACK_CONTACT with your Zalo/contact URL
16
+ * 5. Add forms with: data-form-type="xxx" onsubmit="window.submitToGoogleSheet(event)"
17
+ */
18
+
19
+ // ═══════════════════════════════════════
20
+ // CONFIGURATION — Change these values
21
+ // ═══════════════════════════════════════
22
+ const FORM_CONFIG = {
23
+ // Apps Script URLs per form type
24
+ URLS: {
25
+ // Add your deployed Apps Script URLs here
26
+ // massage: 'https://script.google.com/macros/s/YOUR_ID/exec',
27
+ // course: 'https://script.google.com/macros/s/YOUR_ID/exec',
28
+ },
29
+ // Fallback contact when form fails completely
30
+ FALLBACK_CONTACT: {
31
+ url: 'https://zalo.me/0559669663', // Change to your Zalo/Messenger/etc
32
+ label: '💬 Nhắn tin Zalo ngay', // Button text
33
+ },
34
+ // Retry settings
35
+ MAX_RETRIES: 3,
36
+ // Phone validation regex (Vietnamese)
37
+ PHONE_REGEX: /^0\d{8,10}$/,
38
+ // Messages (Vietnamese — customize for your language)
39
+ MESSAGES: {
40
+ sending: 'Đang gửi...',
41
+ retrying: (attempt, max) => `Đang thử lại (${attempt}/${max})...`,
42
+ phoneInvalid: {
43
+ title: 'Số điện thoại không hợp lệ',
44
+ msg: 'Vui lòng nhập số điện thoại bắt đầu bằng 0, từ 9-11 chữ số.',
45
+ },
46
+ success: {
47
+ title: 'Đăng ký thành công! 🎉',
48
+ msg: 'Chúng tôi sẽ liên hệ bạn trong 30 phút. Nhắn Zalo để được tư vấn nhanh hơn!',
49
+ },
50
+ retryNotice: {
51
+ title: 'Đang thử lại...',
52
+ msg: (attempt, max) => `Lần ${attempt}/${max} — Vui lòng chờ trong giây lát.`,
53
+ },
54
+ error: {
55
+ title: 'Gửi không thành công',
56
+ msg: 'Hệ thống đang bận. Vui lòng nhắn tin Zalo để được hỗ trợ ngay — chúng tôi sẽ phản hồi trong 5 phút!',
57
+ },
58
+ },
59
+ };
60
+
61
+ // ═══════════════════════════════════════
62
+ // TOAST NOTIFICATION SYSTEM
63
+ // ═══════════════════════════════════════
64
+
65
+ function getToastContainer() {
66
+ let c = document.querySelector('.form-toast-container');
67
+ if (!c) {
68
+ c = document.createElement('div');
69
+ c.className = 'form-toast-container';
70
+ document.body.appendChild(c);
71
+ }
72
+ return c;
73
+ }
74
+
75
+ function showFormToast(type, title, msg, options = {}) {
76
+ const container = getToastContainer();
77
+ container.querySelectorAll('.form-toast').forEach(t => hideFormToast(t));
78
+
79
+ const icons = { success: '✅', error: '❌', retrying: '⏳' };
80
+ const toast = document.createElement('div');
81
+ toast.className = `form-toast form-toast--${type}`;
82
+
83
+ const fallback = FORM_CONFIG.FALLBACK_CONTACT;
84
+ toast.innerHTML = `
85
+ <span class="form-toast-icon">${icons[type] || '📋'}</span>
86
+ <div class="form-toast-body">
87
+ <div class="form-toast-title">${title}</div>
88
+ <div class="form-toast-msg">${msg}</div>
89
+ ${options.showFallback ? `<a href="${fallback.url}" target="_blank" class="form-toast-zalo">${fallback.label}</a>` : ''}
90
+ </div>
91
+ <button class="form-toast-close" aria-label="Close">✕</button>
92
+ `;
93
+
94
+ toast.querySelector('.form-toast-close').addEventListener('click', () => hideFormToast(toast));
95
+ container.appendChild(toast);
96
+
97
+ const dismissMs = { success: 6000, error: 15000, retrying: 10000 };
98
+ setTimeout(() => hideFormToast(toast), dismissMs[type] || 8000);
99
+
100
+ return toast;
101
+ }
102
+
103
+ function hideFormToast(toast) {
104
+ if (!toast || !toast.parentNode) return;
105
+ toast.classList.add('hiding');
106
+ setTimeout(() => toast.remove(), 300);
107
+ }
108
+
109
+ // ═══════════════════════════════════════
110
+ // FETCH WITH RETRY (Exponential Backoff)
111
+ // ═══════════════════════════════════════
112
+
113
+ async function fetchWithRetry(url, options, maxRetries, onRetry) {
114
+ let lastError;
115
+ for (let attempt = 1; attempt <= maxRetries; attempt++) {
116
+ try {
117
+ const res = await fetch(url, options);
118
+ if (res.type === 'opaque' || res.ok) return res;
119
+ try {
120
+ const data = await res.json();
121
+ if (data.status === 'success') return res;
122
+ throw new Error(data.message || 'Server error');
123
+ } catch {
124
+ if (res.type === 'opaque') return res;
125
+ throw new Error(`HTTP ${res.status}`);
126
+ }
127
+ } catch (err) {
128
+ lastError = err;
129
+ if (attempt < maxRetries) {
130
+ const delay = Math.pow(2, attempt - 1) * 1000;
131
+ if (onRetry) onRetry(attempt, maxRetries);
132
+ await new Promise(r => setTimeout(r, delay));
133
+ }
134
+ }
135
+ }
136
+ throw lastError;
137
+ }
138
+
139
+ // ═══════════════════════════════════════
140
+ // FORM SUBMISSION HANDLER
141
+ // ═══════════════════════════════════════
142
+
143
+ window.submitToGoogleSheet = function (event) {
144
+ event.preventDefault();
145
+ const form = event.target;
146
+ const btn = form.querySelector('button[type="submit"]');
147
+ if (!btn || btn.disabled) return;
148
+ const originalText = btn.innerText;
149
+ const cfg = FORM_CONFIG;
150
+ const msgs = cfg.MESSAGES;
151
+
152
+ // Phone validation
153
+ const phoneInput = form.querySelector('input[name="phone"]');
154
+ if (phoneInput) {
155
+ const phone = phoneInput.value.replace(/\s+/g, '');
156
+ if (!cfg.PHONE_REGEX.test(phone)) {
157
+ showFormToast('error', msgs.phoneInvalid.title, msgs.phoneInvalid.msg);
158
+ phoneInput.focus();
159
+ return;
160
+ }
161
+ }
162
+
163
+ // Auto-fill source URL
164
+ const urlInput = form.querySelector('input[name="url"]');
165
+ if (urlInput) urlInput.value = window.location.href;
166
+
167
+ const formType = form.getAttribute('data-form-type') || Object.keys(cfg.URLS)[0];
168
+ const scriptURL = cfg.URLS[formType] || Object.values(cfg.URLS)[0];
169
+
170
+ if (!scriptURL) {
171
+ showFormToast('error', 'Lỗi cấu hình', 'Chưa cấu hình URL cho form type: ' + formType);
172
+ return;
173
+ }
174
+
175
+ btn.innerText = msgs.sending;
176
+ btn.disabled = true;
177
+
178
+ fetchWithRetry(
179
+ scriptURL,
180
+ { method: 'POST', body: new FormData(form) },
181
+ cfg.MAX_RETRIES,
182
+ (attempt, max) => {
183
+ btn.innerText = msgs.retrying(attempt, max);
184
+ showFormToast('retrying', msgs.retryNotice.title, msgs.retryNotice.msg(attempt, max));
185
+ }
186
+ )
187
+ .then(() => {
188
+ showFormToast('success', msgs.success.title, msgs.success.msg, { showFallback: true });
189
+ form.reset();
190
+ setTimeout(() => {
191
+ window.open(cfg.FALLBACK_CONTACT.url, '_blank');
192
+ }, 1500);
193
+ })
194
+ .catch(() => {
195
+ showFormToast('error', msgs.error.title, msgs.error.msg, { showFallback: true });
196
+ })
197
+ .finally(() => {
198
+ btn.innerText = originalText;
199
+ btn.disabled = false;
200
+ });
201
+ };