css-to-tailwind-react 0.3.4 → 0.4.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.
@@ -4,35 +4,50 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.transformFiles = transformFiles;
7
+ exports.transformFilesDetailed = transformFilesDetailed;
7
8
  const fs_1 = __importDefault(require("fs"));
8
9
  const path_1 = __importDefault(require("path"));
9
10
  const tailwindMapper_1 = require("./tailwindMapper");
10
11
  const jsxParser_1 = require("./jsxParser");
11
12
  const cssParser_1 = require("./cssParser");
12
- const fileWriter_1 = require("./fileWriter");
13
13
  const logger_1 = require("./utils/logger");
14
14
  const breakpointResolver_1 = require("./utils/breakpointResolver");
15
15
  const variantAssembler_1 = require("./utils/variantAssembler");
16
16
  const jsxDescendantTransformer_1 = require("./jsxDescendantTransformer");
17
17
  const conflictResolver_1 = require("./utils/conflictResolver");
18
18
  async function transformFiles(files, options) {
19
- const results = {
19
+ const detailed = await transformFilesDetailed(files, options);
20
+ return {
21
+ filesScanned: detailed.stats.filesScanned,
22
+ filesModified: detailed.stats.filesModified,
23
+ stylesConverted: detailed.stats.utilitiesGenerated,
24
+ classesReplaced: detailed.stats.classesReplaced,
25
+ warnings: detailed.stats.warnings
26
+ };
27
+ }
28
+ async function transformFilesDetailed(files, options) {
29
+ const stats = {
20
30
  filesScanned: files.length,
21
31
  filesModified: 0,
22
- stylesConverted: 0,
32
+ filesUnchanged: 0,
33
+ filesWithError: 0,
34
+ utilitiesGenerated: 0,
23
35
  classesReplaced: 0,
36
+ conflictsResolved: 0,
37
+ unsupportedSelectors: 0,
38
+ errors: 0,
24
39
  warnings: 0
25
40
  };
41
+ const fileResults = [];
26
42
  const mapper = new tailwindMapper_1.TailwindMapper(options.tailwindConfig || {});
27
43
  const jsxParser = new jsxParser_1.JSXParser(mapper);
28
44
  const screens = options.tailwindConfig?.theme?.screens;
29
45
  const cssParser = new cssParser_1.CSSParser(mapper, screens);
30
- const fileWriter = new fileWriter_1.FileWriter({ dryRun: options.dryRun });
31
46
  (0, breakpointResolver_1.clearBreakpointCache)();
32
47
  const cssClassMap = {};
33
48
  const allDescendantRules = [];
49
+ logger_1.logger.info('\nšŸ” Phase 1: Analyzing CSS files...');
34
50
  const cssFileResults = new Map();
35
- logger_1.logger.info('\nšŸ” Phase 1: Analyzing files...');
36
51
  if (!options.skipExternal) {
37
52
  for (const file of files.filter(f => f.type === 'css')) {
38
53
  try {
@@ -46,7 +61,7 @@ async function transformFiles(files, options) {
46
61
  if (rule.isDescendant) {
47
62
  if (rule.convertedClasses.length > 0) {
48
63
  allDescendantRules.push(rule);
49
- results.stylesConverted += rule.declarations.length;
64
+ stats.utilitiesGenerated += rule.declarations.length;
50
65
  }
51
66
  }
52
67
  else if (rule.className && rule.convertedClasses.length > 0) {
@@ -58,23 +73,25 @@ async function transformFiles(files, options) {
58
73
  cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);
59
74
  }
60
75
  if (rule.fullyConverted) {
61
- results.stylesConverted += rule.declarations.length;
76
+ stats.utilitiesGenerated += rule.declarations.length;
62
77
  }
63
78
  else {
64
- results.stylesConverted += rule.convertedClasses.length;
79
+ stats.utilitiesGenerated += rule.convertedClasses.length;
65
80
  logger_1.logger.verbose(` Rule .${rule.className}: partial conversion (${rule.convertedClasses.length}/${rule.declarations.length} declarations)`);
66
81
  }
67
82
  }
68
83
  });
69
84
  cssFileResults.set(file.path, {
85
+ path: file.path,
70
86
  content,
71
87
  newContent: result.css,
72
88
  rules: result.rules,
73
89
  canDelete: result.canDelete,
74
90
  hasChanges: result.hasChanges,
75
- fullyConvertible
91
+ fullyConvertible,
92
+ warnings: result.warnings
76
93
  });
77
- results.warnings += result.warnings.length;
94
+ stats.warnings += result.warnings.length;
78
95
  logger_1.logger.verbose(`Analyzed ${file.path}:`);
79
96
  logger_1.logger.verbose(` - Total rules: ${totalRules}`);
80
97
  logger_1.logger.verbose(` - Fully converted rules: ${fullyConvertedRules}`);
@@ -85,8 +102,21 @@ async function transformFiles(files, options) {
85
102
  });
86
103
  }
87
104
  catch (error) {
105
+ const errorMessage = error instanceof Error ? error.message : String(error);
88
106
  logger_1.logger.error(`Failed to analyze ${file.path}:`, error);
89
- results.warnings++;
107
+ cssFileResults.set(file.path, {
108
+ path: file.path,
109
+ content: '',
110
+ newContent: '',
111
+ rules: [],
112
+ canDelete: false,
113
+ hasChanges: false,
114
+ fullyConvertible: false,
115
+ warnings: [],
116
+ error: errorMessage
117
+ });
118
+ stats.errors++;
119
+ stats.warnings++;
90
120
  }
91
121
  }
92
122
  }
