css-to-tailwind-react 0.3.4 → 0.4.1

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,37 +4,80 @@ 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
+ const variableRegistry_1 = require("./utils/variableRegistry");
18
19
  async function transformFiles(files, options) {
19
- const results = {
20
+ const detailed = await transformFilesDetailed(files, options);
21
+ return {
22
+ filesScanned: detailed.stats.filesScanned,
23
+ filesModified: detailed.stats.filesModified,
24
+ stylesConverted: detailed.stats.utilitiesGenerated,
25
+ classesReplaced: detailed.stats.classesReplaced,
26
+ warnings: detailed.stats.warnings
27
+ };
28
+ }
29
+ async function transformFilesDetailed(files, options) {
30
+ const stats = {
20
31
  filesScanned: files.length,
21
32
  filesModified: 0,
22
- stylesConverted: 0,
33
+ filesUnchanged: 0,
34
+ filesWithError: 0,
35
+ utilitiesGenerated: 0,
23
36
  classesReplaced: 0,
37
+ conflictsResolved: 0,
38
+ unsupportedSelectors: 0,
39
+ errors: 0,
24
40
  warnings: 0
25
41
  };
42
+ const fileResults = [];
26
43
  const mapper = new tailwindMapper_1.TailwindMapper(options.tailwindConfig || {});
27
44
  const jsxParser = new jsxParser_1.JSXParser(mapper);
28
45
  const screens = options.tailwindConfig?.theme?.screens;
29
- const cssParser = new cssParser_1.CSSParser(mapper, screens);
30
- const fileWriter = new fileWriter_1.FileWriter({ dryRun: options.dryRun });
46
+ const sharedVariableRegistry = new variableRegistry_1.VariableRegistry();
47
+ const cssParser = new cssParser_1.CSSParser(mapper, screens, sharedVariableRegistry);
31
48
  (0, breakpointResolver_1.clearBreakpointCache)();
32
49
  const cssClassMap = {};
33
50
  const allDescendantRules = [];
51
+ const cssFiles = files.filter(f => f.type === 'css');
52
+ const jsxFiles = files.filter(f => f.type === 'jsx');
53
+ logger_1.logger.info('\nšŸ” Phase 0: Collecting CSS variables from all files...');
54
+ if (!options.skipExternal) {
55
+ for (const file of cssFiles) {
56
+ try {
57
+ const content = fs_1.default.readFileSync(file.path, 'utf-8');
58
+ await cssParser.collectVariablesOnly(content, file.path);
59
+ }
60
+ catch (error) {
61
+ logger_1.logger.warn(`Failed to collect variables from ${file.path}: ${error}`);
62
+ }
63
+ }
64
+ for (const file of jsxFiles) {
65
+ if (options.skipInternal)
66
+ continue;
67
+ try {
68
+ const content = fs_1.default.readFileSync(file.path, 'utf-8');
69
+ await cssParser.collectVariablesFromInternalCSS(content, file.path);
70
+ }
71
+ catch (error) {
72
+ logger_1.logger.warn(`Failed to collect internal CSS variables from ${file.path}: ${error}`);
73
+ }
74
+ }
75
+ logger_1.logger.verbose(`Collected ${sharedVariableRegistry.getRegisteredVariables().length} unique CSS variables`);
76
+ }
77
+ logger_1.logger.info('\nšŸ” Phase 1: Analyzing CSS files...');
34
78
  const cssFileResults = new Map();
35
- logger_1.logger.info('\nšŸ” Phase 1: Analyzing files...');
36
79
  if (!options.skipExternal) {
37
- for (const file of files.filter(f => f.type === 'css')) {
80
+ for (const file of cssFiles) {
38
81
  try {
39
82
  const content = fs_1.default.readFileSync(file.path, 'utf-8');
40
83
  const result = await cssParser.parse(content, file.path);
@@ -46,7 +89,7 @@ async function transformFiles(files, options) {
46
89
  if (rule.isDescendant) {
47
90
  if (rule.convertedClasses.length > 0) {
48
91
  allDescendantRules.push(rule);
49
- results.stylesConverted += rule.declarations.length;
92
+ stats.utilitiesGenerated += rule.declarations.length;
50
93
  }
51
94
  }
52
95
  else if (rule.className && rule.convertedClasses.length > 0) {
@@ -58,23 +101,25 @@ async function transformFiles(files, options) {
58
101
  cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);
59
102
  }
60
103
  if (rule.fullyConverted) {
61
- results.stylesConverted += rule.declarations.length;
104
+ stats.utilitiesGenerated += rule.declarations.length;
62
105
  }
63
106
  else {
64
- results.stylesConverted += rule.convertedClasses.length;
107
+ stats.utilitiesGenerated += rule.convertedClasses.length;
65
108
  logger_1.logger.verbose(` Rule .${rule.className}: partial conversion (${rule.convertedClasses.length}/${rule.declarations.length} declarations)`);
66
109
  }
67
110
  }
68
111
  });
69
112
  cssFileResults.set(file.path, {
113
+ path: file.path,
70
114
  content,
71
115
  newContent: result.css,
72
116
  rules: result.rules,
73
117
  canDelete: result.canDelete,
74
118
  hasChanges: result.hasChanges,
75
- fullyConvertible
119
+ fullyConvertible,
120
+ warnings: result.warnings
76
121
  });
77
- results.warnings += result.warnings.length;
122
+ stats.warnings += result.warnings.length;
78
123
  logger_1.logger.verbose(`Analyzed ${file.path}:`);
79
124
  logger_1.logger.verbose(` - Total rules: ${totalRules}`);
80
125
  logger_1.logger.verbose(` - Fully converted rules: ${fullyConvertedRules}`);
@@ -85,26 +130,41 @@ async function transformFiles(files, options) {
85
130
  });
86
131
  }
87
132
  catch (error) {
133
+ const errorMessage = error instanceof Error ? error.message : String(error);
88
134
  logger_1.logger.error(`Failed to analyze ${file.path}:`, error);
89
- results.warnings++;
135
+ cssFileResults.set(file.path, {
136
+ path: file.path,
137
+ content: '',
138
+ newContent: '',
139
+ rules: [],
140
+ canDelete: false,
141
+ hasChanges: false,
142
+ fullyConvertible: false,
143
+ warnings: [],
144
+ error: errorMessage
145
+ });
146
+ stats.errors++;
147
+ stats.warnings++;
90
148
  }
91
149
  }
92
150
  }
