quiver-cli 0.1.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 (281) hide show
  1. package/README.md +188 -0
  2. package/bin/quiver-cli.mjs +2 -0
  3. package/dist/cli.js +3074 -0
  4. package/package.json +55 -0
  5. package/template/.agents/AGENTS.md +25 -0
  6. package/template/.agents/commands/cp.md +116 -0
  7. package/template/.agents/commands/next-setup.md +1064 -0
  8. package/template/.agents/commands/tf-readme.md +38 -0
  9. package/template/.agents/config.json +60 -0
  10. package/template/.agents/skills/agent-browser/SKILL.md +55 -0
  11. package/template/.agents/skills/apps/skybridge/SKILL.md +46 -0
  12. package/template/.agents/skills/apps/skybridge/references/architecture.md +175 -0
  13. package/template/.agents/skills/apps/skybridge/references/copy-template.md +24 -0
  14. package/template/.agents/skills/apps/skybridge/references/csp.md +33 -0
  15. package/template/.agents/skills/apps/skybridge/references/deploy.md +33 -0
  16. package/template/.agents/skills/apps/skybridge/references/discover.md +84 -0
  17. package/template/.agents/skills/apps/skybridge/references/download-file.md +77 -0
  18. package/template/.agents/skills/apps/skybridge/references/fetch-and-render-data.md +151 -0
  19. package/template/.agents/skills/apps/skybridge/references/oauth.md +115 -0
  20. package/template/.agents/skills/apps/skybridge/references/open-external-links.md +71 -0
  21. package/template/.agents/skills/apps/skybridge/references/prompt-llm.md +20 -0
  22. package/template/.agents/skills/apps/skybridge/references/publish.md +19 -0
  23. package/template/.agents/skills/apps/skybridge/references/run-locally.md +51 -0
  24. package/template/.agents/skills/apps/skybridge/references/state-and-context.md +151 -0
  25. package/template/.agents/skills/apps/skybridge/references/ui-guidelines.md +205 -0
  26. package/template/.agents/skills/code/cleanup/SKILL.md +26 -0
  27. package/template/.agents/skills/code/vercel-react-best-practices/AGENTS.md +3810 -0
  28. package/template/.agents/skills/code/vercel-react-best-practices/README.md +123 -0
  29. package/template/.agents/skills/code/vercel-react-best-practices/SKILL.md +149 -0
  30. package/template/.agents/skills/code/vercel-react-best-practices/metadata.json +15 -0
  31. package/template/.agents/skills/code/vercel-react-best-practices/rules/_sections.md +46 -0
  32. package/template/.agents/skills/code/vercel-react-best-practices/rules/_template.md +28 -0
  33. package/template/.agents/skills/code/vercel-react-best-practices/rules/advanced-effect-event-deps.md +56 -0
  34. package/template/.agents/skills/code/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  35. package/template/.agents/skills/code/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
  36. package/template/.agents/skills/code/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
  37. package/template/.agents/skills/code/vercel-react-best-practices/rules/async-api-routes.md +38 -0
  38. package/template/.agents/skills/code/vercel-react-best-practices/rules/async-cheap-condition-before-await.md +37 -0
  39. package/template/.agents/skills/code/vercel-react-best-practices/rules/async-defer-await.md +82 -0
  40. package/template/.agents/skills/code/vercel-react-best-practices/rules/async-dependencies.md +51 -0
  41. package/template/.agents/skills/code/vercel-react-best-practices/rules/async-parallel.md +28 -0
  42. package/template/.agents/skills/code/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
  43. package/template/.agents/skills/code/vercel-react-best-practices/rules/bundle-analyzable-paths.md +63 -0
  44. package/template/.agents/skills/code/vercel-react-best-practices/rules/bundle-barrel-imports.md +60 -0
  45. package/template/.agents/skills/code/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
  46. package/template/.agents/skills/code/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
  47. package/template/.agents/skills/code/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  48. package/template/.agents/skills/code/vercel-react-best-practices/rules/bundle-preload.md +50 -0
  49. package/template/.agents/skills/code/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
  50. package/template/.agents/skills/code/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
  51. package/template/.agents/skills/code/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
  52. package/template/.agents/skills/code/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
  53. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
  54. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
  55. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
  56. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
  57. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
  58. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-early-exit.md +50 -0
  59. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-flatmap-filter.md +60 -0
  60. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
  61. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-index-maps.md +37 -0
  62. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
  63. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
  64. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-request-idle-callback.md +105 -0
  65. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
  66. package/template/.agents/skills/code/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
  67. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-activity.md +26 -0
  68. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  69. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
  70. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
  71. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  72. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  73. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
  74. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-resource-hints.md +85 -0
  75. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-script-defer-async.md +68 -0
  76. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
  77. package/template/.agents/skills/code/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
  78. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
  79. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
  80. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
  81. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
  82. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
  83. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  84. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
  85. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-memo.md +44 -0
  86. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
  87. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-no-inline-components.md +82 -0
  88. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
  89. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-split-combined-hooks.md +64 -0
  90. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
  91. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-use-deferred-value.md +59 -0
  92. package/template/.agents/skills/code/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
  93. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
  94. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
  95. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
  96. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-cache-react.md +76 -0
  97. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
  98. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-hoist-static-io.md +149 -0
  99. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-no-shared-module-state.md +50 -0
  100. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
  101. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-parallel-nested-fetching.md +34 -0
  102. package/template/.agents/skills/code/vercel-react-best-practices/rules/server-serialization.md +38 -0
  103. package/template/.agents/skills/data/prisma-cli/SKILL.md +247 -0
  104. package/template/.agents/skills/data/prisma-cli/references/db-execute.md +78 -0
  105. package/template/.agents/skills/data/prisma-cli/references/db-pull.md +185 -0
  106. package/template/.agents/skills/data/prisma-cli/references/db-push.md +148 -0
  107. package/template/.agents/skills/data/prisma-cli/references/db-seed.md +188 -0
  108. package/template/.agents/skills/data/prisma-cli/references/debug.md +46 -0
  109. package/template/.agents/skills/data/prisma-cli/references/dev.md +157 -0
  110. package/template/.agents/skills/data/prisma-cli/references/format.md +48 -0
  111. package/template/.agents/skills/data/prisma-cli/references/generate.md +173 -0
  112. package/template/.agents/skills/data/prisma-cli/references/init.md +136 -0
  113. package/template/.agents/skills/data/prisma-cli/references/mcp.md +38 -0
  114. package/template/.agents/skills/data/prisma-cli/references/migrate-deploy.md +127 -0
  115. package/template/.agents/skills/data/prisma-cli/references/migrate-dev.md +145 -0
  116. package/template/.agents/skills/data/prisma-cli/references/migrate-diff.md +89 -0
  117. package/template/.agents/skills/data/prisma-cli/references/migrate-reset.md +78 -0
  118. package/template/.agents/skills/data/prisma-cli/references/migrate-resolve.md +57 -0
  119. package/template/.agents/skills/data/prisma-cli/references/migrate-status.md +65 -0
  120. package/template/.agents/skills/data/prisma-cli/references/studio.md +137 -0
  121. package/template/.agents/skills/data/prisma-cli/references/validate.md +53 -0
  122. package/template/.agents/skills/data/prisma-client-api/SKILL.md +216 -0
  123. package/template/.agents/skills/data/prisma-client-api/references/client-methods.md +223 -0
  124. package/template/.agents/skills/data/prisma-client-api/references/constructor.md +208 -0
  125. package/template/.agents/skills/data/prisma-client-api/references/filters.md +256 -0
  126. package/template/.agents/skills/data/prisma-client-api/references/model-queries.md +281 -0
  127. package/template/.agents/skills/data/prisma-client-api/references/query-options.md +276 -0
  128. package/template/.agents/skills/data/prisma-client-api/references/raw-queries.md +194 -0
  129. package/template/.agents/skills/data/prisma-client-api/references/relations.md +308 -0
  130. package/template/.agents/skills/data/prisma-client-api/references/transactions.md +184 -0
  131. package/template/.agents/skills/design/impeccable/SKILL.md +176 -0
  132. package/template/.agents/skills/design/impeccable/reference/adapt.md +311 -0
  133. package/template/.agents/skills/design/impeccable/reference/animate.md +201 -0
  134. package/template/.agents/skills/design/impeccable/reference/audit.md +133 -0
  135. package/template/.agents/skills/design/impeccable/reference/bolder.md +113 -0
  136. package/template/.agents/skills/design/impeccable/reference/brand.md +108 -0
  137. package/template/.agents/skills/design/impeccable/reference/clarify.md +288 -0
  138. package/template/.agents/skills/design/impeccable/reference/codex.md +105 -0
  139. package/template/.agents/skills/design/impeccable/reference/colorize.md +257 -0
  140. package/template/.agents/skills/design/impeccable/reference/craft.md +123 -0
  141. package/template/.agents/skills/design/impeccable/reference/critique.md +767 -0
  142. package/template/.agents/skills/design/impeccable/reference/delight.md +302 -0
  143. package/template/.agents/skills/design/impeccable/reference/distill.md +111 -0
  144. package/template/.agents/skills/design/impeccable/reference/document.md +429 -0
  145. package/template/.agents/skills/design/impeccable/reference/extract.md +69 -0
  146. package/template/.agents/skills/design/impeccable/reference/harden.md +347 -0
  147. package/template/.agents/skills/design/impeccable/reference/init.md +172 -0
  148. package/template/.agents/skills/design/impeccable/reference/interaction-design.md +189 -0
  149. package/template/.agents/skills/design/impeccable/reference/layout.md +161 -0
  150. package/template/.agents/skills/design/impeccable/reference/live.md +718 -0
  151. package/template/.agents/skills/design/impeccable/reference/onboard.md +234 -0
  152. package/template/.agents/skills/design/impeccable/reference/optimize.md +258 -0
  153. package/template/.agents/skills/design/impeccable/reference/overdrive.md +130 -0
  154. package/template/.agents/skills/design/impeccable/reference/polish.md +241 -0
  155. package/template/.agents/skills/design/impeccable/reference/product.md +60 -0
  156. package/template/.agents/skills/design/impeccable/reference/quieter.md +99 -0
  157. package/template/.agents/skills/design/impeccable/reference/shape.md +165 -0
  158. package/template/.agents/skills/design/impeccable/reference/typeset.md +279 -0
  159. package/template/.agents/skills/design/impeccable/scripts/cleanup-deprecated.mjs +284 -0
  160. package/template/.agents/skills/design/impeccable/scripts/command-metadata.json +94 -0
  161. package/template/.agents/skills/design/impeccable/scripts/context-signals.mjs +225 -0
  162. package/template/.agents/skills/design/impeccable/scripts/context.mjs +270 -0
  163. package/template/.agents/skills/design/impeccable/scripts/critique-storage.mjs +242 -0
  164. package/template/.agents/skills/design/impeccable/scripts/design-parser.mjs +835 -0
  165. package/template/.agents/skills/design/impeccable/scripts/detect-csp.mjs +198 -0
  166. package/template/.agents/skills/design/impeccable/scripts/detect.mjs +21 -0
  167. package/template/.agents/skills/design/impeccable/scripts/detector/browser/injected/index.mjs +1733 -0
  168. package/template/.agents/skills/design/impeccable/scripts/detector/cli/main.mjs +244 -0
  169. package/template/.agents/skills/design/impeccable/scripts/detector/detect-antipatterns-browser.js +4551 -0
  170. package/template/.agents/skills/design/impeccable/scripts/detector/detect-antipatterns.mjs +43 -0
  171. package/template/.agents/skills/design/impeccable/scripts/detector/engines/browser/detect-url.mjs +252 -0
  172. package/template/.agents/skills/design/impeccable/scripts/detector/engines/regex/detect-text.mjs +535 -0
  173. package/template/.agents/skills/design/impeccable/scripts/detector/engines/static-html/css-cascade.mjs +986 -0
  174. package/template/.agents/skills/design/impeccable/scripts/detector/engines/static-html/detect-html.mjs +208 -0
  175. package/template/.agents/skills/design/impeccable/scripts/detector/engines/visual/screenshot-contrast.mjs +189 -0
  176. package/template/.agents/skills/design/impeccable/scripts/detector/findings.mjs +12 -0
  177. package/template/.agents/skills/design/impeccable/scripts/detector/node/file-system.mjs +198 -0
  178. package/template/.agents/skills/design/impeccable/scripts/detector/profile/profiler.mjs +166 -0
  179. package/template/.agents/skills/design/impeccable/scripts/detector/registry/antipatterns.mjs +419 -0
  180. package/template/.agents/skills/design/impeccable/scripts/detector/rules/checks.mjs +2316 -0
  181. package/template/.agents/skills/design/impeccable/scripts/detector/shared/color.mjs +124 -0
  182. package/template/.agents/skills/design/impeccable/scripts/detector/shared/constants.mjs +101 -0
  183. package/template/.agents/skills/design/impeccable/scripts/detector/shared/page.mjs +7 -0
  184. package/template/.agents/skills/design/impeccable/scripts/impeccable-paths.mjs +126 -0
  185. package/template/.agents/skills/design/impeccable/scripts/is-generated.mjs +69 -0
  186. package/template/.agents/skills/design/impeccable/scripts/live-accept.mjs +812 -0
  187. package/template/.agents/skills/design/impeccable/scripts/live-browser-session.js +123 -0
  188. package/template/.agents/skills/design/impeccable/scripts/live-browser.js +10316 -0
  189. package/template/.agents/skills/design/impeccable/scripts/live-commit-manual-edits.mjs +1241 -0
  190. package/template/.agents/skills/design/impeccable/scripts/live-complete.mjs +75 -0
  191. package/template/.agents/skills/design/impeccable/scripts/live-completion.mjs +19 -0
  192. package/template/.agents/skills/design/impeccable/scripts/live-copy-edit-agent.mjs +683 -0
  193. package/template/.agents/skills/design/impeccable/scripts/live-discard-manual-edits.mjs +51 -0
  194. package/template/.agents/skills/design/impeccable/scripts/live-event-validation.mjs +136 -0
  195. package/template/.agents/skills/design/impeccable/scripts/live-inject.mjs +557 -0
  196. package/template/.agents/skills/design/impeccable/scripts/live-insert-ui.mjs +458 -0
  197. package/template/.agents/skills/design/impeccable/scripts/live-insert.mjs +272 -0
  198. package/template/.agents/skills/design/impeccable/scripts/live-manual-edit-evidence.mjs +363 -0
  199. package/template/.agents/skills/design/impeccable/scripts/live-manual-edits-buffer.mjs +152 -0
  200. package/template/.agents/skills/design/impeccable/scripts/live-poll.mjs +379 -0
  201. package/template/.agents/skills/design/impeccable/scripts/live-resume.mjs +94 -0
  202. package/template/.agents/skills/design/impeccable/scripts/live-server.mjs +2322 -0
  203. package/template/.agents/skills/design/impeccable/scripts/live-session-store.mjs +289 -0
  204. package/template/.agents/skills/design/impeccable/scripts/live-status.mjs +61 -0
  205. package/template/.agents/skills/design/impeccable/scripts/live-svelte-component.mjs +826 -0
  206. package/template/.agents/skills/design/impeccable/scripts/live-sveltekit-adapter.mjs +274 -0
  207. package/template/.agents/skills/design/impeccable/scripts/live-ui-core.mjs +179 -0
  208. package/template/.agents/skills/design/impeccable/scripts/live-wrap.mjs +894 -0
  209. package/template/.agents/skills/design/impeccable/scripts/live.mjs +246 -0
  210. package/template/.agents/skills/design/impeccable/scripts/modern-screenshot.umd.js +14 -0
  211. package/template/.agents/skills/design/impeccable/scripts/palette.mjs +633 -0
  212. package/template/.agents/skills/design/impeccable/scripts/pin.mjs +214 -0
  213. package/template/.agents/skills/design/shadcn/SKILL.md +242 -0
  214. package/template/.agents/skills/design/shadcn/agents/openai.yml +5 -0
  215. package/template/.agents/skills/design/shadcn/assets/shadcn-small.png +0 -0
  216. package/template/.agents/skills/design/shadcn/assets/shadcn.png +0 -0
  217. package/template/.agents/skills/design/shadcn/cli.md +257 -0
  218. package/template/.agents/skills/design/shadcn/customization.md +202 -0
  219. package/template/.agents/skills/design/shadcn/evals/evals.json +47 -0
  220. package/template/.agents/skills/design/shadcn/mcp.md +94 -0
  221. package/template/.agents/skills/design/shadcn/rules/base-vs-radix.md +306 -0
  222. package/template/.agents/skills/design/shadcn/rules/composition.md +195 -0
  223. package/template/.agents/skills/design/shadcn/rules/forms.md +192 -0
  224. package/template/.agents/skills/design/shadcn/rules/icons.md +101 -0
  225. package/template/.agents/skills/design/shadcn/rules/styling.md +162 -0
  226. package/template/.agents/skills/find-skills/SKILL.md +142 -0
  227. package/template/.agents/skills/integrations/langfuse/SKILL.md +142 -0
  228. package/template/.agents/skills/integrations/langfuse/references/cli.md +52 -0
  229. package/template/.agents/skills/integrations/langfuse/references/error-analysis.md +100 -0
  230. package/template/.agents/skills/integrations/langfuse/references/instrumentation.md +134 -0
  231. package/template/.agents/skills/integrations/langfuse/references/judge-calibration.md +288 -0
  232. package/template/.agents/skills/integrations/langfuse/references/prompt-migration.md +234 -0
  233. package/template/.agents/skills/integrations/langfuse/references/sdk-upgrade.md +175 -0
  234. package/template/.agents/skills/integrations/langfuse/references/skill-feedback.md +52 -0
  235. package/template/.agents/skills/integrations/langfuse/references/user-feedback.md +88 -0
  236. package/template/.agents/skills/integrations/posthog/SKILL.md +102 -0
  237. package/template/.agents/skills/integrations/posthog/references/error-tracking-alerts.md +63 -0
  238. package/template/.agents/skills/integrations/posthog/references/error-tracking-assigning-issues.md +77 -0
  239. package/template/.agents/skills/integrations/posthog/references/error-tracking-fingerprints.md +57 -0
  240. package/template/.agents/skills/integrations/posthog/references/error-tracking-monitoring.md +140 -0
  241. package/template/.agents/skills/integrations/posthog/references/error-tracking-nextjs.md +490 -0
  242. package/template/.agents/skills/integrations/posthog/references/error-tracking-source-maps.md +45 -0
  243. package/template/.agents/skills/integrations/posthog/references/feature-flags-best-practices.md +139 -0
  244. package/template/.agents/skills/integrations/posthog/references/feature-flags-react.md +302 -0
  245. package/template/.agents/skills/integrations/posthog/references/identify-users.md +202 -0
  246. package/template/.agents/skills/integrations/posthog/references/integration-example.md +706 -0
  247. package/template/.agents/skills/integrations/posthog/references/integration-nextjs.md +385 -0
  248. package/template/.agents/skills/integrations/posthog/references/integration-step-1-begin.md +43 -0
  249. package/template/.agents/skills/integrations/posthog/references/integration-step-2-edit.md +37 -0
  250. package/template/.agents/skills/integrations/posthog/references/integration-step-3-revise.md +22 -0
  251. package/template/.agents/skills/integrations/posthog/references/integration-step-4-conclude.md +38 -0
  252. package/template/.agents/skills/integrations/posthog/references/llm-analytics-anthropic.md +200 -0
  253. package/template/.agents/skills/integrations/posthog/references/llm-analytics-basics.md +62 -0
  254. package/template/.agents/skills/integrations/posthog/references/llm-analytics-costs.md +197 -0
  255. package/template/.agents/skills/integrations/posthog/references/llm-analytics-manual-capture.md +397 -0
  256. package/template/.agents/skills/integrations/posthog/references/llm-analytics-traces.md +98 -0
  257. package/template/.agents/skills/integrations/posthog/references/llm-analytics-vercel-ai.md +120 -0
  258. package/template/.agents/skills/repo/repo-ci/SKILL.md +265 -0
  259. package/template/.agents/skills/repo/repo-init-next-js/SKILL.md +129 -0
  260. package/template/.agents/skills/repo/repo-init-next-js/references/file-contents.md +800 -0
  261. package/template/.agents/skills/repo/repo-init-next-js/scripts/setup.sh +47 -0
  262. package/template/.agents/skills/repo/repo-init-node/SKILL.md +196 -0
  263. package/template/.agents/skills/skill-creator/LICENSE.txt +202 -0
  264. package/template/.agents/skills/skill-creator/SKILL.md +485 -0
  265. package/template/.agents/skills/skill-creator/agents/analyzer.md +274 -0
  266. package/template/.agents/skills/skill-creator/agents/comparator.md +202 -0
  267. package/template/.agents/skills/skill-creator/agents/grader.md +223 -0
  268. package/template/.agents/skills/skill-creator/assets/eval_review.html +146 -0
  269. package/template/.agents/skills/skill-creator/eval-viewer/generate_review.py +471 -0
  270. package/template/.agents/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  271. package/template/.agents/skills/skill-creator/references/schemas.md +430 -0
  272. package/template/.agents/skills/skill-creator/scripts/__init__.py +0 -0
  273. package/template/.agents/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
  274. package/template/.agents/skills/skill-creator/scripts/generate_report.py +326 -0
  275. package/template/.agents/skills/skill-creator/scripts/improve_description.py +247 -0
  276. package/template/.agents/skills/skill-creator/scripts/package_skill.py +136 -0
  277. package/template/.agents/skills/skill-creator/scripts/quick_validate.py +103 -0
  278. package/template/.agents/skills/skill-creator/scripts/run_eval.py +310 -0
  279. package/template/.agents/skills/skill-creator/scripts/run_loop.py +328 -0
  280. package/template/.agents/skills/skill-creator/scripts/utils.py +47 -0
  281. package/template/.agents/upstreams.json +80 -0
