mcp-react-toolkit 1.0.1 → 1.2.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 (235) hide show
  1. package/README.md +146 -42
  2. package/package.json +12 -4
  3. package/tools/accessibility-checker/build/index.js +9 -5
  4. package/tools/accessibility-checker/build/index.js.map +1 -1
  5. package/tools/accessibility-checker/build/rules.d.ts.map +1 -1
  6. package/tools/accessibility-checker/build/rules.js +325 -94
  7. package/tools/accessibility-checker/build/rules.js.map +1 -1
  8. package/tools/code-modernizer/build/tools/01-convert-to-typescript.d.ts.map +1 -1
  9. package/tools/code-modernizer/build/tools/01-convert-to-typescript.js +65 -50
  10. package/tools/code-modernizer/build/tools/01-convert-to-typescript.js.map +1 -1
  11. package/tools/code-modernizer/build/types.d.ts +1 -0
  12. package/tools/code-modernizer/build/types.d.ts.map +1 -1
  13. package/tools/code-modernizer/build/utils/ast-parser.d.ts.map +1 -1
  14. package/tools/code-modernizer/build/utils/ast-parser.js +30 -14
  15. package/tools/code-modernizer/build/utils/ast-parser.js.map +1 -1
  16. package/tools/code-modernizer/build/utils/type-generator.d.ts +1 -1
  17. package/tools/code-modernizer/build/utils/type-generator.d.ts.map +1 -1
  18. package/tools/code-modernizer/build/utils/type-generator.js +72 -23
  19. package/tools/code-modernizer/build/utils/type-generator.js.map +1 -1
  20. package/tools/component-factory/build/index.js +59 -7
  21. package/tools/component-factory/build/index.js.map +1 -1
  22. package/tools/component-fixer/README.md +44 -0
  23. package/tools/component-fixer/build/index.d.ts +3 -0
  24. package/tools/component-fixer/build/index.d.ts.map +1 -0
  25. package/tools/component-fixer/build/index.js +647 -0
  26. package/tools/component-fixer/build/index.js.map +1 -0
  27. package/tools/component-fixer/build/index.test.d.ts +2 -0
  28. package/tools/component-fixer/build/index.test.d.ts.map +1 -0
  29. package/tools/component-fixer/build/index.test.js.map +1 -0
  30. package/tools/component-fixer/package.json +20 -0
  31. package/tools/component-reviewer/README.md +54 -0
  32. package/tools/component-reviewer/build/index.d.ts +39 -0
  33. package/tools/component-reviewer/build/index.d.ts.map +1 -0
  34. package/tools/component-reviewer/build/index.js +946 -0
  35. package/tools/component-reviewer/build/index.js.map +1 -0
  36. package/tools/component-reviewer/build/index.test.d.ts +2 -0
  37. package/tools/component-reviewer/build/index.test.d.ts.map +1 -0
  38. package/tools/component-reviewer/build/index.test.js.map +1 -0
  39. package/tools/component-reviewer/package.json +20 -0
  40. package/tools/dep-auditor/build/index.d.ts +1 -0
  41. package/tools/dep-auditor/build/index.d.ts.map +1 -1
  42. package/tools/dep-auditor/build/index.js +71 -16
  43. package/tools/dep-auditor/build/index.js.map +1 -1
  44. package/tools/generate-tests/build/analyzer.d.ts +14 -0
  45. package/tools/generate-tests/build/analyzer.d.ts.map +1 -1
  46. package/tools/generate-tests/build/analyzer.js +96 -42
  47. package/tools/generate-tests/build/analyzer.js.map +1 -1
  48. package/tools/generate-tests/build/generators.d.ts.map +1 -1
  49. package/tools/generate-tests/build/generators.js +304 -79
  50. package/tools/generate-tests/build/generators.js.map +1 -1
  51. package/tools/generate-tests/build/index.js +29 -10
  52. package/tools/generate-tests/build/index.js.map +1 -1
  53. package/tools/json-viewer/build/index.js +29 -6
  54. package/tools/json-viewer/build/index.js.map +1 -1
  55. package/tools/legacy-analyzer/README.md +66 -0
  56. package/tools/legacy-analyzer/build/index.d.ts +3 -0
  57. package/tools/legacy-analyzer/build/index.d.ts.map +1 -0
  58. package/tools/legacy-analyzer/build/index.js +209 -0
  59. package/tools/legacy-analyzer/build/index.js.map +1 -0
  60. package/tools/legacy-analyzer/build/index.test.d.ts +2 -0
  61. package/tools/legacy-analyzer/build/index.test.d.ts.map +1 -0
  62. package/tools/legacy-analyzer/build/index.test.js.map +1 -0
  63. package/tools/legacy-analyzer/build/tools/01-detect-project-tech.d.ts +3 -0
  64. package/tools/legacy-analyzer/build/tools/01-detect-project-tech.d.ts.map +1 -0
  65. package/tools/legacy-analyzer/build/tools/01-detect-project-tech.js +115 -0
  66. package/tools/legacy-analyzer/build/tools/01-detect-project-tech.js.map +1 -0
  67. package/tools/legacy-analyzer/build/tools/02-analyze-folder-structure.d.ts +3 -0
  68. package/tools/legacy-analyzer/build/tools/02-analyze-folder-structure.d.ts.map +1 -0
  69. package/tools/legacy-analyzer/build/tools/02-analyze-folder-structure.js +85 -0
  70. package/tools/legacy-analyzer/build/tools/02-analyze-folder-structure.js.map +1 -0
  71. package/tools/legacy-analyzer/build/tools/03-analyze-components.d.ts +3 -0
  72. package/tools/legacy-analyzer/build/tools/03-analyze-components.d.ts.map +1 -0
  73. package/tools/legacy-analyzer/build/tools/03-analyze-components.js +87 -0
  74. package/tools/legacy-analyzer/build/tools/03-analyze-components.js.map +1 -0
  75. package/tools/legacy-analyzer/build/tools/04-analyze-state-management.d.ts +3 -0
  76. package/tools/legacy-analyzer/build/tools/04-analyze-state-management.d.ts.map +1 -0
  77. package/tools/legacy-analyzer/build/tools/04-analyze-state-management.js +133 -0
  78. package/tools/legacy-analyzer/build/tools/04-analyze-state-management.js.map +1 -0
  79. package/tools/legacy-analyzer/build/tools/05-analyze-api-layer.d.ts +3 -0
  80. package/tools/legacy-analyzer/build/tools/05-analyze-api-layer.d.ts.map +1 -0
  81. package/tools/legacy-analyzer/build/tools/05-analyze-api-layer.js +160 -0
  82. package/tools/legacy-analyzer/build/tools/05-analyze-api-layer.js.map +1 -0
  83. package/tools/legacy-analyzer/build/tools/06-analyze-routing.d.ts +3 -0
  84. package/tools/legacy-analyzer/build/tools/06-analyze-routing.d.ts.map +1 -0
  85. package/tools/legacy-analyzer/build/tools/06-analyze-routing.js +150 -0
  86. package/tools/legacy-analyzer/build/tools/06-analyze-routing.js.map +1 -0
  87. package/tools/legacy-analyzer/build/tools/07-analyze-styling.d.ts +3 -0
  88. package/tools/legacy-analyzer/build/tools/07-analyze-styling.d.ts.map +1 -0
  89. package/tools/legacy-analyzer/build/tools/07-analyze-styling.js +131 -0
  90. package/tools/legacy-analyzer/build/tools/07-analyze-styling.js.map +1 -0
  91. package/tools/legacy-analyzer/build/tools/08-analyze-assets.d.ts +3 -0
  92. package/tools/legacy-analyzer/build/tools/08-analyze-assets.d.ts.map +1 -0
  93. package/tools/legacy-analyzer/build/tools/08-analyze-assets.js +85 -0
  94. package/tools/legacy-analyzer/build/tools/08-analyze-assets.js.map +1 -0
  95. package/tools/legacy-analyzer/build/tools/09-detect-anti-patterns.d.ts +3 -0
  96. package/tools/legacy-analyzer/build/tools/09-detect-anti-patterns.d.ts.map +1 -0
  97. package/tools/legacy-analyzer/build/tools/09-detect-anti-patterns.js +329 -0
  98. package/tools/legacy-analyzer/build/tools/09-detect-anti-patterns.js.map +1 -0
  99. package/tools/legacy-analyzer/build/tools/10-detect-duplication.d.ts +3 -0
  100. package/tools/legacy-analyzer/build/tools/10-detect-duplication.d.ts.map +1 -0
  101. package/tools/legacy-analyzer/build/tools/10-detect-duplication.js +192 -0
  102. package/tools/legacy-analyzer/build/tools/10-detect-duplication.js.map +1 -0
  103. package/tools/legacy-analyzer/build/tools/11-analyze-dependencies-usage.d.ts +3 -0
  104. package/tools/legacy-analyzer/build/tools/11-analyze-dependencies-usage.d.ts.map +1 -0
  105. package/tools/legacy-analyzer/build/tools/11-analyze-dependencies-usage.js +232 -0
  106. package/tools/legacy-analyzer/build/tools/11-analyze-dependencies-usage.js.map +1 -0
  107. package/tools/legacy-analyzer/build/tools/12-analyze-legacy-app.d.ts +3 -0
  108. package/tools/legacy-analyzer/build/tools/12-analyze-legacy-app.d.ts.map +1 -0
  109. package/tools/legacy-analyzer/build/tools/12-analyze-legacy-app.js +247 -0
  110. package/tools/legacy-analyzer/build/tools/12-analyze-legacy-app.js.map +1 -0
  111. package/tools/legacy-analyzer/build/tools/13-detect-features.d.ts +3 -0
  112. package/tools/legacy-analyzer/build/tools/13-detect-features.d.ts.map +1 -0
  113. package/tools/legacy-analyzer/build/tools/13-detect-features.js +141 -0
  114. package/tools/legacy-analyzer/build/tools/13-detect-features.js.map +1 -0
  115. package/tools/legacy-analyzer/build/tools/14-classify-files.d.ts +3 -0
  116. package/tools/legacy-analyzer/build/tools/14-classify-files.d.ts.map +1 -0
  117. package/tools/legacy-analyzer/build/tools/14-classify-files.js +76 -0
  118. package/tools/legacy-analyzer/build/tools/14-classify-files.js.map +1 -0
  119. package/tools/legacy-analyzer/build/tools/15-detect-shared-modules.d.ts +3 -0
  120. package/tools/legacy-analyzer/build/tools/15-detect-shared-modules.d.ts.map +1 -0
  121. package/tools/legacy-analyzer/build/tools/15-detect-shared-modules.js +70 -0
  122. package/tools/legacy-analyzer/build/tools/15-detect-shared-modules.js.map +1 -0
  123. package/tools/legacy-analyzer/build/tools/16-design-target-structure.d.ts +3 -0
  124. package/tools/legacy-analyzer/build/tools/16-design-target-structure.d.ts.map +1 -0
  125. package/tools/legacy-analyzer/build/tools/16-design-target-structure.js +26 -0
  126. package/tools/legacy-analyzer/build/tools/16-design-target-structure.js.map +1 -0
  127. package/tools/legacy-analyzer/build/tools/17-map-files-to-target.d.ts +3 -0
  128. package/tools/legacy-analyzer/build/tools/17-map-files-to-target.d.ts.map +1 -0
  129. package/tools/legacy-analyzer/build/tools/17-map-files-to-target.js +108 -0
  130. package/tools/legacy-analyzer/build/tools/17-map-files-to-target.js.map +1 -0
  131. package/tools/legacy-analyzer/build/tools/18-detect-boundary-violations.d.ts +3 -0
  132. package/tools/legacy-analyzer/build/tools/18-detect-boundary-violations.d.ts.map +1 -0
  133. package/tools/legacy-analyzer/build/tools/18-detect-boundary-violations.js +137 -0
  134. package/tools/legacy-analyzer/build/tools/18-detect-boundary-violations.js.map +1 -0
  135. package/tools/legacy-analyzer/build/tools/19-suggest-module-splitting.d.ts +3 -0
  136. package/tools/legacy-analyzer/build/tools/19-suggest-module-splitting.d.ts.map +1 -0
  137. package/tools/legacy-analyzer/build/tools/19-suggest-module-splitting.js +160 -0
  138. package/tools/legacy-analyzer/build/tools/19-suggest-module-splitting.js.map +1 -0
  139. package/tools/legacy-analyzer/build/tools/20-naming-standardizer.d.ts +3 -0
  140. package/tools/legacy-analyzer/build/tools/20-naming-standardizer.d.ts.map +1 -0
  141. package/tools/legacy-analyzer/build/tools/20-naming-standardizer.js +162 -0
  142. package/tools/legacy-analyzer/build/tools/20-naming-standardizer.js.map +1 -0
  143. package/tools/legacy-analyzer/build/tools/21-generate-refactor-plan.d.ts +3 -0
  144. package/tools/legacy-analyzer/build/tools/21-generate-refactor-plan.d.ts.map +1 -0
  145. package/tools/legacy-analyzer/build/tools/21-generate-refactor-plan.js +108 -0
  146. package/tools/legacy-analyzer/build/tools/21-generate-refactor-plan.js.map +1 -0
  147. package/tools/legacy-analyzer/build/tools/22-refactor-folder-structure.d.ts +3 -0
  148. package/tools/legacy-analyzer/build/tools/22-refactor-folder-structure.d.ts.map +1 -0
  149. package/tools/legacy-analyzer/build/tools/22-refactor-folder-structure.js +98 -0
  150. package/tools/legacy-analyzer/build/tools/22-refactor-folder-structure.js.map +1 -0
  151. package/tools/legacy-analyzer/build/types.d.ts +413 -0
  152. package/tools/legacy-analyzer/build/types.d.ts.map +1 -0
  153. package/tools/legacy-analyzer/build/types.js +12 -0
  154. package/tools/legacy-analyzer/build/types.js.map +1 -0
  155. package/tools/legacy-analyzer/build/utils/ast-parser.d.ts +34 -0
  156. package/tools/legacy-analyzer/build/utils/ast-parser.d.ts.map +1 -0
  157. package/tools/legacy-analyzer/build/utils/ast-parser.js +394 -0
  158. package/tools/legacy-analyzer/build/utils/ast-parser.js.map +1 -0
  159. package/tools/legacy-analyzer/build/utils/file-scanner.d.ts +51 -0
  160. package/tools/legacy-analyzer/build/utils/file-scanner.d.ts.map +1 -0
  161. package/tools/legacy-analyzer/build/utils/file-scanner.js +174 -0
  162. package/tools/legacy-analyzer/build/utils/file-scanner.js.map +1 -0
  163. package/tools/legacy-analyzer/build/utils/import-tracker.d.ts +38 -0
  164. package/tools/legacy-analyzer/build/utils/import-tracker.d.ts.map +1 -0
  165. package/tools/legacy-analyzer/build/utils/import-tracker.js +194 -0
  166. package/tools/legacy-analyzer/build/utils/import-tracker.js.map +1 -0
  167. package/tools/legacy-analyzer/build/utils/refactor-helpers.d.ts +88 -0
  168. package/tools/legacy-analyzer/build/utils/refactor-helpers.d.ts.map +1 -0
  169. package/tools/legacy-analyzer/build/utils/refactor-helpers.js +538 -0
  170. package/tools/legacy-analyzer/build/utils/refactor-helpers.js.map +1 -0
  171. package/tools/legacy-analyzer/package.json +20 -0
  172. package/tools/lighthouse-runner/README.md +45 -0
  173. package/tools/lighthouse-runner/build/index.d.ts +6 -0
  174. package/tools/lighthouse-runner/build/index.d.ts.map +1 -0
  175. package/tools/lighthouse-runner/build/index.js +295 -0
  176. package/tools/lighthouse-runner/build/index.js.map +1 -0
  177. package/tools/lighthouse-runner/build/index.test.d.ts +2 -0
  178. package/tools/lighthouse-runner/build/index.test.d.ts.map +1 -0
  179. package/tools/lighthouse-runner/build/index.test.js.map +1 -0
  180. package/tools/lighthouse-runner/package.json +20 -0
  181. package/tools/monorepo-manager/build/utils.d.ts.map +1 -1
  182. package/tools/monorepo-manager/build/utils.js +12 -9
  183. package/tools/monorepo-manager/build/utils.js.map +1 -1
  184. package/tools/performance-audit/README.md +37 -0
  185. package/tools/performance-audit/build/index.d.ts +13 -0
  186. package/tools/performance-audit/build/index.d.ts.map +1 -0
  187. package/tools/performance-audit/build/index.js +311 -0
  188. package/tools/performance-audit/build/index.js.map +1 -0
  189. package/tools/performance-audit/build/index.test.d.ts +2 -0
  190. package/tools/performance-audit/build/index.test.d.ts.map +1 -0
  191. package/tools/performance-audit/build/index.test.js.map +1 -0
  192. package/tools/performance-audit/package.json +20 -0
  193. package/tools/quality-pipeline/build/index.js +55 -15
  194. package/tools/quality-pipeline/build/index.js.map +1 -1
  195. package/tools/render-analyzer/README.md +43 -0
  196. package/tools/render-analyzer/build/index.d.ts +25 -0
  197. package/tools/render-analyzer/build/index.d.ts.map +1 -0
  198. package/tools/render-analyzer/build/index.js +342 -0
  199. package/tools/render-analyzer/build/index.js.map +1 -0
  200. package/tools/render-analyzer/build/index.test.d.ts +2 -0
  201. package/tools/render-analyzer/build/index.test.d.ts.map +1 -0
  202. package/tools/render-analyzer/build/index.test.js.map +1 -0
  203. package/tools/render-analyzer/package.json +20 -0
  204. package/tools/shared/build/fs.d.ts +8 -0
  205. package/tools/shared/build/fs.d.ts.map +1 -0
  206. package/tools/shared/build/fs.js +45 -0
  207. package/tools/shared/build/fs.js.map +1 -0
  208. package/tools/shared/build/index.d.ts +1 -0
  209. package/tools/shared/build/index.d.ts.map +1 -1
  210. package/tools/shared/build/index.js +1 -0
  211. package/tools/shared/build/index.js.map +1 -1
  212. package/tools/storybook-generator/README.md +39 -0
  213. package/tools/storybook-generator/build/index.d.ts +13 -0
  214. package/tools/storybook-generator/build/index.d.ts.map +1 -0
  215. package/tools/storybook-generator/build/index.js +478 -0
  216. package/tools/storybook-generator/build/index.js.map +1 -0
  217. package/tools/storybook-generator/build/index.test.d.ts +2 -0
  218. package/tools/storybook-generator/build/index.test.d.ts.map +1 -0
  219. package/tools/storybook-generator/build/index.test.js.map +1 -0
  220. package/tools/storybook-generator/package.json +20 -0
  221. package/tools/test-gap-analyzer/README.md +41 -0
  222. package/tools/test-gap-analyzer/build/index.d.ts +20 -0
  223. package/tools/test-gap-analyzer/build/index.d.ts.map +1 -0
  224. package/tools/test-gap-analyzer/build/index.js +371 -0
  225. package/tools/test-gap-analyzer/build/index.js.map +1 -0
  226. package/tools/test-gap-analyzer/build/index.test.d.ts +2 -0
  227. package/tools/test-gap-analyzer/build/index.test.d.ts.map +1 -0
  228. package/tools/test-gap-analyzer/build/index.test.js.map +1 -0
  229. package/tools/test-gap-analyzer/package.json +20 -0
  230. package/tools/typescript-enforcer/build/scanner.d.ts.map +1 -1
  231. package/tools/typescript-enforcer/build/scanner.js +13 -1
  232. package/tools/typescript-enforcer/build/scanner.js.map +1 -1
  233. package/tools/typescript-enforcer/build/types.d.ts +1 -0
  234. package/tools/typescript-enforcer/build/types.d.ts.map +1 -1
  235. package/mcp-publisher +0 -0