@@ -98,13 +128,15 @@ async function transformFiles(files, options) {
98
128
  const originalContent = content;
99
129
  let hasChanges = false;
100
130
  let fileWarnings = [];
131
+ let utilitiesGenerated = 0;
132
+ let classesReplaced = 0;
101
133
  if (!options.skipInline) {
102
134
  try {
103
135
  const jsxResult = jsxParser.parse(content, file.path);
104
136
  if (jsxResult.hasChanges) {
105
137
  content = jsxResult.code;
106
138
  hasChanges = true;
107
- results.stylesConverted += jsxResult.transformations.reduce((sum, t) => sum + t.classes.length, 0);
139
+ utilitiesGenerated += jsxResult.transformations.reduce((sum, t) => sum + t.classes.length, 0);
108
140
  fileWarnings.push(...jsxResult.warnings);
109
141
  }
110
142
  }
@@ -123,7 +155,7 @@ async function transformFiles(files, options) {
123
155
  if (rule.isDescendant) {
124
156
  if (rule.convertedClasses.length > 0) {
125
157
  allDescendantRules.push(rule);
126
- results.stylesConverted += rule.declarations.length;
158
+ utilitiesGenerated += rule.declarations.length;
127
159
  }
128
160
  }
129
161
  else if (rule.convertedClasses.length > 0 && rule.className) {
@@ -134,7 +166,7 @@ async function transformFiles(files, options) {
134
166
  else {
135
167
  cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);
136
168
  }
137
- results.stylesConverted += rule.declarations.length;
169
+ utilitiesGenerated += rule.declarations.length;
138
170
  }
139
171
  });
140
172
  fileWarnings.push(...internalResult.warnings);
@@ -146,30 +178,48 @@ async function transformFiles(files, options) {
146
178
  }
147
179
  }
148
180
  jsxFileResults.set(file.path, {
181
+ path: file.path,
149
182
  content: originalContent,
150
183
  newContent: content,
151
- hasChanges
184
+ hasChanges,
185
+ warnings: fileWarnings,
186
+ utilitiesGenerated,
187
+ classesReplaced
152
188
  });
153
- results.warnings += fileWarnings.length;
189
+ stats.warnings += fileWarnings.length;
154
190
  fileWarnings.forEach(warning => {
155
191
  logger_1.logger.verbose(`āš ļø ${file.path}: ${warning}`);
156
192
  });
157
193
  }
158
194
  catch (error) {
195
+ const errorMessage = error instanceof Error ? error.message : String(error);
159
196
  logger_1.logger.error(`Failed to process ${file.path}:`, error);
160
- results.warnings++;
197
+ jsxFileResults.set(file.path, {
198
+ path: file.path,
199
+ content: '',
200
+ newContent: '',
201
+ hasChanges: false,
202
+ warnings: [],
203
+ utilitiesGenerated: 0,
204
+ classesReplaced: 0,
205
+ error: errorMessage
206
+ });
207
+ stats.errors++;
161
208
  }
162
209
  }