@@ -0,0 +1,706 @@
1
+ # PostHog Next.js App Router Example Project
2
+
3
+ Repository: https://github.com/PostHog/context-mill
4
+ Path: basics/next-app-router
5
+
6
+ ---
7
+
8
+ ## README.md
9
+
10
+ # PostHog Next.js app router example
11
+
12
+ This is a [Next.js](https://nextjs.org) App Router example demonstrating PostHog integration with product analytics, session replay, feature flags, and error tracking.
13
+
14
+ ## Features
15
+
16
+ - **Product analytics**: Track user events and behaviors
17
+ - **Session replay**: Record and replay user sessions
18
+ - **Error tracking**: Capture and track errors
19
+ - **User authentication**: Demo login system with PostHog user identification
20
+ - **Server-side & Client-side tracking**: Examples of both tracking methods
21
+ - **Reverse proxy**: PostHog ingestion through Next.js rewrites
22
+
23
+ ## Getting started
24
+
25
+ ### 1. Install dependencies
26
+
27
+ ```bash
28
+ npm install
29
+ # or
30
+ pnpm install
31
+ ```
32
+
33
+ ### 2. Configure environment variables
34
+
35
+ Create a `.env.local` file in the root directory:
36
+
37
+ ```bash
38
+ NEXT_PUBLIC_POSTHOG_PROJECT_TOKEN=your_posthog_project_token
39
+ NEXT_PUBLIC_POSTHOG_HOST=https://us.i.posthog.com
40
+ ```
41
+
42
+ Get your PostHog project token from your [PostHog project settings](https://app.posthog.com/project/settings).
43
+
44
+ ### 3. Run the development server
45
+
46
+ ```bash
47
+ npm run dev
48
+ # or
49
+ pnpm dev
50
+ ```
51
+
52
+ Open [http://localhost:3000](http://localhost:3000) with your browser to see the app.
53
+
54
+ ## Project structure
55
+
56
+ ```
57
+ src/
58
+ ├── app/
59
+ │ ├── api/
60
+ │ │ └── auth/
61
+ │ │ └── login/
62
+ │ │ └── route.ts # Login API with server-side tracking
63
+ │ ├── burrito/
64
+ │ │ └── page.tsx # Demo feature page with event tracking
65
+ │ ├── profile/
66
+ │ │ └── page.tsx # User profile with error tracking demo
67
+ │ ├── layout.tsx # Root layout with providers
68
+ │ ├── page.tsx # Home/Login page
69
+ │ └── globals.css # Global styles
70
+ ├── components/
71
+ │ └── Header.tsx # Navigation header with auth state
72
+ ├── contexts/
73
+ │ └── AuthContext.tsx # Authentication context with PostHog integration
74
+ └── lib/
75
+ └── posthog-server.ts # Server-side PostHog client
76
+
77
+ instrumentation-client.ts # Client-side PostHog initialization
78
+ ```
79
+
80
+ ## Key integration points
81
+
82
+ ### Client-side initialization (instrumentation-client.ts)
83
+
84
+ ```typescript
85
+ import posthog from "posthog-js"
86
+
87
+ posthog.init(process.env.NEXT_PUBLIC_POSTHOG_PROJECT_TOKEN!, {
88
+ api_host: "/ingest",
89
+ ui_host: "https://us.posthog.com",
90
+ defaults: '2026-01-30',
91
+ capture_exceptions: true,
92
+ debug: process.env.NODE_ENV === "development",
93
+ });
94
+ ```
95
+
96
+ ### User identification (AuthContext.tsx)
97
+
98
+ ```typescript
99
+ posthog.identify(username, {
100
+ username: username,
101
+ });
102
+ ```
103
+
104
+ ### Event tracking (burrito/page.tsx)
105
+
106
+ ```typescript
107
+ posthog.capture('burrito_considered', {
108
+ total_considerations: count,
109
+ username: username,
110
+ });
111
+ ```
112
+
113
+ ### Error tracking (profile/page.tsx)
114
+
115
+ ```typescript
116
+ posthog.captureException(error);
117
+ ```
118
+
119
+ ### Server-side tracking (app/api/auth/login/route.ts)
120
+
121
+ ```typescript
122
+ const posthog = getPostHogClient();
123
+ posthog.capture({
124
+ distinctId: username,
125
+ event: 'server_login',
126
+ properties: { ... }
127
+ });
128
+ ```
129
+
130
+ ## App router differences from pages router
131
+
132
+ This example uses Next.js App Router instead of Pages Router. Key differences:
133
+
134
+ 1. **File-based routing**: Pages in `src/app/` instead of `src/pages/`
135
+ 2. **layout.tsx**: Root layout component wraps all pages
136
+ 3. **API Routes**: Located in `src/app/api/` with `route.ts` files
137
+ 4. **'use client'**: Client components need explicit directive
138
+ 5. **useRouter**: From `next/navigation` instead of `next/router`
139
+ 6. **Metadata**: Exported from layout/page instead of Head component
140
+ 7. **Server Components**: Components are server-side by default
141
+
142
+ ## Learn more
143
+
144
+ - [PostHog Documentation](https://posthog.com/docs)
145
+ - [Next.js App Router Documentation](https://nextjs.org/docs/app)
146
+ - [PostHog Next.js Integration Guide](https://posthog.com/docs/libraries/next-js)
147
+
148
+ ## Deploy on Vercel
149
+
150
+ The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new).
151
+
152
+ Check out the [Next.js deployment documentation](https://nextjs.org/docs/app/building-your-application/deploying) for more details.
153
+
154
+ ---
155
+
156
+ ## .env.example
157
+
158
+ ```example
159
+ # PostHog Configuration
160
+ # Get your PostHog project token from: https://app.posthog.com/project/settings
161
+ NEXT_PUBLIC_POSTHOG_PROJECT_TOKEN=your_posthog_project_token_here
162
+ # NEXT_PUBLIC_POSTHOG_HOST=https://eu.i.posthog.com
163
+ NEXT_PUBLIC_POSTHOG_HOST=https://us.i.posthog.com
164
+ ```
165
+
166
+ ---
167
+
168
+ ## instrumentation-client.ts
169
+
170
+ ```ts
171
+ import posthog from "posthog-js"
172
+
173
+ posthog.init(process.env.NEXT_PUBLIC_POSTHOG_PROJECT_TOKEN!, {
174
+ api_host: "/ingest",
175
+ ui_host: "https://us.posthog.com",
176
+ // Include the defaults option as required by PostHog
177
+ defaults: '2026-01-30',
178
+ // Enables capturing unhandled exceptions via Error Tracking
179
+ capture_exceptions: true,
180
+ // Turn on debug in development mode
181
+ debug: process.env.NODE_ENV === "development",
182
+ });
183
+
184
+ //IMPORTANT: Never combine this approach with other client-side PostHog initialization approaches, especially components like a PostHogProvider. instrumentation-client.ts is the correct solution for initializating client-side PostHog in Next.js 15.3+ apps.
185
+ ```
186
+
187
+ ---
188
+
189
+ ## next.config.ts
190
+
191
+ ```ts
192
+ import type { NextConfig } from "next";
193
+
194
+ const nextConfig: NextConfig = {
195
+ /* config options here */
196
+ async rewrites() {
197
+ return [
198
+ {
199
+ source: "/ingest/static/:path*",
200
+ destination: "https://us-assets.i.posthog.com/static/:path*",
201
+ },
202
+ {
203
+ source: "/ingest/:path*",
204
+ destination: "https://us.i.posthog.com/:path*",
205
+ },
206
+ ];
207
+ },
208
+ // This is required to support PostHog trailing slash API requests
209
+ skipTrailingSlashRedirect: true,
210
+ };
211
+
212
+ export default nextConfig;
213
+
214
+ ```
215
+
216
+ ---
217
+
218
+ ## src/app/api/auth/login/route.ts
219
+
220
+ ```ts
221
+ import { NextResponse } from 'next/server';
222
+ import { getPostHogClient } from '@/lib/posthog-server';
223
+
224
+ const users = new Map<string, { username: string; burritoConsiderations: number }>();
225
+
226
+ export async function POST(request: Request) {
227
+ const { username, password } = await request.json();
228
+
229
+ if (!username || !password) {
230
+ return NextResponse.json({ error: 'Username and password required' }, { status: 400 });
231
+ }
232
+
233
+ let user = users.get(username);
234
+ const isNewUser = !user;
235
+
236
+ if (!user) {
237
+ user = { username, burritoConsiderations: 0 };
238
+ users.set(username, user);
239
+ }
240
+
241
+ // Capture server-side login event
242
+ const posthog = getPostHogClient();
243
+ posthog.capture({
244
+ distinctId: username,
245
+ event: 'server_login',
246
+ properties: {
247
+ username: username,
248
+ isNewUser: isNewUser,
249
+ source: 'api'
250
+ }
251
+ });
252
+
253
+ // Identify user on server side
254
+ posthog.identify({
255
+ distinctId: username,
256
+ properties: {
257
+ username: username,
258
+ createdAt: isNewUser ? new Date().toISOString() : undefined
259
+ }
260
+ });
261
+
262
+ return NextResponse.json({ success: true, user });
263
+ }
264
+ ```
265
+
266
+ ---
267
+
268
+ ## src/app/burrito/page.tsx
269
+
270
+ ```tsx
271
+ 'use client';
272
+
273
+ import { useState } from 'react';
274
+ import { useAuth } from '@/contexts/AuthContext';
275
+ import { useRouter } from 'next/navigation';
276
+ import posthog from 'posthog-js';
277
+
278
+ export default function BurritoPage() {
279
+ const { user, incrementBurritoConsiderations } = useAuth();
280
+ const router = useRouter();
281
+ const [hasConsidered, setHasConsidered] = useState(false);
282
+
283
+ // Redirect to home if not logged in
284
+ if (!user) {
285
+ router.push('/');
286
+ return null;
287
+ }
288
+
289
+ const handleConsideration = () => {
290
+ incrementBurritoConsiderations();
291
+ setHasConsidered(true);
292
+ setTimeout(() => setHasConsidered(false), 2000);
293
+
294
+ // Capture burrito consideration event
295
+ posthog.capture('burrito_considered', {
296
+ total_considerations: user.burritoConsiderations + 1,
297
+ username: user.username,
298
+ });
299
+ };
300
+
301
+ return (
302
+ <div className="container">
303
+ <h1>Burrito consideration zone</h1>
304
+ <p>Take a moment to truly consider the potential of burritos.</p>
305
+
306
+ <div style={{ textAlign: 'center' }}>
307
+ <button
308
+ onClick={handleConsideration}
309
+ className="btn-burrito"
310
+ >
311
+ I have considered the burrito potential
312
+ </button>
313
+
314
+ {hasConsidered && (
315
+ <p className="success">
316
+ Thank you for your consideration! Count: {user.burritoConsiderations}
317
+ </p>
318
+ )}
319
+ </div>
320
+
321
+ <div className="stats">
322
+ <h3>Consideration stats</h3>
323
+ <p>Total considerations: {user.burritoConsiderations}</p>
324
+ </div>
325
+ </div>
326
+ );
327
+ }
328
+ ```
329
+
330
+ ---
331
+
332
+ ## src/app/layout.tsx
333
+
334
+ ```tsx
335
+ import type { Metadata } from "next";
336
+ import "./globals.css";
337
+ import { AuthProvider } from "@/contexts/AuthContext";
338
+ import Header from "@/components/Header";
339
+
340
+ export const metadata: Metadata = {
341
+ title: "Burrito Consideration App",
342
+ description: "Consider the potential of burritos",
343
+ };
344
+
345
+ export default function RootLayout({
346
+ children,
347
+ }: Readonly<{
348
+ children: React.ReactNode;
349
+ }>) {
350
+ return (
351
+ <html lang="en">
352
+ <body>
353
+ <AuthProvider>
354
+ <Header />
355
+ <main>{children}</main>
356
+ </AuthProvider>
357
+ </body>
358
+ </html>
359
+ );
360
+ }
361
+
362
+ ```
363
+
364
+ ---
365
+
366
+ ## src/app/page.tsx
367
+
368
+ ```tsx
369
+ 'use client';
370
+
371
+ import { useState } from 'react';
372
+ import { useAuth } from '@/contexts/AuthContext';
373
+
374
+ export default function Home() {
375
+ const { user, login } = useAuth();
376
+ const [username, setUsername] = useState('');
377
+ const [password, setPassword] = useState('');
378
+ const [error, setError] = useState('');
379
+
380
+ const handleSubmit = async (e: React.FormEvent) => {
381
+ e.preventDefault();
382
+ setError('');
383
+
384
+ try {
385
+ const success = await login(username, password);
386
+ if (success) {
387
+ setUsername('');
388
+ setPassword('');
389
+ } else {
390
+ setError('Please provide both username and password');
391
+ }
392
+ } catch (err) {
393
+ console.error('Login failed:', err);
394
+ setError('An error occurred during login');
395
+ }
396
+ };
397
+
398
+ if (user) {
399
+ return (
400
+ <div className="container">
401
+ <h1>Welcome back, {user.username}!</h1>
402
+ <p>You are now logged in. Feel free to explore:</p>
403
+ <ul>
404
+ <li>Consider the potential of burritos</li>
405
+ <li>View your profile and statistics</li>
406
+ </ul>
407
+ </div>
408
+ );
409
+ }
410
+
411
+ return (
412
+ <div className="container">
413
+ <h1>Welcome to Burrito Consideration App</h1>
414
+ <p>Please sign in to begin your burrito journey</p>
415
+
416
+ <form onSubmit={handleSubmit} className="form">
417
+ <div className="form-group">
418
+ <label htmlFor="username">Username:</label>
419
+ <input
420
+ type="text"
421
+ id="username"
422
+ value={username}
423
+ onChange={(e) => setUsername(e.target.value)}
424
+ placeholder="Enter any username"
425
+ />
426
+ </div>
427
+
428
+ <div className="form-group">
429
+ <label htmlFor="password">Password:</label>
430
+ <input
431
+ type="password"
432
+ id="password"
433
+ value={password}
434
+ onChange={(e) => setPassword(e.target.value)}
435
+ placeholder="Enter any password"
436
+ />
437
+ </div>
438
+
439
+ {error && <p className="error">{error}</p>}
440
+
441
+ <button type="submit" className="btn-primary">Sign In</button>
442
+ </form>
443
+
444
+ <p className="note">
445
+ Note: This is a demo app. Use any username and password to sign in.
446
+ </p>
447
+ </div>
448
+ );
449
+ }
450
+ ```
451
+
452
+ ---
453
+
454
+ ## src/app/profile/page.tsx
455
+
456
+ ```tsx
457
+ 'use client';
458
+
459
+ import { useAuth } from '@/contexts/AuthContext';
460
+ import { useRouter } from 'next/navigation';
461
+ import posthog from 'posthog-js';
462
+
463
+ export default function ProfilePage() {
464
+ const { user } = useAuth();
465
+ const router = useRouter();
466
+
467
+ // Redirect to home if not logged in
468
+ if (!user) {
469
+ router.push('/');
470
+ return null;
471
+ }
472
+
473
+ const triggerTestError = () => {
474
+ try {
475
+ throw new Error('Test error for PostHog error tracking');
476
+ } catch (err) {
477
+ posthog.captureException(err);
478
+ console.error('Captured error:', err);
479
+ alert('Error captured and sent to PostHog!');
480
+ }
481
+ };
482
+
483
+ return (
484
+ <div className="container">
485
+ <h1>User Profile</h1>
486
+
487
+ <div className="stats">
488
+ <h2>Your Information</h2>
489
+ <p><strong>Username:</strong> {user.username}</p>
490
+ <p><strong>Burrito Considerations:</strong> {user.burritoConsiderations}</p>
491
+ </div>
492
+
493
+ <div style={{ marginTop: '2rem' }}>
494
+ <button onClick={triggerTestError} className="btn-primary" style={{ backgroundColor: '#dc3545' }}>
495
+ Trigger Test Error (for PostHog)
496
+ </button>
497
+ </div>
498
+
499
+ <div style={{ marginTop: '2rem' }}>
500
+ <h3>Your Burrito Journey</h3>
501
+ {user.burritoConsiderations === 0 ? (
502
+ <p>You haven&apos;t considered any burritos yet. Visit the Burrito Consideration page to start!</p>
503
+ ) : user.burritoConsiderations === 1 ? (
504
+ <p>You&apos;ve considered the burrito potential once. Keep going!</p>
505
+ ) : user.burritoConsiderations < 5 ? (
506
+ <p>You&apos;re getting the hang of burrito consideration!</p>
507
+ ) : user.burritoConsiderations < 10 ? (
508
+ <p>You&apos;re becoming a burrito consideration expert!</p>
509
+ ) : (
510
+ <p>You are a true burrito consideration master! 🌯</p>
511
+ )}
512
+ </div>
513
+ </div>
514
+ );
515
+ }
516
+ ```
517
+
518
+ ---
519
+
520
+ ## src/components/Header.tsx
521
+
522
+ ```tsx
523
+ 'use client';
524
+
525
+ import Link from 'next/link';
526
+ import { useAuth } from '@/contexts/AuthContext';
527
+
528
+ export default function Header() {
529
+ const { user, logout } = useAuth();
530
+
531
+ return (
532
+ <header className="header">
533
+ <div className="header-container">
534
+ <nav>
535
+ <Link href="/">Home</Link>
536
+ {user && (
537
+ <>
538
+ <Link href="/burrito">Burrito Consideration</Link>
539
+ <Link href="/profile">Profile</Link>
540
+ </>
541
+ )}
542
+ </nav>
543
+ <div className="user-section">
544
+ {user ? (
545
+ <>
546
+ <span>Welcome, {user.username}!</span>
547
+ <button onClick={logout} className="btn-logout">
548
+ Logout
549
+ </button>
550
+ </>
551
+ ) : (
552
+ <span>Not logged in</span>
553
+ )}
554
+ </div>
555
+ </div>
556
+ </header>
557
+ );
558
+ }
559
+ ```
560
+
561
+ ---
562
+
563
+ ## src/contexts/AuthContext.tsx
564
+
565
+ ```tsx
566
+ 'use client';
567
+
568
+ import { createContext, useContext, useState, ReactNode } from 'react';
569
+ import posthog from 'posthog-js';
570
+
571
+ interface User {
572
+ username: string;
573
+ burritoConsiderations: number;
574
+ }
575
+
576
+ interface AuthContextType {
577
+ user: User | null;
578
+ login: (username: string, password: string) => Promise<boolean>;
579
+ logout: () => void;
580
+ incrementBurritoConsiderations: () => void;
581
+ }
582
+
583
+ const AuthContext = createContext<AuthContextType | undefined>(undefined);
584
+
585
+ const users: Map<string, User> = new Map();
586
+
587
+ export function AuthProvider({ children }: { children: ReactNode }) {
588
+ // Use lazy initializer to read from localStorage only once on mount
589
+ const [user, setUser] = useState<User | null>(() => {
590
+ if (typeof window === 'undefined') return null;
591
+
592
+ const storedUsername = localStorage.getItem('currentUser');
593
+ if (storedUsername) {
594
+ const existingUser = users.get(storedUsername);
595
+ if (existingUser) {
596
+ return existingUser;
597
+ }
598
+ }
599
+ return null;
600
+ });
601
+
602
+ const login = async (username: string, password: string): Promise<boolean> => {
603
+ try {
604
+ const response = await fetch('/api/auth/login', {
605
+ method: 'POST',
606
+ headers: { 'Content-Type': 'application/json' },
607
+ body: JSON.stringify({ username, password }),
608
+ });
609
+
610
+ if (response.ok) {
611
+ const { user: userData } = await response.json();
612
+
613
+ let localUser = users.get(username);
614
+ if (!localUser) {
615
+ localUser = userData as User;
616
+ users.set(username, localUser);
617
+ }
618
+
619
+ setUser(localUser);
620
+ localStorage.setItem('currentUser', username);
621
+
622
+ // Identify user in PostHog using username as distinct ID
623
+ posthog.identify(username, {
624
+ username: username,
625
+ });
626
+
627
+ // Capture login event
628
+ posthog.capture('user_logged_in', {
629
+ username: username,
630
+ });
631
+
632
+ return true;
633
+ }
634
+ return false;
635
+ } catch (error) {
636
+ console.error('Login error:', error);
637
+ return false;
638
+ }
639
+ };
640
+
641
+ const logout = () => {
642
+ // Capture logout event before resetting
643
+ posthog.capture('user_logged_out');
644
+ posthog.reset();
645
+
646
+ setUser(null);
647
+ localStorage.removeItem('currentUser');
648
+ };
649
+
650
+ const incrementBurritoConsiderations = () => {
651
+ if (user) {
652
+ user.burritoConsiderations++;
653
+ users.set(user.username, user);
654
+ setUser({ ...user });
655
+ }
656
+ };
657
+
658
+ return (
659
+ <AuthContext.Provider value={{ user, login, logout, incrementBurritoConsiderations }}>
660
+ {children}
661
+ </AuthContext.Provider>
662
+ );
663
+ }
664
+
665
+ export function useAuth() {
666
+ const context = useContext(AuthContext);
667
+ if (context === undefined) {
668
+ throw new Error('useAuth must be used within an AuthProvider');
669
+ }
670
+ return context;
671
+ }
672
+ ```
673
+
674
+ ---
675
+
676
+ ## src/lib/posthog-server.ts
677
+
678
+ ```ts
679
+ import { PostHog } from 'posthog-node';
680
+
681
+ let posthogClient: PostHog | null = null;
682
+
683
+ export function getPostHogClient() {
684
+ if (!posthogClient) {
685
+ posthogClient = new PostHog(
686
+ process.env.NEXT_PUBLIC_POSTHOG_PROJECT_TOKEN!,
687
+ {
688
+ host: process.env.NEXT_PUBLIC_POSTHOG_HOST,
689
+ flushAt: 1,
690
+ flushInterval: 0
691
+ }
692
+ );
693
+ posthogClient.debug(true);
694
+ }
695
+ return posthogClient;
696
+ }
697
+
698
+ export async function shutdownPostHog() {
699
+ if (posthogClient) {
700
+ await posthogClient.shutdown();
701
+ }
702
+ }
703
+ ```
704
+
705
+ ---
706
+