@@ -0,0 +1,43 @@
1
+ # render-analyzer
2
+
3
+ MCP server that profiles React components for unnecessary re-renders, missing memoization, and inline object/function patterns.
4
+
5
+ ## Tools
6
+
7
+ | Tool | What it does |
8
+ |---|---|
9
+ | `detect_rerenders` | Scan a directory for inline objects, inline functions, and missing `React.memo` |
10
+ | `check_memo` | Report memoization rate — how many components use `memo`, `useMemo`, `useCallback` |
11
+ | `analyze_props` | Analyze prop counts and patterns across all components |
12
+
13
+ ## Usage
14
+
15
+ ```sh
16
+ echo '{"jsonrpc":"2.0","id":1,"method":"tools/call","params":{"name":"detect_rerenders","arguments":{"path":"/path/to/src"}}}' \
17
+ | node build/index.js
18
+ ```
19
+
20
+ ## Output
21
+
22
+ ```json
23
+ {
24
+ "success": true,
25
+ "summary": { "totalComponents": 40, "totalIssues": 12, "componentsWithIssues": 8 },
26
+ "profiles": [
27
+ {
28
+ "name": "PostCard",
29
+ "hasMemo": false,
30
+ "inlineObjects": 3,
31
+ "inlineFunctions": 2,
32
+ "issues": [...]
33
+ }
34
+ ]
35
+ }
36
+ ```
37
+
38
+ ## Build & test
39
+
40
+ ```sh
41
+ npm run build
42
+ npm test
43
+ ```
@@ -0,0 +1,25 @@
1
+ #!/usr/bin/env node
2
+ interface RenderIssue {
3
+ type: 'missing-memo' | 'missing-usememo' | 'missing-usecallback' | 'inline-object' | 'inline-array' | 'inline-function' | 'new-object-prop' | 'context-value';
4
+ component: string;
5
+ file: string;
6
+ line: number;
7
+ description: string;
8
+ severity: 'high' | 'medium' | 'low';
9
+ fix: string;
10
+ }
11
+ interface ComponentRenderProfile {
12
+ name: string;
13
+ file: string;
14
+ hasMemo: boolean;
15
+ hasUseMemo: boolean;
16
+ hasUseCallback: boolean;
17
+ propsCount: number;
18
+ inlineObjects: number;
19
+ inlineFunctions: number;
20
+ issues: RenderIssue[];
21
+ }
22
+ export declare function extractComponents(content: string): string[];
23
+ export declare function analyzeComponent(content: string, componentName: string, filePath: string): ComponentRenderProfile;
24
+ export {};
25
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AASA,UAAU,WAAW;IACnB,IAAI,EAAE,cAAc,GAAG,iBAAiB,GAAG,qBAAqB,GAAG,eAAe,GAAG,cAAc,GAAG,iBAAiB,GAAG,iBAAiB,GAAG,eAAe,CAAC;IAC9J,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAC;IACpC,GAAG,EAAE,MAAM,CAAC;CACb;AAED,UAAU,sBAAsB;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,OAAO,CAAC;IACpB,cAAc,EAAE,OAAO,CAAC;IACxB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,EAAE,WAAW,EAAE,CAAC;CACvB;AAwBD,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,CAQ3D;AAED,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,sBAAsB,CAgKjH"}
@@ -0,0 +1,342 @@
1
+ #!/usr/bin/env node
2
+ import { McpServerBase, safeReadFile } from '@mcp-showcase/shared';
3
+ import * as fs from 'fs';
4
+ import * as path from 'path';
5
+ // ============================================================================
6
+ // SOURCE ANALYSIS
7
+ // ============================================================================
8
+ function scanDirectory(dir) {
9
+ const files = [];
10
+ if (!fs.existsSync(dir))
11
+ return files;
12
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
13
+ for (const entry of entries) {
14
+ if (entry.isSymbolicLink())
15
+ continue;
16
+ const fullPath = path.join(dir, entry.name);
17
+ if (entry.isDirectory()) {
18
+ if (['node_modules', 'build', 'dist', '.next', '__tests__', '.turbo', '.git'].includes(entry.name))
19
+ continue;
20
+ files.push(...scanDirectory(fullPath));
21
+ }
22
+ else if (entry.name.match(/\.(tsx|jsx)$/)) {
23
+ if (entry.name.includes('.test.') || entry.name.includes('.spec.') || entry.name.includes('.stories.'))
24
+ continue;
25
+ files.push(fullPath);
26
+ }
27
+ }
28
+ return files;
29
+ }
30
+ export function extractComponents(content) {
31
+ const components = [];
32
+ const fnRegex = /(?:export\s+(?:default\s+)?)?(?:const|function)\s+([A-Z]\w+)/g;
33
+ let match;
34
+ while ((match = fnRegex.exec(content)) !== null) {
35
+ if (!components.includes(match[1]))
36
+ components.push(match[1]);
37
+ }
38
+ return components;
39
+ }
40
+ export function analyzeComponent(content, componentName, filePath) {
41
+ const hasMemo = content.includes(`memo(${componentName})`) || content.includes('React.memo');
42
+ const hasUseMemo = content.includes('useMemo');
43
+ const hasUseCallback = content.includes('useCallback');
44
+ let inlineObjects = 0;
45
+ let inlineFunctions = 0;
46
+ let propsCount = 0;
47
+ const issues = [];
48
+ const compStart = content.indexOf(componentName);
49
+ if (compStart === -1) {
50
+ return { name: componentName, file: filePath, hasMemo, hasUseMemo, hasUseCallback, propsCount, inlineObjects, inlineFunctions, issues };
51
+ }
52
+ const componentBody = content.slice(compStart);
53
+ const bodyLines = componentBody.split('\n');
54
+ for (let i = 0; i < bodyLines.length; i++) {
55
+ const line = bodyLines[i];
56
+ const lineNum = content.slice(0, compStart).split('\n').length + i;
57
+ // Inline object literals as props: style={{...}}
58
+ const inlineObjMatches = line.match(/\{\{[^}]+\}\}/g);
59
+ if (inlineObjMatches) {
60
+ inlineObjects += inlineObjMatches.length;
61
+ for (const _m of inlineObjMatches) {
62
+ issues.push({
63
+ type: 'inline-object',
64
+ component: componentName,
65
+ file: filePath,
66
+ line: lineNum,
67
+ description: 'Inline object literal creates a new reference on every render, causing child re-renders.',
68
+ severity: 'medium',
69
+ fix: 'Extract to a const outside the component or wrap with useMemo:\nconst style = useMemo(() => ({ /* styles */ }), []);',
70
+ });
71
+ }
72
+ }
73
+ // Inline array literals as props: items={[...]}
74
+ const inlineArrMatches = line.match(/=\s*\[[^\]]*\]/g);
75
+ if (inlineArrMatches && line.includes('<')) {
76
+ inlineObjects += inlineArrMatches.length;
77
+ for (const _m of inlineArrMatches) {
78
+ issues.push({
79
+ type: 'inline-array',
80
+ component: componentName,
81
+ file: filePath,
82
+ line: lineNum,
83
+ description: 'Inline array literal creates a new reference on every render.',
84
+ severity: 'medium',
85
+ fix: 'Extract to useMemo:\nconst items = useMemo(() => [...], [deps]);',
86
+ });
87
+ }
88
+ }
89
+ // Inline arrow functions as props: onClick={() => ...}
90
+ const inlineFnMatches = line.match(/on\w+=\{(?:\([^)]*\)\s*=>|[\w]+\s*=>)/g);
91
+ if (inlineFnMatches) {
92
+ inlineFunctions += inlineFnMatches.length;
93
+ for (const _m of inlineFnMatches) {
94
+ issues.push({
95
+ type: 'inline-function',
96
+ component: componentName,
97
+ file: filePath,
98
+ line: lineNum,
99
+ description: 'Inline function creates a new reference on every render. Use useCallback to memoize.',
100
+ severity: 'medium',
101
+ fix: 'const handler = useCallback((e) => { /* handler logic */ }, [deps]);',
102
+ });
103
+ }
104
+ }
105
+ // Count props
106
+ const propsMatch = line.match(/\(\s*\{\s*([^}]+)\s*\}/);
107
+ if (propsMatch) {
108
+ propsCount = propsMatch[1].split(',').length;
109
+ }
110
+ // new Date/Object inside component
111
+ if (line.match(/new\s+(Date|Object|Array|Map|Set|RegExp)\(/)) {
112
+ issues.push({
113
+ type: 'new-object-prop',
114
+ component: componentName,
115
+ file: filePath,
116
+ line: lineNum,
117
+ description: 'Creating new object instance on every render. Move outside component or memoize.',
118
+ severity: 'low',
119
+ fix: 'const obj = useMemo(() => new Date(), []);',
120
+ });
121
+ }
122
+ // Context value without useMemo
123
+ if (line.includes('value=') && line.includes('{') && !hasUseMemo) {
124
+ issues.push({
125
+ type: 'context-value',
126
+ component: componentName,
127
+ file: filePath,
128
+ line: lineNum,
129
+ description: 'Context value object is recreated on every render. Wrap with useMemo.',
130
+ severity: 'high',
131
+ fix: 'const contextValue = useMemo(() => ({ prop1, prop2 }), [prop1, prop2]);',
132
+ });
133
+ }
134
+ }
135
+ // Missing memo check (only flag if component has props)
136
+ if (!hasMemo && !content.includes('export default memo(') && propsCount > 0) {
137
+ issues.push({
138
+ type: 'missing-memo',
139
+ component: componentName,
140
+ file: filePath,
141
+ line: 1,
142
+ description: 'Component is not wrapped with React.memo. It will re-render whenever parent re-renders, even if props haven\'t changed.',
143
+ severity: 'medium',
144
+ fix: `export default memo(${componentName});`,
145
+ });
146
+ }
147
+ // Missing key prop in .map() renders
148
+ const mapMatches = [...componentBody.matchAll(/\.map\s*\(\s*(?:\([^)]*\)|[\w]+)\s*=>/g)];
149
+ for (const mapMatch of mapMatches) {
150
+ const mapIdx = mapMatch.index ?? 0;
151
+ const mapBlock = componentBody.slice(mapIdx, mapIdx + 300);
152
+ // Check if the returned JSX element has a key prop
153
+ if (!mapBlock.includes('key=') && mapBlock.includes('<')) {
154
+ const lineNum = content.slice(0, compStart + mapIdx).split('\n').length;
155
+ issues.push({
156
+ type: 'inline-function',
157
+ component: componentName,
158
+ file: filePath,
159
+ line: lineNum,
160
+ description: '.map() render missing key prop. React uses key to identify list items — missing keys cause unnecessary re-renders and reconciliation bugs.',
161
+ severity: 'high',
162
+ fix: 'Add a stable key prop to the root element: items.map((item) => <Component key={item.id} />)',
163
+ });
164
+ }
165
+ }
166
+ // useEffect with no dependency array (runs on every render)
167
+ const effectMatches = [...componentBody.matchAll(/useEffect\s*\(\s*(?:async\s*)?\(\s*\)\s*=>/g)];
168
+ for (const effectMatch of effectMatches) {
169
+ const effectIdx = effectMatch.index ?? 0;
170
+ const effectBlock = componentBody.slice(effectIdx, effectIdx + 200);
171
+ // If no closing ", [" or ", []" pattern → missing deps array
172
+ if (!effectBlock.includes(', [') && !effectBlock.includes(',[')) {
173
+ const lineNum = content.slice(0, compStart + effectIdx).split('\n').length;
174
+ issues.push({
175
+ type: 'missing-usecallback',
176
+ component: componentName,
177
+ file: filePath,
178
+ line: lineNum,
179
+ description: 'useEffect missing dependency array — runs on every render. This is likely a bug or performance issue.',
180
+ severity: 'high',
181
+ fix: 'Add dependency array as second argument: useEffect(() => { ... }, [dep1, dep2])\nUse [] for mount-only effects.',
182
+ });
183
+ }
184
+ }
185
+ return { name: componentName, file: filePath, hasMemo, hasUseMemo, hasUseCallback, propsCount, inlineObjects, inlineFunctions, issues };
186
+ }
187
+ // ============================================================================
188
+ // MAIN SERVER
189
+ // ============================================================================
190
+ class RenderAnalyzerServer extends McpServerBase {
191
+ constructor() {
192
+ super({ name: 'render-analyzer', version: '1.0.0' });
193
+ }
194
+ registerTools() {
195
+ this.addTool('detect_rerenders', 'Analyze React component files for unnecessary re-render patterns: inline objects/arrays/functions, missing memo, context value issues.', {
196
+ type: 'object',
197
+ properties: {
198
+ path: { type: 'string', description: 'Path to component file or directory to analyze' },
199
+ severity: { type: 'string', enum: ['high', 'medium', 'low', 'all'], description: 'Minimum severity to report (default: all)' },
200
+ },
201
+ required: ['path'],
202
+ }, (args) => this.handleDetectRerenders(args));
203
+ this.addTool('check_memo', 'Check which components are wrapped with React.memo, use useMemo, or useCallback — and which are not.', {
204
+ type: 'object',
205
+ properties: {
206
+ path: { type: 'string', description: 'Path to component file or directory' },
207
+ },
208
+ required: ['path'],
209
+ }, (args) => this.handleCheckMemo(args));
210
+ this.addTool('analyze_props', 'Find components that pass inline objects or functions as props — the most common cause of unnecessary child re-renders.', {
211
+ type: 'object',
212
+ properties: {
213
+ path: { type: 'string', description: 'Path to component file or directory' },
214
+ },
215
+ required: ['path'],
216
+ }, (args) => this.handleAnalyzeProps(args));
217
+ }
218
+ async handleDetectRerenders(args) {
219
+ const { path: targetPath, severity = 'all' } = args;
220
+ try {
221
+ const stat = fs.statSync(targetPath);
222
+ const files = stat.isDirectory() ? scanDirectory(targetPath) : [targetPath];
223
+ const severityOrder = { high: 0, medium: 1, low: 2 };
224
+ const minSeverity = severityOrder[severity] ?? 2;
225
+ const profiles = [];
226
+ let totalIssues = 0;
227
+ for (const file of files) {
228
+ const content = safeReadFile(file);
229
+ if (content === null)
230
+ continue;
231
+ const components = extractComponents(content);
232
+ for (const comp of components) {
233
+ const profile = analyzeComponent(content, comp, file);
234
+ const filteredIssues = profile.issues.filter(i => severityOrder[i.severity] <= minSeverity);
235
+ profile.issues = filteredIssues;
236
+ totalIssues += filteredIssues.length;
237
+ profiles.push(profile);
238
+ }
239
+ }
240
+ return this.success({
241
+ summary: {
242
+ totalComponents: profiles.length,
243
+ totalIssues,
244
+ componentsWithIssues: profiles.filter(p => p.issues.length > 0).length,
245
+ },
246
+ profiles: profiles.filter(p => p.issues.length > 0),
247
+ });
248
+ }
249
+ catch (error) {
250
+ return this.error(error);
251
+ }
252
+ }
253
+ async handleCheckMemo(args) {
254
+ const { path: targetPath } = args;
255
+ try {
256
+ const stat = fs.statSync(targetPath);
257
+ const files = stat.isDirectory() ? scanDirectory(targetPath) : [targetPath];
258
+ const results = [];
259
+ let totalComponents = 0;
260
+ let memoizedCount = 0;
261
+ let useMemoCount = 0;
262
+ let useCallbackCount = 0;
263
+ for (const file of files) {
264
+ const content = safeReadFile(file);
265
+ if (content === null)
266
+ continue;
267
+ const components = extractComponents(content);
268
+ for (const comp of components) {
269
+ totalComponents++;
270
+ const profile = analyzeComponent(content, comp, file);
271
+ if (profile.hasMemo)
272
+ memoizedCount++;
273
+ if (profile.hasUseMemo)
274
+ useMemoCount++;
275
+ if (profile.hasUseCallback)
276
+ useCallbackCount++;
277
+ results.push({
278
+ component: comp,
279
+ file,
280
+ hasMemo: profile.hasMemo,
281
+ hasUseMemo: profile.hasUseMemo,
282
+ hasUseCallback: profile.hasUseCallback,
283
+ propsCount: profile.propsCount,
284
+ });
285
+ }
286
+ }
287
+ return this.success({
288
+ summary: {
289
+ totalComponents,
290
+ memoized: memoizedCount,
291
+ notMemoized: totalComponents - memoizedCount,
292
+ useMemoUsage: useMemoCount,
293
+ useCallbackUsage: useCallbackCount,
294
+ memoizationRate: totalComponents > 0 ? Math.round((memoizedCount / totalComponents) * 100) : 100,
295
+ },
296
+ components: results,
297
+ });
298
+ }
299
+ catch (error) {
300
+ return this.error(error);
301
+ }
302
+ }
303
+ async handleAnalyzeProps(args) {
304
+ const { path: targetPath } = args;
305
+ try {
306
+ const stat = fs.statSync(targetPath);
307
+ const files = stat.isDirectory() ? scanDirectory(targetPath) : [targetPath];
308
+ const results = [];
309
+ for (const file of files) {
310
+ const content = safeReadFile(file);
311
+ if (content === null)
312
+ continue;
313
+ const components = extractComponents(content);
314
+ for (const comp of components) {
315
+ const profile = analyzeComponent(content, comp, file);
316
+ if (profile.inlineObjects > 0 || profile.inlineFunctions > 0) {
317
+ results.push({
318
+ component: comp,
319
+ file,
320
+ inlineObjects: profile.inlineObjects,
321
+ inlineFunctions: profile.inlineFunctions,
322
+ propsCount: profile.propsCount,
323
+ issues: profile.issues.filter(i => ['inline-object', 'inline-array', 'inline-function'].includes(i.type)),
324
+ });
325
+ }
326
+ }
327
+ }
328
+ return this.success({
329
+ componentsWithPropIssues: results.length,
330
+ results,
331
+ });
332
+ }
333
+ catch (error) {
334
+ return this.error(error);
335
+ }
336
+ }
337
+ }
338
+ // ============================================================================
339
+ // ENTRY POINT
340
+ // ============================================================================
341
+ new RenderAnalyzerServer().run().catch(console.error);
342
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../src/index.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../src/index.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ {
2
+ "name": "@mcp-showcase/render-analyzer",
3
+ "version": "1.0.0",
4
+ "type": "module",
5
+ "main": "./build/index.js",
6
+ "scripts": {
7
+ "build": "tsc && chmod +x build/index.js",
8
+ "dev": "tsc --watch",
9
+ "test": "vitest run"
10
+ },
11
+ "dependencies": {
12
+ "@mcp-showcase/shared": "*",
13
+ "@modelcontextprotocol/sdk": "^1.12.0"
14
+ },
15
+ "devDependencies": {
16
+ "@types/node": "^20.0.0",
17
+ "typescript": "^5.0.0",
18
+ "vitest": "^2.0.0"
19
+ }
20
+ }
@@ -0,0 +1,8 @@
1
+ export declare const MAX_FILE_BYTES: number;
2
+ export declare const DEFAULT_SKIP_DIRS: Set<string>;
3
+ export declare function safeReadJson<T>(filePath: string): T | null;
4
+ export declare function safeReadFile(filePath: string): string | null;
5
+ export declare function isNextJsProject(dir: string): boolean;
6
+ export declare const NEXTJS_ROUTE_FILES: Set<string>;
7
+ export declare function isServerComponent(filePath: string, content: string): boolean;
8
+ //# sourceMappingURL=fs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fs.d.ts","sourceRoot":"","sources":["../src/fs.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,cAAc,QAAmB,CAAC;AAE/C,eAAO,MAAM,iBAAiB,aAG5B,CAAC;AAEH,wBAAgB,YAAY,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,GAAG,CAAC,GAAG,IAAI,CAO1D;AAED,wBAAgB,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAQ5D;AAED,wBAAgB,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAMpD;AAED,eAAO,MAAM,kBAAkB,aAK7B,CAAC;AAEH,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAI5E"}
@@ -0,0 +1,45 @@
1
+ import * as fs from 'fs';
2
+ import * as path from 'path';
3
+ export const MAX_FILE_BYTES = 10 * 1024 * 1024; // 10 MB
4
+ export const DEFAULT_SKIP_DIRS = new Set([
5
+ 'node_modules', 'build', 'dist', '.next', '.turbo', '__tests__',
6
+ '.git', 'coverage', '.cache', 'out', '.vercel', '.svelte-kit',
7
+ ]);
8
+ export function safeReadJson(filePath) {
9
+ try {
10
+ const raw = fs.readFileSync(filePath, 'utf-8');
11
+ return JSON.parse(raw);
12
+ }
13
+ catch {
14
+ return null;
15
+ }
16
+ }
17
+ export function safeReadFile(filePath) {
18
+ try {
19
+ const stat = fs.statSync(filePath);
20
+ if (stat.size > MAX_FILE_BYTES)
21
+ return null;
22
+ return fs.readFileSync(filePath, 'utf-8');
23
+ }
24
+ catch {
25
+ return null;
26
+ }
27
+ }
28
+ export function isNextJsProject(dir) {
29
+ return (fs.existsSync(path.join(dir, 'next.config.js')) ||
30
+ fs.existsSync(path.join(dir, 'next.config.ts')) ||
31
+ fs.existsSync(path.join(dir, 'next.config.mjs')));
32
+ }
33
+ export const NEXTJS_ROUTE_FILES = new Set([
34
+ 'page.tsx', 'page.ts', 'layout.tsx', 'layout.ts',
35
+ 'loading.tsx', 'loading.ts', 'error.tsx', 'error.ts',
36
+ 'not-found.tsx', 'not-found.ts', 'template.tsx', 'template.ts',
37
+ 'route.ts', 'route.tsx',
38
+ ]);
39
+ export function isServerComponent(filePath, content) {
40
+ const name = path.basename(filePath);
41
+ if (!NEXTJS_ROUTE_FILES.has(name))
42
+ return false;
43
+ return !content.includes("'use client'") && !content.includes('"use client"');
44
+ }
45
+ //# sourceMappingURL=fs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fs.js","sourceRoot":"","sources":["../src/fs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAE7B,MAAM,CAAC,MAAM,cAAc,GAAG,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC,CAAC,QAAQ;AAExD,MAAM,CAAC,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAAC;IACvC,cAAc,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,WAAW;IAC/D,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,aAAa;CAC9D,CAAC,CAAC;AAEH,MAAM,UAAU,YAAY,CAAI,QAAgB;IAC9C,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QAC/C,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAM,CAAC;IAC9B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,QAAgB;IAC3C,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACnC,IAAI,IAAI,CAAC,IAAI,GAAG,cAAc;YAAE,OAAO,IAAI,CAAC;QAC5C,OAAO,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,GAAW;IACzC,OAAO,CACL,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;QAC/C,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;QAC/C,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC,CACjD,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,kBAAkB,GAAG,IAAI,GAAG,CAAC;IACxC,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW;IAChD,aAAa,EAAE,YAAY,EAAE,WAAW,EAAE,UAAU;IACpD,eAAe,EAAE,cAAc,EAAE,cAAc,EAAE,aAAa;IAC9D,UAAU,EAAE,WAAW;CACxB,CAAC,CAAC;AAEH,MAAM,UAAU,iBAAiB,CAAC,QAAgB,EAAE,OAAe;IACjE,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IACrC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC;QAAE,OAAO,KAAK,CAAC;IAChD,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;AAChF,CAAC"}
@@ -1,4 +1,5 @@
1
1
  export * from './types.js';