163
210
  if (Object.keys(cssClassMap).length > 0) {
164
211
  logger_1.logger.info('\nšŸ”„ Phase 3: Replacing className references...');
165
212
  for (const [filePath, fileResult] of jsxFileResults) {
213
+ if (fileResult.error)
214
+ continue;
166
215
  let content = fileResult.newContent;
167
216
  let hasChanges = fileResult.hasChanges;
168
217
  const replacementResult = replaceClassNameReferences(content, cssClassMap);
169
218
  if (replacementResult.hasChanges) {
170
219
  content = replacementResult.code;
171
220
  hasChanges = true;
172
- results.classesReplaced += replacementResult.replacements;
221
+ fileResult.classesReplaced += replacementResult.replacements;
222
+ stats.classesReplaced += replacementResult.replacements;
173
223
  logger_1.logger.verbose(`Replaced ${replacementResult.replacements} class references in ${path_1.default.basename(filePath)}`);
174
224
  }
175
225
  jsxFileResults.set(filePath, {
@@ -182,17 +232,20 @@ async function transformFiles(files, options) {
182
232
  if (allDescendantRules.length > 0) {
183
233
  logger_1.logger.info('\n🌳 Phase 3.5: Applying descendant selector rules...');
184
234
  for (const [filePath, fileResult] of jsxFileResults) {
235
+ if (fileResult.error)
236
+ continue;
185
237
  let content = fileResult.newContent;
186
238
  let hasChanges = fileResult.hasChanges;
187
239
  const descendantResult = (0, jsxDescendantTransformer_1.transformDescendantSelectors)(content, allDescendantRules);
188
240
  if (descendantResult.hasChanges) {
189
241
  content = descendantResult.code;
190
242
  hasChanges = true;
191
- results.classesReplaced += descendantResult.transformations;
243
+ fileResult.classesReplaced += descendantResult.transformations;
244
+ stats.classesReplaced += descendantResult.transformations;
192
245
  logger_1.logger.verbose(`Applied ${descendantResult.transformations} descendant transformations in ${path_1.default.basename(filePath)}`);
193
246
  }
194
247
  if (descendantResult.warnings.length > 0) {
195
- results.warnings += descendantResult.warnings.length;
248
+ stats.warnings += descendantResult.warnings.length;
196
249
  descendantResult.warnings.forEach(warning => {
197
250
  logger_1.logger.verbose(`āš ļø ${filePath}: ${warning}`);
198
251
  });
@@ -204,47 +257,69 @@ async function transformFiles(files, options) {
204
257
  });
205
258
  }
206
259
  }
207
- logger_1.logger.info('\nšŸ’¾ Phase 4: Writing changes...');
208
260
  for (const [filePath, fileResult] of jsxFileResults) {
209
- if (fileResult.hasChanges) {
210
- const success = await fileWriter.writeFile(filePath, fileResult.newContent, fileResult.content);
211
- if (success) {
212
- results.filesModified++;
261
+ if (fileResult.error) {
262
+ fileResults.push({
263
+ filePath,
264
+ originalContent: fileResult.content,
265
+ newContent: fileResult.newContent,
266
+ hasChanges: false,
267
+ status: 'error',
268
+ error: fileResult.error
269
+ });
270
+ stats.filesWithError++;
271
+ continue;
272
+ }
273
+ const hasChanges = fileResult.newContent !== fileResult.content;
274
+ fileResults.push({
275
+ filePath,
276
+ originalContent: fileResult.content,
277
+ newContent: fileResult.newContent,
278
+ hasChanges,
279
+ status: hasChanges ? 'modified' : 'unchanged',
280
+ transformations: {
281
+ utilitiesGenerated: fileResult.utilitiesGenerated,
282
+ classesReplaced: fileResult.classesReplaced,
283
+ conflictsResolved: 0
213
284
  }
285
+ });
286
+ if (hasChanges) {
287
+ stats.filesModified++;
288
+ }
289
+ else {
290
+ stats.filesUnchanged++;
214
291
  }
215
292
  }
216
- if (!options.skipExternal) {
217
- for (const [filePath, fileResult] of cssFileResults) {
218
- if (!fileResult.hasChanges)
219
- continue;
220
- if (fileResult.canDelete && options.deleteCss) {
221
- const success = await fileWriter.deleteFile(filePath);
222
- if (success) {
223
- results.filesModified++;
224
- logger_1.logger.info(`šŸ—‘ļø Deleted ${path_1.default.basename(filePath)} (all rules converted)`);
225
- }
226
- }
227
- else if (fileResult.canDelete && !options.deleteCss) {
228
- logger_1.logger.info(`ā„¹ļø ${path_1.default.basename(filePath)} is now empty (use --delete-css to remove)`);
229
- }
230
- else if (fileResult.fullyConvertible) {
231
- const success = await fileWriter.writeFile(filePath, fileResult.newContent, fileResult.content);
232
- if (success) {
233
- results.filesModified++;
234
- }
235
- }
236
- else {
237
- const success = await fileWriter.writeFile(filePath, fileResult.newContent, fileResult.content);
238
- if (success) {
239
- results.filesModified++;
240
- const convertedCount = fileResult.rules.filter(r => r.convertedClasses.length > 0).length;
241
- const totalCount = fileResult.rules.length;
242
- logger_1.logger.info(`šŸ“ ${path_1.default.basename(filePath)}: converted ${convertedCount}/${totalCount} rules (unconverted properties kept)`);
243
- }
244
- }
293
+ for (const [filePath, fileResult] of cssFileResults) {
294
+ if (fileResult.error) {
295
+ fileResults.push({
296
+ filePath,
297
+ originalContent: fileResult.content,
298
+ newContent: fileResult.newContent,
299
+ hasChanges: false,
300
+ status: 'error',
301
+ error: fileResult.error
302
+ });
303
+ stats.filesWithError++;
304
+ continue;
305
+ }
306
+ const hasChanges = fileResult.hasChanges && fileResult.newContent !== fileResult.content;
307
+ fileResults.push({
308
+ filePath,
309
+ originalContent: fileResult.content,
310
+ newContent: fileResult.newContent,
311
+ hasChanges,
312
+ status: hasChanges ? 'modified' : 'unchanged'
313
+ });
314
+ if (hasChanges) {
315
+ stats.filesModified++;
316
+ }
317
+ else {
318
+ stats.filesUnchanged++;
245
319
  }
246
320
  }
247
- return results;
321
+ stats.utilitiesGenerated = stats.classesReplaced + stats.utilitiesGenerated;
322
+ return { fileResults, stats };
248
323
  }
249
324
  function buildClassInfoFromRule(rule, sourceFile) {
250
325
  return {
@@ -336,4 +411,4 @@ function replaceClassNameReferences(code, classMap) {
336
411
  });
337
412
  return { code: modifiedCode, hasChanges, replacements };
338
413
  }
339
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transformer.js","sourceRoot":"","sources":["../src/transformer.ts"],"names":[],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport { ScannedFile } from './scanner';\nimport { TailwindMapper } from './tailwindMapper';\nimport { JSXParser } from './jsxParser';\nimport { CSSParser, CSSRule, UtilityWithVariant } from './cssParser';\nimport { FileWriter } from './fileWriter';\nimport { TailwindConfig } from './utils/config';\nimport { logger } from './utils/logger';\nimport { clearBreakpointCache } from './utils/breakpointResolver';\nimport { \n  assembleUtilities, \n  mergeUtilities,\n  normalizeVariantOrder \n} from './utils/variantAssembler';\nimport { transformDescendantSelectors } from './jsxDescendantTransformer';\nimport { \n  UtilityWithMeta, \n  ResolvedUtility, \n  resolveConflicts, \n  resolvedUtilitiesToStrings \n} from './utils/conflictResolver';\nimport { Specificity, ZERO_SPECIFICITY } from './utils/specificityCalculator';\n\nexport interface TransformOptions {\n  dryRun: boolean;\n  deleteCss: boolean;\n  skipExternal: boolean;\n  skipInline: boolean;\n  skipInternal: boolean;\n  tailwindConfig: TailwindConfig | null;\n  projectRoot: string;\n}\n\nexport interface TransformResults {\n  filesScanned: number;\n  filesModified: number;\n  stylesConverted: number;\n  classesReplaced: number;\n  warnings: number;\n}\n\ninterface ClassInfo {\n  utilities: UtilityWithMeta[];\n  sourceFile: string;\n  fullyConvertible: boolean;\n}\n\ninterface CSSClassMap {\n  [className: string]: ClassInfo;\n}\n\ninterface CollectedRules {\n  simpleRules: CSSRule[];\n  descendantRules: CSSRule[];\n}\n\nexport async function transformFiles(\n  files: ScannedFile[],\n  options: TransformOptions\n): Promise<TransformResults> {\n  const results: TransformResults = {\n    filesScanned: files.length,\n    filesModified: 0,\n    stylesConverted: 0,\n    classesReplaced: 0,\n    warnings: 0\n  };\n\n  const mapper = new TailwindMapper(options.tailwindConfig || {});\n  const jsxParser = new JSXParser(mapper);\n  const screens = options.tailwindConfig?.theme?.screens;\n  const cssParser = new CSSParser(mapper, screens);\n  const fileWriter = new FileWriter({ dryRun: options.dryRun });\n\n  clearBreakpointCache();\n\n  const cssClassMap: CSSClassMap = {};\n  const allDescendantRules: CSSRule[] = [];\n  const cssFileResults: Map<string, {\n    content: string;\n    newContent: string;\n    rules: CSSRule[];\n    canDelete: boolean;\n    hasChanges: boolean;\n    fullyConvertible: boolean;\n  }> = new Map();\n\n  logger.info('\\n🔍 Phase 1: Analyzing files...');\n\n  if (!options.skipExternal) {\n    for (const file of files.filter(f => f.type === 'css')) {\n      try {\n        const content = fs.readFileSync(file.path, 'utf-8');\n        const result = await cssParser.parse(content, file.path);\n\n        const totalRules = result.rules.length;\n        const fullyConvertedRules = result.rules.filter(r => r.fullyConverted).length;\n        const partiallyConvertedRules = result.rules.filter(r => r.partialConversion).length;\n        const fullyConvertible = totalRules > 0 && totalRules === fullyConvertedRules && partiallyConvertedRules === 0;\n\n        result.rules.forEach(rule => {\n          if (rule.isDescendant) {\n            if (rule.convertedClasses.length > 0) {\n              allDescendantRules.push(rule);\n              results.stylesConverted += rule.declarations.length;\n            }\n          } else if (rule.className && rule.convertedClasses.length > 0) {\n            const existing = cssClassMap[rule.className];\n            if (existing) {\n              mergeRuleIntoClassInfo(existing, rule);\n            } else {\n              cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);\n            }\n            if (rule.fullyConverted) {\n              results.stylesConverted += rule.declarations.length;\n            } else {\n              results.stylesConverted += rule.convertedClasses.length;\n              logger.verbose(`  Rule .${rule.className}: partial conversion (${rule.convertedClasses.length}/${rule.declarations.length} declarations)`);\n            }\n          }\n        });\n\n        cssFileResults.set(file.path, {\n          content,\n          newContent: result.css,\n          rules: result.rules,\n          canDelete: result.canDelete,\n          hasChanges: result.hasChanges,\n          fullyConvertible\n        });\n\n        results.warnings += result.warnings.length;\n\n        logger.verbose(`Analyzed ${file.path}:`);\n        logger.verbose(`  - Total rules: ${totalRules}`);\n        logger.verbose(`  - Fully converted rules: ${fullyConvertedRules}`);\n        logger.verbose(`  - Partially converted rules: ${partiallyConvertedRules}`);\n        logger.verbose(`  - Fully convertible: ${fullyConvertible}`);\n\n        result.warnings.forEach(warning => {\n          logger.verbose(`⚠️  ${file.path}: ${warning}`);\n        });\n\n      } catch (error) {\n        logger.error(`Failed to analyze ${file.path}:`, error);\n        results.warnings++;\n      }\n    }\n  }\n\n  logger.info('\\n⚛️  Phase 2: Transforming React components...');\n\n  const jsxFileResults: Map<string, {\n    content: string;\n    newContent: string;\n    hasChanges: boolean;\n  }> = new Map();\n\n  for (const file of files.filter(f => f.type === 'jsx')) {\n    try {\n      let content = fs.readFileSync(file.path, 'utf-8');\n      const originalContent = content;\n      let hasChanges = false;\n      let fileWarnings: string[] = [];\n\n      if (!options.skipInline) {\n        try {\n          const jsxResult = jsxParser.parse(content, file.path);\n          \n          if (jsxResult.hasChanges) {\n            content = jsxResult.code;\n            hasChanges = true;\n            results.stylesConverted += jsxResult.transformations.reduce(\n              (sum, t) => sum + t.classes.length, 0\n            );\n            fileWarnings.push(...jsxResult.warnings);\n          }\n        } catch (error) {\n          logger.warn(`Failed to parse JSX inline styles in ${file.path}: ${error}`);\n          fileWarnings.push(`JSX parse error: ${error}`);\n        }\n      }\n\n      if (!options.skipInternal) {\n        try {\n          const internalResult = await cssParser.parseInternalCSS(content, file.path);\n          \n          if (internalResult.hasChanges) {\n            content = internalResult.html;\n            hasChanges = true;\n            \n            internalResult.rules.forEach(rule => {\n              if (rule.isDescendant) {\n                if (rule.convertedClasses.length > 0) {\n                  allDescendantRules.push(rule);\n                  results.stylesConverted += rule.declarations.length;\n                }\n              } else if (rule.convertedClasses.length > 0 && rule.className) {\n                const existing = cssClassMap[rule.className];\n                if (existing) {\n                  mergeRuleIntoClassInfo(existing, rule);\n                } else {\n                  cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);\n                }\n                results.stylesConverted += rule.declarations.length;\n              }\n            });\n            \n            fileWarnings.push(...internalResult.warnings);\n          }\n        } catch (error) {\n          logger.warn(`Failed to parse internal CSS in ${file.path}: ${error}`);\n          fileWarnings.push(`Internal CSS parse error: ${error}`);\n        }\n      }\n\n      jsxFileResults.set(file.path, {\n        content: originalContent,\n        newContent: content,\n        hasChanges\n      });\n\n      results.warnings += fileWarnings.length;\n\n      fileWarnings.forEach(warning => {\n        logger.verbose(`⚠️  ${file.path}: ${warning}`);\n      });\n\n    } catch (error) {\n      logger.error(`Failed to process ${file.path}:`, error);\n      results.warnings++;\n    }\n  }\n\n  if (Object.keys(cssClassMap).length > 0) {\n    logger.info('\\n🔄 Phase 3: Replacing className references...');\n\n    for (const [filePath, fileResult] of jsxFileResults) {\n      let content = fileResult.newContent;\n      let hasChanges = fileResult.hasChanges;\n\n      const replacementResult = replaceClassNameReferences(content, cssClassMap);\n      if (replacementResult.hasChanges) {\n        content = replacementResult.code;\n        hasChanges = true;\n        results.classesReplaced += replacementResult.replacements;\n        \n        logger.verbose(`Replaced ${replacementResult.replacements} class references in ${path.basename(filePath)}`);\n      }\n\n      jsxFileResults.set(filePath, {\n        ...fileResult,\n        newContent: content,\n        hasChanges\n      });\n    }\n  }\n\n  if (allDescendantRules.length > 0) {\n    logger.info('\\n🌳 Phase 3.5: Applying descendant selector rules...');\n\n    for (const [filePath, fileResult] of jsxFileResults) {\n      let content = fileResult.newContent;\n      let hasChanges = fileResult.hasChanges;\n\n      const descendantResult = transformDescendantSelectors(content, allDescendantRules);\n      if (descendantResult.hasChanges) {\n        content = descendantResult.code;\n        hasChanges = true;\n        results.classesReplaced += descendantResult.transformations;\n        \n        logger.verbose(`Applied ${descendantResult.transformations} descendant transformations in ${path.basename(filePath)}`);\n      }\n\n      if (descendantResult.warnings.length > 0) {\n        results.warnings += descendantResult.warnings.length;\n        descendantResult.warnings.forEach(warning => {\n          logger.verbose(`⚠️  ${filePath}: ${warning}`);\n        });\n      }\n\n      jsxFileResults.set(filePath, {\n        ...fileResult,\n        newContent: content,\n        hasChanges\n      });\n    }\n  }\n\n  logger.info('\\n💾 Phase 4: Writing changes...');\n\n  for (const [filePath, fileResult] of jsxFileResults) {\n    if (fileResult.hasChanges) {\n      const success = await fileWriter.writeFile(filePath, fileResult.newContent, fileResult.content);\n      if (success) {\n        results.filesModified++;\n      }\n    }\n  }\n\n  if (!options.skipExternal) {\n    for (const [filePath, fileResult] of cssFileResults) {\n      if (!fileResult.hasChanges) continue;\n\n      if (fileResult.canDelete && options.deleteCss) {\n        const success = await fileWriter.deleteFile(filePath);\n        if (success) {\n          results.filesModified++;\n          logger.info(`🗑️  Deleted ${path.basename(filePath)} (all rules converted)`);\n        }\n      } else if (fileResult.canDelete && !options.deleteCss) {\n        logger.info(`ℹ️  ${path.basename(filePath)} is now empty (use --delete-css to remove)`);\n      } else if (fileResult.fullyConvertible) {\n        const success = await fileWriter.writeFile(filePath, fileResult.newContent, fileResult.content);\n        if (success) {\n          results.filesModified++;\n        }\n      } else {\n        const success = await fileWriter.writeFile(filePath, fileResult.newContent, fileResult.content);\n        if (success) {\n          results.filesModified++;\n          const convertedCount = fileResult.rules.filter(r => r.convertedClasses.length > 0).length;\n          const totalCount = fileResult.rules.length;\n          logger.info(`📝 ${path.basename(filePath)}: converted ${convertedCount}/${totalCount} rules (unconverted properties kept)`);\n        }\n      }\n    }\n  }\n\n  return results;\n}\n\nfunction buildClassInfoFromRule(rule: CSSRule, sourceFile: string): ClassInfo {\n  return {\n    utilities: rule.utilities.map(u => ({\n      value: u.value,\n      variants: normalizeVariantOrder([...u.variants]),\n      cssProperty: u.cssProperty,\n      specificity: u.specificity,\n      sourceOrder: u.sourceOrder,\n      originalSelector: rule.selector\n    })),\n    sourceFile,\n    fullyConvertible: rule.fullyConverted\n  };\n}\n\nfunction mergeRuleIntoClassInfo(info: ClassInfo, rule: CSSRule): void {\n  for (const utility of rule.utilities) {\n    const utilityWithMeta: UtilityWithMeta = {\n      value: utility.value,\n      variants: normalizeVariantOrder([...utility.variants]),\n      cssProperty: utility.cssProperty,\n      specificity: utility.specificity,\n      sourceOrder: utility.sourceOrder,\n      originalSelector: rule.selector\n    };\n    \n    info.utilities.push(utilityWithMeta);\n  }\n}\n\nfunction assembleTailwindClasses(info: ClassInfo): string {\n  const { resolved } = resolveConflicts(info.utilities, false);\n  return resolvedUtilitiesToStrings(resolved).join(' ');\n}\n\nfunction replaceClassNameReferences(\n  code: string, \n  classMap: CSSClassMap\n): { \n  code: string; \n  hasChanges: boolean; \n  replacements: number \n} {\n  let hasChanges = false;\n  let replacements = 0;\n  let modifiedCode = code;\n\n  Object.entries(classMap).forEach(([oldClass, info]) => {\n    if (info.utilities.length === 0) {\n      return;\n    }\n\n    const tailwindClassString = assembleTailwindClasses(info);\n    \n    if (info.fullyConvertible) {\n      const pattern1 = new RegExp(`className=\"${oldClass}\"`, 'g');\n      if (pattern1.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern1, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className=\"${oldClass}\" with \"${tailwindClassString}\"`);\n      }\n\n      const pattern2 = new RegExp(`className=\\\\{\"${oldClass}\"\\\\}`, 'g');\n      if (pattern2.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern2, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className={\"${oldClass}\"} with \"${tailwindClassString}\"`);\n      }\n\n      const pattern3 = new RegExp(`className=\\\\{\\`\\\\s*${oldClass}\\\\s*\\`\\\\}`, 'g');\n      if (pattern3.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern3, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className={\\`${oldClass}\\`} with \"${tailwindClassString}\"`);\n      }\n    } else {\n      const combinedClassString = `${oldClass} ${tailwindClassString}`;\n      \n      const pattern1 = new RegExp(`className=\"${oldClass}\"`, 'g');\n      if (pattern1.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern1, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className=\"${oldClass}\" → \"${combinedClassString}\"`);\n      }\n\n      const pattern2 = new RegExp(`className=\\\\{\"${oldClass}\"\\\\}`, 'g');\n      if (pattern2.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern2, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className={\"${oldClass}\"} → \"${combinedClassString}\"`);\n      }\n\n      const pattern3 = new RegExp(`className=\\\\{\\`\\\\s*${oldClass}\\\\s*\\`\\\\}`, 'g');\n      if (pattern3.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern3, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className={\\`${oldClass}\\`} → \"${combinedClassString}\"`);\n      }\n    }\n  });\n\n  return { code: modifiedCode, hasChanges, replacements };\n}"]}
414
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transformer.js","sourceRoot":"","sources":["../src/transformer.ts"],"names":[],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport { ScannedFile } from './scanner';\nimport { TailwindMapper } from './tailwindMapper';\nimport { JSXParser } from './jsxParser';\nimport { CSSParser, CSSRule, UtilityWithVariant } from './cssParser';\nimport { TailwindConfig } from './utils/config';\nimport { logger } from './utils/logger';\nimport { clearBreakpointCache } from './utils/breakpointResolver';\nimport { \n  assembleUtilities, \n  normalizeVariantOrder \n} from './utils/variantAssembler';\nimport { transformDescendantSelectors } from './jsxDescendantTransformer';\nimport { \n  UtilityWithMeta, \n  resolveConflicts, \n  resolvedUtilitiesToStrings \n} from './utils/conflictResolver';\nimport { Specificity } from './utils/specificityCalculator';\nimport { FileResult, SummaryStats } from './utils/reporter';\n\nexport interface TransformOptions {\n  dryRun: boolean;\n  deleteCss: boolean;\n  skipExternal: boolean;\n  skipInline: boolean;\n  skipInternal: boolean;\n  tailwindConfig: TailwindConfig | null;\n  projectRoot: string;\n}\n\nexport interface TransformResults {\n  filesScanned: number;\n  filesModified: number;\n  stylesConverted: number;\n  classesReplaced: number;\n  warnings: number;\n}\n\nexport interface DetailedTransformResults {\n  fileResults: FileResult[];\n  stats: SummaryStats;\n}\n\ninterface ClassInfo {\n  utilities: UtilityWithMeta[];\n  sourceFile: string;\n  fullyConvertible: boolean;\n}\n\ninterface CSSClassMap {\n  [className: string]: ClassInfo;\n}\n\ninterface ProcessedCSSFile {\n  path: string;\n  content: string;\n  newContent: string;\n  rules: CSSRule[];\n  canDelete: boolean;\n  hasChanges: boolean;\n  fullyConvertible: boolean;\n  warnings: string[];\n  error?: string;\n}\n\ninterface ProcessedJSXFile {\n  path: string;\n  content: string;\n  newContent: string;\n  hasChanges: boolean;\n  warnings: string[];\n  error?: string;\n  utilitiesGenerated: number;\n  classesReplaced: number;\n}\n\nexport async function transformFiles(\n  files: ScannedFile[],\n  options: TransformOptions\n): Promise<TransformResults> {\n  const detailed = await transformFilesDetailed(files, options);\n  return {\n    filesScanned: detailed.stats.filesScanned,\n    filesModified: detailed.stats.filesModified,\n    stylesConverted: detailed.stats.utilitiesGenerated,\n    classesReplaced: detailed.stats.classesReplaced,\n    warnings: detailed.stats.warnings\n  };\n}\n\nexport async function transformFilesDetailed(\n  files: ScannedFile[],\n  options: TransformOptions\n): Promise<DetailedTransformResults> {\n  const stats: SummaryStats = {\n    filesScanned: files.length,\n    filesModified: 0,\n    filesUnchanged: 0,\n    filesWithError: 0,\n    utilitiesGenerated: 0,\n    classesReplaced: 0,\n    conflictsResolved: 0,\n    unsupportedSelectors: 0,\n    errors: 0,\n    warnings: 0\n  };\n\n  const fileResults: FileResult[] = [];\n\n  const mapper = new TailwindMapper(options.tailwindConfig || {});\n  const jsxParser = new JSXParser(mapper);\n  const screens = options.tailwindConfig?.theme?.screens;\n  const cssParser = new CSSParser(mapper, screens);\n\n  clearBreakpointCache();\n\n  const cssClassMap: CSSClassMap = {};\n  const allDescendantRules: CSSRule[] = [];\n\n  logger.info('\\n🔍 Phase 1: Analyzing CSS files...');\n\n  const cssFileResults: Map<string, ProcessedCSSFile> = new Map();\n\n  if (!options.skipExternal) {\n    for (const file of files.filter(f => f.type === 'css')) {\n      try {\n        const content = fs.readFileSync(file.path, 'utf-8');\n        const result = await cssParser.parse(content, file.path);\n\n        const totalRules = result.rules.length;\n        const fullyConvertedRules = result.rules.filter(r => r.fullyConverted).length;\n        const partiallyConvertedRules = result.rules.filter(r => r.partialConversion).length;\n        const fullyConvertible = totalRules > 0 && totalRules === fullyConvertedRules && partiallyConvertedRules === 0;\n\n        result.rules.forEach(rule => {\n          if (rule.isDescendant) {\n            if (rule.convertedClasses.length > 0) {\n              allDescendantRules.push(rule);\n              stats.utilitiesGenerated += rule.declarations.length;\n            }\n          } else if (rule.className && rule.convertedClasses.length > 0) {\n            const existing = cssClassMap[rule.className];\n            if (existing) {\n              mergeRuleIntoClassInfo(existing, rule);\n            } else {\n              cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);\n            }\n            if (rule.fullyConverted) {\n              stats.utilitiesGenerated += rule.declarations.length;\n            } else {\n              stats.utilitiesGenerated += rule.convertedClasses.length;\n              logger.verbose(`  Rule .${rule.className}: partial conversion (${rule.convertedClasses.length}/${rule.declarations.length} declarations)`);\n            }\n          }\n        });\n\n        cssFileResults.set(file.path, {\n          path: file.path,\n          content,\n          newContent: result.css,\n          rules: result.rules,\n          canDelete: result.canDelete,\n          hasChanges: result.hasChanges,\n          fullyConvertible,\n          warnings: result.warnings\n        });\n\n        stats.warnings += result.warnings.length;\n\n        logger.verbose(`Analyzed ${file.path}:`);\n        logger.verbose(`  - Total rules: ${totalRules}`);\n        logger.verbose(`  - Fully converted rules: ${fullyConvertedRules}`);\n        logger.verbose(`  - Partially converted rules: ${partiallyConvertedRules}`);\n        logger.verbose(`  - Fully convertible: ${fullyConvertible}`);\n\n        result.warnings.forEach(warning => {\n          logger.verbose(`⚠️  ${file.path}: ${warning}`);\n        });\n\n      } catch (error) {\n        const errorMessage = error instanceof Error ? error.message : String(error);\n        logger.error(`Failed to analyze ${file.path}:`, error);\n        cssFileResults.set(file.path, {\n          path: file.path,\n          content: '',\n          newContent: '',\n          rules: [],\n          canDelete: false,\n          hasChanges: false,\n          fullyConvertible: false,\n          warnings: [],\n          error: errorMessage\n        });\n        stats.errors++;\n        stats.warnings++;\n      }\n    }\n  }\n\n  logger.info('\\n⚛️  Phase 2: Transforming React components...');\n\n  const jsxFileResults: Map<string, ProcessedJSXFile> = new Map();\n\n  for (const file of files.filter(f => f.type === 'jsx')) {\n    try {\n      let content = fs.readFileSync(file.path, 'utf-8');\n      const originalContent = content;\n      let hasChanges = false;\n      let fileWarnings: string[] = [];\n      let utilitiesGenerated = 0;\n      let classesReplaced = 0;\n\n      if (!options.skipInline) {\n        try {\n          const jsxResult = jsxParser.parse(content, file.path);\n          \n          if (jsxResult.hasChanges) {\n            content = jsxResult.code;\n            hasChanges = true;\n            utilitiesGenerated += jsxResult.transformations.reduce(\n              (sum, t) => sum + t.classes.length, 0\n            );\n            fileWarnings.push(...jsxResult.warnings);\n          }\n        } catch (error) {\n          logger.warn(`Failed to parse JSX inline styles in ${file.path}: ${error}`);\n          fileWarnings.push(`JSX parse error: ${error}`);\n        }\n      }\n\n      if (!options.skipInternal) {\n        try {\n          const internalResult = await cssParser.parseInternalCSS(content, file.path);\n          \n          if (internalResult.hasChanges) {\n            content = internalResult.html;\n            hasChanges = true;\n            \n            internalResult.rules.forEach(rule => {\n              if (rule.isDescendant) {\n                if (rule.convertedClasses.length > 0) {\n                  allDescendantRules.push(rule);\n                  utilitiesGenerated += rule.declarations.length;\n                }\n              } else if (rule.convertedClasses.length > 0 && rule.className) {\n                const existing = cssClassMap[rule.className];\n                if (existing) {\n                  mergeRuleIntoClassInfo(existing, rule);\n                } else {\n                  cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);\n                }\n                utilitiesGenerated += rule.declarations.length;\n              }\n            });\n            \n            fileWarnings.push(...internalResult.warnings);\n          }\n        } catch (error) {\n          logger.warn(`Failed to parse internal CSS in ${file.path}: ${error}`);\n          fileWarnings.push(`Internal CSS parse error: ${error}`);\n        }\n      }\n\n      jsxFileResults.set(file.path, {\n        path: file.path,\n        content: originalContent,\n        newContent: content,\n        hasChanges,\n        warnings: fileWarnings,\n        utilitiesGenerated,\n        classesReplaced\n      });\n\n      stats.warnings += fileWarnings.length;\n\n      fileWarnings.forEach(warning => {\n        logger.verbose(`⚠️  ${file.path}: ${warning}`);\n      });\n\n    } catch (error) {\n      const errorMessage = error instanceof Error ? error.message : String(error);\n      logger.error(`Failed to process ${file.path}:`, error);\n      jsxFileResults.set(file.path, {\n        path: file.path,\n        content: '',\n        newContent: '',\n        hasChanges: false,\n        warnings: [],\n        utilitiesGenerated: 0,\n        classesReplaced: 0,\n        error: errorMessage\n      });\n      stats.errors++;\n    }\n  }\n\n  if (Object.keys(cssClassMap).length > 0) {\n    logger.info('\\n🔄 Phase 3: Replacing className references...');\n\n    for (const [filePath, fileResult] of jsxFileResults) {\n      if (fileResult.error) continue;\n      \n      let content = fileResult.newContent;\n      let hasChanges = fileResult.hasChanges;\n\n      const replacementResult = replaceClassNameReferences(content, cssClassMap);\n      if (replacementResult.hasChanges) {\n        content = replacementResult.code;\n        hasChanges = true;\n        fileResult.classesReplaced += replacementResult.replacements;\n        stats.classesReplaced += replacementResult.replacements;\n        \n        logger.verbose(`Replaced ${replacementResult.replacements} class references in ${path.basename(filePath)}`);\n      }\n\n      jsxFileResults.set(filePath, {\n        ...fileResult,\n        newContent: content,\n        hasChanges\n      });\n    }\n  }\n\n  if (allDescendantRules.length > 0) {\n    logger.info('\\n🌳 Phase 3.5: Applying descendant selector rules...');\n\n    for (const [filePath, fileResult] of jsxFileResults) {\n      if (fileResult.error) continue;\n      \n      let content = fileResult.newContent;\n      let hasChanges = fileResult.hasChanges;\n\n      const descendantResult = transformDescendantSelectors(content, allDescendantRules);\n      if (descendantResult.hasChanges) {\n        content = descendantResult.code;\n        hasChanges = true;\n        fileResult.classesReplaced += descendantResult.transformations;\n        stats.classesReplaced += descendantResult.transformations;\n        \n        logger.verbose(`Applied ${descendantResult.transformations} descendant transformations in ${path.basename(filePath)}`);\n      }\n\n      if (descendantResult.warnings.length > 0) {\n        stats.warnings += descendantResult.warnings.length;\n        descendantResult.warnings.forEach(warning => {\n          logger.verbose(`⚠️  ${filePath}: ${warning}`);\n        });\n      }\n\n      jsxFileResults.set(filePath, {\n        ...fileResult,\n        newContent: content,\n        hasChanges\n      });\n    }\n  }\n\n  for (const [filePath, fileResult] of jsxFileResults) {\n    if (fileResult.error) {\n      fileResults.push({\n        filePath,\n        originalContent: fileResult.content,\n        newContent: fileResult.newContent,\n        hasChanges: false,\n        status: 'error',\n        error: fileResult.error\n      });\n      stats.filesWithError++;\n      continue;\n    }\n    \n    const hasChanges = fileResult.newContent !== fileResult.content;\n    \n    fileResults.push({\n      filePath,\n      originalContent: fileResult.content,\n      newContent: fileResult.newContent,\n      hasChanges,\n      status: hasChanges ? 'modified' : 'unchanged',\n      transformations: {\n        utilitiesGenerated: fileResult.utilitiesGenerated,\n        classesReplaced: fileResult.classesReplaced,\n        conflictsResolved: 0\n      }\n    });\n    \n    if (hasChanges) {\n      stats.filesModified++;\n    } else {\n      stats.filesUnchanged++;\n    }\n  }\n\n  for (const [filePath, fileResult] of cssFileResults) {\n    if (fileResult.error) {\n      fileResults.push({\n        filePath,\n        originalContent: fileResult.content,\n        newContent: fileResult.newContent,\n        hasChanges: false,\n        status: 'error',\n        error: fileResult.error\n      });\n      stats.filesWithError++;\n      continue;\n    }\n    \n    const hasChanges = fileResult.hasChanges && fileResult.newContent !== fileResult.content;\n    \n    fileResults.push({\n      filePath,\n      originalContent: fileResult.content,\n      newContent: fileResult.newContent,\n      hasChanges,\n      status: hasChanges ? 'modified' : 'unchanged'\n    });\n    \n    if (hasChanges) {\n      stats.filesModified++;\n    } else {\n      stats.filesUnchanged++;\n    }\n  }\n\n  stats.utilitiesGenerated = stats.classesReplaced + stats.utilitiesGenerated;\n\n  return { fileResults, stats };\n}\n\nfunction buildClassInfoFromRule(rule: CSSRule, sourceFile: string): ClassInfo {\n  return {\n    utilities: rule.utilities.map(u => ({\n      value: u.value,\n      variants: normalizeVariantOrder([...u.variants]),\n      cssProperty: u.cssProperty,\n      specificity: u.specificity,\n      sourceOrder: u.sourceOrder,\n      originalSelector: rule.selector\n    })),\n    sourceFile,\n    fullyConvertible: rule.fullyConverted\n  };\n}\n\nfunction mergeRuleIntoClassInfo(info: ClassInfo, rule: CSSRule): void {\n  for (const utility of rule.utilities) {\n    const utilityWithMeta: UtilityWithMeta = {\n      value: utility.value,\n      variants: normalizeVariantOrder([...utility.variants]),\n      cssProperty: utility.cssProperty,\n      specificity: utility.specificity,\n      sourceOrder: utility.sourceOrder,\n      originalSelector: rule.selector\n    };\n    \n    info.utilities.push(utilityWithMeta);\n  }\n}\n\nfunction assembleTailwindClasses(info: ClassInfo): string {\n  const { resolved } = resolveConflicts(info.utilities, false);\n  return resolvedUtilitiesToStrings(resolved).join(' ');\n}\n\nfunction replaceClassNameReferences(\n  code: string, \n  classMap: CSSClassMap\n): { \n  code: string; \n  hasChanges: boolean; \n  replacements: number \n} {\n  let hasChanges = false;\n  let replacements = 0;\n  let modifiedCode = code;\n\n  Object.entries(classMap).forEach(([oldClass, info]) => {\n    if (info.utilities.length === 0) {\n      return;\n    }\n\n    const tailwindClassString = assembleTailwindClasses(info);\n    \n    if (info.fullyConvertible) {\n      const pattern1 = new RegExp(`className=\"${oldClass}\"`, 'g');\n      if (pattern1.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern1, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className=\"${oldClass}\" with \"${tailwindClassString}\"`);\n      }\n\n      const pattern2 = new RegExp(`className=\\\\{\"${oldClass}\"\\\\}`, 'g');\n      if (pattern2.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern2, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className={\"${oldClass}\"} with \"${tailwindClassString}\"`);\n      }\n\n      const pattern3 = new RegExp(`className=\\\\{\\`\\\\s*${oldClass}\\\\s*\\`\\\\}`, 'g');\n      if (pattern3.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern3, `className=\"${tailwindClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Replaced className={\\`${oldClass}\\`} with \"${tailwindClassString}\"`);\n      }\n    } else {\n      const combinedClassString = `${oldClass} ${tailwindClassString}`;\n      \n      const pattern1 = new RegExp(`className=\"${oldClass}\"`, 'g');\n      if (pattern1.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern1, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className=\"${oldClass}\" → \"${combinedClassString}\"`);\n      }\n\n      const pattern2 = new RegExp(`className=\\\\{\"${oldClass}\"\\\\}`, 'g');\n      if (pattern2.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern2, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className={\"${oldClass}\"} → \"${combinedClassString}\"`);\n      }\n\n      const pattern3 = new RegExp(`className=\\\\{\\`\\\\s*${oldClass}\\\\s*\\`\\\\}`, 'g');\n      if (pattern3.test(modifiedCode)) {\n        modifiedCode = modifiedCode.replace(pattern3, `className=\"${combinedClassString}\"`);\n        hasChanges = true;\n        replacements++;\n        logger.verbose(`Appended to className={\\`${oldClass}\\`} → \"${combinedClassString}\"`);\n      }\n    }\n  });\n\n  return { code: modifiedCode, hasChanges, replacements };\n}\n"]}
@@ -0,0 +1,26 @@
1
+ export interface DiffLine {
2
+ type: 'context' | 'added' | 'removed';
3
+ content: string;
4
+ oldLineNumber?: number;
5
+ newLineNumber?: number;
6
+ }
7
+ export interface DiffHunk {
8
+ oldStart: number;
9
+ oldLines: number;
10
+ newStart: number;
11
+ newLines: number;
12
+ lines: DiffLine[];
13
+ }
14
+ export interface DiffResult {
15
+ hunks: DiffHunk[];
16
+ hasChanges: boolean;
17
+ }
18
+ export declare function computeUnifiedDiff(oldContent: string, newContent: string, contextLines?: number): DiffResult;
19
+ export declare function formatDiffHeader(filePath: string): string;
20
+ export declare function formatDiffHunk(hunk: DiffHunk): string;
21
+ export declare function formatDiff(filePath: string, diff: DiffResult): string;
22
+ export declare function computeAndFormatDiff(oldContent: string, newContent: string, filePath: string): string;
23
+ export declare function getChangeStats(diff: DiffResult): {
24
+ added: number;
25
+ removed: number;
26
+ };