@codyswann/lisa 1.47.1 → 1.49.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 (904) hide show
  1. package/.claude-plugin/marketplace.json +48 -0
  2. package/all/deletions.json +71 -1
  3. package/all/merge/.claude/settings.json +28 -0
  4. package/cdk/copy-overwrite/eslint.config.ts +11 -21
  5. package/cdk/copy-overwrite/eslint.slow.config.ts +4 -73
  6. package/cdk/copy-overwrite/jest.config.ts +14 -12
  7. package/cdk/copy-overwrite/tsconfig.json +1 -1
  8. package/cdk/create-only/.github/workflows/ci.yml +1 -1
  9. package/cdk/create-only/.github/workflows/deploy.yml +1 -1
  10. package/cdk/merge/.claude/settings.json +29 -0
  11. package/cdk/package-lisa/package.lisa.json +1 -0
  12. package/dist/configs/eslint/base.d.ts +1491 -0
  13. package/dist/configs/eslint/base.d.ts.map +1 -0
  14. package/dist/configs/eslint/base.js +386 -0
  15. package/dist/configs/eslint/base.js.map +1 -0
  16. package/dist/configs/eslint/cdk.d.ts +32 -0
  17. package/dist/configs/eslint/cdk.d.ts.map +1 -0
  18. package/dist/configs/eslint/cdk.js +127 -0
  19. package/dist/configs/eslint/cdk.js.map +1 -0
  20. package/dist/configs/eslint/expo.d.ts +16 -0
  21. package/dist/configs/eslint/expo.d.ts.map +1 -0
  22. package/dist/configs/eslint/expo.js +264 -0
  23. package/dist/configs/eslint/expo.js.map +1 -0
  24. package/dist/configs/eslint/index.d.ts +18 -0
  25. package/dist/configs/eslint/index.d.ts.map +1 -0
  26. package/dist/configs/eslint/index.js +18 -0
  27. package/dist/configs/eslint/index.js.map +1 -0
  28. package/dist/configs/eslint/nestjs.d.ts +32 -0
  29. package/dist/configs/eslint/nestjs.d.ts.map +1 -0
  30. package/dist/configs/eslint/nestjs.js +128 -0
  31. package/dist/configs/eslint/nestjs.js.map +1 -0
  32. package/dist/configs/eslint/slow.d.ts +80 -0
  33. package/dist/configs/eslint/slow.d.ts.map +1 -0
  34. package/dist/configs/eslint/slow.js +83 -0
  35. package/dist/configs/eslint/slow.js.map +1 -0
  36. package/dist/configs/eslint/typescript.d.ts +19 -0
  37. package/dist/configs/eslint/typescript.d.ts.map +1 -0
  38. package/dist/configs/eslint/typescript.js +81 -0
  39. package/dist/configs/eslint/typescript.js.map +1 -0
  40. package/{typescript/copy-overwrite/jest.base.ts → dist/configs/jest/base.d.ts} +9 -69
  41. package/dist/configs/jest/base.d.ts.map +1 -0
  42. package/dist/configs/jest/base.js +83 -0
  43. package/dist/configs/jest/base.js.map +1 -0
  44. package/dist/configs/jest/cdk.d.ts +35 -0
  45. package/dist/configs/jest/cdk.d.ts.map +1 -0
  46. package/dist/configs/jest/cdk.js +30 -0
  47. package/dist/configs/jest/cdk.js.map +1 -0
  48. package/dist/configs/jest/expo.d.ts +56 -0
  49. package/dist/configs/jest/expo.d.ts.map +1 -0
  50. package/dist/configs/jest/expo.js +60 -0
  51. package/dist/configs/jest/expo.js.map +1 -0
  52. package/dist/configs/jest/index.d.ts +14 -0
  53. package/dist/configs/jest/index.d.ts.map +1 -0
  54. package/dist/configs/jest/index.js +14 -0
  55. package/dist/configs/jest/index.js.map +1 -0
  56. package/dist/configs/jest/nestjs.d.ts +35 -0
  57. package/dist/configs/jest/nestjs.d.ts.map +1 -0
  58. package/dist/configs/jest/nestjs.js +47 -0
  59. package/dist/configs/jest/nestjs.js.map +1 -0
  60. package/dist/configs/jest/typescript.d.ts +31 -0
  61. package/dist/configs/jest/typescript.d.ts.map +1 -0
  62. package/dist/configs/jest/typescript.js +34 -0
  63. package/dist/configs/jest/typescript.js.map +1 -0
  64. package/dist/core/lisa.d.ts +14 -0
  65. package/dist/core/lisa.d.ts.map +1 -1
  66. package/dist/core/lisa.js +47 -0
  67. package/dist/core/lisa.js.map +1 -1
  68. package/expo/copy-overwrite/eslint.config.ts +5 -20
  69. package/expo/copy-overwrite/eslint.expo.ts +2 -2
  70. package/expo/copy-overwrite/eslint.slow.config.ts +4 -90
  71. package/expo/copy-overwrite/jest.config.ts +14 -12
  72. package/expo/copy-overwrite/tsconfig.json +1 -1
  73. package/expo/create-only/.github/workflows/ci.yml +1 -1
  74. package/expo/create-only/.github/workflows/deploy.yml +1 -1
  75. package/expo/deletions.json +33 -0
  76. package/expo/merge/.claude/settings.json +29 -0
  77. package/expo/package-lisa/package.lisa.json +1 -10
  78. package/nestjs/copy-overwrite/eslint.config.ts +5 -20
  79. package/nestjs/copy-overwrite/eslint.slow.config.ts +4 -89
  80. package/nestjs/copy-overwrite/jest.config.ts +14 -12
  81. package/nestjs/copy-overwrite/tsconfig.json +1 -1
  82. package/nestjs/create-only/.github/workflows/ci.yml +1 -1
  83. package/nestjs/create-only/.github/workflows/deploy.yml +1 -1
  84. package/nestjs/deletions.json +8 -0
  85. package/nestjs/merge/.claude/settings.json +29 -0
  86. package/nestjs/package-lisa/package.lisa.json +1 -0
  87. package/package.json +86 -43
  88. package/plugins/lisa-cdk/.claude-plugin/plugin.json +86 -0
  89. package/{all/copy-overwrite/.claude/commands/git/commit-and-submit-pr.md → plugins/lisa-cdk/commands/git-commit-and-submit-pr.md} +1 -1
  90. package/{all/copy-overwrite/.claude/commands/git/commit-submit-pr-and-verify.md → plugins/lisa-cdk/commands/git-commit-submit-pr-and-verify.md} +1 -1
  91. package/{all/copy-overwrite/.claude/commands/git/commit-submit-pr-deploy-and-verify.md → plugins/lisa-cdk/commands/git-commit-submit-pr-deploy-and-verify.md} +1 -1
  92. package/{all/copy-overwrite/.claude/commands/git/commit.md → plugins/lisa-cdk/commands/git-commit.md} +1 -1
  93. package/{all/copy-overwrite/.claude/commands/git/prune.md → plugins/lisa-cdk/commands/git-prune.md} +1 -1
  94. package/{all/copy-overwrite/.claude/commands/git/submit-pr.md → plugins/lisa-cdk/commands/git-submit-pr.md} +1 -1
  95. package/plugins/lisa-cdk/commands/jira-add-journey.md +7 -0
  96. package/{all/copy-overwrite/.claude/commands/jira/create.md → plugins/lisa-cdk/commands/jira-create.md} +1 -1
  97. package/plugins/lisa-cdk/commands/jira-evidence.md +7 -0
  98. package/plugins/lisa-cdk/commands/jira-fix.md +7 -0
  99. package/plugins/lisa-cdk/commands/jira-implement.md +7 -0
  100. package/plugins/lisa-cdk/commands/jira-journey.md +7 -0
  101. package/{all/copy-overwrite/.claude/commands/jira/sync.md → plugins/lisa-cdk/commands/jira-sync.md} +1 -1
  102. package/{all/copy-overwrite/.claude/commands/jira/verify.md → plugins/lisa-cdk/commands/jira-verify.md} +1 -1
  103. package/{all/copy-overwrite/.claude/commands/lisa/review-implementation.md → plugins/lisa-cdk/commands/lisa-review-implementation.md} +1 -1
  104. package/{all/copy-overwrite/.claude/commands/plan/add-test-coverage.md → plugins/lisa-cdk/commands/plan-add-test-coverage.md} +1 -1
  105. package/{all/copy-overwrite/.claude/commands/plan/create.md → plugins/lisa-cdk/commands/plan-create.md} +1 -1
  106. package/{all/copy-overwrite/.claude/commands/plan/execute.md → plugins/lisa-cdk/commands/plan-execute.md} +1 -1
  107. package/{all/copy-overwrite/.claude/commands/plan/fix-linter-error.md → plugins/lisa-cdk/commands/plan-fix-linter-error.md} +1 -1
  108. package/{all/copy-overwrite/.claude/commands/plan/local-code-review.md → plugins/lisa-cdk/commands/plan-local-code-review.md} +1 -1
  109. package/{all/copy-overwrite/.claude/commands/plan/lower-code-complexity.md → plugins/lisa-cdk/commands/plan-lower-code-complexity.md} +1 -1
  110. package/{all/copy-overwrite/.claude/commands/plan/reduce-max-lines-per-function.md → plugins/lisa-cdk/commands/plan-reduce-max-lines-per-function.md} +1 -1
  111. package/{all/copy-overwrite/.claude/commands/plan/reduce-max-lines.md → plugins/lisa-cdk/commands/plan-reduce-max-lines.md} +1 -1
  112. package/{all/copy-overwrite/.claude/commands/pull-request/review.md → plugins/lisa-cdk/commands/pull-request-review.md} +1 -1
  113. package/{all/copy-overwrite/.claude/commands/security/zap-scan.md → plugins/lisa-cdk/commands/security-zap-scan.md} +1 -1
  114. package/{all/copy-overwrite/.claude/commands/sonarqube/check.md → plugins/lisa-cdk/commands/sonarqube-check.md} +1 -1
  115. package/{all/copy-overwrite/.claude/commands/sonarqube/fix.md → plugins/lisa-cdk/commands/sonarqube-fix.md} +1 -1
  116. package/{all/copy-overwrite/.claude/commands/tasks/load.md → plugins/lisa-cdk/commands/tasks-load.md} +1 -1
  117. package/{all/copy-overwrite/.claude/commands/tasks/sync.md → plugins/lisa-cdk/commands/tasks-sync.md} +1 -1
  118. package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/install-pkgs.sh +3 -3
  119. package/plugins/lisa-cdk/rules/lisa.md +37 -0
  120. package/plugins/lisa-cdk/skills/jira-add-journey/SKILL.md +120 -0
  121. package/plugins/lisa-cdk/skills/jira-create/SKILL.md +95 -0
  122. package/plugins/lisa-cdk/skills/jira-evidence/SKILL.md +73 -0
  123. package/plugins/lisa-cdk/skills/jira-evidence/scripts/post-evidence.sh +163 -0
  124. package/plugins/lisa-cdk/skills/jira-fix/SKILL.md +16 -0
  125. package/plugins/lisa-cdk/skills/jira-implement/SKILL.md +18 -0
  126. package/plugins/lisa-cdk/skills/jira-journey/SKILL.md +125 -0
  127. package/plugins/lisa-cdk/skills/jira-journey/scripts/generate-templates.py +233 -0
  128. package/plugins/lisa-cdk/skills/jira-journey/scripts/parse-plan.py +368 -0
  129. package/plugins/lisa-cdk/skills/jira-verify/SKILL.md +48 -0
  130. package/plugins/lisa-expo/.claude-plugin/plugin.json +86 -0
  131. package/plugins/lisa-expo/agents/agent-architect.md +310 -0
  132. package/plugins/lisa-expo/agents/architecture-specialist.md +53 -0
  133. package/plugins/lisa-expo/agents/debug-specialist.md +204 -0
  134. package/plugins/lisa-expo/agents/git-history-analyzer.md +183 -0
  135. package/plugins/lisa-expo/agents/hooks-expert.md +74 -0
  136. package/plugins/lisa-expo/agents/implementer.md +54 -0
  137. package/plugins/lisa-expo/agents/learner.md +44 -0
  138. package/plugins/lisa-expo/agents/performance-specialist.md +95 -0
  139. package/plugins/lisa-expo/agents/product-specialist.md +72 -0
  140. package/plugins/lisa-expo/agents/quality-specialist.md +55 -0
  141. package/plugins/lisa-expo/agents/security-specialist.md +58 -0
  142. package/plugins/lisa-expo/agents/skill-evaluator.md +246 -0
  143. package/plugins/lisa-expo/agents/slash-command-architect.md +87 -0
  144. package/plugins/lisa-expo/agents/test-specialist.md +64 -0
  145. package/plugins/lisa-expo/agents/verification-specialist.md +189 -0
  146. package/plugins/lisa-expo/agents/web-search-researcher.md +112 -0
  147. package/plugins/lisa-expo/commands/git-commit-and-submit-pr.md +7 -0
  148. package/plugins/lisa-expo/commands/git-commit-submit-pr-and-verify.md +7 -0
  149. package/plugins/lisa-expo/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
  150. package/plugins/lisa-expo/commands/git-commit.md +7 -0
  151. package/plugins/lisa-expo/commands/git-prune.md +6 -0
  152. package/plugins/lisa-expo/commands/git-submit-pr.md +7 -0
  153. package/plugins/lisa-expo/commands/jira-add-journey.md +7 -0
  154. package/plugins/lisa-expo/commands/jira-create.md +7 -0
  155. package/plugins/lisa-expo/commands/jira-evidence.md +7 -0
  156. package/plugins/lisa-expo/commands/jira-fix.md +7 -0
  157. package/plugins/lisa-expo/commands/jira-implement.md +7 -0
  158. package/plugins/lisa-expo/commands/jira-journey.md +7 -0
  159. package/plugins/lisa-expo/commands/jira-sync.md +7 -0
  160. package/plugins/lisa-expo/commands/jira-verify.md +7 -0
  161. package/plugins/lisa-expo/commands/lisa-review-implementation.md +7 -0
  162. package/plugins/lisa-expo/commands/plan-add-test-coverage.md +7 -0
  163. package/plugins/lisa-expo/commands/plan-create.md +6 -0
  164. package/plugins/lisa-expo/commands/plan-execute.md +7 -0
  165. package/plugins/lisa-expo/commands/plan-fix-linter-error.md +7 -0
  166. package/plugins/lisa-expo/commands/plan-local-code-review.md +6 -0
  167. package/plugins/lisa-expo/commands/plan-lower-code-complexity.md +6 -0
  168. package/plugins/lisa-expo/commands/plan-reduce-max-lines-per-function.md +7 -0
  169. package/plugins/lisa-expo/commands/plan-reduce-max-lines.md +7 -0
  170. package/plugins/lisa-expo/commands/pull-request-review.md +7 -0
  171. package/plugins/lisa-expo/commands/security-zap-scan.md +6 -0
  172. package/plugins/lisa-expo/commands/sonarqube-check.md +6 -0
  173. package/plugins/lisa-expo/commands/sonarqube-fix.md +6 -0
  174. package/plugins/lisa-expo/commands/tasks-load.md +7 -0
  175. package/plugins/lisa-expo/commands/tasks-sync.md +7 -0
  176. package/plugins/lisa-expo/hooks/debug-hook.sh +47 -0
  177. package/plugins/lisa-expo/hooks/enforce-plan-rules.sh +15 -0
  178. package/plugins/lisa-expo/hooks/format-on-edit.sh +76 -0
  179. package/plugins/lisa-expo/hooks/install-pkgs.sh +64 -0
  180. package/plugins/lisa-expo/hooks/lint-on-edit.sh +81 -0
  181. package/plugins/lisa-expo/hooks/notify-ntfy.sh +183 -0
  182. package/plugins/lisa-expo/hooks/setup-jira-cli.sh +52 -0
  183. package/plugins/lisa-expo/hooks/sg-scan-on-edit.sh +68 -0
  184. package/plugins/lisa-expo/hooks/sync-tasks.sh +107 -0
  185. package/plugins/lisa-expo/hooks/ticket-sync-reminder.sh +23 -0
  186. package/plugins/lisa-expo/hooks/track-plan-sessions.sh +164 -0
  187. package/plugins/lisa-expo/hooks/verify-completion.sh +77 -0
  188. package/plugins/lisa-expo/rules/README.md +240 -0
  189. package/plugins/lisa-expo/rules/coding-philosophy.md +428 -0
  190. package/plugins/lisa-expo/rules/lisa.md +37 -0
  191. package/plugins/lisa-expo/rules/verfication.md +596 -0
  192. package/plugins/lisa-expo/skills/agent-design-best-practices/SKILL.md +219 -0
  193. package/plugins/lisa-expo/skills/git-commit/SKILL.md +48 -0
  194. package/plugins/lisa-expo/skills/git-commit-and-submit-pr/SKILL.md +8 -0
  195. package/plugins/lisa-expo/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
  196. package/plugins/lisa-expo/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
  197. package/plugins/lisa-expo/skills/git-prune/SKILL.md +35 -0
  198. package/plugins/lisa-expo/skills/git-submit-pr/SKILL.md +44 -0
  199. package/plugins/lisa-expo/skills/jira-add-journey/SKILL.md +126 -0
  200. package/plugins/lisa-expo/skills/jira-create/SKILL.md +101 -0
  201. package/plugins/lisa-expo/skills/jira-evidence/SKILL.md +78 -0
  202. package/plugins/lisa-expo/skills/jira-evidence/scripts/post-evidence.sh +163 -0
  203. package/plugins/lisa-expo/skills/jira-fix/SKILL.md +16 -0
  204. package/plugins/lisa-expo/skills/jira-implement/SKILL.md +18 -0
  205. package/plugins/lisa-expo/skills/jira-journey/SKILL.md +190 -0
  206. package/plugins/lisa-expo/skills/jira-journey/scripts/generate-templates.py +281 -0
  207. package/plugins/lisa-expo/skills/jira-journey/scripts/parse-plan.py +368 -0
  208. package/plugins/lisa-expo/skills/jira-sync/SKILL.md +63 -0
  209. package/plugins/lisa-expo/skills/jira-verify/SKILL.md +47 -0
  210. package/plugins/lisa-expo/skills/jsdoc-best-practices/SKILL.md +432 -0
  211. package/plugins/lisa-expo/skills/lisa-review-implementation/SKILL.md +209 -0
  212. package/plugins/lisa-expo/skills/plan-add-test-coverage/SKILL.md +44 -0
  213. package/plugins/lisa-expo/skills/plan-execute/SKILL.md +89 -0
  214. package/plugins/lisa-expo/skills/plan-fix-linter-error/SKILL.md +45 -0
  215. package/plugins/lisa-expo/skills/plan-local-code-review/SKILL.md +88 -0
  216. package/plugins/lisa-expo/skills/plan-lower-code-complexity/SKILL.md +44 -0
  217. package/plugins/lisa-expo/skills/plan-reduce-max-lines/SKILL.md +45 -0
  218. package/plugins/lisa-expo/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
  219. package/plugins/lisa-expo/skills/pull-request-review/SKILL.md +68 -0
  220. package/plugins/lisa-expo/skills/skill-creator/LICENSE.txt +202 -0
  221. package/plugins/lisa-expo/skills/skill-creator/SKILL.md +210 -0
  222. package/plugins/lisa-expo/skills/skill-creator/scripts/init_skill.py +305 -0
  223. package/plugins/lisa-expo/skills/skill-creator/scripts/package_skill.py +112 -0
  224. package/plugins/lisa-expo/skills/skill-creator/scripts/quick_validate.py +67 -0
  225. package/plugins/lisa-expo/skills/sonarqube-check/SKILL.md +11 -0
  226. package/plugins/lisa-expo/skills/sonarqube-fix/SKILL.md +8 -0
  227. package/plugins/lisa-expo/skills/tasks-load/SKILL.md +88 -0
  228. package/plugins/lisa-expo/skills/tasks-sync/SKILL.md +108 -0
  229. package/plugins/lisa-nestjs/.claude-plugin/plugin.json +86 -0
  230. package/plugins/lisa-nestjs/agents/agent-architect.md +310 -0
  231. package/plugins/lisa-nestjs/agents/architecture-specialist.md +53 -0
  232. package/plugins/lisa-nestjs/agents/debug-specialist.md +204 -0
  233. package/plugins/lisa-nestjs/agents/git-history-analyzer.md +183 -0
  234. package/plugins/lisa-nestjs/agents/hooks-expert.md +74 -0
  235. package/plugins/lisa-nestjs/agents/implementer.md +54 -0
  236. package/plugins/lisa-nestjs/agents/learner.md +44 -0
  237. package/plugins/lisa-nestjs/agents/performance-specialist.md +95 -0
  238. package/plugins/lisa-nestjs/agents/product-specialist.md +72 -0
  239. package/plugins/lisa-nestjs/agents/quality-specialist.md +55 -0
  240. package/plugins/lisa-nestjs/agents/security-specialist.md +58 -0
  241. package/plugins/lisa-nestjs/agents/skill-evaluator.md +246 -0
  242. package/plugins/lisa-nestjs/agents/slash-command-architect.md +87 -0
  243. package/plugins/lisa-nestjs/agents/test-specialist.md +64 -0
  244. package/plugins/lisa-nestjs/agents/verification-specialist.md +189 -0
  245. package/plugins/lisa-nestjs/agents/web-search-researcher.md +112 -0
  246. package/plugins/lisa-nestjs/commands/git-commit-and-submit-pr.md +7 -0
  247. package/plugins/lisa-nestjs/commands/git-commit-submit-pr-and-verify.md +7 -0
  248. package/plugins/lisa-nestjs/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
  249. package/plugins/lisa-nestjs/commands/git-commit.md +7 -0
  250. package/plugins/lisa-nestjs/commands/git-prune.md +6 -0
  251. package/plugins/lisa-nestjs/commands/git-submit-pr.md +7 -0
  252. package/plugins/lisa-nestjs/commands/jira-add-journey.md +7 -0
  253. package/plugins/lisa-nestjs/commands/jira-create.md +7 -0
  254. package/plugins/lisa-nestjs/commands/jira-evidence.md +7 -0
  255. package/plugins/lisa-nestjs/commands/jira-fix.md +7 -0
  256. package/plugins/lisa-nestjs/commands/jira-implement.md +7 -0
  257. package/plugins/lisa-nestjs/commands/jira-journey.md +7 -0
  258. package/plugins/lisa-nestjs/commands/jira-sync.md +7 -0
  259. package/plugins/lisa-nestjs/commands/jira-verify.md +7 -0
  260. package/plugins/lisa-nestjs/commands/lisa-review-implementation.md +7 -0
  261. package/plugins/lisa-nestjs/commands/plan-add-test-coverage.md +7 -0
  262. package/plugins/lisa-nestjs/commands/plan-create.md +6 -0
  263. package/plugins/lisa-nestjs/commands/plan-execute.md +7 -0
  264. package/plugins/lisa-nestjs/commands/plan-fix-linter-error.md +7 -0
  265. package/plugins/lisa-nestjs/commands/plan-local-code-review.md +6 -0
  266. package/plugins/lisa-nestjs/commands/plan-lower-code-complexity.md +6 -0
  267. package/plugins/lisa-nestjs/commands/plan-reduce-max-lines-per-function.md +7 -0
  268. package/plugins/lisa-nestjs/commands/plan-reduce-max-lines.md +7 -0
  269. package/plugins/lisa-nestjs/commands/pull-request-review.md +7 -0
  270. package/plugins/lisa-nestjs/commands/security-zap-scan.md +6 -0
  271. package/plugins/lisa-nestjs/commands/sonarqube-check.md +6 -0
  272. package/plugins/lisa-nestjs/commands/sonarqube-fix.md +6 -0
  273. package/plugins/lisa-nestjs/commands/tasks-load.md +7 -0
  274. package/plugins/lisa-nestjs/commands/tasks-sync.md +7 -0
  275. package/plugins/lisa-nestjs/hooks/debug-hook.sh +47 -0
  276. package/plugins/lisa-nestjs/hooks/enforce-plan-rules.sh +15 -0
  277. package/plugins/lisa-nestjs/hooks/format-on-edit.sh +76 -0
  278. package/plugins/lisa-nestjs/hooks/install-pkgs.sh +64 -0
  279. package/plugins/lisa-nestjs/hooks/lint-on-edit.sh +81 -0
  280. package/plugins/lisa-nestjs/hooks/notify-ntfy.sh +183 -0
  281. package/plugins/lisa-nestjs/hooks/setup-jira-cli.sh +52 -0
  282. package/plugins/lisa-nestjs/hooks/sg-scan-on-edit.sh +68 -0
  283. package/plugins/lisa-nestjs/hooks/sync-tasks.sh +107 -0
  284. package/plugins/lisa-nestjs/hooks/ticket-sync-reminder.sh +23 -0
  285. package/plugins/lisa-nestjs/hooks/track-plan-sessions.sh +164 -0
  286. package/plugins/lisa-nestjs/hooks/verify-completion.sh +77 -0
  287. package/plugins/lisa-nestjs/rules/README.md +240 -0
  288. package/plugins/lisa-nestjs/rules/coding-philosophy.md +428 -0
  289. package/plugins/lisa-nestjs/rules/lisa.md +37 -0
  290. package/plugins/lisa-nestjs/rules/verfication.md +596 -0
  291. package/plugins/lisa-nestjs/skills/agent-design-best-practices/SKILL.md +219 -0
  292. package/plugins/lisa-nestjs/skills/git-commit/SKILL.md +48 -0
  293. package/plugins/lisa-nestjs/skills/git-commit-and-submit-pr/SKILL.md +8 -0
  294. package/plugins/lisa-nestjs/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
  295. package/plugins/lisa-nestjs/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
  296. package/plugins/lisa-nestjs/skills/git-prune/SKILL.md +35 -0
  297. package/plugins/lisa-nestjs/skills/git-submit-pr/SKILL.md +44 -0
  298. package/plugins/lisa-nestjs/skills/jira-add-journey/SKILL.md +120 -0
  299. package/plugins/lisa-nestjs/skills/jira-create/SKILL.md +95 -0
  300. package/plugins/lisa-nestjs/skills/jira-evidence/SKILL.md +73 -0
  301. package/plugins/lisa-nestjs/skills/jira-evidence/scripts/post-evidence.sh +163 -0
  302. package/plugins/lisa-nestjs/skills/jira-fix/SKILL.md +16 -0
  303. package/plugins/lisa-nestjs/skills/jira-implement/SKILL.md +18 -0
  304. package/plugins/lisa-nestjs/skills/jira-journey/SKILL.md +125 -0
  305. package/plugins/lisa-nestjs/skills/jira-journey/scripts/generate-templates.py +233 -0
  306. package/plugins/lisa-nestjs/skills/jira-journey/scripts/parse-plan.py +368 -0
  307. package/plugins/lisa-nestjs/skills/jira-sync/SKILL.md +63 -0
  308. package/plugins/lisa-nestjs/skills/jira-verify/SKILL.md +48 -0
  309. package/plugins/lisa-nestjs/skills/jsdoc-best-practices/SKILL.md +432 -0
  310. package/plugins/lisa-nestjs/skills/lisa-review-implementation/SKILL.md +209 -0
  311. package/plugins/lisa-nestjs/skills/plan-add-test-coverage/SKILL.md +44 -0
  312. package/plugins/lisa-nestjs/skills/plan-execute/SKILL.md +89 -0
  313. package/plugins/lisa-nestjs/skills/plan-fix-linter-error/SKILL.md +45 -0
  314. package/plugins/lisa-nestjs/skills/plan-local-code-review/SKILL.md +88 -0
  315. package/plugins/lisa-nestjs/skills/plan-lower-code-complexity/SKILL.md +44 -0
  316. package/plugins/lisa-nestjs/skills/plan-reduce-max-lines/SKILL.md +45 -0
  317. package/plugins/lisa-nestjs/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
  318. package/plugins/lisa-nestjs/skills/pull-request-review/SKILL.md +68 -0
  319. package/plugins/lisa-nestjs/skills/security-zap-scan/SKILL.md +33 -0
  320. package/plugins/lisa-nestjs/skills/skill-creator/LICENSE.txt +202 -0
  321. package/plugins/lisa-nestjs/skills/skill-creator/SKILL.md +210 -0
  322. package/plugins/lisa-nestjs/skills/skill-creator/scripts/init_skill.py +305 -0
  323. package/plugins/lisa-nestjs/skills/skill-creator/scripts/package_skill.py +112 -0
  324. package/plugins/lisa-nestjs/skills/skill-creator/scripts/quick_validate.py +67 -0
  325. package/plugins/lisa-nestjs/skills/sonarqube-check/SKILL.md +11 -0
  326. package/plugins/lisa-nestjs/skills/sonarqube-fix/SKILL.md +8 -0
  327. package/plugins/lisa-nestjs/skills/tasks-load/SKILL.md +88 -0
  328. package/plugins/lisa-nestjs/skills/tasks-sync/SKILL.md +108 -0
  329. package/plugins/lisa-rails/.claude-plugin/plugin.json +77 -0
  330. package/plugins/lisa-rails/agents/agent-architect.md +310 -0
  331. package/plugins/lisa-rails/agents/architecture-specialist.md +53 -0
  332. package/plugins/lisa-rails/agents/debug-specialist.md +204 -0
  333. package/plugins/lisa-rails/agents/git-history-analyzer.md +183 -0
  334. package/plugins/lisa-rails/agents/hooks-expert.md +74 -0
  335. package/plugins/lisa-rails/agents/implementer.md +54 -0
  336. package/plugins/lisa-rails/agents/learner.md +44 -0
  337. package/plugins/lisa-rails/agents/performance-specialist.md +95 -0
  338. package/plugins/lisa-rails/agents/product-specialist.md +72 -0
  339. package/plugins/lisa-rails/agents/quality-specialist.md +55 -0
  340. package/plugins/lisa-rails/agents/security-specialist.md +58 -0
  341. package/plugins/lisa-rails/agents/skill-evaluator.md +246 -0
  342. package/plugins/lisa-rails/agents/slash-command-architect.md +87 -0
  343. package/plugins/lisa-rails/agents/test-specialist.md +64 -0
  344. package/plugins/lisa-rails/agents/verification-specialist.md +189 -0
  345. package/plugins/lisa-rails/agents/web-search-researcher.md +112 -0
  346. package/plugins/lisa-rails/commands/git-commit-and-submit-pr.md +7 -0
  347. package/plugins/lisa-rails/commands/git-commit-submit-pr-and-verify.md +7 -0
  348. package/plugins/lisa-rails/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
  349. package/plugins/lisa-rails/commands/git-commit.md +7 -0
  350. package/plugins/lisa-rails/commands/git-prune.md +6 -0
  351. package/plugins/lisa-rails/commands/git-submit-pr.md +7 -0
  352. package/plugins/lisa-rails/commands/jira-add-journey.md +7 -0
  353. package/plugins/lisa-rails/commands/jira-create.md +7 -0
  354. package/plugins/lisa-rails/commands/jira-evidence.md +7 -0
  355. package/plugins/lisa-rails/commands/jira-fix.md +7 -0
  356. package/plugins/lisa-rails/commands/jira-implement.md +7 -0
  357. package/plugins/lisa-rails/commands/jira-journey.md +7 -0
  358. package/plugins/lisa-rails/commands/jira-sync.md +7 -0
  359. package/plugins/lisa-rails/commands/jira-verify.md +7 -0
  360. package/plugins/lisa-rails/commands/lisa-review-implementation.md +7 -0
  361. package/plugins/lisa-rails/commands/plan-add-test-coverage.md +7 -0
  362. package/plugins/lisa-rails/commands/plan-create.md +6 -0
  363. package/plugins/lisa-rails/commands/plan-execute.md +7 -0
  364. package/plugins/lisa-rails/commands/plan-fix-linter-error.md +7 -0
  365. package/plugins/lisa-rails/commands/plan-local-code-review.md +6 -0
  366. package/plugins/lisa-rails/commands/plan-lower-code-complexity.md +6 -0
  367. package/plugins/lisa-rails/commands/plan-reduce-max-lines-per-function.md +7 -0
  368. package/plugins/lisa-rails/commands/plan-reduce-max-lines.md +7 -0
  369. package/plugins/lisa-rails/commands/pull-request-review.md +7 -0
  370. package/plugins/lisa-rails/commands/security-zap-scan.md +6 -0
  371. package/plugins/lisa-rails/commands/sonarqube-check.md +6 -0
  372. package/plugins/lisa-rails/commands/sonarqube-fix.md +6 -0
  373. package/plugins/lisa-rails/commands/tasks-load.md +7 -0
  374. package/plugins/lisa-rails/commands/tasks-sync.md +7 -0
  375. package/plugins/lisa-rails/hooks/debug-hook.sh +47 -0
  376. package/plugins/lisa-rails/hooks/enforce-plan-rules.sh +15 -0
  377. package/plugins/lisa-rails/hooks/format-on-edit.sh +76 -0
  378. package/plugins/lisa-rails/hooks/install-pkgs.sh +64 -0
  379. package/plugins/lisa-rails/hooks/lint-on-edit.sh +81 -0
  380. package/plugins/lisa-rails/hooks/notify-ntfy.sh +183 -0
  381. package/plugins/lisa-rails/hooks/setup-jira-cli.sh +52 -0
  382. package/plugins/lisa-rails/hooks/sg-scan-on-edit.sh +68 -0
  383. package/plugins/lisa-rails/hooks/sync-tasks.sh +107 -0
  384. package/plugins/lisa-rails/hooks/ticket-sync-reminder.sh +23 -0
  385. package/plugins/lisa-rails/hooks/track-plan-sessions.sh +164 -0
  386. package/plugins/lisa-rails/hooks/verify-completion.sh +77 -0
  387. package/plugins/lisa-rails/rules/README.md +240 -0
  388. package/plugins/lisa-rails/rules/coding-philosophy.md +428 -0
  389. package/plugins/lisa-rails/rules/lisa.md +37 -0
  390. package/plugins/lisa-rails/rules/rails-conventions.md +176 -0
  391. package/plugins/lisa-rails/rules/verfication.md +596 -0
  392. package/plugins/lisa-rails/skills/agent-design-best-practices/SKILL.md +219 -0
  393. package/plugins/lisa-rails/skills/git-commit/SKILL.md +48 -0
  394. package/plugins/lisa-rails/skills/git-commit-and-submit-pr/SKILL.md +8 -0
  395. package/plugins/lisa-rails/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
  396. package/plugins/lisa-rails/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
  397. package/plugins/lisa-rails/skills/git-prune/SKILL.md +35 -0
  398. package/plugins/lisa-rails/skills/git-submit-pr/SKILL.md +44 -0
  399. package/plugins/lisa-rails/skills/jira-add-journey/SKILL.md +65 -0
  400. package/plugins/lisa-rails/skills/jira-evidence/SKILL.md +70 -0
  401. package/plugins/lisa-rails/skills/jira-evidence/scripts/post-evidence.sh +163 -0
  402. package/plugins/lisa-rails/skills/jira-fix/SKILL.md +16 -0
  403. package/plugins/lisa-rails/skills/jira-implement/SKILL.md +18 -0
  404. package/plugins/lisa-rails/skills/jira-journey/SKILL.md +64 -0
  405. package/plugins/lisa-rails/skills/jira-journey/scripts/generate-templates.py +233 -0
  406. package/plugins/lisa-rails/skills/jira-journey/scripts/parse-plan.py +368 -0
  407. package/plugins/lisa-rails/skills/jira-sync/SKILL.md +63 -0
  408. package/plugins/lisa-rails/skills/jsdoc-best-practices/SKILL.md +432 -0
  409. package/plugins/lisa-rails/skills/lisa-review-implementation/SKILL.md +209 -0
  410. package/plugins/lisa-rails/skills/plan-execute/SKILL.md +89 -0
  411. package/plugins/lisa-rails/skills/plan-local-code-review/SKILL.md +88 -0
  412. package/plugins/lisa-rails/skills/pull-request-review/SKILL.md +68 -0
  413. package/plugins/lisa-rails/skills/security-zap-scan/SKILL.md +33 -0
  414. package/plugins/lisa-rails/skills/skill-creator/LICENSE.txt +202 -0
  415. package/plugins/lisa-rails/skills/skill-creator/SKILL.md +210 -0
  416. package/plugins/lisa-rails/skills/skill-creator/scripts/init_skill.py +305 -0
  417. package/plugins/lisa-rails/skills/skill-creator/scripts/package_skill.py +112 -0
  418. package/plugins/lisa-rails/skills/skill-creator/scripts/quick_validate.py +67 -0
  419. package/plugins/lisa-rails/skills/sonarqube-check/SKILL.md +11 -0
  420. package/plugins/lisa-rails/skills/sonarqube-fix/SKILL.md +8 -0
  421. package/plugins/lisa-rails/skills/tasks-load/SKILL.md +88 -0
  422. package/plugins/lisa-rails/skills/tasks-sync/SKILL.md +108 -0
  423. package/plugins/lisa-typescript/.claude-plugin/plugin.json +86 -0
  424. package/plugins/lisa-typescript/agents/agent-architect.md +310 -0
  425. package/plugins/lisa-typescript/agents/architecture-specialist.md +53 -0
  426. package/plugins/lisa-typescript/agents/debug-specialist.md +204 -0
  427. package/plugins/lisa-typescript/agents/git-history-analyzer.md +183 -0
  428. package/plugins/lisa-typescript/agents/hooks-expert.md +74 -0
  429. package/plugins/lisa-typescript/agents/implementer.md +54 -0
  430. package/plugins/lisa-typescript/agents/learner.md +44 -0
  431. package/plugins/lisa-typescript/agents/performance-specialist.md +95 -0
  432. package/plugins/lisa-typescript/agents/product-specialist.md +72 -0
  433. package/plugins/lisa-typescript/agents/quality-specialist.md +55 -0
  434. package/plugins/lisa-typescript/agents/security-specialist.md +58 -0
  435. package/plugins/lisa-typescript/agents/skill-evaluator.md +246 -0
  436. package/plugins/lisa-typescript/agents/slash-command-architect.md +87 -0
  437. package/plugins/lisa-typescript/agents/test-specialist.md +64 -0
  438. package/plugins/lisa-typescript/agents/verification-specialist.md +189 -0
  439. package/plugins/lisa-typescript/agents/web-search-researcher.md +112 -0
  440. package/plugins/lisa-typescript/commands/git-commit-and-submit-pr.md +7 -0
  441. package/plugins/lisa-typescript/commands/git-commit-submit-pr-and-verify.md +7 -0
  442. package/plugins/lisa-typescript/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
  443. package/plugins/lisa-typescript/commands/git-commit.md +7 -0
  444. package/plugins/lisa-typescript/commands/git-prune.md +6 -0
  445. package/plugins/lisa-typescript/commands/git-submit-pr.md +7 -0
  446. package/plugins/lisa-typescript/commands/jira-add-journey.md +7 -0
  447. package/plugins/lisa-typescript/commands/jira-create.md +7 -0
  448. package/plugins/lisa-typescript/commands/jira-evidence.md +7 -0
  449. package/plugins/lisa-typescript/commands/jira-fix.md +7 -0
  450. package/plugins/lisa-typescript/commands/jira-implement.md +7 -0
  451. package/plugins/lisa-typescript/commands/jira-journey.md +7 -0
  452. package/plugins/lisa-typescript/commands/jira-sync.md +7 -0
  453. package/plugins/lisa-typescript/commands/jira-verify.md +7 -0
  454. package/plugins/lisa-typescript/commands/lisa-review-implementation.md +7 -0
  455. package/plugins/lisa-typescript/commands/plan-add-test-coverage.md +7 -0
  456. package/plugins/lisa-typescript/commands/plan-create.md +6 -0
  457. package/plugins/lisa-typescript/commands/plan-execute.md +7 -0
  458. package/plugins/lisa-typescript/commands/plan-fix-linter-error.md +7 -0
  459. package/plugins/lisa-typescript/commands/plan-local-code-review.md +6 -0
  460. package/plugins/lisa-typescript/commands/plan-lower-code-complexity.md +6 -0
  461. package/plugins/lisa-typescript/commands/plan-reduce-max-lines-per-function.md +7 -0
  462. package/plugins/lisa-typescript/commands/plan-reduce-max-lines.md +7 -0
  463. package/plugins/lisa-typescript/commands/pull-request-review.md +7 -0
  464. package/plugins/lisa-typescript/commands/security-zap-scan.md +6 -0
  465. package/plugins/lisa-typescript/commands/sonarqube-check.md +6 -0
  466. package/plugins/lisa-typescript/commands/sonarqube-fix.md +6 -0
  467. package/plugins/lisa-typescript/commands/tasks-load.md +7 -0
  468. package/plugins/lisa-typescript/commands/tasks-sync.md +7 -0
  469. package/plugins/lisa-typescript/hooks/debug-hook.sh +47 -0
  470. package/plugins/lisa-typescript/hooks/enforce-plan-rules.sh +15 -0
  471. package/plugins/lisa-typescript/hooks/format-on-edit.sh +76 -0
  472. package/plugins/lisa-typescript/hooks/install-pkgs.sh +64 -0
  473. package/plugins/lisa-typescript/hooks/lint-on-edit.sh +81 -0
  474. package/plugins/lisa-typescript/hooks/notify-ntfy.sh +183 -0
  475. package/plugins/lisa-typescript/hooks/setup-jira-cli.sh +52 -0
  476. package/plugins/lisa-typescript/hooks/sg-scan-on-edit.sh +68 -0
  477. package/plugins/lisa-typescript/hooks/sync-tasks.sh +107 -0
  478. package/plugins/lisa-typescript/hooks/ticket-sync-reminder.sh +23 -0
  479. package/plugins/lisa-typescript/hooks/track-plan-sessions.sh +164 -0
  480. package/plugins/lisa-typescript/hooks/verify-completion.sh +77 -0
  481. package/plugins/lisa-typescript/rules/README.md +240 -0
  482. package/plugins/lisa-typescript/rules/coding-philosophy.md +428 -0
  483. package/plugins/lisa-typescript/rules/lisa.md +37 -0
  484. package/plugins/lisa-typescript/rules/verfication.md +596 -0
  485. package/plugins/lisa-typescript/skills/agent-design-best-practices/SKILL.md +219 -0
  486. package/plugins/lisa-typescript/skills/git-commit/SKILL.md +48 -0
  487. package/plugins/lisa-typescript/skills/git-commit-and-submit-pr/SKILL.md +8 -0
  488. package/plugins/lisa-typescript/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
  489. package/plugins/lisa-typescript/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
  490. package/plugins/lisa-typescript/skills/git-prune/SKILL.md +35 -0
  491. package/plugins/lisa-typescript/skills/git-submit-pr/SKILL.md +44 -0
  492. package/plugins/lisa-typescript/skills/jira-add-journey/SKILL.md +120 -0
  493. package/plugins/lisa-typescript/skills/jira-create/SKILL.md +95 -0
  494. package/plugins/lisa-typescript/skills/jira-evidence/SKILL.md +73 -0
  495. package/plugins/lisa-typescript/skills/jira-evidence/scripts/post-evidence.sh +163 -0
  496. package/plugins/lisa-typescript/skills/jira-fix/SKILL.md +16 -0
  497. package/plugins/lisa-typescript/skills/jira-implement/SKILL.md +18 -0
  498. package/plugins/lisa-typescript/skills/jira-journey/SKILL.md +125 -0
  499. package/plugins/lisa-typescript/skills/jira-journey/scripts/generate-templates.py +233 -0
  500. package/plugins/lisa-typescript/skills/jira-journey/scripts/parse-plan.py +368 -0
  501. package/plugins/lisa-typescript/skills/jira-sync/SKILL.md +63 -0
  502. package/plugins/lisa-typescript/skills/jira-verify/SKILL.md +48 -0
  503. package/plugins/lisa-typescript/skills/jsdoc-best-practices/SKILL.md +432 -0
  504. package/plugins/lisa-typescript/skills/lisa-review-implementation/SKILL.md +209 -0
  505. package/plugins/lisa-typescript/skills/plan-add-test-coverage/SKILL.md +44 -0
  506. package/plugins/lisa-typescript/skills/plan-execute/SKILL.md +89 -0
  507. package/plugins/lisa-typescript/skills/plan-fix-linter-error/SKILL.md +45 -0
  508. package/plugins/lisa-typescript/skills/plan-local-code-review/SKILL.md +88 -0
  509. package/plugins/lisa-typescript/skills/plan-lower-code-complexity/SKILL.md +44 -0
  510. package/plugins/lisa-typescript/skills/plan-reduce-max-lines/SKILL.md +45 -0
  511. package/plugins/lisa-typescript/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
  512. package/plugins/lisa-typescript/skills/pull-request-review/SKILL.md +68 -0
  513. package/plugins/lisa-typescript/skills/security-zap-scan/SKILL.md +33 -0
  514. package/plugins/lisa-typescript/skills/skill-creator/LICENSE.txt +202 -0
  515. package/plugins/lisa-typescript/skills/skill-creator/SKILL.md +210 -0
  516. package/plugins/lisa-typescript/skills/skill-creator/scripts/init_skill.py +305 -0
  517. package/plugins/lisa-typescript/skills/skill-creator/scripts/package_skill.py +112 -0
  518. package/plugins/lisa-typescript/skills/skill-creator/scripts/quick_validate.py +67 -0
  519. package/plugins/lisa-typescript/skills/sonarqube-check/SKILL.md +11 -0
  520. package/plugins/lisa-typescript/skills/sonarqube-fix/SKILL.md +8 -0
  521. package/plugins/lisa-typescript/skills/tasks-load/SKILL.md +88 -0
  522. package/plugins/lisa-typescript/skills/tasks-sync/SKILL.md +108 -0
  523. package/plugins/src/base/agents/agent-architect.md +310 -0
  524. package/plugins/src/base/agents/architecture-specialist.md +53 -0
  525. package/plugins/src/base/agents/debug-specialist.md +204 -0
  526. package/plugins/src/base/agents/git-history-analyzer.md +183 -0
  527. package/plugins/src/base/agents/hooks-expert.md +74 -0
  528. package/plugins/src/base/agents/implementer.md +54 -0
  529. package/plugins/src/base/agents/learner.md +44 -0
  530. package/plugins/src/base/agents/performance-specialist.md +95 -0
  531. package/plugins/src/base/agents/product-specialist.md +72 -0
  532. package/plugins/src/base/agents/quality-specialist.md +55 -0
  533. package/plugins/src/base/agents/security-specialist.md +58 -0
  534. package/plugins/src/base/agents/skill-evaluator.md +246 -0
  535. package/plugins/src/base/agents/slash-command-architect.md +87 -0
  536. package/plugins/src/base/agents/test-specialist.md +64 -0
  537. package/plugins/src/base/agents/verification-specialist.md +189 -0
  538. package/plugins/src/base/agents/web-search-researcher.md +112 -0
  539. package/plugins/src/base/commands/git-commit-and-submit-pr.md +7 -0
  540. package/plugins/src/base/commands/git-commit-submit-pr-and-verify.md +7 -0
  541. package/plugins/src/base/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
  542. package/plugins/src/base/commands/git-commit.md +7 -0
  543. package/plugins/src/base/commands/git-prune.md +6 -0
  544. package/plugins/src/base/commands/git-submit-pr.md +7 -0
  545. package/plugins/src/base/commands/jira-add-journey.md +7 -0
  546. package/plugins/src/base/commands/jira-create.md +7 -0
  547. package/plugins/src/base/commands/jira-evidence.md +7 -0
  548. package/plugins/src/base/commands/jira-fix.md +7 -0
  549. package/plugins/src/base/commands/jira-implement.md +7 -0
  550. package/plugins/src/base/commands/jira-journey.md +7 -0
  551. package/plugins/src/base/commands/jira-sync.md +7 -0
  552. package/plugins/src/base/commands/jira-verify.md +7 -0
  553. package/plugins/src/base/commands/lisa-review-implementation.md +7 -0
  554. package/plugins/src/base/commands/plan-add-test-coverage.md +7 -0
  555. package/plugins/src/base/commands/plan-create.md +6 -0
  556. package/plugins/src/base/commands/plan-execute.md +7 -0
  557. package/plugins/src/base/commands/plan-fix-linter-error.md +7 -0
  558. package/plugins/src/base/commands/plan-local-code-review.md +6 -0
  559. package/plugins/src/base/commands/plan-lower-code-complexity.md +6 -0
  560. package/plugins/src/base/commands/plan-reduce-max-lines-per-function.md +7 -0
  561. package/plugins/src/base/commands/plan-reduce-max-lines.md +7 -0
  562. package/plugins/src/base/commands/pull-request-review.md +7 -0
  563. package/plugins/src/base/commands/security-zap-scan.md +6 -0
  564. package/plugins/src/base/commands/sonarqube-check.md +6 -0
  565. package/plugins/src/base/commands/sonarqube-fix.md +6 -0
  566. package/plugins/src/base/commands/tasks-load.md +7 -0
  567. package/plugins/src/base/commands/tasks-sync.md +7 -0
  568. package/plugins/src/base/hooks/debug-hook.sh +47 -0
  569. package/plugins/src/base/hooks/enforce-plan-rules.sh +15 -0
  570. package/plugins/src/base/hooks/format-on-edit.sh +76 -0
  571. package/plugins/src/base/hooks/install-pkgs.sh +64 -0
  572. package/plugins/src/base/hooks/lint-on-edit.sh +81 -0
  573. package/plugins/src/base/hooks/notify-ntfy.sh +183 -0
  574. package/plugins/src/base/hooks/setup-jira-cli.sh +52 -0
  575. package/plugins/src/base/hooks/sg-scan-on-edit.sh +68 -0
  576. package/plugins/src/base/hooks/sync-tasks.sh +107 -0
  577. package/plugins/src/base/hooks/ticket-sync-reminder.sh +23 -0
  578. package/plugins/src/base/hooks/track-plan-sessions.sh +164 -0
  579. package/plugins/src/base/hooks/verify-completion.sh +77 -0
  580. package/plugins/src/base/rules/README.md +240 -0
  581. package/plugins/src/base/rules/coding-philosophy.md +428 -0
  582. package/plugins/src/base/rules/lisa.md +37 -0
  583. package/plugins/src/base/rules/verfication.md +596 -0
  584. package/plugins/src/base/skills/agent-design-best-practices/SKILL.md +219 -0
  585. package/plugins/src/base/skills/git-commit/SKILL.md +48 -0
  586. package/plugins/src/base/skills/git-commit-and-submit-pr/SKILL.md +8 -0
  587. package/plugins/src/base/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
  588. package/plugins/src/base/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
  589. package/plugins/src/base/skills/git-prune/SKILL.md +35 -0
  590. package/plugins/src/base/skills/git-submit-pr/SKILL.md +44 -0
  591. package/plugins/src/base/skills/jira-add-journey/SKILL.md +120 -0
  592. package/plugins/src/base/skills/jira-create/SKILL.md +95 -0
  593. package/plugins/src/base/skills/jira-evidence/SKILL.md +73 -0
  594. package/plugins/src/base/skills/jira-evidence/scripts/post-evidence.sh +163 -0
  595. package/plugins/src/base/skills/jira-fix/SKILL.md +16 -0
  596. package/plugins/src/base/skills/jira-implement/SKILL.md +18 -0
  597. package/plugins/src/base/skills/jira-journey/SKILL.md +125 -0
  598. package/plugins/src/base/skills/jira-journey/scripts/generate-templates.py +233 -0
  599. package/plugins/src/base/skills/jira-journey/scripts/parse-plan.py +368 -0
  600. package/plugins/src/base/skills/jira-sync/SKILL.md +63 -0
  601. package/plugins/src/base/skills/jira-verify/SKILL.md +48 -0
  602. package/plugins/src/base/skills/jsdoc-best-practices/SKILL.md +432 -0
  603. package/plugins/src/base/skills/lisa-review-implementation/SKILL.md +209 -0
  604. package/plugins/src/base/skills/plan-add-test-coverage/SKILL.md +44 -0
  605. package/plugins/src/base/skills/plan-execute/SKILL.md +89 -0
  606. package/plugins/src/base/skills/plan-fix-linter-error/SKILL.md +45 -0
  607. package/plugins/src/base/skills/plan-local-code-review/SKILL.md +88 -0
  608. package/plugins/src/base/skills/plan-lower-code-complexity/SKILL.md +44 -0
  609. package/plugins/src/base/skills/plan-reduce-max-lines/SKILL.md +45 -0
  610. package/plugins/src/base/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
  611. package/plugins/src/base/skills/pull-request-review/SKILL.md +68 -0
  612. package/plugins/src/base/skills/security-zap-scan/SKILL.md +33 -0
  613. package/plugins/src/base/skills/skill-creator/LICENSE.txt +202 -0
  614. package/plugins/src/base/skills/skill-creator/SKILL.md +210 -0
  615. package/plugins/src/base/skills/skill-creator/scripts/init_skill.py +305 -0
  616. package/plugins/src/base/skills/skill-creator/scripts/package_skill.py +112 -0
  617. package/plugins/src/base/skills/skill-creator/scripts/quick_validate.py +67 -0
  618. package/plugins/src/base/skills/sonarqube-check/SKILL.md +11 -0
  619. package/plugins/src/base/skills/sonarqube-fix/SKILL.md +8 -0
  620. package/plugins/src/base/skills/tasks-load/SKILL.md +88 -0
  621. package/plugins/src/base/skills/tasks-sync/SKILL.md +108 -0
  622. package/plugins/src/cdk/.claude-plugin/plugin.json +86 -0
  623. package/plugins/src/expo/.claude-plugin/plugin.json +86 -0
  624. package/plugins/src/expo/agents/ops-specialist.md +124 -0
  625. package/plugins/src/expo/rules/expo-verification.md +261 -0
  626. package/plugins/src/expo/skills/apollo-client/SKILL.md +238 -0
  627. package/plugins/src/expo/skills/apollo-client/references/mutation-patterns.md +360 -0
  628. package/plugins/src/expo/skills/atomic-design-gluestack/SKILL.md +360 -0
  629. package/plugins/src/expo/skills/atomic-design-gluestack/references/atomic-levels.md +417 -0
  630. package/plugins/src/expo/skills/atomic-design-gluestack/references/folder-structure.md +257 -0
  631. package/plugins/src/expo/skills/atomic-design-gluestack/references/gluestack-mapping.md +233 -0
  632. package/plugins/src/expo/skills/atomic-design-gluestack/scripts/validate_atomic_structure.py +329 -0
  633. package/plugins/src/expo/skills/container-view-pattern/SKILL.md +299 -0
  634. package/plugins/src/expo/skills/container-view-pattern/references/examples.md +749 -0
  635. package/plugins/src/expo/skills/container-view-pattern/references/patterns.md +318 -0
  636. package/plugins/src/expo/skills/container-view-pattern/scripts/create_component.py +200 -0
  637. package/plugins/src/expo/skills/container-view-pattern/scripts/validate_component.py +209 -0
  638. package/plugins/src/expo/skills/cross-platform-compatibility/SKILL.md +268 -0
  639. package/plugins/src/expo/skills/cross-platform-compatibility/references/common-issues.md +619 -0
  640. package/plugins/src/expo/skills/cross-platform-compatibility/references/file-extensions.md +340 -0
  641. package/plugins/src/expo/skills/cross-platform-compatibility/references/platform-api.md +276 -0
  642. package/plugins/src/expo/skills/cross-platform-compatibility/scripts/validate_cross_platform.py +416 -0
  643. package/plugins/src/expo/skills/directory-structure/SKILL.md +202 -0
  644. package/plugins/src/expo/skills/directory-structure/scripts/validate_structure.py +445 -0
  645. package/plugins/src/expo/skills/expo-env-config/SKILL.md +309 -0
  646. package/plugins/src/expo/skills/expo-env-config/references/validation-patterns.md +417 -0
  647. package/plugins/src/expo/skills/expo-router-best-practices/SKILL.md +431 -0
  648. package/plugins/src/expo/skills/expo-router-best-practices/references/official-docs.md +290 -0
  649. package/plugins/src/expo/skills/expo-router-best-practices/scripts/generate-route.py +171 -0
  650. package/plugins/src/expo/skills/gluestack-nativewind/SKILL.md +411 -0
  651. package/plugins/src/expo/skills/gluestack-nativewind/references/color-tokens.md +343 -0
  652. package/plugins/src/expo/skills/gluestack-nativewind/references/component-mapping.md +307 -0
  653. package/plugins/src/expo/skills/gluestack-nativewind/references/spacing-scale.md +300 -0
  654. package/plugins/src/expo/skills/gluestack-nativewind/scripts/validate_styling.py +315 -0
  655. package/plugins/src/expo/skills/jira-add-journey/SKILL.md +126 -0
  656. package/plugins/src/expo/skills/jira-create/SKILL.md +101 -0
  657. package/plugins/src/expo/skills/jira-evidence/SKILL.md +78 -0
  658. package/plugins/src/expo/skills/jira-evidence/scripts/post-evidence.sh +163 -0
  659. package/plugins/src/expo/skills/jira-journey/SKILL.md +190 -0
  660. package/plugins/src/expo/skills/jira-journey/scripts/generate-templates.py +281 -0
  661. package/plugins/src/expo/skills/jira-journey/scripts/parse-plan.py +368 -0
  662. package/plugins/src/expo/skills/jira-verify/SKILL.md +47 -0
  663. package/plugins/src/expo/skills/local-state/SKILL.md +362 -0
  664. package/plugins/src/expo/skills/local-state/references/async-storage.md +505 -0
  665. package/plugins/src/expo/skills/local-state/references/persistence-patterns.md +711 -0
  666. package/plugins/src/expo/skills/local-state/references/reactive-variables.md +446 -0
  667. package/plugins/src/expo/skills/ops-browser-uat/SKILL.md +124 -0
  668. package/plugins/src/expo/skills/ops-check-logs/SKILL.md +211 -0
  669. package/plugins/src/expo/skills/ops-db-ops/SKILL.md +119 -0
  670. package/plugins/src/expo/skills/ops-deploy/SKILL.md +119 -0
  671. package/plugins/src/expo/skills/ops-monitor-errors/SKILL.md +99 -0
  672. package/plugins/src/expo/skills/ops-performance/SKILL.md +165 -0
  673. package/plugins/src/expo/skills/ops-run-local/SKILL.md +166 -0
  674. package/plugins/src/expo/skills/ops-verify-health/SKILL.md +101 -0
  675. package/plugins/src/expo/skills/owasp-zap/SKILL.md +56 -0
  676. package/plugins/src/expo/skills/playwright-selectors/SKILL.md +223 -0
  677. package/plugins/src/expo/skills/testing-library/SKILL.md +314 -0
  678. package/plugins/src/expo/skills/testing-library/references/async-patterns.md +420 -0
  679. package/plugins/src/expo/skills/testing-library/references/expo-router-testing.md +556 -0
  680. package/plugins/src/expo/skills/testing-library/references/mocking-patterns.md +590 -0
  681. package/plugins/src/expo/skills/testing-library/references/query-priority.md +291 -0
  682. package/plugins/src/nestjs/.claude-plugin/plugin.json +86 -0
  683. package/plugins/src/nestjs/skills/nestjs-graphql/SKILL.md +176 -0
  684. package/plugins/src/nestjs/skills/nestjs-graphql/references/advanced-features.md +527 -0
  685. package/plugins/src/nestjs/skills/nestjs-graphql/references/project-patterns.md +483 -0
  686. package/plugins/src/nestjs/skills/nestjs-graphql/references/quick-start.md +257 -0
  687. package/plugins/src/nestjs/skills/nestjs-graphql/references/resolvers-mutations.md +413 -0
  688. package/plugins/src/nestjs/skills/nestjs-graphql/references/types-scalars.md +513 -0
  689. package/plugins/src/nestjs/skills/nestjs-rules/SKILL.md +536 -0
  690. package/plugins/src/nestjs/skills/typeorm-patterns/SKILL.md +275 -0
  691. package/plugins/src/nestjs/skills/typeorm-patterns/references/configuration-patterns.md +487 -0
  692. package/plugins/src/nestjs/skills/typeorm-patterns/references/entity-patterns.md +450 -0
  693. package/plugins/src/nestjs/skills/typeorm-patterns/references/observability-patterns.md +536 -0
  694. package/plugins/src/rails/.claude-plugin/plugin.json +77 -0
  695. package/plugins/src/rails/rules/rails-conventions.md +176 -0
  696. package/plugins/src/rails/skills/action-controller-best-practices/SKILL.md +374 -0
  697. package/plugins/src/rails/skills/action-view-best-practices/SKILL.md +335 -0
  698. package/plugins/src/rails/skills/active-record-model-best-practices/SKILL.md +166 -0
  699. package/plugins/src/rails/skills/jira-add-journey/SKILL.md +65 -0
  700. package/plugins/src/rails/skills/jira-create/SKILL.md +41 -0
  701. package/plugins/src/rails/skills/jira-evidence/SKILL.md +70 -0
  702. package/plugins/src/rails/skills/jira-evidence/scripts/post-evidence.sh +163 -0
  703. package/plugins/src/rails/skills/jira-journey/SKILL.md +64 -0
  704. package/plugins/src/rails/skills/jira-verify/SKILL.md +29 -0
  705. package/plugins/src/rails/skills/plan-add-test-coverage/SKILL.md +45 -0
  706. package/plugins/src/rails/skills/plan-fix-linter-error/SKILL.md +45 -0
  707. package/plugins/src/rails/skills/plan-lower-code-complexity/SKILL.md +48 -0
  708. package/plugins/src/rails/skills/plan-reduce-max-lines/SKILL.md +46 -0
  709. package/plugins/src/rails/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
  710. package/plugins/src/typescript/.claude-plugin/plugin.json +86 -0
  711. package/rails/copy-overwrite/.claude/settings.json +80 -0
  712. package/rails/create-only/.github/workflows/ci.yml +1 -1
  713. package/rails/deletions.json +11 -1
  714. package/scripts/build-plugins.sh +22 -0
  715. package/scripts/cleanup-amplify-branches.sh +150 -0
  716. package/scripts/cleanup-github-branches.sh +202 -0
  717. package/scripts/github-status-check.sh +301 -0
  718. package/scripts/install-claude-plugins.sh +45 -0
  719. package/scripts/lisa-commit-and-pr-local.sh +204 -0
  720. package/scripts/lisa-update-local.sh +158 -0
  721. package/scripts/update-node-version.ts +197 -0
  722. package/tsconfig/build.json +8 -0
  723. package/tsconfig/cdk.json +16 -0
  724. package/tsconfig/eslint.json +12 -0
  725. package/tsconfig/expo.json +18 -0
  726. package/tsconfig/nestjs.json +18 -0
  727. package/tsconfig/spec.json +7 -0
  728. package/{typescript/copy-overwrite/tsconfig.typescript.json → tsconfig/typescript.json} +1 -1
  729. package/typescript/copy-overwrite/eslint.config.ts +6 -20
  730. package/typescript/copy-overwrite/eslint.slow.config.ts +4 -73
  731. package/typescript/copy-overwrite/jest.config.ts +8 -12
  732. package/typescript/copy-overwrite/tsconfig.json +1 -1
  733. package/typescript/create-only/.github/workflows/ci.yml +1 -1
  734. package/typescript/deletions.json +18 -1
  735. package/typescript/merge/.claude/settings.json +29 -0
  736. package/typescript/package-lisa/package.lisa.json +1 -35
  737. package/all/copy-overwrite/.claude/hooks/check-tired-boss.sh +0 -61
  738. package/all/copy-overwrite/.claude/rules/lisa.md +0 -53
  739. package/all/copy-overwrite/.claude/settings.json +0 -321
  740. package/all/copy-overwrite/.claude/skills/skill-creator/scripts/__pycache__/quick_validate.cpython-312.pyc +0 -0
  741. package/all/copy-overwrite/CLAUDE.md +0 -59
  742. package/all/copy-overwrite/HUMAN.md +0 -309
  743. package/eslint-plugin-code-organization/README.md +0 -149
  744. package/eslint-plugin-code-organization/__tests__/enforce-statement-order.test.js +0 -473
  745. package/eslint-plugin-code-organization/index.js +0 -28
  746. package/eslint-plugin-code-organization/package.json +0 -10
  747. package/eslint-plugin-code-organization/rules/enforce-statement-order.js +0 -162
  748. package/expo/copy-overwrite/eslint-plugin-component-structure/README.md +0 -234
  749. package/expo/copy-overwrite/eslint-plugin-component-structure/__tests__/plugin-index.test.js +0 -89
  750. package/expo/copy-overwrite/eslint-plugin-component-structure/__tests__/require-memo-in-view.test.js +0 -201
  751. package/expo/copy-overwrite/eslint-plugin-component-structure/__tests__/single-component-per-file.test.js +0 -294
  752. package/expo/copy-overwrite/eslint-plugin-component-structure/index.js +0 -37
  753. package/expo/copy-overwrite/eslint-plugin-component-structure/package.json +0 -10
  754. package/expo/copy-overwrite/eslint-plugin-component-structure/rules/enforce-component-structure.js +0 -235
  755. package/expo/copy-overwrite/eslint-plugin-component-structure/rules/no-return-in-view.js +0 -96
  756. package/expo/copy-overwrite/eslint-plugin-component-structure/rules/require-memo-in-view.js +0 -183
  757. package/expo/copy-overwrite/eslint-plugin-component-structure/rules/single-component-per-file.js +0 -243
  758. package/expo/copy-overwrite/eslint-plugin-ui-standards/README.md +0 -192
  759. package/expo/copy-overwrite/eslint-plugin-ui-standards/index.js +0 -31
  760. package/expo/copy-overwrite/eslint-plugin-ui-standards/package.json +0 -10
  761. package/expo/copy-overwrite/eslint-plugin-ui-standards/rules/no-classname-outside-ui.js +0 -56
  762. package/expo/copy-overwrite/eslint-plugin-ui-standards/rules/no-direct-rn-imports.js +0 -60
  763. package/rails/copy-overwrite/CLAUDE.md +0 -56
  764. package/typescript/copy-overwrite/.claude/settings.json +0 -320
  765. package/typescript/copy-overwrite/eslint-plugin-code-organization/README.md +0 -149
  766. package/typescript/copy-overwrite/eslint-plugin-code-organization/__tests__/enforce-statement-order.test.js +0 -473
  767. package/typescript/copy-overwrite/eslint-plugin-code-organization/index.js +0 -28
  768. package/typescript/copy-overwrite/eslint-plugin-code-organization/package.json +0 -10
  769. package/typescript/copy-overwrite/eslint-plugin-code-organization/rules/enforce-statement-order.js +0 -162
  770. package/typescript/copy-overwrite/eslint.base.ts +0 -429
  771. package/typescript/copy-overwrite/eslint.typescript.ts +0 -142
  772. package/typescript/copy-overwrite/jest.typescript.ts +0 -72
  773. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/agent-architect.md +0 -0
  774. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/architecture-specialist.md +0 -0
  775. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/debug-specialist.md +0 -0
  776. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/git-history-analyzer.md +0 -0
  777. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/hooks-expert.md +0 -0
  778. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/implementer.md +0 -0
  779. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/learner.md +0 -0
  780. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/performance-specialist.md +0 -0
  781. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/product-specialist.md +0 -0
  782. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/quality-specialist.md +0 -0
  783. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/security-specialist.md +0 -0
  784. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/skill-evaluator.md +0 -0
  785. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/slash-command-architect.md +0 -0
  786. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/test-specialist.md +0 -0
  787. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/verification-specialist.md +0 -0
  788. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/web-search-researcher.md +0 -0
  789. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/debug-hook.sh +0 -0
  790. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/enforce-plan-rules.sh +0 -0
  791. /package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/format-on-edit.sh +0 -0
  792. /package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/lint-on-edit.sh +0 -0
  793. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/notify-ntfy.sh +0 -0
  794. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/setup-jira-cli.sh +0 -0
  795. /package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/sg-scan-on-edit.sh +0 -0
  796. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/sync-tasks.sh +0 -0
  797. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/ticket-sync-reminder.sh +0 -0
  798. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/track-plan-sessions.sh +0 -0
  799. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/verify-completion.sh +0 -0
  800. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk/rules}/README.md +0 -0
  801. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/rules/coding-philosophy.md +0 -0
  802. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/rules/verfication.md +0 -0
  803. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/agent-design-best-practices/SKILL.md +0 -0
  804. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-commit/SKILL.md +0 -0
  805. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-commit-and-submit-pr/SKILL.md +0 -0
  806. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-commit-submit-pr-and-verify/SKILL.md +0 -0
  807. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +0 -0
  808. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-prune/SKILL.md +0 -0
  809. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-submit-pr/SKILL.md +0 -0
  810. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/jira-sync/SKILL.md +0 -0
  811. /package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/skills/jsdoc-best-practices/SKILL.md +0 -0
  812. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/lisa-review-implementation/SKILL.md +0 -0
  813. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-add-test-coverage/SKILL.md +0 -0
  814. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-execute/SKILL.md +0 -0
  815. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-fix-linter-error/SKILL.md +0 -0
  816. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-local-code-review/SKILL.md +0 -0
  817. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-lower-code-complexity/SKILL.md +0 -0
  818. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-reduce-max-lines/SKILL.md +0 -0
  819. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-reduce-max-lines-per-function/SKILL.md +0 -0
  820. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/pull-request-review/SKILL.md +0 -0
  821. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/security-zap-scan/SKILL.md +0 -0
  822. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/LICENSE.txt +0 -0
  823. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/SKILL.md +0 -0
  824. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/scripts/init_skill.py +0 -0
  825. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/scripts/package_skill.py +0 -0
  826. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/scripts/quick_validate.py +0 -0
  827. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/sonarqube-check/SKILL.md +0 -0
  828. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/sonarqube-fix/SKILL.md +0 -0
  829. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/tasks-load/SKILL.md +0 -0
  830. /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/tasks-sync/SKILL.md +0 -0
  831. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/agents/ops-specialist.md +0 -0
  832. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/rules/expo-verification.md +0 -0
  833. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/apollo-client/SKILL.md +0 -0
  834. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/apollo-client/references/mutation-patterns.md +0 -0
  835. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/SKILL.md +0 -0
  836. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/references/atomic-levels.md +0 -0
  837. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/references/folder-structure.md +0 -0
  838. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/references/gluestack-mapping.md +0 -0
  839. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/scripts/validate_atomic_structure.py +0 -0
  840. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/SKILL.md +0 -0
  841. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/references/examples.md +0 -0
  842. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/references/patterns.md +0 -0
  843. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/scripts/create_component.py +0 -0
  844. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/scripts/validate_component.py +0 -0
  845. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/SKILL.md +0 -0
  846. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/references/common-issues.md +0 -0
  847. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/references/file-extensions.md +0 -0
  848. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/references/platform-api.md +0 -0
  849. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/scripts/validate_cross_platform.py +0 -0
  850. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/directory-structure/SKILL.md +0 -0
  851. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/directory-structure/scripts/validate_structure.py +0 -0
  852. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-env-config/SKILL.md +0 -0
  853. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-env-config/references/validation-patterns.md +0 -0
  854. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-router-best-practices/SKILL.md +0 -0
  855. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-router-best-practices/references/official-docs.md +0 -0
  856. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-router-best-practices/scripts/generate-route.py +0 -0
  857. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/SKILL.md +0 -0
  858. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/references/color-tokens.md +0 -0
  859. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/references/component-mapping.md +0 -0
  860. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/references/spacing-scale.md +0 -0
  861. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/scripts/validate_styling.py +0 -0
  862. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/local-state/SKILL.md +0 -0
  863. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/local-state/references/async-storage.md +0 -0
  864. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/local-state/references/persistence-patterns.md +0 -0
  865. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/local-state/references/reactive-variables.md +0 -0
  866. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-browser-uat/SKILL.md +0 -0
  867. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-check-logs/SKILL.md +0 -0
  868. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-db-ops/SKILL.md +0 -0
  869. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-deploy/SKILL.md +0 -0
  870. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-monitor-errors/SKILL.md +0 -0
  871. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-performance/SKILL.md +0 -0
  872. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-run-local/SKILL.md +0 -0
  873. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-verify-health/SKILL.md +0 -0
  874. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/owasp-zap/SKILL.md +0 -0
  875. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/playwright-selectors/SKILL.md +0 -0
  876. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-expo}/skills/security-zap-scan/SKILL.md +0 -0
  877. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/SKILL.md +0 -0
  878. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/references/async-patterns.md +0 -0
  879. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/references/expo-router-testing.md +0 -0
  880. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/references/mocking-patterns.md +0 -0
  881. /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/references/query-priority.md +0 -0
  882. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/SKILL.md +0 -0
  883. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/advanced-features.md +0 -0
  884. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/project-patterns.md +0 -0
  885. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/quick-start.md +0 -0
  886. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/resolvers-mutations.md +0 -0
  887. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/types-scalars.md +0 -0
  888. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-rules/SKILL.md +0 -0
  889. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/typeorm-patterns/SKILL.md +0 -0
  890. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/typeorm-patterns/references/configuration-patterns.md +0 -0
  891. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/typeorm-patterns/references/entity-patterns.md +0 -0
  892. /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/typeorm-patterns/references/observability-patterns.md +0 -0
  893. /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/action-controller-best-practices/SKILL.md +0 -0
  894. /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/action-view-best-practices/SKILL.md +0 -0
  895. /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/active-record-model-best-practices/SKILL.md +0 -0
  896. /package/{all/copy-overwrite/.claude → plugins/lisa-rails}/skills/jira-create/SKILL.md +0 -0
  897. /package/{all/copy-overwrite/.claude → plugins/lisa-rails}/skills/jira-verify/SKILL.md +0 -0
  898. /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-add-test-coverage/SKILL.md +0 -0
  899. /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-fix-linter-error/SKILL.md +0 -0
  900. /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-lower-code-complexity/SKILL.md +0 -0
  901. /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-reduce-max-lines/SKILL.md +0 -0
  902. /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-reduce-max-lines-per-function/SKILL.md +0 -0
  903. /package/{all/create-only/scripts → scripts}/setup-deploy-key.sh +0 -0
  904. /package/{typescript/copy-overwrite/tsconfig.base.json → tsconfig/base.json} +0 -0
