mcp-react-toolkit 1.0.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 (228) hide show
  1. package/CONTRIBUTING.md +157 -0
  2. package/HOW_IT_WORKS.md +270 -0
  3. package/README.md +259 -0
  4. package/demo/legacy-app/src/App.jsx +12 -0
  5. package/demo/legacy-app/src/components/Dashboard.jsx +51 -0
  6. package/demo/legacy-app/src/components/UserCard.jsx +32 -0
  7. package/demo/legacy-app/src/hooks/useUsers.js +38 -0
  8. package/demo/legacy-app/src/utils/api.js +30 -0
  9. package/glama.json +4 -0
  10. package/package.json +39 -0
  11. package/tools/accessibility-checker/build/index.d.ts +3 -0
  12. package/tools/accessibility-checker/build/index.d.ts.map +1 -0
  13. package/tools/accessibility-checker/build/index.js +112 -0
  14. package/tools/accessibility-checker/build/index.js.map +1 -0
  15. package/tools/accessibility-checker/build/rules.d.ts +22 -0
  16. package/tools/accessibility-checker/build/rules.d.ts.map +1 -0
  17. package/tools/accessibility-checker/build/rules.js +244 -0
  18. package/tools/accessibility-checker/build/rules.js.map +1 -0
  19. package/tools/accessibility-checker/build/rules.test.d.ts +2 -0
  20. package/tools/accessibility-checker/build/rules.test.d.ts.map +1 -0
  21. package/tools/accessibility-checker/build/rules.test.js.map +1 -0
  22. package/tools/accessibility-checker/package.json +20 -0
  23. package/tools/code-modernizer/build/index.d.ts +3 -0
  24. package/tools/code-modernizer/build/index.d.ts.map +1 -0
  25. package/tools/code-modernizer/build/index.js +58 -0
  26. package/tools/code-modernizer/build/index.js.map +1 -0
  27. package/tools/code-modernizer/build/tools/01-convert-to-typescript.d.ts +3 -0
  28. package/tools/code-modernizer/build/tools/01-convert-to-typescript.d.ts.map +1 -0
  29. package/tools/code-modernizer/build/tools/01-convert-to-typescript.js +110 -0
  30. package/tools/code-modernizer/build/tools/01-convert-to-typescript.js.map +1 -0
  31. package/tools/code-modernizer/build/types.d.ts +57 -0
  32. package/tools/code-modernizer/build/types.d.ts.map +1 -0
  33. package/tools/code-modernizer/build/types.js +5 -0
  34. package/tools/code-modernizer/build/types.js.map +1 -0
  35. package/tools/code-modernizer/build/utils/ast-parser.d.ts +6 -0
  36. package/tools/code-modernizer/build/utils/ast-parser.d.ts.map +1 -0
  37. package/tools/code-modernizer/build/utils/ast-parser.js +177 -0
  38. package/tools/code-modernizer/build/utils/ast-parser.js.map +1 -0
  39. package/tools/code-modernizer/build/utils/file-ops.d.ts +8 -0
  40. package/tools/code-modernizer/build/utils/file-ops.d.ts.map +1 -0
  41. package/tools/code-modernizer/build/utils/file-ops.js +63 -0
  42. package/tools/code-modernizer/build/utils/file-ops.js.map +1 -0
  43. package/tools/code-modernizer/build/utils/file-ops.test.d.ts +2 -0
  44. package/tools/code-modernizer/build/utils/file-ops.test.d.ts.map +1 -0
  45. package/tools/code-modernizer/build/utils/file-ops.test.js.map +1 -0
  46. package/tools/code-modernizer/build/utils/type-generator.d.ts +4 -0
  47. package/tools/code-modernizer/build/utils/type-generator.d.ts.map +1 -0
  48. package/tools/code-modernizer/build/utils/type-generator.js +37 -0
  49. package/tools/code-modernizer/build/utils/type-generator.js.map +1 -0
  50. package/tools/code-modernizer/package.json +23 -0
  51. package/tools/component-factory/build/index.d.ts +3 -0
  52. package/tools/component-factory/build/index.d.ts.map +1 -0
  53. package/tools/component-factory/build/index.js +534 -0
  54. package/tools/component-factory/build/index.js.map +1 -0
  55. package/tools/component-factory/build/utils.d.ts +6 -0
  56. package/tools/component-factory/build/utils.d.ts.map +1 -0
  57. package/tools/component-factory/build/utils.js +11 -0
  58. package/tools/component-factory/build/utils.js.map +1 -0
  59. package/tools/component-factory/build/utils.test.d.ts +2 -0
  60. package/tools/component-factory/build/utils.test.d.ts.map +1 -0
  61. package/tools/component-factory/build/utils.test.js.map +1 -0
  62. package/tools/component-factory/package.json +20 -0
  63. package/tools/component-factory/templates/accordion.tsx +57 -0
  64. package/tools/component-factory/templates/alert.tsx +59 -0
  65. package/tools/component-factory/templates/aspect-ratio.tsx +8 -0
  66. package/tools/component-factory/templates/avatar.tsx +51 -0
  67. package/tools/component-factory/templates/badge.tsx +37 -0
  68. package/tools/component-factory/templates/breadcrumb.tsx +116 -0
  69. package/tools/component-factory/templates/button.tsx +57 -0
  70. package/tools/component-factory/templates/calendar.tsx +66 -0
  71. package/tools/component-factory/templates/card.tsx +80 -0
  72. package/tools/component-factory/templates/checkbox.tsx +31 -0
  73. package/tools/component-factory/templates/collapsible.tsx +11 -0
  74. package/tools/component-factory/templates/command.tsx +150 -0
  75. package/tools/component-factory/templates/context-menu.tsx +199 -0
  76. package/tools/component-factory/templates/dialog.tsx +123 -0
  77. package/tools/component-factory/templates/drawer.tsx +118 -0
  78. package/tools/component-factory/templates/dropdown-menu.tsx +201 -0
  79. package/tools/component-factory/templates/form.tsx +178 -0
  80. package/tools/component-factory/templates/hover-card.tsx +29 -0
  81. package/tools/component-factory/templates/input-otp.tsx +71 -0
  82. package/tools/component-factory/templates/input.tsx +23 -0
  83. package/tools/component-factory/templates/label.tsx +27 -0
  84. package/tools/component-factory/templates/menubar.tsx +236 -0
  85. package/tools/component-factory/templates/navigation-menu.tsx +128 -0
  86. package/tools/component-factory/templates/pagination.tsx +120 -0
  87. package/tools/component-factory/templates/popover.tsx +31 -0
  88. package/tools/component-factory/templates/progress.tsx +28 -0
  89. package/tools/component-factory/templates/radio-group.tsx +44 -0
  90. package/tools/component-factory/templates/scroll-area.tsx +48 -0
  91. package/tools/component-factory/templates/select.tsx +159 -0
  92. package/tools/component-factory/templates/separator.tsx +32 -0
  93. package/tools/component-factory/templates/sheet.tsx +140 -0
  94. package/tools/component-factory/templates/skeleton.tsx +15 -0
  95. package/tools/component-factory/templates/slider.tsx +28 -0
  96. package/tools/component-factory/templates/sonner.tsx +31 -0
  97. package/tools/component-factory/templates/switch.tsx +29 -0
  98. package/tools/component-factory/templates/table.tsx +117 -0
  99. package/tools/component-factory/templates/tabs.tsx +56 -0
  100. package/tools/component-factory/templates/textarea.tsx +22 -0
  101. package/tools/component-factory/templates/toggle-group.tsx +61 -0
  102. package/tools/component-factory/templates/toggle.tsx +45 -0
  103. package/tools/component-factory/templates/tooltip.tsx +30 -0
  104. package/tools/dep-auditor/build/index.d.ts +18 -0
  105. package/tools/dep-auditor/build/index.d.ts.map +1 -0
  106. package/tools/dep-auditor/build/index.js +247 -0
  107. package/tools/dep-auditor/build/index.js.map +1 -0
  108. package/tools/dep-auditor/build/index.test.d.ts +2 -0
  109. package/tools/dep-auditor/build/index.test.d.ts.map +1 -0
  110. package/tools/dep-auditor/build/index.test.js.map +1 -0
  111. package/tools/dep-auditor/package.json +20 -0
  112. package/tools/generate-tests/build/analyzer.d.ts +31 -0
  113. package/tools/generate-tests/build/analyzer.d.ts.map +1 -0
  114. package/tools/generate-tests/build/analyzer.js +105 -0
  115. package/tools/generate-tests/build/analyzer.js.map +1 -0
  116. package/tools/generate-tests/build/analyzer.test.d.ts +2 -0
  117. package/tools/generate-tests/build/analyzer.test.d.ts.map +1 -0
  118. package/tools/generate-tests/build/analyzer.test.js.map +1 -0
  119. package/tools/generate-tests/build/generators.d.ts +6 -0
  120. package/tools/generate-tests/build/generators.d.ts.map +1 -0
  121. package/tools/generate-tests/build/generators.js +161 -0
  122. package/tools/generate-tests/build/generators.js.map +1 -0
  123. package/tools/generate-tests/build/index.d.ts +3 -0
  124. package/tools/generate-tests/build/index.d.ts.map +1 -0
  125. package/tools/generate-tests/build/index.js +148 -0
  126. package/tools/generate-tests/build/index.js.map +1 -0
  127. package/tools/generate-tests/package.json +20 -0
  128. package/tools/json-viewer/build/index.d.ts +3 -0
  129. package/tools/json-viewer/build/index.d.ts.map +1 -0
  130. package/tools/json-viewer/build/index.js +282 -0
  131. package/tools/json-viewer/build/index.js.map +1 -0
  132. package/tools/json-viewer/build/utils.d.ts +5 -0
  133. package/tools/json-viewer/build/utils.d.ts.map +1 -0
  134. package/tools/json-viewer/build/utils.js +40 -0
  135. package/tools/json-viewer/build/utils.js.map +1 -0
  136. package/tools/json-viewer/build/utils.test.d.ts +2 -0
  137. package/tools/json-viewer/build/utils.test.d.ts.map +1 -0
  138. package/tools/json-viewer/build/utils.test.js.map +1 -0
  139. package/tools/json-viewer/package.json +20 -0
  140. package/tools/monorepo-manager/build/index.d.ts +3 -0
  141. package/tools/monorepo-manager/build/index.d.ts.map +1 -0
  142. package/tools/monorepo-manager/build/index.js +318 -0
  143. package/tools/monorepo-manager/build/index.js.map +1 -0
  144. package/tools/monorepo-manager/build/types.d.ts +17 -0
  145. package/tools/monorepo-manager/build/types.d.ts.map +1 -0
  146. package/tools/monorepo-manager/build/types.js +2 -0
  147. package/tools/monorepo-manager/build/types.js.map +1 -0
  148. package/tools/monorepo-manager/build/utils.d.ts +9 -0
  149. package/tools/monorepo-manager/build/utils.d.ts.map +1 -0
  150. package/tools/monorepo-manager/build/utils.js +135 -0
  151. package/tools/monorepo-manager/build/utils.js.map +1 -0
  152. package/tools/monorepo-manager/build/utils.test.d.ts +2 -0
  153. package/tools/monorepo-manager/build/utils.test.d.ts.map +1 -0
  154. package/tools/monorepo-manager/build/utils.test.js.map +1 -0
  155. package/tools/monorepo-manager/package.json +20 -0
  156. package/tools/quality-pipeline/build/index.d.ts +3 -0
  157. package/tools/quality-pipeline/build/index.d.ts.map +1 -0
  158. package/tools/quality-pipeline/build/index.js +538 -0
  159. package/tools/quality-pipeline/build/index.js.map +1 -0
  160. package/tools/quality-pipeline/build/utils.d.ts +9 -0
  161. package/tools/quality-pipeline/build/utils.d.ts.map +1 -0
  162. package/tools/quality-pipeline/build/utils.js +15 -0
  163. package/tools/quality-pipeline/build/utils.js.map +1 -0
  164. package/tools/quality-pipeline/build/utils.test.d.ts +2 -0
  165. package/tools/quality-pipeline/build/utils.test.d.ts.map +1 -0
  166. package/tools/quality-pipeline/build/utils.test.js.map +1 -0
  167. package/tools/quality-pipeline/package.json +20 -0
  168. package/tools/shared/build/McpServerBase.d.ts +18 -0
  169. package/tools/shared/build/McpServerBase.d.ts.map +1 -0
  170. package/tools/shared/build/McpServerBase.js +74 -0
  171. package/tools/shared/build/McpServerBase.js.map +1 -0
  172. package/tools/shared/build/ToolRegistry.d.ts +9 -0
  173. package/tools/shared/build/ToolRegistry.d.ts.map +1 -0
  174. package/tools/shared/build/ToolRegistry.js +22 -0
  175. package/tools/shared/build/ToolRegistry.js.map +1 -0
  176. package/tools/shared/build/index.d.ts +4 -0
  177. package/tools/shared/build/index.d.ts.map +1 -0
  178. package/tools/shared/build/index.js +4 -0
  179. package/tools/shared/build/index.js.map +1 -0
  180. package/tools/shared/build/types.d.ts +36 -0
  181. package/tools/shared/build/types.d.ts.map +1 -0
  182. package/tools/shared/build/types.js +5 -0
  183. package/tools/shared/build/types.js.map +1 -0
  184. package/tools/shared/package.json +23 -0
  185. package/tools/typescript-enforcer/build/index.d.ts +3 -0
  186. package/tools/typescript-enforcer/build/index.d.ts.map +1 -0
  187. package/tools/typescript-enforcer/build/index.js +155 -0
  188. package/tools/typescript-enforcer/build/index.js.map +1 -0
  189. package/tools/typescript-enforcer/build/rules/branded-types.d.ts +3 -0
  190. package/tools/typescript-enforcer/build/rules/branded-types.d.ts.map +1 -0
  191. package/tools/typescript-enforcer/build/rules/branded-types.js +4 -0
  192. package/tools/typescript-enforcer/build/rules/branded-types.js.map +1 -0
  193. package/tools/typescript-enforcer/build/rules/discriminated-unions.d.ts +3 -0
  194. package/tools/typescript-enforcer/build/rules/discriminated-unions.d.ts.map +1 -0
  195. package/tools/typescript-enforcer/build/rules/discriminated-unions.js +4 -0
  196. package/tools/typescript-enforcer/build/rules/discriminated-unions.js.map +1 -0
  197. package/tools/typescript-enforcer/build/rules/generics.d.ts +3 -0
  198. package/tools/typescript-enforcer/build/rules/generics.d.ts.map +1 -0
  199. package/tools/typescript-enforcer/build/rules/generics.js +182 -0
  200. package/tools/typescript-enforcer/build/rules/generics.js.map +1 -0
  201. package/tools/typescript-enforcer/build/rules/modifiers.d.ts +3 -0
  202. package/tools/typescript-enforcer/build/rules/modifiers.d.ts.map +1 -0
  203. package/tools/typescript-enforcer/build/rules/modifiers.js +214 -0
  204. package/tools/typescript-enforcer/build/rules/modifiers.js.map +1 -0
  205. package/tools/typescript-enforcer/build/rules/no-any.d.ts +3 -0
  206. package/tools/typescript-enforcer/build/rules/no-any.d.ts.map +1 -0
  207. package/tools/typescript-enforcer/build/rules/no-any.js +138 -0
  208. package/tools/typescript-enforcer/build/rules/no-any.js.map +1 -0
  209. package/tools/typescript-enforcer/build/rules/type-guards.d.ts +3 -0
  210. package/tools/typescript-enforcer/build/rules/type-guards.d.ts.map +1 -0
  211. package/tools/typescript-enforcer/build/rules/type-guards.js +176 -0
  212. package/tools/typescript-enforcer/build/rules/type-guards.js.map +1 -0
  213. package/tools/typescript-enforcer/build/rules/utility-types.d.ts +3 -0
  214. package/tools/typescript-enforcer/build/rules/utility-types.d.ts.map +1 -0
  215. package/tools/typescript-enforcer/build/rules/utility-types.js +101 -0
  216. package/tools/typescript-enforcer/build/rules/utility-types.js.map +1 -0
  217. package/tools/typescript-enforcer/build/scanner.d.ts +4 -0
  218. package/tools/typescript-enforcer/build/scanner.d.ts.map +1 -0
  219. package/tools/typescript-enforcer/build/scanner.js +114 -0
  220. package/tools/typescript-enforcer/build/scanner.js.map +1 -0
  221. package/tools/typescript-enforcer/build/scanner.test.d.ts +2 -0
  222. package/tools/typescript-enforcer/build/scanner.test.d.ts.map +1 -0
  223. package/tools/typescript-enforcer/build/scanner.test.js.map +1 -0
  224. package/tools/typescript-enforcer/build/types.d.ts +55 -0
  225. package/tools/typescript-enforcer/build/types.d.ts.map +1 -0
  226. package/tools/typescript-enforcer/build/types.js +2 -0
  227. package/tools/typescript-enforcer/build/types.js.map +1 -0
  228. package/tools/typescript-enforcer/package.json +20 -0
