@sentry/warden 0.1.1 → 0.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 (589) hide show
  1. package/dist/cli/commands/init.d.ts.map +1 -1
  2. package/dist/cli/commands/init.js +36 -2
  3. package/dist/cli/commands/init.js.map +1 -1
  4. package/dist/cli/commands/setup-app/manifest.d.ts.map +1 -1
  5. package/dist/cli/commands/setup-app/manifest.js +3 -1
  6. package/dist/cli/commands/setup-app/manifest.js.map +1 -1
  7. package/dist/cli/commands/setup-app.js +1 -1
  8. package/dist/cli/commands/setup-app.js.map +1 -1
  9. package/dist/cli/diff-apply.d.ts +15 -0
  10. package/dist/cli/diff-apply.d.ts.map +1 -0
  11. package/dist/cli/diff-apply.js +69 -0
  12. package/dist/cli/diff-apply.js.map +1 -0
  13. package/dist/cli/files.d.ts +11 -1
  14. package/dist/cli/files.d.ts.map +1 -1
  15. package/dist/cli/files.js +145 -4
  16. package/dist/cli/files.js.map +1 -1
  17. package/dist/cli/fix.d.ts +1 -5
  18. package/dist/cli/fix.d.ts.map +1 -1
  19. package/dist/cli/fix.js +3 -62
  20. package/dist/cli/fix.js.map +1 -1
  21. package/dist/cli/git.d.ts.map +1 -1
  22. package/dist/cli/git.js +5 -9
  23. package/dist/cli/git.js.map +1 -1
  24. package/dist/cli/index.js +0 -0
  25. package/dist/cli/output/tasks.d.ts.map +1 -1
  26. package/dist/cli/output/tasks.js +5 -1
  27. package/dist/cli/output/tasks.js.map +1 -1
  28. package/dist/config/schema.d.ts.map +1 -1
  29. package/dist/config/schema.js +15 -1
  30. package/dist/config/schema.js.map +1 -1
  31. package/dist/diff/coalesce.d.ts +32 -2
  32. package/dist/diff/coalesce.d.ts.map +1 -1
  33. package/dist/diff/coalesce.js +174 -2
  34. package/dist/diff/coalesce.js.map +1 -1
  35. package/dist/output/dedup.d.ts +7 -4
  36. package/dist/output/dedup.d.ts.map +1 -1
  37. package/dist/output/dedup.js +48 -12
  38. package/dist/output/dedup.js.map +1 -1
  39. package/dist/output/renderer.d.ts.map +1 -1
  40. package/dist/output/renderer.js +52 -7
  41. package/dist/output/renderer.js.map +1 -1
  42. package/dist/output/stale.d.ts.map +1 -1
  43. package/dist/output/stale.js +7 -0
  44. package/dist/output/stale.js.map +1 -1
  45. package/dist/output/types.d.ts +15 -1
  46. package/dist/output/types.d.ts.map +1 -1
  47. package/dist/sdk/analyze.d.ts +18 -0
  48. package/dist/sdk/analyze.d.ts.map +1 -0
  49. package/dist/sdk/analyze.js +421 -0
  50. package/dist/sdk/analyze.js.map +1 -0
  51. package/dist/sdk/errors.d.ts +23 -0
  52. package/dist/sdk/errors.d.ts.map +1 -0
  53. package/dist/sdk/errors.js +74 -0
  54. package/dist/sdk/errors.js.map +1 -0
  55. package/dist/sdk/extract.d.ts +44 -0
  56. package/dist/sdk/extract.d.ts.map +1 -0
  57. package/dist/sdk/extract.js +224 -0
  58. package/dist/sdk/extract.js.map +1 -0
  59. package/dist/sdk/prepare.d.ts +13 -0
  60. package/dist/sdk/prepare.d.ts.map +1 -0
  61. package/dist/sdk/prepare.js +73 -0
  62. package/dist/sdk/prepare.js.map +1 -0
  63. package/dist/sdk/prompt.d.ts +30 -0
  64. package/dist/sdk/prompt.d.ts.map +1 -0
  65. package/dist/sdk/prompt.js +109 -0
  66. package/dist/sdk/prompt.js.map +1 -0
  67. package/dist/sdk/retry.d.ts +12 -0
  68. package/dist/sdk/retry.d.ts.map +1 -0
  69. package/dist/sdk/retry.js +31 -0
  70. package/dist/sdk/retry.js.map +1 -0
  71. package/dist/sdk/runner.d.ts +22 -199
  72. package/dist/sdk/runner.d.ts.map +1 -1
  73. package/dist/sdk/runner.js +26 -884
  74. package/dist/sdk/runner.js.map +1 -1
  75. package/dist/sdk/types.d.ts +127 -0
  76. package/dist/sdk/types.d.ts.map +1 -0
  77. package/dist/sdk/types.js +5 -0
  78. package/dist/sdk/types.js.map +1 -0
  79. package/dist/sdk/usage.d.ts +20 -0
  80. package/dist/sdk/usage.d.ts.map +1 -0
  81. package/dist/sdk/usage.js +44 -0
  82. package/dist/sdk/usage.js.map +1 -0
  83. package/dist/skills/remote.d.ts.map +1 -1
  84. package/dist/skills/remote.js +3 -7
  85. package/dist/skills/remote.js.map +1 -1
  86. package/dist/types/index.d.ts +1 -0
  87. package/dist/types/index.d.ts.map +1 -1
  88. package/dist/types/index.js +2 -0
  89. package/dist/types/index.js.map +1 -1
  90. package/dist/utils/exec.d.ts +61 -0
  91. package/dist/utils/exec.d.ts.map +1 -0
  92. package/dist/utils/exec.js +111 -0
  93. package/dist/utils/exec.js.map +1 -0
  94. package/dist/utils/index.d.ts +2 -0
  95. package/dist/utils/index.d.ts.map +1 -1
  96. package/dist/utils/index.js +1 -0
  97. package/dist/utils/index.js.map +1 -1
  98. package/package.json +15 -16
  99. package/.agents/skills/find-bugs/SKILL.md +0 -75
  100. package/.agents/skills/vercel-react-best-practices/AGENTS.md +0 -2934
  101. package/.agents/skills/vercel-react-best-practices/SKILL.md +0 -136
  102. package/.agents/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +0 -55
  103. package/.agents/skills/vercel-react-best-practices/rules/advanced-init-once.md +0 -42
  104. package/.agents/skills/vercel-react-best-practices/rules/advanced-use-latest.md +0 -39
  105. package/.agents/skills/vercel-react-best-practices/rules/async-api-routes.md +0 -38
  106. package/.agents/skills/vercel-react-best-practices/rules/async-defer-await.md +0 -80
  107. package/.agents/skills/vercel-react-best-practices/rules/async-dependencies.md +0 -51
  108. package/.agents/skills/vercel-react-best-practices/rules/async-parallel.md +0 -28
  109. package/.agents/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +0 -99
  110. package/.agents/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +0 -59
  111. package/.agents/skills/vercel-react-best-practices/rules/bundle-conditional.md +0 -31
  112. package/.agents/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +0 -49
  113. package/.agents/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +0 -35
  114. package/.agents/skills/vercel-react-best-practices/rules/bundle-preload.md +0 -50
  115. package/.agents/skills/vercel-react-best-practices/rules/client-event-listeners.md +0 -74
  116. package/.agents/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +0 -71
  117. package/.agents/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +0 -48
  118. package/.agents/skills/vercel-react-best-practices/rules/client-swr-dedup.md +0 -56
  119. package/.agents/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +0 -107
  120. package/.agents/skills/vercel-react-best-practices/rules/js-cache-function-results.md +0 -80
  121. package/.agents/skills/vercel-react-best-practices/rules/js-cache-property-access.md +0 -28
  122. package/.agents/skills/vercel-react-best-practices/rules/js-cache-storage.md +0 -70
  123. package/.agents/skills/vercel-react-best-practices/rules/js-combine-iterations.md +0 -32
  124. package/.agents/skills/vercel-react-best-practices/rules/js-early-exit.md +0 -50
  125. package/.agents/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +0 -45
  126. package/.agents/skills/vercel-react-best-practices/rules/js-index-maps.md +0 -37
  127. package/.agents/skills/vercel-react-best-practices/rules/js-length-check-first.md +0 -49
  128. package/.agents/skills/vercel-react-best-practices/rules/js-min-max-loop.md +0 -82
  129. package/.agents/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +0 -24
  130. package/.agents/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +0 -57
  131. package/.agents/skills/vercel-react-best-practices/rules/rendering-activity.md +0 -26
  132. package/.agents/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +0 -47
  133. package/.agents/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +0 -40
  134. package/.agents/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +0 -38
  135. package/.agents/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +0 -46
  136. package/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +0 -82
  137. package/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +0 -30
  138. package/.agents/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +0 -28
  139. package/.agents/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +0 -75
  140. package/.agents/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +0 -39
  141. package/.agents/skills/vercel-react-best-practices/rules/rerender-dependencies.md +0 -45
  142. package/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +0 -40
  143. package/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state.md +0 -29
  144. package/.agents/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +0 -74
  145. package/.agents/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +0 -58
  146. package/.agents/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +0 -38
  147. package/.agents/skills/vercel-react-best-practices/rules/rerender-memo.md +0 -44
  148. package/.agents/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +0 -45
  149. package/.agents/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +0 -35
  150. package/.agents/skills/vercel-react-best-practices/rules/rerender-transitions.md +0 -40
  151. package/.agents/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +0 -73
  152. package/.agents/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +0 -73
  153. package/.agents/skills/vercel-react-best-practices/rules/server-auth-actions.md +0 -96
  154. package/.agents/skills/vercel-react-best-practices/rules/server-cache-lru.md +0 -41
  155. package/.agents/skills/vercel-react-best-practices/rules/server-cache-react.md +0 -76
  156. package/.agents/skills/vercel-react-best-practices/rules/server-dedup-props.md +0 -65
  157. package/.agents/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +0 -83
  158. package/.agents/skills/vercel-react-best-practices/rules/server-serialization.md +0 -38
  159. package/.claude/settings.json +0 -57
  160. package/.claude/skills/agent-prompt/SKILL.md +0 -54
  161. package/.claude/skills/agent-prompt/references/agentic-patterns.md +0 -94
  162. package/.claude/skills/agent-prompt/references/anti-patterns.md +0 -140
  163. package/.claude/skills/agent-prompt/references/context-design.md +0 -124
  164. package/.claude/skills/agent-prompt/references/core-principles.md +0 -75
  165. package/.claude/skills/agent-prompt/references/model-guidance.md +0 -118
  166. package/.claude/skills/agent-prompt/references/output-formats.md +0 -98
  167. package/.claude/skills/agent-prompt/references/skill-structure.md +0 -115
  168. package/.claude/skills/agent-prompt/references/system-prompts.md +0 -115
  169. package/.claude/skills/notseer/SKILL.md +0 -131
  170. package/.claude/skills/skill-writer/SKILL.md +0 -140
  171. package/.claude/skills/testing-guidelines/SKILL.md +0 -132
  172. package/.claude/skills/warden-skill/SKILL.md +0 -226
  173. package/.claude/skills/warden-skill/references/config-schema.md +0 -116
  174. package/.dex/config.toml +0 -2
  175. package/.github/workflows/ci.yml +0 -33
  176. package/.github/workflows/release.yml +0 -59
  177. package/.github/workflows/warden.yml +0 -40
  178. package/AGENTS.md +0 -89
  179. package/CONTRIBUTING.md +0 -60
  180. package/SPEC.md +0 -263
  181. package/action.yml +0 -87
  182. package/assets/favicon.png +0 -0
  183. package/assets/warden-icon-bw.svg +0 -5
  184. package/assets/warden-icon-purple.png +0 -0
  185. package/assets/warden-icon-purple.svg +0 -5
  186. package/dist/action/159.index.js +0 -523
  187. package/dist/action/159.index.js.map +0 -1
  188. package/dist/action/action/index.d.ts +0 -2
  189. package/dist/action/action/index.d.ts.map +0 -1
  190. package/dist/action/action/main.d.ts +0 -2
  191. package/dist/action/action/main.d.ts.map +0 -1
  192. package/dist/action/cli/args.d.ts +0 -74
  193. package/dist/action/cli/args.d.ts.map +0 -1
  194. package/dist/action/cli/args.test.d.ts +0 -2
  195. package/dist/action/cli/args.test.d.ts.map +0 -1
  196. package/dist/action/cli/commands/add.d.ts +0 -7
  197. package/dist/action/cli/commands/add.d.ts.map +0 -1
  198. package/dist/action/cli/commands/init.d.ts +0 -10
  199. package/dist/action/cli/commands/init.d.ts.map +0 -1
  200. package/dist/action/cli/commands/init.test.d.ts +0 -2
  201. package/dist/action/cli/commands/init.test.d.ts.map +0 -1
  202. package/dist/action/cli/commands/setup-app/browser.d.ts +0 -9
  203. package/dist/action/cli/commands/setup-app/browser.d.ts.map +0 -1
  204. package/dist/action/cli/commands/setup-app/credentials.d.ts +0 -15
  205. package/dist/action/cli/commands/setup-app/credentials.d.ts.map +0 -1
  206. package/dist/action/cli/commands/setup-app/manifest.d.ts +0 -24
  207. package/dist/action/cli/commands/setup-app/manifest.d.ts.map +0 -1
  208. package/dist/action/cli/commands/setup-app/server.d.ts +0 -28
  209. package/dist/action/cli/commands/setup-app/server.d.ts.map +0 -1
  210. package/dist/action/cli/commands/setup-app.d.ts +0 -11
  211. package/dist/action/cli/commands/setup-app.d.ts.map +0 -1
  212. package/dist/action/cli/commands/sync.d.ts +0 -9
  213. package/dist/action/cli/commands/sync.d.ts.map +0 -1
  214. package/dist/action/cli/context.d.ts +0 -27
  215. package/dist/action/cli/context.d.ts.map +0 -1
  216. package/dist/action/cli/files.d.ts +0 -22
  217. package/dist/action/cli/files.d.ts.map +0 -1
  218. package/dist/action/cli/files.test.d.ts +0 -2
  219. package/dist/action/cli/files.test.d.ts.map +0 -1
  220. package/dist/action/cli/fix.d.ts +0 -41
  221. package/dist/action/cli/fix.d.ts.map +0 -1
  222. package/dist/action/cli/fix.test.d.ts +0 -2
  223. package/dist/action/cli/fix.test.d.ts.map +0 -1
  224. package/dist/action/cli/git.d.ts +0 -73
  225. package/dist/action/cli/git.d.ts.map +0 -1
  226. package/dist/action/cli/git.test.d.ts +0 -2
  227. package/dist/action/cli/git.test.d.ts.map +0 -1
  228. package/dist/action/cli/index.d.ts +0 -3
  229. package/dist/action/cli/index.d.ts.map +0 -1
  230. package/dist/action/cli/main.d.ts +0 -7
  231. package/dist/action/cli/main.d.ts.map +0 -1
  232. package/dist/action/cli/output/box.d.ts +0 -75
  233. package/dist/action/cli/output/box.d.ts.map +0 -1
  234. package/dist/action/cli/output/formatters.d.ts +0 -90
  235. package/dist/action/cli/output/formatters.d.ts.map +0 -1
  236. package/dist/action/cli/output/formatters.test.d.ts +0 -2
  237. package/dist/action/cli/output/formatters.test.d.ts.map +0 -1
  238. package/dist/action/cli/output/icons.d.ts +0 -15
  239. package/dist/action/cli/output/icons.d.ts.map +0 -1
  240. package/dist/action/cli/output/index.d.ts +0 -10
  241. package/dist/action/cli/output/index.d.ts.map +0 -1
  242. package/dist/action/cli/output/ink-runner.d.ts +0 -29
  243. package/dist/action/cli/output/ink-runner.d.ts.map +0 -1
  244. package/dist/action/cli/output/jsonl.d.ts +0 -43
  245. package/dist/action/cli/output/jsonl.d.ts.map +0 -1
  246. package/dist/action/cli/output/jsonl.test.d.ts +0 -2
  247. package/dist/action/cli/output/jsonl.test.d.ts.map +0 -1
  248. package/dist/action/cli/output/reporter.d.ts +0 -108
  249. package/dist/action/cli/output/reporter.d.ts.map +0 -1
  250. package/dist/action/cli/output/tasks.d.ts +0 -89
  251. package/dist/action/cli/output/tasks.d.ts.map +0 -1
  252. package/dist/action/cli/output/tty.d.ts +0 -21
  253. package/dist/action/cli/output/tty.d.ts.map +0 -1
  254. package/dist/action/cli/output/tty.test.d.ts +0 -2
  255. package/dist/action/cli/output/tty.test.d.ts.map +0 -1
  256. package/dist/action/cli/output/verbosity.d.ts +0 -20
  257. package/dist/action/cli/output/verbosity.d.ts.map +0 -1
  258. package/dist/action/cli/output/verbosity.test.d.ts +0 -2
  259. package/dist/action/cli/output/verbosity.test.d.ts.map +0 -1
  260. package/dist/action/cli/terminal.d.ts +0 -19
  261. package/dist/action/cli/terminal.d.ts.map +0 -1
  262. package/dist/action/cli/terminal.test.d.ts +0 -2
  263. package/dist/action/cli/terminal.test.d.ts.map +0 -1
  264. package/dist/action/config/index.d.ts +0 -4
  265. package/dist/action/config/index.d.ts.map +0 -1
  266. package/dist/action/config/loader.d.ts +0 -27
  267. package/dist/action/config/loader.d.ts.map +0 -1
  268. package/dist/action/config/loader.test.d.ts +0 -2
  269. package/dist/action/config/loader.test.d.ts.map +0 -1
  270. package/dist/action/config/schema.d.ts +0 -318
  271. package/dist/action/config/schema.d.ts.map +0 -1
  272. package/dist/action/config/writer.d.ts +0 -11
  273. package/dist/action/config/writer.d.ts.map +0 -1
  274. package/dist/action/config/writer.test.d.ts +0 -2
  275. package/dist/action/config/writer.test.d.ts.map +0 -1
  276. package/dist/action/diff/classify.d.ts +0 -29
  277. package/dist/action/diff/classify.d.ts.map +0 -1
  278. package/dist/action/diff/classify.test.d.ts +0 -2
  279. package/dist/action/diff/classify.test.d.ts.map +0 -1
  280. package/dist/action/diff/coalesce.d.ts +0 -42
  281. package/dist/action/diff/coalesce.d.ts.map +0 -1
  282. package/dist/action/diff/coalesce.test.d.ts +0 -2
  283. package/dist/action/diff/coalesce.test.d.ts.map +0 -1
  284. package/dist/action/diff/context.d.ts +0 -30
  285. package/dist/action/diff/context.d.ts.map +0 -1
  286. package/dist/action/diff/context.test.d.ts +0 -2
  287. package/dist/action/diff/context.test.d.ts.map +0 -1
  288. package/dist/action/diff/index.d.ts +0 -5
  289. package/dist/action/diff/index.d.ts.map +0 -1
  290. package/dist/action/diff/parser.d.ts +0 -52
  291. package/dist/action/diff/parser.d.ts.map +0 -1
  292. package/dist/action/diff/parser.test.d.ts +0 -2
  293. package/dist/action/diff/parser.test.d.ts.map +0 -1
  294. package/dist/action/event/context.d.ts +0 -9
  295. package/dist/action/event/context.d.ts.map +0 -1
  296. package/dist/action/event/index.d.ts +0 -3
  297. package/dist/action/event/index.d.ts.map +0 -1
  298. package/dist/action/event/schedule-context.d.ts +0 -30
  299. package/dist/action/event/schedule-context.d.ts.map +0 -1
  300. package/dist/action/examples/examples.integration.test.d.ts +0 -2
  301. package/dist/action/examples/examples.integration.test.d.ts.map +0 -1
  302. package/dist/action/examples/index.d.ts +0 -50
  303. package/dist/action/examples/index.d.ts.map +0 -1
  304. package/dist/action/examples/index.test.d.ts +0 -2
  305. package/dist/action/examples/index.test.d.ts.map +0 -1
  306. package/dist/action/examples/setup.d.ts +0 -2
  307. package/dist/action/examples/setup.d.ts.map +0 -1
  308. package/dist/action/index.d.ts +0 -11
  309. package/dist/action/index.d.ts.map +0 -1
  310. package/dist/action/index.js +0 -38231
  311. package/dist/action/index.js.map +0 -1
  312. package/dist/action/licenses.txt +0 -992
  313. package/dist/action/main.d.ts +0 -2
  314. package/dist/action/main.d.ts.map +0 -1
  315. package/dist/action/main.js +0 -707
  316. package/dist/action/main.js.map +0 -1
  317. package/dist/action/output/dedup.d.ts +0 -153
  318. package/dist/action/output/dedup.d.ts.map +0 -1
  319. package/dist/action/output/dedup.test.d.ts +0 -2
  320. package/dist/action/output/dedup.test.d.ts.map +0 -1
  321. package/dist/action/output/github-checks.d.ts +0 -106
  322. package/dist/action/output/github-checks.d.ts.map +0 -1
  323. package/dist/action/output/github-checks.test.d.ts +0 -2
  324. package/dist/action/output/github-checks.test.d.ts.map +0 -1
  325. package/dist/action/output/github-issues.d.ts +0 -35
  326. package/dist/action/output/github-issues.d.ts.map +0 -1
  327. package/dist/action/output/index.d.ts +0 -6
  328. package/dist/action/output/index.d.ts.map +0 -1
  329. package/dist/action/output/issue-renderer.d.ts +0 -20
  330. package/dist/action/output/issue-renderer.d.ts.map +0 -1
  331. package/dist/action/output/renderer.d.ts +0 -4
  332. package/dist/action/output/renderer.d.ts.map +0 -1
  333. package/dist/action/output/renderer.test.d.ts +0 -2
  334. package/dist/action/output/renderer.test.d.ts.map +0 -1
  335. package/dist/action/output/stale.d.ts +0 -31
  336. package/dist/action/output/stale.d.ts.map +0 -1
  337. package/dist/action/output/stale.test.d.ts +0 -2
  338. package/dist/action/output/stale.test.d.ts.map +0 -1
  339. package/dist/action/output/types.d.ts +0 -31
  340. package/dist/action/output/types.d.ts.map +0 -1
  341. package/dist/action/package.json +0 -3
  342. package/dist/action/sdk/index.d.ts +0 -2
  343. package/dist/action/sdk/index.d.ts.map +0 -1
  344. package/dist/action/sdk/runner.d.ts +0 -202
  345. package/dist/action/sdk/runner.d.ts.map +0 -1
  346. package/dist/action/sdk/runner.test.d.ts +0 -2
  347. package/dist/action/sdk/runner.test.d.ts.map +0 -1
  348. package/dist/action/skills/index.d.ts +0 -5
  349. package/dist/action/skills/index.d.ts.map +0 -1
  350. package/dist/action/skills/loader.d.ts +0 -111
  351. package/dist/action/skills/loader.d.ts.map +0 -1
  352. package/dist/action/skills/loader.test.d.ts +0 -2
  353. package/dist/action/skills/loader.test.d.ts.map +0 -1
  354. package/dist/action/skills/remote.d.ts +0 -117
  355. package/dist/action/skills/remote.d.ts.map +0 -1
  356. package/dist/action/skills/remote.test.d.ts +0 -2
  357. package/dist/action/skills/remote.test.d.ts.map +0 -1
  358. package/dist/action/sourcemap-register.cjs +0 -1
  359. package/dist/action/triggers/matcher.d.ts +0 -30
  360. package/dist/action/triggers/matcher.d.ts.map +0 -1
  361. package/dist/action/triggers/matcher.test.d.ts +0 -2
  362. package/dist/action/triggers/matcher.test.d.ts.map +0 -1
  363. package/dist/action/types/index.d.ts +0 -269
  364. package/dist/action/types/index.d.ts.map +0 -1
  365. package/dist/action/utils/async.d.ts +0 -5
  366. package/dist/action/utils/async.d.ts.map +0 -1
  367. package/dist/action/utils/index.d.ts +0 -16
  368. package/dist/action/utils/index.d.ts.map +0 -1
  369. package/dist/action/utils/index.test.d.ts +0 -2
  370. package/dist/action/utils/index.test.d.ts.map +0 -1
  371. package/dist/action/utils/version.d.ts +0 -3
  372. package/dist/action/utils/version.d.ts.map +0 -1
  373. package/dist/cli/args.test.d.ts +0 -2
  374. package/dist/cli/args.test.d.ts.map +0 -1
  375. package/dist/cli/args.test.js +0 -392
  376. package/dist/cli/args.test.js.map +0 -1
  377. package/dist/cli/commands/init.test.d.ts +0 -2
  378. package/dist/cli/commands/init.test.d.ts.map +0 -1
  379. package/dist/cli/commands/init.test.js +0 -117
  380. package/dist/cli/commands/init.test.js.map +0 -1
  381. package/dist/cli/files.test.d.ts +0 -2
  382. package/dist/cli/files.test.d.ts.map +0 -1
  383. package/dist/cli/files.test.js +0 -117
  384. package/dist/cli/files.test.js.map +0 -1
  385. package/dist/cli/fix.test.d.ts +0 -2
  386. package/dist/cli/fix.test.d.ts.map +0 -1
  387. package/dist/cli/fix.test.js +0 -251
  388. package/dist/cli/fix.test.js.map +0 -1
  389. package/dist/cli/git.test.d.ts +0 -2
  390. package/dist/cli/git.test.d.ts.map +0 -1
  391. package/dist/cli/git.test.js +0 -96
  392. package/dist/cli/git.test.js.map +0 -1
  393. package/dist/cli/output/formatters.test.d.ts +0 -2
  394. package/dist/cli/output/formatters.test.d.ts.map +0 -1
  395. package/dist/cli/output/formatters.test.js +0 -152
  396. package/dist/cli/output/formatters.test.js.map +0 -1
  397. package/dist/cli/output/jsonl.test.d.ts +0 -2
  398. package/dist/cli/output/jsonl.test.d.ts.map +0 -1
  399. package/dist/cli/output/jsonl.test.js +0 -284
  400. package/dist/cli/output/jsonl.test.js.map +0 -1
  401. package/dist/cli/output/tty.test.d.ts +0 -2
  402. package/dist/cli/output/tty.test.d.ts.map +0 -1
  403. package/dist/cli/output/tty.test.js +0 -105
  404. package/dist/cli/output/tty.test.js.map +0 -1
  405. package/dist/cli/output/verbosity.test.d.ts +0 -2
  406. package/dist/cli/output/verbosity.test.d.ts.map +0 -1
  407. package/dist/cli/output/verbosity.test.js +0 -35
  408. package/dist/cli/output/verbosity.test.js.map +0 -1
  409. package/dist/cli/terminal.test.d.ts +0 -2
  410. package/dist/cli/terminal.test.d.ts.map +0 -1
  411. package/dist/cli/terminal.test.js +0 -123
  412. package/dist/cli/terminal.test.js.map +0 -1
  413. package/dist/config/loader.test.d.ts +0 -2
  414. package/dist/config/loader.test.d.ts.map +0 -1
  415. package/dist/config/loader.test.js +0 -263
  416. package/dist/config/loader.test.js.map +0 -1
  417. package/dist/config/writer.test.d.ts +0 -2
  418. package/dist/config/writer.test.d.ts.map +0 -1
  419. package/dist/config/writer.test.js +0 -98
  420. package/dist/config/writer.test.js.map +0 -1
  421. package/dist/diff/classify.test.d.ts +0 -2
  422. package/dist/diff/classify.test.d.ts.map +0 -1
  423. package/dist/diff/classify.test.js +0 -140
  424. package/dist/diff/classify.test.js.map +0 -1
  425. package/dist/diff/coalesce.test.d.ts +0 -2
  426. package/dist/diff/coalesce.test.d.ts.map +0 -1
  427. package/dist/diff/coalesce.test.js +0 -159
  428. package/dist/diff/coalesce.test.js.map +0 -1
  429. package/dist/diff/context.test.d.ts +0 -2
  430. package/dist/diff/context.test.d.ts.map +0 -1
  431. package/dist/diff/context.test.js +0 -190
  432. package/dist/diff/context.test.js.map +0 -1
  433. package/dist/diff/parser.test.d.ts +0 -2
  434. package/dist/diff/parser.test.d.ts.map +0 -1
  435. package/dist/diff/parser.test.js +0 -178
  436. package/dist/diff/parser.test.js.map +0 -1
  437. package/dist/examples/examples.integration.test.d.ts +0 -2
  438. package/dist/examples/examples.integration.test.d.ts.map +0 -1
  439. package/dist/examples/examples.integration.test.js +0 -55
  440. package/dist/examples/examples.integration.test.js.map +0 -1
  441. package/dist/examples/index.test.d.ts +0 -2
  442. package/dist/examples/index.test.d.ts.map +0 -1
  443. package/dist/examples/index.test.js +0 -88
  444. package/dist/examples/index.test.js.map +0 -1
  445. package/dist/output/dedup.test.d.ts +0 -2
  446. package/dist/output/dedup.test.d.ts.map +0 -1
  447. package/dist/output/dedup.test.js +0 -357
  448. package/dist/output/dedup.test.js.map +0 -1
  449. package/dist/output/github-checks.test.d.ts +0 -2
  450. package/dist/output/github-checks.test.d.ts.map +0 -1
  451. package/dist/output/github-checks.test.js +0 -255
  452. package/dist/output/github-checks.test.js.map +0 -1
  453. package/dist/output/renderer.test.d.ts +0 -2
  454. package/dist/output/renderer.test.d.ts.map +0 -1
  455. package/dist/output/renderer.test.js +0 -645
  456. package/dist/output/renderer.test.js.map +0 -1
  457. package/dist/output/stale.test.d.ts +0 -2
  458. package/dist/output/stale.test.d.ts.map +0 -1
  459. package/dist/output/stale.test.js +0 -330
  460. package/dist/output/stale.test.js.map +0 -1
  461. package/dist/sdk/runner.test.d.ts +0 -2
  462. package/dist/sdk/runner.test.d.ts.map +0 -1
  463. package/dist/sdk/runner.test.js +0 -677
  464. package/dist/sdk/runner.test.js.map +0 -1
  465. package/dist/skills/loader.test.d.ts +0 -2
  466. package/dist/skills/loader.test.d.ts.map +0 -1
  467. package/dist/skills/loader.test.js +0 -241
  468. package/dist/skills/loader.test.js.map +0 -1
  469. package/dist/skills/remote.test.d.ts +0 -2
  470. package/dist/skills/remote.test.d.ts.map +0 -1
  471. package/dist/skills/remote.test.js +0 -582
  472. package/dist/skills/remote.test.js.map +0 -1
  473. package/dist/triggers/matcher.test.d.ts +0 -2
  474. package/dist/triggers/matcher.test.d.ts.map +0 -1
  475. package/dist/triggers/matcher.test.js +0 -234
  476. package/dist/triggers/matcher.test.js.map +0 -1
  477. package/dist/utils/index.test.d.ts +0 -2
  478. package/dist/utils/index.test.d.ts.map +0 -1
  479. package/dist/utils/index.test.js +0 -68
  480. package/dist/utils/index.test.js.map +0 -1
  481. package/docs/astro.config.mjs +0 -43
  482. package/docs/package.json +0 -19
  483. package/docs/pnpm-lock.yaml +0 -4000
  484. package/docs/public/favicon.svg +0 -5
  485. package/docs/src/components/Code.astro +0 -141
  486. package/docs/src/components/PackageManagerTabs.astro +0 -183
  487. package/docs/src/components/Terminal.astro +0 -212
  488. package/docs/src/layouts/Base.astro +0 -380
  489. package/docs/src/pages/cli.astro +0 -167
  490. package/docs/src/pages/config.astro +0 -395
  491. package/docs/src/pages/guide.astro +0 -450
  492. package/docs/src/pages/index.astro +0 -490
  493. package/docs/src/styles/global.css +0 -551
  494. package/docs/src/utils/version.ts +0 -6
  495. package/docs/tsconfig.json +0 -3
  496. package/docs/vercel.json +0 -5
  497. package/eslint.config.js +0 -33
  498. package/src/action/index.ts +0 -1
  499. package/src/action/main.ts +0 -868
  500. package/src/cli/args.test.ts +0 -477
  501. package/src/cli/args.ts +0 -414
  502. package/src/cli/commands/add.ts +0 -447
  503. package/src/cli/commands/init.test.ts +0 -137
  504. package/src/cli/commands/init.ts +0 -134
  505. package/src/cli/commands/setup-app/browser.ts +0 -38
  506. package/src/cli/commands/setup-app/credentials.ts +0 -45
  507. package/src/cli/commands/setup-app/manifest.ts +0 -48
  508. package/src/cli/commands/setup-app/server.ts +0 -172
  509. package/src/cli/commands/setup-app.ts +0 -156
  510. package/src/cli/commands/sync.ts +0 -114
  511. package/src/cli/context.ts +0 -131
  512. package/src/cli/files.test.ts +0 -155
  513. package/src/cli/files.ts +0 -89
  514. package/src/cli/fix.test.ts +0 -310
  515. package/src/cli/fix.ts +0 -387
  516. package/src/cli/git.test.ts +0 -119
  517. package/src/cli/git.ts +0 -318
  518. package/src/cli/index.ts +0 -14
  519. package/src/cli/main.ts +0 -672
  520. package/src/cli/output/box.ts +0 -235
  521. package/src/cli/output/formatters.test.ts +0 -187
  522. package/src/cli/output/formatters.ts +0 -269
  523. package/src/cli/output/icons.ts +0 -19
  524. package/src/cli/output/index.ts +0 -44
  525. package/src/cli/output/ink-runner.tsx +0 -366
  526. package/src/cli/output/jsonl.test.ts +0 -347
  527. package/src/cli/output/jsonl.ts +0 -126
  528. package/src/cli/output/reporter.ts +0 -434
  529. package/src/cli/output/tasks.ts +0 -374
  530. package/src/cli/output/tty.test.ts +0 -117
  531. package/src/cli/output/tty.ts +0 -60
  532. package/src/cli/output/verbosity.test.ts +0 -40
  533. package/src/cli/output/verbosity.ts +0 -31
  534. package/src/cli/terminal.test.ts +0 -148
  535. package/src/cli/terminal.ts +0 -301
  536. package/src/config/index.ts +0 -3
  537. package/src/config/loader.test.ts +0 -313
  538. package/src/config/loader.ts +0 -103
  539. package/src/config/schema.ts +0 -168
  540. package/src/config/writer.test.ts +0 -119
  541. package/src/config/writer.ts +0 -84
  542. package/src/diff/classify.test.ts +0 -162
  543. package/src/diff/classify.ts +0 -92
  544. package/src/diff/coalesce.test.ts +0 -208
  545. package/src/diff/coalesce.ts +0 -133
  546. package/src/diff/context.test.ts +0 -226
  547. package/src/diff/context.ts +0 -201
  548. package/src/diff/index.ts +0 -4
  549. package/src/diff/parser.test.ts +0 -212
  550. package/src/diff/parser.ts +0 -149
  551. package/src/event/context.ts +0 -132
  552. package/src/event/index.ts +0 -2
  553. package/src/event/schedule-context.ts +0 -101
  554. package/src/examples/examples.integration.test.ts +0 -66
  555. package/src/examples/index.test.ts +0 -101
  556. package/src/examples/index.ts +0 -122
  557. package/src/examples/setup.ts +0 -25
  558. package/src/index.ts +0 -115
  559. package/src/output/dedup.test.ts +0 -419
  560. package/src/output/dedup.ts +0 -607
  561. package/src/output/github-checks.test.ts +0 -300
  562. package/src/output/github-checks.ts +0 -476
  563. package/src/output/github-issues.ts +0 -329
  564. package/src/output/index.ts +0 -5
  565. package/src/output/issue-renderer.ts +0 -197
  566. package/src/output/renderer.test.ts +0 -727
  567. package/src/output/renderer.ts +0 -217
  568. package/src/output/stale.test.ts +0 -375
  569. package/src/output/stale.ts +0 -155
  570. package/src/output/types.ts +0 -34
  571. package/src/sdk/index.ts +0 -1
  572. package/src/sdk/runner.test.ts +0 -806
  573. package/src/sdk/runner.ts +0 -1232
  574. package/src/skills/index.ts +0 -36
  575. package/src/skills/loader.test.ts +0 -300
  576. package/src/skills/loader.ts +0 -423
  577. package/src/skills/remote.test.ts +0 -704
  578. package/src/skills/remote.ts +0 -604
  579. package/src/triggers/matcher.test.ts +0 -277
  580. package/src/triggers/matcher.ts +0 -152
  581. package/src/types/index.ts +0 -194
  582. package/src/utils/async.ts +0 -18
  583. package/src/utils/index.test.ts +0 -84
  584. package/src/utils/index.ts +0 -51
  585. package/src/utils/version.ts +0 -17
  586. package/tsconfig.json +0 -25
  587. package/vitest.config.ts +0 -8
  588. package/vitest.integration.config.ts +0 -11
  589. package/warden.toml +0 -19