@@ -1,294 +0,0 @@
1
- /**
2
- * This file is managed by Lisa.
3
- * Do not edit directly — changes will be overwritten on the next `lisa` run.
4
- */
5
-
6
- /**
7
- * Unit tests for the single-component-per-file ESLint rule
8
- *
9
- * Tests that View and Container files contain exactly one React component.
10
- * Ensures components/ui/** and components/shared/** directories are excluded from the rule.
11
- * @module eslint-plugin-component-structure/tests
12
- */
13
-
14
- const { RuleTester } = require("eslint");
15
-
16
- const rule = require("../rules/single-component-per-file");
17
-
18
- const FEATURE_EXAMPLE_COMPONENTS_PATH = "/features/example/components";
19
- const SHARED_COMPONENTS_PATH = "/components/shared";
20
- const UI_COMPONENTS_PATH = "/components/ui";
21
-
22
- const ruleTester = new RuleTester({
23
- languageOptions: {
24
- ecmaVersion: 2020,
25
- sourceType: "module",
26
- parserOptions: {
27
- ecmaFeatures: {
28
- jsx: true,
29
- },
30
- },
31
- },
32
- });
33
-
34
- ruleTester.run("single-component-per-file", rule, {
35
- valid: [
36
- // 1. Single component - arrow function
37
- {
38
- code: `
39
- const MyView = () => <div>Hello</div>;
40
- MyView.displayName = "MyView";
41
- export default MyView;
42
- `,
43
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
44
- },
45
- // 2. Single component - memo wrapped
46
- {
47
- code: `
48
- import { memo } from "react";
49
- const MyView = memo(() => <div>Hello</div>);
50
- MyView.displayName = "MyView";
51
- export default MyView;
52
- `,
53
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
54
- },
55
- // 3. Single component - React.memo wrapped
56
- {
57
- code: `
58
- import React from "react";
59
- const MyView = React.memo(() => <div>Hello</div>);
60
- MyView.displayName = "MyView";
61
- export default MyView;
62
- `,
63
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
64
- },
65
- // 4. Single component - function declaration
66
- {
67
- code: `
68
- function MyView() {
69
- return <div>Hello</div>;
70
- }
71
- export default MyView;
72
- `,
73
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
74
- },
75
- // 5. Single component - TypeScript React.FC (parser will handle TypeScript syntax)
76
- {
77
- code: `
78
- const MyView: React.FC = () => <div>Hello</div>;
79
- MyView.displayName = "MyView";
80
- export default MyView;
81
- `,
82
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
83
- languageOptions: {
84
- parser: require("@typescript-eslint/parser"),
85
- },
86
- },
87
- // 6. Single component in Container file
88
- {
89
- code: `
90
- const MyContainer = () => {
91
- return <div>Hello</div>;
92
- };
93
- export default MyContainer;
94
- `,
95
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyContainer.tsx`,
96
- },
97
- // 7. PascalCase function that doesn't return JSX (not a component)
98
- {
99
- code: `
100
- const MyView = () => <div>Hello</div>;
101
- const HelperFunction = () => {
102
- return "not JSX";
103
- };
104
- export default MyView;
105
- `,
106
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
107
- },
108
- // 8. Non-View/Container file (rule should not apply)
109
- {
110
- code: `
111
- const Component1 = () => <div>1</div>;
112
- const Component2 = () => <div>2</div>;
113
- export { Component1, Component2 };
114
- `,
115
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/utils.tsx`,
116
- },
117
- // 9. Excluded directory - UI components
118
- {
119
- code: `
120
- const Component1 = () => <div>1</div>;
121
- const Component2 = () => <div>2</div>;
122
- export { Component1, Component2 };
123
- `,
124
- filename: `${UI_COMPONENTS_PATH}/MyView.tsx`,
125
- },
126
- // 10. Excluded directory - Shared components
127
- {
128
- code: `
129
- const Component1 = () => <div>1</div>;
130
- const Component2 = () => <div>2</div>;
131
- export { Component1, Component2 };
132
- `,
133
- filename: `${SHARED_COMPONENTS_PATH}/MyView.tsx`,
134
- },
135
- // 11. Single component - conditional expression
136
- {
137
- code: `
138
- const MyView = ({ show }) => show ? <div>Visible</div> : <div>Hidden</div>;
139
- export default MyView;
140
- `,
141
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
142
- },
143
- // 12. Single component - logical expression
144
- {
145
- code: `
146
- const MyView = ({ show }) => show && <div>Content</div>;
147
- export default MyView;
148
- `,
149
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
150
- },
151
- ],
152
- invalid: [
153
- // 1. Two arrow function components
154
- {
155
- code: `
156
- const Component1 = () => <div>First</div>;
157
- const Component2 = () => <div>Second</div>;
158
- export default Component1;
159
- `,
160
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
161
- errors: [
162
- {
163
- messageId: "multipleComponents",
164
- data: {
165
- componentName: "Component2",
166
- firstComponentName: "Component1",
167
- },
168
- },
169
- ],
170
- },
171
- // 2. Two memo-wrapped components
172
- {
173
- code: `
174
- import { memo } from "react";
175
- const Component1 = memo(() => <div>First</div>);
176
- const Component2 = memo(() => <div>Second</div>);
177
- export default Component1;
178
- `,
179
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
180
- errors: [
181
- {
182
- messageId: "multipleComponents",
183
- data: {
184
- componentName: "Component2",
185
- firstComponentName: "Component1",
186
- },
187
- },
188
- ],
189
- },
190
- // 3. Main component and helper component (realistic violation)
191
- {
192
- code: `
193
- import React from "react";
194
- const MessageItem = ({ item }) => <div>{item}</div>;
195
- const MessageListView = ({ messages }) => (
196
- <div>{messages.map(msg => <MessageItem item={msg} />)}</div>
197
- );
198
- export default MessageListView;
199
- `,
200
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MessageListView.tsx`,
201
- errors: [
202
- {
203
- messageId: "multipleComponents",
204
- data: {
205
- componentName: "MessageListView",
206
- firstComponentName: "MessageItem",
207
- },
208
- },
209
- ],
210
- },
211
- // 4. Function declaration and arrow function
212
- {
213
- code: `
214
- function Component1() {
215
- return <div>First</div>;
216
- }
217
- const Component2 = () => <div>Second</div>;
218
- export default Component1;
219
- `,
220
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
221
- errors: [
222
- {
223
- messageId: "multipleComponents",
224
- data: {
225
- componentName: "Component2",
226
- firstComponentName: "Component1",
227
- },
228
- },
229
- ],
230
- },
231
- // 5. Three components (multiple violations)
232
- {
233
- code: `
234
- const Component1 = () => <div>First</div>;
235
- const Component2 = () => <div>Second</div>;
236
- const Component3 = () => <div>Third</div>;
237
- export default Component1;
238
- `,
239
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
240
- errors: [
241
- {
242
- messageId: "multipleComponents",
243
- data: {
244
- componentName: "Component2",
245
- firstComponentName: "Component1",
246
- },
247
- },
248
- {
249
- messageId: "multipleComponents",
250
- data: {
251
- componentName: "Component3",
252
- firstComponentName: "Component1",
253
- },
254
- },
255
- ],
256
- },
257
- // 6. Container file with multiple components
258
- {
259
- code: `
260
- const Helper = () => <div>Helper</div>;
261
- const MyContainer = () => <div><Helper /></div>;
262
- export default MyContainer;
263
- `,
264
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyContainer.tsx`,
265
- errors: [
266
- {
267
- messageId: "multipleComponents",
268
- data: {
269
- componentName: "MyContainer",
270
- firstComponentName: "Helper",
271
- },
272
- },
273
- ],
274
- },
275
- // 7. Multiple components with conditional expressions
276
- {
277
- code: `
278
- const Component1 = ({ show }) => show ? <div>First</div> : null;
279
- const Component2 = ({ show }) => show && <div>Second</div>;
280
- export default Component1;
281
- `,
282
- filename: `${FEATURE_EXAMPLE_COMPONENTS_PATH}/MyView.tsx`,
283
- errors: [
284
- {
285
- messageId: "multipleComponents",
286
- data: {
287
- componentName: "Component2",
288
- firstComponentName: "Component1",
289
- },
290
- },
291
- ],
292
- },
293
- ],
294
- });
@@ -1,37 +0,0 @@
1
- /**
2
- * This file is managed by Lisa.
3
- * Do not edit directly — changes will be overwritten on the next `lisa` run.
4
- */
5
-
6
- /**
7
- * ESLint plugin for component structure standards
8
- *
9
- * This plugin enforces component structure and patterns for React components
10
- * in the frontend application. Supports ESLint 9 flat config format.
11
- *
12
- * Rules:
13
- * - enforce-component-structure: Ensures components follow the Container/View pattern
14
- * - no-return-in-view: Disallows return statements in View components
15
- * - require-memo-in-view: Enforces React.memo usage in View components
16
- * - single-component-per-file: Ensures only one React component per file
17
- * @module eslint-plugin-component-structure
18
- */
19
- const enforceComponentStructure = require("./rules/enforce-component-structure");
20
- const noReturnInView = require("./rules/no-return-in-view");
21
- const requireMemoInView = require("./rules/require-memo-in-view");
22
- const singleComponentPerFile = require("./rules/single-component-per-file");
23
-
24
- const plugin = {
25
- meta: {
26
- name: "eslint-plugin-component-structure",
27
- version: "1.0.0",
28
- },
29
- rules: {
30
- "enforce-component-structure": enforceComponentStructure,
31
- "no-return-in-view": noReturnInView,
32
- "require-memo-in-view": requireMemoInView,
33
- "single-component-per-file": singleComponentPerFile,
34
- },
35
- };
36
-
37
- module.exports = plugin;
@@ -1,10 +0,0 @@
1
- {
2
- "name": "eslint-plugin-component-structure",
3
- "version": "1.0.0",
4
- "description": "ESLint plugin for component structure standards",
5
- "main": "index.js",
6
- "private": true,
7
- "peerDependencies": {
8
- "eslint": ">=9.0.0"
9
- }
10
- }
@@ -1,235 +0,0 @@
1
- /**
2
- * This file is managed by Lisa.
3
- * Do not edit directly — changes will be overwritten on the next `lisa` run.
4
- */
5
-
6
- const fs = require("fs");
7
- const path = require("path");
8
-
9
- module.exports = {
10
- meta: {
11
- type: "problem",
12
- docs: {
13
- description:
14
- "Enforce component structure in features/**/components directories",
15
- category: "Best Practices",
16
- recommended: true,
17
- },
18
- fixable: null,
19
- schema: [],
20
- messages: {
21
- missingContainer:
22
- 'Component directory "{{componentName}}" is missing {{componentName}}Container.tsx file',
23
- missingView:
24
- 'Component directory "{{componentName}}" is missing {{componentName}}View.tsx file',
25
- missingIndex:
26
- 'Component directory "{{componentName}}" is missing index.tsx file',
27
- incorrectIndexExport:
28
- "index.tsx should export {{componentName}}Container or {{componentName}}View as default",
29
- componentNotInDirectory:
30
- "Component files must be inside a directory named after the component",
31
- incorrectFileNaming: "{{fileName}} should be named {{expectedName}}",
32
- invalidFileInComponentDirectory:
33
- "Only index.ts(x), {{componentName}}Container.tsx, and {{componentName}}View.tsx are allowed in component directories. Found: {{fileName}}",
34
- },
35
- },
36
-
37
- create(context) {
38
- const filename = context.getFilename();
39
- const normalizedPath = filename.replace(/\\/g, "/");
40
-
41
- // Get the path after components/ or screens/
42
- const componentsMatch = normalizedPath.match(
43
- /\/(components|screens)\/(.+)$/
44
- );
45
- if (!componentsMatch) return {};
46
- const afterComponents = componentsMatch[2];
47
-
48
- const pathParts = afterComponents.split("/");
49
-
50
- // If file is directly in components/ directory (not in a subdirectory)
51
- if (pathParts.length === 1) {
52
- const fileName = pathParts[0];
53
- if (fileName.endsWith(".tsx") || fileName.endsWith(".jsx")) {
54
- context.report({
55
- node: context.getSourceCode().ast,
56
- messageId: "componentNotInDirectory",
57
- });
58
- }
59
- return {};
60
- }
61
-
62
- // Get component name and file name from the END of the path
63
- // This handles both ComponentName/file.tsx and custom/ui/ComponentName/file.tsx
64
- const fileName = pathParts[pathParts.length - 1];
65
- const componentName = pathParts[pathParts.length - 2];
66
-
67
- // Skip validation for files in __tests__ directories
68
- if (componentName === "__tests__") {
69
- return {};
70
- }
71
-
72
- // Only check .ts/.tsx/.jsx files
73
- if (
74
- !fileName ||
75
- (!fileName.endsWith(".ts") &&
76
- !fileName.endsWith(".tsx") &&
77
- !fileName.endsWith(".jsx"))
78
- ) {
79
- return {};
80
- }
81
-
82
- // Get the directory path
83
- const dirPath = path.dirname(filename);
84
-
85
- // Check if file is one of the allowed types
86
- const isIndex =
87
- fileName === "index.ts" ||
88
- fileName === "index.tsx" ||
89
- fileName === "index.jsx";
90
-
91
- // Allow *Container.*.tsx and *Container.*.jsx patterns (e.g., MyComponentContainer.native.tsx)
92
- const containerPattern = new RegExp(
93
- `^${componentName}Container\\.[^.]+\\.(tsx|jsx)$`
94
- );
95
- const isContainer =
96
- fileName === `${componentName}Container.tsx` ||
97
- fileName === `${componentName}Container.jsx` ||
98
- containerPattern.test(fileName);
99
-
100
- // Allow *View.*.tsx and *View.*.jsx patterns (e.g., MyComponentView.web.tsx)
101
- const viewPattern = new RegExp(
102
- `^${componentName}View\\.[^.]+\\.(tsx|jsx)$`
103
- );
104
- const isView =
105
- fileName === `${componentName}View.tsx` ||
106
- fileName === `${componentName}View.jsx` ||
107
- viewPattern.test(fileName);
108
-
109
- // Report error if file is not one of the allowed types
110
- if (!isIndex && !isContainer && !isView) {
111
- context.report({
112
- node: context.getSourceCode().ast,
113
- messageId: "invalidFileInComponentDirectory",
114
- data: { fileName, componentName },
115
- });
116
- return {};
117
- }
118
-
119
- // Check file naming
120
- if (
121
- fileName === "index.ts" ||
122
- fileName === "index.tsx" ||
123
- fileName === "index.jsx"
124
- ) {
125
- // Check if index.tsx exports the Container
126
- return {
127
- Program(node) {
128
- const sourceCode = context.getSourceCode();
129
- const text = sourceCode.getText();
130
-
131
- // Check for export patterns (allow Container or View)
132
- const defaultExportPattern = new RegExp(
133
- `export\\s*{\\s*default\\s*}\\s*from\\s*['"\`]\\.\\/${componentName}(Container|View)['"\`]|` +
134
- `export\\s*\\*\\s*from\\s*['"\`]\\.\\/${componentName}(Container|View)['"\`]|` +
135
- `export\\s*{\\s*${componentName}(Container|View)\\s*as\\s*default\\s*}|` +
136
- `export\\s*default\\s*${componentName}(Container|View)`
137
- );
138
-
139
- if (!defaultExportPattern.test(text)) {
140
- context.report({
141
- node,
142
- messageId: "incorrectIndexExport",
143
- data: { componentName },
144
- });
145
- }
146
- },
147
- };
148
- } else if (
149
- fileName.endsWith("Container.tsx") ||
150
- fileName.endsWith("Container.jsx")
151
- ) {
152
- const expectedName = `${componentName}Container.tsx`;
153
- if (
154
- fileName !== expectedName &&
155
- fileName !== `${componentName}Container.jsx`
156
- ) {
157
- context.report({
158
- node: context.getSourceCode().ast,
159
- messageId: "incorrectFileNaming",
160
- data: { fileName, expectedName },
161
- });
162
- }
163
- } else if (fileName.endsWith("View.tsx") || fileName.endsWith("View.jsx")) {
164
- const expectedName = `${componentName}View.tsx`;
165
- if (
166
- fileName !== expectedName &&
167
- fileName !== `${componentName}View.jsx`
168
- ) {
169
- context.report({
170
- node: context.getSourceCode().ast,
171
- messageId: "incorrectFileNaming",
172
- data: { fileName, expectedName },
173
- });
174
- }
175
- }
176
-
177
- // Check for required files in the directory (only once per directory)
178
- // We'll do this check only for the first file we encounter
179
- const cache = new Map();
180
- const checkRequiredFiles = () => {
181
- try {
182
- const files = cache.has(dirPath)
183
- ? cache.get(dirPath)
184
- : (() => {
185
- const dirFiles = fs.readdirSync(dirPath);
186
- cache.set(dirPath, dirFiles);
187
- return dirFiles;
188
- })();
189
- const hasContainer = files.some(
190
- f =>
191
- f === `${componentName}Container.tsx` ||
192
- f === `${componentName}Container.jsx`
193
- );
194
- const hasView = files.some(
195
- f =>
196
- f === `${componentName}View.tsx` || f === `${componentName}View.jsx`
197
- );
198
- const hasIndex = files.some(
199
- f => f === "index.tsx" || f === "index.jsx"
200
- );
201
-
202
- if (!hasContainer) {
203
- context.report({
204
- node: context.getSourceCode().ast,
205
- messageId: "missingContainer",
206
- data: { componentName },
207
- });
208
- }
209
- if (!hasView) {
210
- context.report({
211
- node: context.getSourceCode().ast,
212
- messageId: "missingView",
213
- data: { componentName },
214
- });
215
- }
216
- if (!hasIndex) {
217
- context.report({
218
- node: context.getSourceCode().ast,
219
- messageId: "missingIndex",
220
- data: { componentName },
221
- });
222
- }
223
- } catch (_err) {
224
- // Directory might not exist or be accessible
225
- }
226
- };
227
-
228
- // Only check once per file
229
- if (fileName === "index.tsx" || fileName === "index.jsx") {
230
- checkRequiredFiles();
231
- }
232
-
233
- return {};
234
- },
235
- };
@@ -1,96 +0,0 @@
1
- /**
2
- * This file is managed by Lisa.
3
- * Do not edit directly — changes will be overwritten on the next `lisa` run.
4
- */
5
-
6
- module.exports = {
7
- meta: {
8
- type: "problem",
9
- docs: {
10
- description:
11
- "Disallow return statements in View components - use arrow function shorthand",
12
- category: "Best Practices",
13
- recommended: true,
14
- },
15
- fixable: null,
16
- schema: [],
17
- messages: {
18
- noReturnInView:
19
- "View components should use arrow function shorthand: () => (...) instead of () => { return (...) }. Hoist any definitions outside of the arrow function body or into the corresponding Container.",
20
- },
21
- },
22
-
23
- create(context) {
24
- const filename = context.getFilename();
25
- const normalizedPath = filename.replace(/\\/g, "/");
26
-
27
- // Only check View.tsx and View.jsx files
28
- if (!filename.endsWith("View.tsx") && !filename.endsWith("View.jsx")) {
29
- return {};
30
- }
31
-
32
- // Check if file is in features/**/components, features/**/screens, or components directory
33
- const isFeatureComponent =
34
- normalizedPath.includes("features/") &&
35
- normalizedPath.includes("/components/");
36
- const isFeatureScreen =
37
- normalizedPath.includes("features/") &&
38
- normalizedPath.includes("/screens/");
39
- const isComponentsDir =
40
- normalizedPath.includes("/components/") &&
41
- !normalizedPath.includes("/components/ui/") &&
42
- !normalizedPath.includes("/components/custom/ui/");
43
-
44
- if (!isFeatureComponent && !isFeatureScreen && !isComponentsDir) {
45
- return {};
46
- }
47
-
48
- return {
49
- ArrowFunctionExpression(node) {
50
- // Check if this is a component (starts with capital letter or is exported)
51
- const parent = node.parent;
52
-
53
- // Helper to check if variable has a View component name
54
- const isViewComponent = name =>
55
- /^[A-Z]/.test(name) && name.includes("View");
56
-
57
- // Determine if this is a component
58
- const isComponent = (() => {
59
- // Check if it's a default export
60
- if (parent.type === "ExportDefaultDeclaration") {
61
- return true;
62
- }
63
-
64
- // Check if it's a variable declaration with PascalCase name
65
- if (
66
- parent.type === "VariableDeclarator" &&
67
- parent.id.type === "Identifier"
68
- ) {
69
- return isViewComponent(parent.id.name);
70
- }
71
-
72
- // Check if it's part of an export statement
73
- if (
74
- parent.type === "VariableDeclarator" &&
75
- parent.parent.type === "VariableDeclaration" &&
76
- parent.parent.parent.type === "ExportNamedDeclaration"
77
- ) {
78
- return isViewComponent(parent.id.name);
79
- }
80
-
81
- return false;
82
- })();
83
-
84
- if (!isComponent) return;
85
-
86
- // Check if the arrow function has a block body (any BlockStatement is forbidden)
87
- if (node.body.type === "BlockStatement") {
88
- context.report({
89
- node,
90
- messageId: "noReturnInView",
91
- });
92
- }
93
- },
94
- };
95
- },
96
- };