93
151
  logger_1.logger.info('\nāš›ļø Phase 2: Transforming React components...');
94
152
  const jsxFileResults = new Map();
95
- for (const file of files.filter(f => f.type === 'jsx')) {
153
+ for (const file of jsxFiles) {
96
154
  try {
97
155
  let content = fs_1.default.readFileSync(file.path, 'utf-8');
98
156
  const originalContent = content;
99
157
  let hasChanges = false;
100
158
  let fileWarnings = [];
159
+ let utilitiesGenerated = 0;
160
+ let classesReplaced = 0;
101
161
  if (!options.skipInline) {
102
162
  try {
103
163
  const jsxResult = jsxParser.parse(content, file.path);
104
164
  if (jsxResult.hasChanges) {
105
165
  content = jsxResult.code;
106
166
  hasChanges = true;
107
- results.stylesConverted += jsxResult.transformations.reduce((sum, t) => sum + t.classes.length, 0);
167
+ utilitiesGenerated += jsxResult.transformations.reduce((sum, t) => sum + t.classes.length, 0);
108
168
  fileWarnings.push(...jsxResult.warnings);
109
169
  }
110
170
  }
@@ -123,7 +183,7 @@ async function transformFiles(files, options) {
123
183
  if (rule.isDescendant) {
124
184
  if (rule.convertedClasses.length > 0) {
125
185
  allDescendantRules.push(rule);
126
- results.stylesConverted += rule.declarations.length;
186
+ utilitiesGenerated += rule.declarations.length;
127
187
  }
128
188
  }
129
189
  else if (rule.convertedClasses.length > 0 && rule.className) {
@@ -134,7 +194,7 @@ async function transformFiles(files, options) {
134
194
  else {
135
195
  cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);
136
196
  }
137
- results.stylesConverted += rule.declarations.length;
197
+ utilitiesGenerated += rule.declarations.length;
138
198
  }
139
199
  });
140
200
  fileWarnings.push(...internalResult.warnings);
@@ -146,30 +206,48 @@ async function transformFiles(files, options) {
146
206
  }
147
207
  }
148
208
  jsxFileResults.set(file.path, {
209
+ path: file.path,
149
210
  content: originalContent,
150
211
  newContent: content,
151
- hasChanges
212
+ hasChanges,
213
+ warnings: fileWarnings,
214
+ utilitiesGenerated,
215
+ classesReplaced
152
216
  });
153
- results.warnings += fileWarnings.length;
217
+ stats.warnings += fileWarnings.length;
154
218
  fileWarnings.forEach(warning => {
155
219
  logger_1.logger.verbose(`āš ļø ${file.path}: ${warning}`);
156
220
  });
157
221
  }
158
222
  catch (error) {
223
+ const errorMessage = error instanceof Error ? error.message : String(error);
159
224
  logger_1.logger.error(`Failed to process ${file.path}:`, error);
160
- results.warnings++;
225
+ jsxFileResults.set(file.path, {
226
+ path: file.path,
227
+ content: '',
228
+ newContent: '',
229
+ hasChanges: false,
230
+ warnings: [],
231
+ utilitiesGenerated: 0,
232
+ classesReplaced: 0,
233
+ error: errorMessage
234
+ });
235
+ stats.errors++;
161
236
  }
162
237
  }