2
2
  export { McpServerBase } from './McpServerBase.js';
3
3
  export { ToolRegistry } from './ToolRegistry.js';
4
+ export { safeReadJson, safeReadFile, isNextJsProject, isServerComponent, NEXTJS_ROUTE_FILES, DEFAULT_SKIP_DIRS, MAX_FILE_BYTES, } from './fs.js';
4
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EACL,YAAY,EACZ,YAAY,EACZ,eAAe,EACf,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,cAAc,GACf,MAAM,SAAS,CAAC"}
@@ -1,4 +1,5 @@
1
1
  export * from './types.js';
2
2
  export { McpServerBase } from './McpServerBase.js';
3
3
  export { ToolRegistry } from './ToolRegistry.js';
4
+ export { safeReadJson, safeReadFile, isNextJsProject, isServerComponent, NEXTJS_ROUTE_FILES, DEFAULT_SKIP_DIRS, MAX_FILE_BYTES, } from './fs.js';
4
5
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EACL,YAAY,EACZ,YAAY,EACZ,eAAe,EACf,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,cAAc,GACf,MAAM,SAAS,CAAC"}
@@ -0,0 +1,39 @@
1
+ # storybook-generator
2
+
3
+ MCP server that auto-generates comprehensive Storybook stories for React components — Default, Playground, per-variant, per-size, callbacks, accessibility, and interactive play functions.
4
+
5
+ ## Tools
6
+
7
+ | Tool | What it does |
8
+ |---|---|
9
+ | `generate_stories` | Generate `.stories.tsx` for a component file or directory |
10
+ | `check_story_coverage` | Report which components have stories and which don't |
11
+
12
+ ## Usage
13
+
14
+ ```sh
15
+ # Generate stories for a single component
16
+ echo '{"jsonrpc":"2.0","id":1,"method":"tools/call","params":{"name":"generate_stories","arguments":{"path":"src/components/Button.tsx"}}}' \
17
+ | node build/index.js
18
+
19
+ # Check coverage across a directory
20
+ echo '{"jsonrpc":"2.0","id":1,"method":"tools/call","params":{"name":"check_story_coverage","arguments":{"path":"src/components"}}}' \
21
+ | node build/index.js
22
+ ```
23
+
24
+ ## Generated stories include
25
+
26
+ - `Default` — basic render with sensible defaults
27
+ - `Playground` — full `argTypes` enabling Storybook controls
28
+ - Per-variant stories (extracted from union types or `cva()`)
29
+ - Per-size stories
30
+ - `Disabled` / `Loading` states (when props exist)
31
+ - `WithCallbacks` — `vi.fn()` handlers shown in Actions panel
32
+ - `play` function for interactive components (button, input)
33
+
34
+ ## Build & test
35
+
36
+ ```sh
37
+ npm run build
38
+ npm test
39
+ ```
@@ -0,0 +1,13 @@
1
+ #!/usr/bin/env node
2
+ interface PropField {
3
+ name: string;
4
+ type: string;
5
+ optional: boolean;
6
+ }
7
+ export declare function extractPropsInterface(content: string, componentName: string): PropField[];
8
+ export declare function extractVariantValues(content: string, key: 'variant' | 'size'): string[];
9
+ export declare function propTypeToControl(propType: string): string;
10
+ export declare function generateArgTypes(props: PropField[]): string;
11
+ export declare function getMockValue(propName: string, propType: string, componentName: string): string | null;
12
+ export {};
13
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AASA,UAAU,SAAS;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,OAAO,CAAC;CACnB;AA2CD,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,SAAS,EAAE,CAqBzF;AAED,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,GAAG,MAAM,GAAG,MAAM,EAAE,CAwBvF;AAoCD,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAY1D;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,MAAM,CAY3D;AAMD,wBAAgB,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAwDrG"}