@@ -0,0 +1,176 @@
1
+ export function checkTypeGuards(source, filePath) {
2
+ const violations = [];
3
+ const lines = source.split('\n');
4
+ for (let i = 0; i < lines.length; i++) {
5
+ const line = lines[i];
6
+ const trimmed = line.trim();
7
+ if (trimmed.startsWith('//') || trimmed.startsWith('*') || trimmed.startsWith('/*'))
8
+ continue;
9
+ const objectAssertRegex = /\bconst\s+(\w+)\s*=\s*(\w+)\s+as\s+\{/;
10
+ const objAssertMatch = line.match(objectAssertRegex);
11
+ if (objAssertMatch) {
12
+ violations.push({
13
+ rule: 'type-guards',
14
+ severity: 'warning',
15
+ line: i + 1,
16
+ column: line.indexOf('as {') + 1,
17
+ current: `const ${objAssertMatch[1]} = ${objAssertMatch[2]} as { ... }`,
18
+ suggestion: `Use a type guard: function is${objAssertMatch[1].charAt(0).toUpperCase() + objAssertMatch[1].slice(1)}(v: unknown): v is { ... }`,
19
+ fix: `// Replace type assertion with a type guard function:\n// function is${objAssertMatch[1].charAt(0).toUpperCase() + objAssertMatch[1].slice(1)}(v: unknown): v is { ... } {\n// return typeof v === 'object' && v !== null && '...' in v;\n// }`,
20
+ why: "Type assertions ('as') bypass TypeScript's type checking. Type guards validate the shape at runtime and narrow the type safely.",
21
+ });
22
+ }
23
+ const funcAssertion = line.match(/(\w+)\s+as\s+(\w[\w<>, ]*)\s*[;,)]/);
24
+ if (funcAssertion && !line.includes('//') && !objAssertMatch) {
25
+ const castTarget = funcAssertion[2].trim();
26
+ if (!['string', 'number', 'boolean', 'never', 'unknown', 'any', 'object'].includes(castTarget) && !castTarget.startsWith('typeof')) {
27
+ const isInsideFunc = lines.slice(Math.max(0, i - 20), i).some(l => /(?:function|=>)\s*\{/.test(l) || /=>\s*$/.test(l));
28
+ if (isInsideFunc) {
29
+ violations.push({
30
+ rule: 'type-guards',
31
+ severity: 'info',
32
+ line: i + 1,
33
+ column: line.indexOf(' as ') + 1,
34
+ current: `${funcAssertion[1]} as ${castTarget}`,
35
+ suggestion: `Create a type guard: function is${castTarget}(v: unknown): v is ${castTarget}`,
36
+ fix: `// Use a type guard instead of 'as' cast:\n// function is${castTarget}(v: unknown): v is ${castTarget} {\n// return typeof v === 'object' && v !== null && '...' in v;\n// }`,
37
+ why: "'as' assertions silence TypeScript without validating the actual shape. Type guards enforce correctness at runtime.",
38
+ });
39
+ }
40
+ }
41
+ }
42
+ const typeofCheck = line.match(/function\s+(is\w+)\s*\(\s*(\w+)\s*:\s*(\w+)\s*\)\s*:\s*boolean\s*\{/);
43
+ if (typeofCheck) {
44
+ const funcName = typeofCheck[1];
45
+ const paramName = typeofCheck[2];
46
+ const paramType = typeofCheck[3];
47
+ const funcEnd = findFunctionEnd(lines, i);
48
+ const funcBody = lines.slice(i, funcEnd + 1).join('\n');
49
+ const hasTypeof = funcBody.includes('typeof');
50
+ const hasInstanceof = funcBody.includes('instanceof');
51
+ const hasPropertyCheck = funcBody.includes('in ');
52
+ if (hasTypeof || hasInstanceof || hasPropertyCheck) {
53
+ let targetType = 'unknown';
54
+ if (funcBody.includes("=== 'string'"))
55
+ targetType = 'string';
56
+ else if (funcBody.includes("=== 'number'"))
57
+ targetType = 'number';
58
+ else if (funcBody.includes("=== 'boolean'"))
59
+ targetType = 'boolean';
60
+ else if (funcBody.includes("=== 'object'"))
61
+ targetType = 'object';
62
+ else if (funcBody.includes('instanceof')) {
63
+ const instanceofMatch = funcBody.match(/instanceof\s+(\w+)/);
64
+ if (instanceofMatch)
65
+ targetType = instanceofMatch[1];
66
+ }
67
+ violations.push({
68
+ rule: 'type-guards',
69
+ severity: 'info',
70
+ line: i + 1,
71
+ column: 1,
72
+ current: `function ${funcName}(...): boolean`,
73
+ suggestion: `function ${funcName}(...): value is ${targetType}`,
74
+ fix: `// Use type predicate instead of boolean return:\n// function ${funcName}(${paramName}: ${paramType}): ${paramName} is ${targetType} {\n// return typeof ${paramName} === '${targetType.toLowerCase()}';\n// }`,
75
+ why: "Type predicates ('is' keyword) let TypeScript narrow the type automatically after the check, instead of just returning boolean.",
76
+ });
77
+ }
78
+ }
79
+ const arrowTypeCheck = line.match(/const\s+(is\w+)\s*=\s*\(\s*(\w+)\s*:\s*(\w+)\s*\)\s*:\s*boolean\s*=>/);
80
+ if (arrowTypeCheck) {
81
+ violations.push({
82
+ rule: 'type-guards',
83
+ severity: 'info',
84
+ line: i + 1,
85
+ column: 1,
86
+ current: `const ${arrowTypeCheck[1]} = (...): boolean =>`,
87
+ suggestion: `const ${arrowTypeCheck[1]} = (...): param is Type =>`,
88
+ fix: `// Use type predicate:\n// const ${arrowTypeCheck[1]} = (${arrowTypeCheck[2]}: ${arrowTypeCheck[3]}): ${arrowTypeCheck[2]} is TargetType => typeof ${arrowTypeCheck[2]} === 'string'`,
89
+ why: "Type predicates enable automatic type narrowing in if/else blocks.",
90
+ });
91
+ }
92
+ const inlineTypeof = line.match(/if\s*\(\s*typeof\s+(\w+)\s*===?\s*['"](\w+)['"]\s*\)/);
93
+ if (inlineTypeof) {
94
+ const varName = inlineTypeof[1];
95
+ const checkType = inlineTypeof[2];
96
+ const nextLines = lines.slice(i, Math.min(i + 10, lines.length)).join('\n');
97
+ const hasCast = nextLines.includes(`as ${checkType.charAt(0).toUpperCase() + checkType.slice(1)}`) ||
98
+ nextLines.includes(`as ${checkType}`);
99
+ if (hasCast) {
100
+ violations.push({
101
+ rule: 'type-guards',
102
+ severity: 'warning',
103
+ line: i + 1,
104
+ column: 1,
105
+ current: `if (typeof ${varName} === '${checkType}') { ... as ${checkType} }`,
106
+ suggestion: `Create a type guard function: function is${checkType.charAt(0).toUpperCase() + checkType.slice(1)}(v: unknown): v is ${checkType}`,
107
+ fix: `// Extract to type guard to eliminate casts:\n// function is${checkType.charAt(0).toUpperCase() + checkType.slice(1)}(v: unknown): v is ${checkType} {\n// return typeof v === '${checkType}';\n// }`,
108
+ why: "Type guards eliminate the need for type assertions ('as') inside conditional blocks, making code safer.",
109
+ });
110
+ }
111
+ }
112
+ const instanceofCheck = line.match(/if\s*\(\s*(\w+)\s+instanceof\s+(\w+)\s*\)/);
113
+ if (instanceofCheck) {
114
+ const varName = instanceofCheck[1];
115
+ const className = instanceofCheck[2];
116
+ const nextLines = lines.slice(i, Math.min(i + 10, lines.length)).join('\n');
117
+ const hasCast = nextLines.includes(`as ${className}`);
118
+ if (hasCast) {
119
+ violations.push({
120
+ rule: 'type-guards',
121
+ severity: 'warning',
122
+ line: i + 1,
123
+ column: 1,
124
+ current: `if (${varName} instanceof ${className}) { ... as ${className} }`,
125
+ suggestion: `Create a type guard: function is${className}(v: unknown): v is ${className}`,
126
+ fix: `// Extract to type guard:\n// function is${className}(v: unknown): v is ${className} {\n// return v instanceof ${className};\n// }`,
127
+ why: "After instanceof, TypeScript should narrow the type automatically. If you still need 'as', use a type guard instead.",
128
+ });
129
+ }
130
+ }
131
+ const propertyCheck = line.match(/if\s*\(\s*['"](\w+)['"]\s+in\s+(\w+)\s*\)/);
132
+ if (propertyCheck) {
133
+ const propName = propertyCheck[1];
134
+ const varName = propertyCheck[2];
135
+ const nextLines = lines.slice(i, Math.min(i + 10, lines.length)).join('\n');
136
+ const hasCast = nextLines.includes('as ');
137
+ if (hasCast) {
138
+ violations.push({
139
+ rule: 'type-guards',
140
+ severity: 'info',
141
+ line: i + 1,
142
+ column: 1,
143
+ current: `if ('${propName}' in ${varName}) { ... as ... }`,
144
+ suggestion: `Create a type guard for the property check`,
145
+ fix: `// Create a type guard:\n// function has${propName.charAt(0).toUpperCase() + propName.slice(1)}(obj: unknown): obj is { ${propName}: unknown } {\n// return typeof obj === 'object' && obj !== null && '${propName}' in obj;\n// }`,
146
+ why: 'Type guards for property checks enable safe access without casts.',
147
+ });
148
+ }
149
+ }
150
+ const nullCheck = line.match(/function\s+(isNotNull|isNonNull|isDefined|isPresent)\s*\(\s*(\w+)\s*:\s*(\w+)\s*\)\s*:\s*boolean/);
151
+ if (nullCheck) {
152
+ violations.push({
153
+ rule: 'type-guards',
154
+ severity: 'info',
155
+ line: i + 1,
156
+ column: 1,
157
+ current: `function ${nullCheck[1]}(...): boolean`,
158
+ suggestion: `function ${nullCheck[1]}<T>(value: T | null | undefined): value is T`,
159
+ fix: `// Use generic type predicate for null checks:\n// function ${nullCheck[1]}<T>(value: T | null | undefined): value is T {\n// return value !== null && value !== undefined;\n// }`,
160
+ why: "Generic type predicates preserve the non-null type through the type system.",
161
+ });
162
+ }
163
+ }
164
+ return { violations };
165
+ }
166
+ function findFunctionEnd(lines, startLine) {
167
+ let depth = 0;
168
+ for (let i = startLine; i < lines.length; i++) {
169
+ depth += (lines[i].match(/{/g) || []).length;
170
+ depth -= (lines[i].match(/}/g) || []).length;
171
+ if (depth === 0 && i > startLine)
172
+ return i;
173
+ }
174
+ return lines.length - 1;
175
+ }
176
+ //# sourceMappingURL=type-guards.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"type-guards.js","sourceRoot":"","sources":["../../src/rules/type-guards.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { RuleCheckResult } from '../types.js';
2
+ export declare function checkUtilityTypes(source: string, filePath: string): RuleCheckResult;
3
+ //# sourceMappingURL=utility-types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utility-types.d.ts","sourceRoot":"","sources":["../../src/rules/utility-types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAa,eAAe,EAAE,MAAM,aAAa,CAAC;AAE9D,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,eAAe,CA4GnF"}
@@ -0,0 +1,101 @@
1
+ export function checkUtilityTypes(source, filePath) {
2
+ const violations = [];
3
+ const lines = source.split('\n');
4
+ for (let i = 0; i < lines.length; i++) {
5
+ const line = lines[i];
6
+ const trimmed = line.trim();
7
+ if (trimmed.startsWith('//') || trimmed.startsWith('*') || trimmed.startsWith('/*'))
8
+ continue;
9
+ const allOptionalRegex = /interface\s+(\w+)\s*\{([^}]*)\}/g;
10
+ let match;
11
+ while ((match = allOptionalRegex.exec(line)) !== null) {
12
+ const body = match[2];
13
+ const props = body.split(';').filter(p => p.trim());
14
+ const allOptional = props.every(p => p.includes('?:'));
15
+ if (allOptional && props.length >= 3) {
16
+ violations.push({
17
+ rule: 'utility-types',
18
+ severity: 'info',
19
+ line: i + 1,
20
+ column: 1,
21
+ current: `interface ${match[1]} (all properties optional)`,
22
+ suggestion: `type ${match[1]} = Partial<FullInterface>`,
23
+ fix: `// Use Partial<T> instead of manually making all properties optional:\n// type ${match[1]} = Partial<${match[1].replace(/Options|Config/, '')}>`,
24
+ why: 'Partial<T> is more maintainable - when the base interface changes, Partial automatically includes new properties.',
25
+ });
26
+ }
27
+ }
28
+ const pickPattern = /interface\s+(\w+)\s*\{\s*(\w+):\s*(\w+);\s*(\w+):\s*(\w+);\s*\}/g;
29
+ while ((match = pickPattern.exec(line)) !== null) {
30
+ if (match[1].includes('Pick') || match[1].includes('Selected')) {
31
+ violations.push({
32
+ rule: 'utility-types',
33
+ severity: 'info',
34
+ line: i + 1,
35
+ column: 1,
36
+ current: `interface ${match[1]} { ${match[2]}: ${match[3]}; ${match[4]}: ${match[5]} }`,
37
+ suggestion: `type ${match[1]} = Pick<BaseInterface, '${match[2]}' | '${match[4]}'>`,
38
+ fix: `// Use Pick<T, K> to select specific properties from an existing type:\n// type ${match[1]} = Pick<BaseType, '${match[2]}' | '${match[4]}'>`,
39
+ why: 'Pick<T, K> keeps types DRY - if the base type changes, the picked type automatically updates.',
40
+ });
41
+ }
42
+ }
43
+ const recordPattern = /\{\s*\[key:\s*string\]:\s*(\w+)\s*\}/g;
44
+ while ((match = recordPattern.exec(line)) !== null) {
45
+ violations.push({
46
+ rule: 'utility-types',
47
+ severity: 'info',
48
+ line: i + 1,
49
+ column: match.index + 1,
50
+ current: `{ [key: string]: ${match[1]} }`,
51
+ suggestion: `Record<string, ${match[1]}>`,
52
+ fix: `// Use Record<K, V> for cleaner object type definitions:\n// type MyMap = Record<string, ${match[1]}>`,
53
+ why: 'Record<string, T> is more readable and idiomatic than manual index signatures.',
54
+ });
55
+ }
56
+ const nullableUnion = line.match(/type\s+(\w+)\s*=\s*(\w+)\s*\|\s*null\s*\|\s*undefined/);
57
+ if (nullableUnion) {
58
+ violations.push({
59
+ rule: 'utility-types',
60
+ severity: 'info',
61
+ line: i + 1,
62
+ column: 1,
63
+ current: `type ${nullableUnion[1]} = ${nullableUnion[2]} | null | undefined`,
64
+ suggestion: `type ${nullableUnion[1]} = NonNullable<${nullableUnion[2]}>`,
65
+ fix: `// Use NonNullable<T> to remove null and undefined:\n// type ${nullableUnion[1]} = NonNullable<SomeNullableType>`,
66
+ why: 'NonNullable<T> clearly communicates intent and automatically handles new nullable additions to the base type.',
67
+ });
68
+ }
69
+ const awaitedPattern = line.match(/type\s+(\w+)\s*=\s*(\w+)\s*extends\s*Promise<infer\s+(\w+)>\s*\?\s*\3\s*:\s*never/);
70
+ if (awaitedPattern) {
71
+ violations.push({
72
+ rule: 'utility-types',
73
+ severity: 'info',
74
+ line: i + 1,
75
+ column: 1,
76
+ current: line.trim(),
77
+ suggestion: `type ${awaitedPattern[1]} = Awaited<${awaitedPattern[2]}>`,
78
+ fix: `// Use Awaited<T> to unwrap Promise types:\n// type ${awaitedPattern[1]} = Awaited<PromiseType>`,
79
+ why: 'Awaited<T> is built-in and handles nested Promises correctly.',
80
+ });
81
+ }
82
+ const typeAssertion = line.match(/const\s+(\w+)\s*:\s*(\w+)\s*=/);
83
+ if (typeAssertion && !line.includes('satisfies')) {
84
+ const nextLines = lines.slice(i, Math.min(i + 5, lines.length)).join('\n');
85
+ if (nextLines.includes('as ') || nextLines.includes(typeAssertion[1] + '.')) {
86
+ violations.push({
87
+ rule: 'utility-types',
88
+ severity: 'info',
89
+ line: i + 1,
90
+ column: 1,
91
+ current: `const ${typeAssertion[1]}: ${typeAssertion[2]} = ...`,
92
+ suggestion: `const ${typeAssertion[1]} = ... satisfies ${typeAssertion[2]}`,
93
+ fix: `// Use 'satisfies' to validate type while preserving narrower inference:\n// const ${typeAssertion[1]} = { ... } satisfies ${typeAssertion[2]}`,
94
+ why: "'satisfies' validates the type without widening, preserving autocomplete and literal types.",
95
+ });
96
+ }
97
+ }
98
+ }
99
+ return { violations };
100
+ }
101
+ //# sourceMappingURL=utility-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utility-types.js","sourceRoot":"","sources":["../../src/rules/utility-types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { FileScanResult, DirectoryScanResult, ScanOptions } from './types.js';
2
+ export declare function scanFile(filePath: string, options?: ScanOptions): FileScanResult;
3
+ export declare function scanDirectory(dir: string, options?: ScanOptions): DirectoryScanResult;
4
+ //# sourceMappingURL=scanner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanner.d.ts","sourceRoot":"","sources":["../src/scanner.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAa,cAAc,EAAE,mBAAmB,EAAE,WAAW,EAAY,MAAM,YAAY,CAAC;AAqBxG,wBAAgB,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,GAAE,WAAgB,GAAG,cAAc,CAyCpF;AAwBD,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,GAAE,WAAgB,GAAG,mBAAmB,CA6CzF"}
@@ -0,0 +1,114 @@
1
+ import * as fs from 'fs';
2
+ import * as path from 'path';
3
+ import { checkNoAny } from './rules/no-any.js';
4
+ import { checkGenerics } from './rules/generics.js';
5
+ import { checkUtilityTypes } from './rules/utility-types.js';
6
+ import { checkModifiers } from './rules/modifiers.js';
7
+ import { checkTypeGuards } from './rules/type-guards.js';
8
+ import { checkDiscriminatedUnions } from './rules/discriminated-unions.js';
9
+ import { checkBrandedTypes } from './rules/branded-types.js';
10
+ const RULES = {
11
+ 'no-any': checkNoAny,
12
+ 'generics': checkGenerics,
13
+ 'utility-types': checkUtilityTypes,
14
+ 'modifiers': checkModifiers,
15
+ 'type-guards': checkTypeGuards,
16
+ 'discriminated-unions': checkDiscriminatedUnions,
17
+ 'branded-types': checkBrandedTypes,
18
+ };
19
+ export function scanFile(filePath, options = {}) {
20
+ const source = fs.readFileSync(filePath, 'utf-8');
21
+ const rulesToRun = options.rules || Object.keys(RULES);
22
+ const minSeverity = options.severity || 'info';
23
+ const severityOrder = { error: 0, warning: 1, info: 2 };
24
+ const minSeverityLevel = severityOrder[minSeverity] ?? 2;
25
+ const allViolations = [];
26
+ for (const ruleName of rulesToRun) {
27
+ const checker = RULES[ruleName];
28
+ if (checker) {
29
+ try {
30
+ const result = checker(source, filePath);
31
+ allViolations.push(...result.violations);
32
+ }
33
+ catch {
34
+ // Skip rules that fail on this file
35
+ }
36
+ }
37
+ }
38
+ const filtered = allViolations.filter(v => severityOrder[v.severity] <= minSeverityLevel);
39
+ filtered.sort((a, b) => a.line - b.line);
40
+ const errors = filtered.filter(v => v.severity === 'error').length;
41
+ const warnings = filtered.filter(v => v.severity === 'warning').length;
42
+ const infos = filtered.filter(v => v.severity === 'info').length;
43
+ let score = 10;
44
+ score -= errors * 2;
45
+ score -= warnings * 1;
46
+ score -= infos * 0.25;
47
+ score = Math.max(0, Math.round(score * 10) / 10);
48
+ return {
49
+ file: filePath,
50
+ violations: filtered,
51
+ summary: { errors, warnings, infos, total: filtered.length },
52
+ score,
53
+ };
54
+ }
55
+ function scanDirectoryRecursive(dir, options = {}) {
56
+ const files = [];
57
+ const ignorePatterns = options.ignore || ['node_modules', 'build', 'dist', '.next', '.git', '__tests__', '.test.', '.spec.', '.stories.'];
58
+ if (!fs.existsSync(dir))
59
+ return files;
60
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
61
+ for (const entry of entries) {
62
+ const fullPath = path.join(dir, entry.name);
63
+ if (ignorePatterns.some(pattern => entry.name.includes(pattern)))
64
+ continue;
65
+ if (entry.isDirectory()) {
66
+ files.push(...scanDirectoryRecursive(fullPath, options));
67
+ }
68
+ else if (entry.name.match(/\.(ts|tsx|js|jsx)$/)) {
69
+ files.push(fullPath);
70
+ }
71
+ }
72
+ return files;
73
+ }
74
+ export function scanDirectory(dir, options = {}) {
75
+ let files = scanDirectoryRecursive(dir, options);
76
+ if (options.maxFiles && files.length > options.maxFiles) {
77
+ files = files.slice(0, options.maxFiles);
78
+ }
79
+ const results = [];
80
+ for (const file of files) {
81
+ try {
82
+ const result = scanFile(file, options);
83
+ if (result.summary.total > 0 || options.severity === undefined) {
84
+ results.push(result);
85
+ }
86
+ }
87
+ catch {
88
+ // Skip files that can't be read
89
+ }
90
+ }
91
+ results.sort((a, b) => a.score - b.score);
92
+ const totalViolations = results.reduce((sum, r) => sum + r.summary.total, 0);
93
+ const totalErrors = results.reduce((sum, r) => sum + r.summary.errors, 0);
94
+ const totalWarnings = results.reduce((sum, r) => sum + r.summary.warnings, 0);
95
+ const totalInfos = results.reduce((sum, r) => sum + r.summary.infos, 0);
96
+ const byRule = {};
97
+ for (const result of results) {
98
+ for (const v of result.violations) {
99
+ byRule[v.rule] = (byRule[v.rule] || 0) + 1;
100
+ }
101
+ }
102
+ const sorted = [...results].sort((a, b) => a.score - b.score);
103
+ return {
104
+ directory: dir,
105
+ filesScanned: files.length,
106
+ totalViolations,
107
+ results,
108
+ worstFiles: sorted.slice(0, 10).map(r => ({ file: r.file, score: r.score, violations: r.summary.total })),
109
+ bestFiles: sorted.slice(-5).reverse().map(r => ({ file: r.file, score: r.score, violations: r.summary.total })),
110
+ byRule,
111
+ summary: { errors: totalErrors, warnings: totalWarnings, infos: totalInfos },
112
+ };
113
+ }
114
+ //# sourceMappingURL=scanner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanner.js","sourceRoot":"","sources":["../src/scanner.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=scanner.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanner.test.d.ts","sourceRoot":"","sources":["../src/scanner.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanner.test.js","sourceRoot":"","sources":["../src/scanner.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,55 @@
1
+ export type RuleName = 'no-any' | 'generics' | 'utility-types' | 'modifiers' | 'type-guards' | 'discriminated-unions' | 'branded-types';
2
+ export type Severity = 'error' | 'warning' | 'info';
3
+ export interface Violation {
4
+ rule: RuleName;
5
+ severity: Severity;
6
+ line: number;
7
+ column: number;
8
+ current: string;
9
+ suggestion: string;
10
+ fix: string;
11
+ why: string;
12
+ }
13
+ export interface FileScanResult {
14
+ file: string;
15
+ violations: Violation[];
16
+ summary: {
17
+ errors: number;
18
+ warnings: number;
19
+ infos: number;
20
+ total: number;
21
+ };
22
+ score: number;
23
+ }
24
+ export interface DirectoryScanResult {
25
+ directory: string;
26
+ filesScanned: number;
27
+ totalViolations: number;
28
+ results: FileScanResult[];
29
+ worstFiles: {
30
+ file: string;
31
+ score: number;
32
+ violations: number;
33
+ }[];
34
+ bestFiles: {
35
+ file: string;
36
+ score: number;
37
+ violations: number;
38
+ }[];
39
+ byRule: Record<RuleName, number>;
40
+ summary: {
41
+ errors: number;
42
+ warnings: number;
43
+ infos: number;
44
+ };
45
+ }
46
+ export interface ScanOptions {
47
+ rules?: RuleName[];
48
+ severity?: Severity;
49
+ ignore?: string[];
50
+ maxFiles?: number;
51
+ }
52
+ export interface RuleCheckResult {
53
+ violations: Violation[];
54
+ }
55
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAChB,QAAQ,GACR,UAAU,GACV,eAAe,GACf,WAAW,GACX,aAAa,GACb,sBAAsB,GACtB,eAAe,CAAC;AAEpB,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;AAEpD,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,EAAE,QAAQ,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,SAAS,EAAE,CAAC;IACxB,OAAO,EAAE;QACP,MAAM,EAAE,MAAM,CAAC;QACf,QAAQ,EAAE,MAAM,CAAC;QACjB,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IACF,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,mBAAmB;IAClC,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,MAAM,CAAC;IACxB,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,UAAU,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAClE,SAAS,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IACjE,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;IACjC,OAAO,EAAE;QACP,MAAM,EAAE,MAAM,CAAC;QACf,QAAQ,EAAE,MAAM,CAAC;QACjB,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;CACH;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,CAAC,EAAE,QAAQ,EAAE,CAAC;IACnB,QAAQ,CAAC,EAAE,QAAQ,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,eAAe;IAC9B,UAAU,EAAE,SAAS,EAAE,CAAC;CACzB"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,20 @@
1
+ {
2
+ "name": "@mcp-showcase/typescript-enforcer",
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
+ }