163
238
  if (Object.keys(cssClassMap).length > 0) {
164
239
  logger_1.logger.info('\nšŸ”„ Phase 3: Replacing className references...');
165
240
  for (const [filePath, fileResult] of jsxFileResults) {
241
+ if (fileResult.error)
242
+ continue;
166
243
  let content = fileResult.newContent;
167
244
  let hasChanges = fileResult.hasChanges;
168
245
  const replacementResult = replaceClassNameReferences(content, cssClassMap);
169
246
  if (replacementResult.hasChanges) {
170
247
  content = replacementResult.code;
171
248
  hasChanges = true;
172
- results.classesReplaced += replacementResult.replacements;
249
+ fileResult.classesReplaced += replacementResult.replacements;
250
+ stats.classesReplaced += replacementResult.replacements;
173
251
  logger_1.logger.verbose(`Replaced ${replacementResult.replacements} class references in ${path_1.default.basename(filePath)}`);
174
252
  }
175
253
  jsxFileResults.set(filePath, {
@@ -182,17 +260,20 @@ async function transformFiles(files, options) {
182
260
  if (allDescendantRules.length > 0) {
183
261
  logger_1.logger.info('\n🌳 Phase 3.5: Applying descendant selector rules...');
184
262
  for (const [filePath, fileResult] of jsxFileResults) {
263
+ if (fileResult.error)
264
+ continue;
185
265
  let content = fileResult.newContent;
186
266
  let hasChanges = fileResult.hasChanges;
187
267
  const descendantResult = (0, jsxDescendantTransformer_1.transformDescendantSelectors)(content, allDescendantRules);
188
268
  if (descendantResult.hasChanges) {
189
269
  content = descendantResult.code;
190
270
  hasChanges = true;
191
- results.classesReplaced += descendantResult.transformations;
271
+ fileResult.classesReplaced += descendantResult.transformations;
272
+ stats.classesReplaced += descendantResult.transformations;
192
273
  logger_1.logger.verbose(`Applied ${descendantResult.transformations} descendant transformations in ${path_1.default.basename(filePath)}`);
193
274
  }
194
275
  if (descendantResult.warnings.length > 0) {
195
- results.warnings += descendantResult.warnings.length;
276
+ stats.warnings += descendantResult.warnings.length;
196
277
  descendantResult.warnings.forEach(warning => {
197
278
  logger_1.logger.verbose(`āš ļø ${filePath}: ${warning}`);
198
279
  });
@@ -204,47 +285,69 @@ async function transformFiles(files, options) {
204
285
  });
205
286
  }
206
287
  }
207
- logger_1.logger.info('\nšŸ’¾ Phase 4: Writing changes...');
208
288
  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++;
289
+ if (fileResult.error) {
290
+ fileResults.push({
291
+ filePath,
292
+ originalContent: fileResult.content,
293
+ newContent: fileResult.newContent,
294
+ hasChanges: false,
295
+ status: 'error',
296
+ error: fileResult.error
297
+ });
298
+ stats.filesWithError++;
299
+ continue;
300
+ }
301
+ const hasChanges = fileResult.newContent !== fileResult.content;
302
+ fileResults.push({
303
+ filePath,
304
+ originalContent: fileResult.content,
305
+ newContent: fileResult.newContent,
306
+ hasChanges,
307
+ status: hasChanges ? 'modified' : 'unchanged',
308
+ transformations: {
309
+ utilitiesGenerated: fileResult.utilitiesGenerated,
310
+ classesReplaced: fileResult.classesReplaced,
311
+ conflictsResolved: 0
213
312
  }
313
+ });
314
+ if (hasChanges) {
315
+ stats.filesModified++;
316
+ }
317
+ else {
318
+ stats.filesUnchanged++;
214
319
  }
215
320
  }
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
- }
321
+ for (const [filePath, fileResult] of cssFileResults) {
322
+ if (fileResult.error) {
323
+ fileResults.push({
324
+ filePath,
325
+ originalContent: fileResult.content,
326
+ newContent: fileResult.newContent,
327
+ hasChanges: false,
328
+ status: 'error',
329
+ error: fileResult.error
330
+ });
331
+ stats.filesWithError++;
332
+ continue;
333
+ }
334
+ const hasChanges = fileResult.hasChanges && fileResult.newContent !== fileResult.content;
335
+ fileResults.push({
336
+ filePath,
337
+ originalContent: fileResult.content,
338
+ newContent: fileResult.newContent,
339
+ hasChanges,
340
+ status: hasChanges ? 'modified' : 'unchanged'
341
+ });
342
+ if (hasChanges) {
343
+ stats.filesModified++;
344
+ }
345
+ else {
346
+ stats.filesUnchanged++;
245
347
  }
246
348
  }
247
- return results;
349
+ stats.utilitiesGenerated = stats.classesReplaced + stats.utilitiesGenerated;
350
+ return { fileResults, stats };
248
351
  }
249
352
  function buildClassInfoFromRule(rule, sourceFile) {
250
353
  return {
@@ -336,4 +439,4 @@ function replaceClassNameReferences(code, classMap) {
336
439
  });
337
440
  return { code: modifiedCode, hasChanges, replacements };
338
441
  }
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}"]}
442
+ //# 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';\nimport { VariableRegistry } from './utils/variableRegistry';\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  \n  const sharedVariableRegistry = new VariableRegistry();\n  const cssParser = new CSSParser(mapper, screens, sharedVariableRegistry);\n\n  clearBreakpointCache();\n\n  const cssClassMap: CSSClassMap = {};\n  const allDescendantRules: CSSRule[] = [];\n\n  const cssFiles = files.filter(f => f.type === 'css');\n  const jsxFiles = files.filter(f => f.type === 'jsx');\n\n  logger.info('\\n🔍 Phase 0: Collecting CSS variables from all files...');\n\n  if (!options.skipExternal) {\n    for (const file of cssFiles) {\n      try {\n        const content = fs.readFileSync(file.path, 'utf-8');\n        await cssParser.collectVariablesOnly(content, file.path);\n      } catch (error) {\n        logger.warn(`Failed to collect variables from ${file.path}: ${error}`);\n      }\n    }\n    \n    for (const file of jsxFiles) {\n      if (options.skipInternal) continue;\n      try {\n        const content = fs.readFileSync(file.path, 'utf-8');\n        await cssParser.collectVariablesFromInternalCSS(content, file.path);\n      } catch (error) {\n        logger.warn(`Failed to collect internal CSS variables from ${file.path}: ${error}`);\n      }\n    }\n    \n    logger.verbose(`Collected ${sharedVariableRegistry.getRegisteredVariables().length} unique CSS variables`);\n  }\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 cssFiles) {\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 jsxFiles) {\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
+ };