@@ -1,32 +0,0 @@
1
- ---
2
- title: Combine Multiple Array Iterations
3
- impact: LOW-MEDIUM
4
- impactDescription: reduces iterations
5
- tags: javascript, arrays, loops, performance
6
- ---
7
-
8
- ## Combine Multiple Array Iterations
9
-
10
- Multiple `.filter()` or `.map()` calls iterate the array multiple times. Combine into one loop.
11
-
12
- **Incorrect (3 iterations):**
13
-
14
- ```typescript
15
- const admins = users.filter(u => u.isAdmin)
16
- const testers = users.filter(u => u.isTester)
17
- const inactive = users.filter(u => !u.isActive)
18
- ```
19
-
20
- **Correct (1 iteration):**
21
-
22
- ```typescript
23
- const admins: User[] = []
24
- const testers: User[] = []
25
- const inactive: User[] = []
26
-
27
- for (const user of users) {
28
- if (user.isAdmin) admins.push(user)
29
- if (user.isTester) testers.push(user)
30
- if (!user.isActive) inactive.push(user)
31
- }
32
- ```
@@ -1,50 +0,0 @@
1
- ---
2
- title: Early Return from Functions
3
- impact: LOW-MEDIUM
4
- impactDescription: avoids unnecessary computation
5
- tags: javascript, functions, optimization, early-return
6
- ---
7
-
8
- ## Early Return from Functions
9
-
10
- Return early when result is determined to skip unnecessary processing.
11
-
12
- **Incorrect (processes all items even after finding answer):**
13
-
14
- ```typescript
15
- function validateUsers(users: User[]) {
16
- let hasError = false
17
- let errorMessage = ''
18
-
19
- for (const user of users) {
20
- if (!user.email) {
21
- hasError = true
22
- errorMessage = 'Email required'
23
- }
24
- if (!user.name) {
25
- hasError = true
26
- errorMessage = 'Name required'
27
- }
28
- // Continues checking all users even after error found
29
- }
30
-
31
- return hasError ? { valid: false, error: errorMessage } : { valid: true }
32
- }
33
- ```
34
-
35
- **Correct (returns immediately on first error):**
36
-
37
- ```typescript
38
- function validateUsers(users: User[]) {
39
- for (const user of users) {
40
- if (!user.email) {
41
- return { valid: false, error: 'Email required' }
42
- }
43
- if (!user.name) {
44
- return { valid: false, error: 'Name required' }
45
- }
46
- }
47
-
48
- return { valid: true }
49
- }
50
- ```
@@ -1,45 +0,0 @@
1
- ---
2
- title: Hoist RegExp Creation
3
- impact: LOW-MEDIUM
4
- impactDescription: avoids recreation
5
- tags: javascript, regexp, optimization, memoization
6
- ---
7
-
8
- ## Hoist RegExp Creation
9
-
10
- Don't create RegExp inside render. Hoist to module scope or memoize with `useMemo()`.
11
-
12
- **Incorrect (new RegExp every render):**
13
-
14
- ```tsx
15
- function Highlighter({ text, query }: Props) {
16
- const regex = new RegExp(`(${query})`, 'gi')
17
- const parts = text.split(regex)
18
- return <>{parts.map((part, i) => ...)}</>
19
- }
20
- ```
21
-
22
- **Correct (memoize or hoist):**
23
-
24
- ```tsx
25
- const EMAIL_REGEX = /^[^\s@]+@[^\s@]+\.[^\s@]+$/
26
-
27
- function Highlighter({ text, query }: Props) {
28
- const regex = useMemo(
29
- () => new RegExp(`(${escapeRegex(query)})`, 'gi'),
30
- [query]
31
- )
32
- const parts = text.split(regex)
33
- return <>{parts.map((part, i) => ...)}</>
34
- }
35
- ```
36
-
37
- **Warning (global regex has mutable state):**
38
-
39
- Global regex (`/g`) has mutable `lastIndex` state:
40
-
41
- ```typescript
42
- const regex = /foo/g
43
- regex.test('foo') // true, lastIndex = 3
44
- regex.test('foo') // false, lastIndex = 0
45
- ```
@@ -1,37 +0,0 @@
1
- ---
2
- title: Build Index Maps for Repeated Lookups
3
- impact: LOW-MEDIUM
4
- impactDescription: 1M ops to 2K ops
5
- tags: javascript, map, indexing, optimization, performance
6
- ---
7
-
8
- ## Build Index Maps for Repeated Lookups
9
-
10
- Multiple `.find()` calls by the same key should use a Map.
11
-
12
- **Incorrect (O(n) per lookup):**
13
-
14
- ```typescript
15
- function processOrders(orders: Order[], users: User[]) {
16
- return orders.map(order => ({
17
- ...order,
18
- user: users.find(u => u.id === order.userId)
19
- }))
20
- }
21
- ```
22
-
23
- **Correct (O(1) per lookup):**
24
-
25
- ```typescript
26
- function processOrders(orders: Order[], users: User[]) {
27
- const userById = new Map(users.map(u => [u.id, u]))
28
-
29
- return orders.map(order => ({
30
- ...order,
31
- user: userById.get(order.userId)
32
- }))
33
- }
34
- ```
35
-
36
- Build map once (O(n)), then all lookups are O(1).
37
- For 1000 orders × 1000 users: 1M ops → 2K ops.
@@ -1,49 +0,0 @@
1
- ---
2
- title: Early Length Check for Array Comparisons
3
- impact: MEDIUM-HIGH
4
- impactDescription: avoids expensive operations when lengths differ
5
- tags: javascript, arrays, performance, optimization, comparison
6
- ---
7
-
8
- ## Early Length Check for Array Comparisons
9
-
10
- When comparing arrays with expensive operations (sorting, deep equality, serialization), check lengths first. If lengths differ, the arrays cannot be equal.
11
-
12
- In real-world applications, this optimization is especially valuable when the comparison runs in hot paths (event handlers, render loops).
13
-
14
- **Incorrect (always runs expensive comparison):**
15
-
16
- ```typescript
17
- function hasChanges(current: string[], original: string[]) {
18
- // Always sorts and joins, even when lengths differ
19
- return current.sort().join() !== original.sort().join()
20
- }
21
- ```
22
-
23
- Two O(n log n) sorts run even when `current.length` is 5 and `original.length` is 100. There is also overhead of joining the arrays and comparing the strings.
24
-
25
- **Correct (O(1) length check first):**
26
-
27
- ```typescript
28
- function hasChanges(current: string[], original: string[]) {
29
- // Early return if lengths differ
30
- if (current.length !== original.length) {
31
- return true
32
- }
33
- // Only sort when lengths match
34
- const currentSorted = current.toSorted()
35
- const originalSorted = original.toSorted()
36
- for (let i = 0; i < currentSorted.length; i++) {
37
- if (currentSorted[i] !== originalSorted[i]) {
38
- return true
39
- }
40
- }
41
- return false
42
- }
43
- ```
44
-
45
- This new approach is more efficient because:
46
- - It avoids the overhead of sorting and joining the arrays when lengths differ
47
- - It avoids consuming memory for the joined strings (especially important for large arrays)
48
- - It avoids mutating the original arrays
49
- - It returns early when a difference is found
@@ -1,82 +0,0 @@
1
- ---
2
- title: Use Loop for Min/Max Instead of Sort
3
- impact: LOW
4
- impactDescription: O(n) instead of O(n log n)
5
- tags: javascript, arrays, performance, sorting, algorithms
6
- ---
7
-
8
- ## Use Loop for Min/Max Instead of Sort
9
-
10
- Finding the smallest or largest element only requires a single pass through the array. Sorting is wasteful and slower.
11
-
12
- **Incorrect (O(n log n) - sort to find latest):**
13
-
14
- ```typescript
15
- interface Project {
16
- id: string
17
- name: string
18
- updatedAt: number
19
- }
20
-
21
- function getLatestProject(projects: Project[]) {
22
- const sorted = [...projects].sort((a, b) => b.updatedAt - a.updatedAt)
23
- return sorted[0]
24
- }
25
- ```
26
-
27
- Sorts the entire array just to find the maximum value.
28
-
29
- **Incorrect (O(n log n) - sort for oldest and newest):**
30
-
31
- ```typescript
32
- function getOldestAndNewest(projects: Project[]) {
33
- const sorted = [...projects].sort((a, b) => a.updatedAt - b.updatedAt)
34
- return { oldest: sorted[0], newest: sorted[sorted.length - 1] }
35
- }
36
- ```
37
-
38
- Still sorts unnecessarily when only min/max are needed.
39
-
40
- **Correct (O(n) - single loop):**
41
-
42
- ```typescript
43
- function getLatestProject(projects: Project[]) {
44
- if (projects.length === 0) return null
45
-
46
- let latest = projects[0]
47
-
48
- for (let i = 1; i < projects.length; i++) {
49
- if (projects[i].updatedAt > latest.updatedAt) {
50
- latest = projects[i]
51
- }
52
- }
53
-
54
- return latest
55
- }
56
-
57
- function getOldestAndNewest(projects: Project[]) {
58
- if (projects.length === 0) return { oldest: null, newest: null }
59
-
60
- let oldest = projects[0]
61
- let newest = projects[0]
62
-
63
- for (let i = 1; i < projects.length; i++) {
64
- if (projects[i].updatedAt < oldest.updatedAt) oldest = projects[i]
65
- if (projects[i].updatedAt > newest.updatedAt) newest = projects[i]
66
- }
67
-
68
- return { oldest, newest }
69
- }
70
- ```
71
-
72
- Single pass through the array, no copying, no sorting.
73
-
74
- **Alternative (Math.min/Math.max for small arrays):**
75
-
76
- ```typescript
77
- const numbers = [5, 2, 8, 1, 9]
78
- const min = Math.min(...numbers)
79
- const max = Math.max(...numbers)
80
- ```
81
-
82
- This works for small arrays, but can be slower or just throw an error for very large arrays due to spread operator limitations. Maximal array length is approximately 124000 in Chrome 143 and 638000 in Safari 18; exact numbers may vary - see [the fiddle](https://jsfiddle.net/qw1jabsx/4/). Use the loop approach for reliability.
@@ -1,24 +0,0 @@
1
- ---
2
- title: Use Set/Map for O(1) Lookups
3
- impact: LOW-MEDIUM
4
- impactDescription: O(n) to O(1)
5
- tags: javascript, set, map, data-structures, performance
6
- ---
7
-
8
- ## Use Set/Map for O(1) Lookups
9
-
10
- Convert arrays to Set/Map for repeated membership checks.
11
-
12
- **Incorrect (O(n) per check):**
13
-
14
- ```typescript
15
- const allowedIds = ['a', 'b', 'c', ...]
16
- items.filter(item => allowedIds.includes(item.id))
17
- ```
18
-
19
- **Correct (O(1) per check):**
20
-
21
- ```typescript
22
- const allowedIds = new Set(['a', 'b', 'c', ...])
23
- items.filter(item => allowedIds.has(item.id))
24
- ```
@@ -1,57 +0,0 @@
1
- ---
2
- title: Use toSorted() Instead of sort() for Immutability
3
- impact: MEDIUM-HIGH
4
- impactDescription: prevents mutation bugs in React state
5
- tags: javascript, arrays, immutability, react, state, mutation
6
- ---
7
-
8
- ## Use toSorted() Instead of sort() for Immutability
9
-
10
- `.sort()` mutates the array in place, which can cause bugs with React state and props. Use `.toSorted()` to create a new sorted array without mutation.
11
-
12
- **Incorrect (mutates original array):**
13
-
14
- ```typescript
15
- function UserList({ users }: { users: User[] }) {
16
- // Mutates the users prop array!
17
- const sorted = useMemo(
18
- () => users.sort((a, b) => a.name.localeCompare(b.name)),
19
- [users]
20
- )
21
- return <div>{sorted.map(renderUser)}</div>
22
- }
23
- ```
24
-
25
- **Correct (creates new array):**
26
-
27
- ```typescript
28
- function UserList({ users }: { users: User[] }) {
29
- // Creates new sorted array, original unchanged
30
- const sorted = useMemo(
31
- () => users.toSorted((a, b) => a.name.localeCompare(b.name)),
32
- [users]
33
- )
34
- return <div>{sorted.map(renderUser)}</div>
35
- }
36
- ```
37
-
38
- **Why this matters in React:**
39
-
40
- 1. Props/state mutations break React's immutability model - React expects props and state to be treated as read-only
41
- 2. Causes stale closure bugs - Mutating arrays inside closures (callbacks, effects) can lead to unexpected behavior
42
-
43
- **Browser support (fallback for older browsers):**
44
-
45
- `.toSorted()` is available in all modern browsers (Chrome 110+, Safari 16+, Firefox 115+, Node.js 20+). For older environments, use spread operator:
46
-
47
- ```typescript
48
- // Fallback for older browsers
49
- const sorted = [...items].sort((a, b) => a.value - b.value)
50
- ```
51
-
52
- **Other immutable array methods:**
53
-
54
- - `.toSorted()` - immutable sort
55
- - `.toReversed()` - immutable reverse
56
- - `.toSpliced()` - immutable splice
57
- - `.with()` - immutable element replacement
@@ -1,26 +0,0 @@
1
- ---
2
- title: Use Activity Component for Show/Hide
3
- impact: MEDIUM
4
- impactDescription: preserves state/DOM
5
- tags: rendering, activity, visibility, state-preservation
6
- ---
7
-
8
- ## Use Activity Component for Show/Hide
9
-
10
- Use React's `<Activity>` to preserve state/DOM for expensive components that frequently toggle visibility.
11
-
12
- **Usage:**
13
-
14
- ```tsx
15
- import { Activity } from 'react'
16
-
17
- function Dropdown({ isOpen }: Props) {
18
- return (
19
- <Activity mode={isOpen ? 'visible' : 'hidden'}>
20
- <ExpensiveMenu />
21
- </Activity>
22
- )
23
- }
24
- ```
25
-
26
- Avoids expensive re-renders and state loss.
@@ -1,47 +0,0 @@
1
- ---
2
- title: Animate SVG Wrapper Instead of SVG Element
3
- impact: LOW
4
- impactDescription: enables hardware acceleration
5
- tags: rendering, svg, css, animation, performance
6
- ---
7
-
8
- ## Animate SVG Wrapper Instead of SVG Element
9
-
10
- Many browsers don't have hardware acceleration for CSS3 animations on SVG elements. Wrap SVG in a `<div>` and animate the wrapper instead.
11
-
12
- **Incorrect (animating SVG directly - no hardware acceleration):**
13
-
14
- ```tsx
15
- function LoadingSpinner() {
16
- return (
17
- <svg
18
- className="animate-spin"
19
- width="24"
20
- height="24"
21
- viewBox="0 0 24 24"
22
- >
23
- <circle cx="12" cy="12" r="10" stroke="currentColor" />
24
- </svg>
25
- )
26
- }
27
- ```
28
-
29
- **Correct (animating wrapper div - hardware accelerated):**
30
-
31
- ```tsx
32
- function LoadingSpinner() {
33
- return (
34
- <div className="animate-spin">
35
- <svg
36
- width="24"
37
- height="24"
38
- viewBox="0 0 24 24"
39
- >
40
- <circle cx="12" cy="12" r="10" stroke="currentColor" />
41
- </svg>
42
- </div>
43
- )
44
- }
45
- ```
46
-
47
- This applies to all CSS transforms and transitions (`transform`, `opacity`, `translate`, `scale`, `rotate`). The wrapper div allows browsers to use GPU acceleration for smoother animations.
@@ -1,40 +0,0 @@
1
- ---
2
- title: Use Explicit Conditional Rendering
3
- impact: LOW
4
- impactDescription: prevents rendering 0 or NaN
5
- tags: rendering, conditional, jsx, falsy-values
6
- ---
7
-
8
- ## Use Explicit Conditional Rendering
9
-
10
- Use explicit ternary operators (`? :`) instead of `&&` for conditional rendering when the condition can be `0`, `NaN`, or other falsy values that render.
11
-
12
- **Incorrect (renders "0" when count is 0):**
13
-
14
- ```tsx
15
- function Badge({ count }: { count: number }) {
16
- return (
17
- <div>
18
- {count && <span className="badge">{count}</span>}
19
- </div>
20
- )
21
- }
22
-
23
- // When count = 0, renders: <div>0</div>
24
- // When count = 5, renders: <div><span class="badge">5</span></div>
25
- ```
26
-
27
- **Correct (renders nothing when count is 0):**
28
-
29
- ```tsx
30
- function Badge({ count }: { count: number }) {
31
- return (
32
- <div>
33
- {count > 0 ? <span className="badge">{count}</span> : null}
34
- </div>
35
- )
36
- }
37
-
38
- // When count = 0, renders: <div></div>
39
- // When count = 5, renders: <div><span class="badge">5</span></div>
40
- ```
@@ -1,38 +0,0 @@
1
- ---
2
- title: CSS content-visibility for Long Lists
3
- impact: HIGH
4
- impactDescription: faster initial render
5
- tags: rendering, css, content-visibility, long-lists
6
- ---
7
-
8
- ## CSS content-visibility for Long Lists
9
-
10
- Apply `content-visibility: auto` to defer off-screen rendering.
11
-
12
- **CSS:**
13
-
14
- ```css
15
- .message-item {
16
- content-visibility: auto;
17
- contain-intrinsic-size: 0 80px;
18
- }
19
- ```
20
-
21
- **Example:**
22
-
23
- ```tsx
24
- function MessageList({ messages }: { messages: Message[] }) {
25
- return (
26
- <div className="overflow-y-auto h-screen">
27
- {messages.map(msg => (
28
- <div key={msg.id} className="message-item">
29
- <Avatar user={msg.author} />
30
- <div>{msg.content}</div>
31
- </div>
32
- ))}
33
- </div>
34
- )
35
- }
36
- ```
37
-
38
- For 1000 messages, browser skips layout/paint for ~990 off-screen items (10× faster initial render).
@@ -1,46 +0,0 @@
1
- ---
2
- title: Hoist Static JSX Elements
3
- impact: LOW
4
- impactDescription: avoids re-creation
5
- tags: rendering, jsx, static, optimization
6
- ---
7
-
8
- ## Hoist Static JSX Elements
9
-
10
- Extract static JSX outside components to avoid re-creation.
11
-
12
- **Incorrect (recreates element every render):**
13
-
14
- ```tsx
15
- function LoadingSkeleton() {
16
- return <div className="animate-pulse h-20 bg-gray-200" />
17
- }
18
-
19
- function Container() {
20
- return (
21
- <div>
22
- {loading && <LoadingSkeleton />}
23
- </div>
24
- )
25
- }
26
- ```
27
-
28
- **Correct (reuses same element):**
29
-
30
- ```tsx
31
- const loadingSkeleton = (
32
- <div className="animate-pulse h-20 bg-gray-200" />
33
- )
34
-
35
- function Container() {
36
- return (
37
- <div>
38
- {loading && loadingSkeleton}
39
- </div>
40
- )
41
- }
42
- ```
43
-
44
- This is especially helpful for large and static SVG nodes, which can be expensive to recreate on every render.
45
-
46
- **Note:** If your project has [React Compiler](https://react.dev/learn/react-compiler) enabled, the compiler automatically hoists static JSX elements and optimizes component re-renders, making manual hoisting unnecessary.
@@ -1,82 +0,0 @@
1
- ---
2
- title: Prevent Hydration Mismatch Without Flickering
3
- impact: MEDIUM
4
- impactDescription: avoids visual flicker and hydration errors
5
- tags: rendering, ssr, hydration, localStorage, flicker
6
- ---
7
-
8
- ## Prevent Hydration Mismatch Without Flickering
9
-
10
- When rendering content that depends on client-side storage (localStorage, cookies), avoid both SSR breakage and post-hydration flickering by injecting a synchronous script that updates the DOM before React hydrates.
11
-
12
- **Incorrect (breaks SSR):**
13
-
14
- ```tsx
15
- function ThemeWrapper({ children }: { children: ReactNode }) {
16
- // localStorage is not available on server - throws error
17
- const theme = localStorage.getItem('theme') || 'light'
18
-
19
- return (
20
- <div className={theme}>
21
- {children}
22
- </div>
23
- )
24
- }
25
- ```
26
-
27
- Server-side rendering will fail because `localStorage` is undefined.
28
-
29
- **Incorrect (visual flickering):**
30
-
31
- ```tsx
32
- function ThemeWrapper({ children }: { children: ReactNode }) {
33
- const [theme, setTheme] = useState('light')
34
-
35
- useEffect(() => {
36
- // Runs after hydration - causes visible flash
37
- const stored = localStorage.getItem('theme')
38
- if (stored) {
39
- setTheme(stored)
40
- }
41
- }, [])
42
-
43
- return (
44
- <div className={theme}>
45
- {children}
46
- </div>
47
- )
48
- }
49
- ```
50
-
51
- Component first renders with default value (`light`), then updates after hydration, causing a visible flash of incorrect content.
52
-
53
- **Correct (no flicker, no hydration mismatch):**
54
-
55
- ```tsx
56
- function ThemeWrapper({ children }: { children: ReactNode }) {
57
- return (
58
- <>
59
- <div id="theme-wrapper">
60
- {children}
61
- </div>
62
- <script
63
- dangerouslySetInnerHTML={{
64
- __html: `
65
- (function() {
66
- try {
67
- var theme = localStorage.getItem('theme') || 'light';
68
- var el = document.getElementById('theme-wrapper');
69
- if (el) el.className = theme;
70
- } catch (e) {}
71
- })();
72
- `,
73
- }}
74
- />
75
- </>
76
- )
77
- }
78
- ```
79
-
80
- The inline script executes synchronously before showing the element, ensuring the DOM already has the correct value. No flickering, no hydration mismatch.
81
-
82
- This pattern is especially useful for theme toggles, user preferences, authentication states, and any client-only data that should render immediately without flashing default values.
@@ -1,30 +0,0 @@
1
- ---
2
- title: Suppress Expected Hydration Mismatches
3
- impact: LOW-MEDIUM
4
- impactDescription: avoids noisy hydration warnings for known differences
5
- tags: rendering, hydration, ssr, nextjs
6
- ---
7
-
8
- ## Suppress Expected Hydration Mismatches
9
-
10
- In SSR frameworks (e.g., Next.js), some values are intentionally different on server vs client (random IDs, dates, locale/timezone formatting). For these *expected* mismatches, wrap the dynamic text in an element with `suppressHydrationWarning` to prevent noisy warnings. Do not use this to hide real bugs. Don’t overuse it.
11
-
12
- **Incorrect (known mismatch warnings):**
13
-
14
- ```tsx
15
- function Timestamp() {
16
- return <span>{new Date().toLocaleString()}</span>
17
- }
18
- ```
19
-
20
- **Correct (suppress expected mismatch only):**
21
-
22
- ```tsx
23
- function Timestamp() {
24
- return (
25
- <span suppressHydrationWarning>
26
- {new Date().toLocaleString()}
27
- </span>
28
- )
29
- }
30
- ```