css-to-tailwind-react 0.3.2 ā 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.
- package/dist/cli.js +107 -24
- package/dist/cssParser.js +45 -15
- package/dist/fileWriter.d.ts +11 -3
- package/dist/fileWriter.js +34 -39
- package/dist/index.d.ts +4 -2
- package/dist/index.js +11 -2
- package/dist/tailwindMapper.d.ts +7 -0
- package/dist/tailwindMapper.js +181 -1
- package/dist/transformer.d.ts +6 -0
- package/dist/transformer.js +184 -81
- package/dist/utils/diff.d.ts +26 -0
- package/dist/utils/diff.js +197 -0
- package/dist/utils/logger.d.ts +2 -0
- package/dist/utils/logger.js +21 -7
- package/dist/utils/propertyMapper.js +45 -4
- package/dist/utils/reporter.d.ts +50 -0
- package/dist/utils/reporter.js +215 -0
- package/package.json +1 -1
package/dist/transformer.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ScannedFile } from './scanner';
|
|
2
2
|
import { TailwindConfig } from './utils/config';
|
|
3
|
+
import { FileResult, SummaryStats } from './utils/reporter';
|
|
3
4
|
export interface TransformOptions {
|
|
4
5
|
dryRun: boolean;
|
|
5
6
|
deleteCss: boolean;
|
|
@@ -16,4 +17,9 @@ export interface TransformResults {
|
|
|
16
17
|
classesReplaced: number;
|
|
17
18
|
warnings: number;
|
|
18
19
|
}
|
|
20
|
+
export interface DetailedTransformResults {
|
|
21
|
+
fileResults: FileResult[];
|
|
22
|
+
stats: SummaryStats;
|
|
23
|
+
}
|
|
19
24
|
export declare function transformFiles(files: ScannedFile[], options: TransformOptions): Promise<TransformResults>;
|
|
25
|
+
export declare function transformFilesDetailed(files: ScannedFile[], options: TransformOptions): Promise<DetailedTransformResults>;
|
package/dist/transformer.js
CHANGED
|
@@ -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
|
|
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
|
-
|
|
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,10 +61,10 @@ async function transformFiles(files, options) {
|
|
|
46
61
|
if (rule.isDescendant) {
|
|
47
62
|
if (rule.convertedClasses.length > 0) {
|
|
48
63
|
allDescendantRules.push(rule);
|
|
49
|
-
|
|
64
|
+
stats.utilitiesGenerated += rule.declarations.length;
|
|
50
65
|
}
|
|
51
66
|
}
|
|
52
|
-
else if (rule.
|
|
67
|
+
else if (rule.className && rule.convertedClasses.length > 0) {
|
|
53
68
|
const existing = cssClassMap[rule.className];
|
|
54
69
|
if (existing) {
|
|
55
70
|
mergeRuleIntoClassInfo(existing, rule);
|
|
@@ -57,22 +72,26 @@ async function transformFiles(files, options) {
|
|
|
57
72
|
else {
|
|
58
73
|
cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);
|
|
59
74
|
}
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
75
|
+
if (rule.fullyConverted) {
|
|
76
|
+
stats.utilitiesGenerated += rule.declarations.length;
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
stats.utilitiesGenerated += rule.convertedClasses.length;
|
|
80
|
+
logger_1.logger.verbose(` Rule .${rule.className}: partial conversion (${rule.convertedClasses.length}/${rule.declarations.length} declarations)`);
|
|
81
|
+
}
|
|
65
82
|
}
|
|
66
83
|
});
|
|
67
84
|
cssFileResults.set(file.path, {
|
|
85
|
+
path: file.path,
|
|
68
86
|
content,
|
|
69
87
|
newContent: result.css,
|
|
70
88
|
rules: result.rules,
|
|
71
89
|
canDelete: result.canDelete,
|
|
72
90
|
hasChanges: result.hasChanges,
|
|
73
|
-
fullyConvertible
|
|
91
|
+
fullyConvertible,
|
|
92
|
+
warnings: result.warnings
|
|
74
93
|
});
|
|
75
|
-
|
|
94
|
+
stats.warnings += result.warnings.length;
|
|
76
95
|
logger_1.logger.verbose(`Analyzed ${file.path}:`);
|
|
77
96
|
logger_1.logger.verbose(` - Total rules: ${totalRules}`);
|
|
78
97
|
logger_1.logger.verbose(` - Fully converted rules: ${fullyConvertedRules}`);
|
|
@@ -83,8 +102,21 @@ async function transformFiles(files, options) {
|
|
|
83
102
|
});
|
|
84
103
|
}
|
|
85
104
|
catch (error) {
|
|
105
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
86
106
|
logger_1.logger.error(`Failed to analyze ${file.path}:`, error);
|
|
87
|
-
|
|
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++;
|
|
88
120
|
}
|
|
89
121
|
}
|
|
90
122
|
}
|
|
@@ -96,13 +128,15 @@ async function transformFiles(files, options) {
|
|
|
96
128
|
const originalContent = content;
|
|
97
129
|
let hasChanges = false;
|
|
98
130
|
let fileWarnings = [];
|
|
131
|
+
let utilitiesGenerated = 0;
|
|
132
|
+
let classesReplaced = 0;
|
|
99
133
|
if (!options.skipInline) {
|
|
100
134
|
try {
|
|
101
135
|
const jsxResult = jsxParser.parse(content, file.path);
|
|
102
136
|
if (jsxResult.hasChanges) {
|
|
103
137
|
content = jsxResult.code;
|
|
104
138
|
hasChanges = true;
|
|
105
|
-
|
|
139
|
+
utilitiesGenerated += jsxResult.transformations.reduce((sum, t) => sum + t.classes.length, 0);
|
|
106
140
|
fileWarnings.push(...jsxResult.warnings);
|
|
107
141
|
}
|
|
108
142
|
}
|
|
@@ -121,7 +155,7 @@ async function transformFiles(files, options) {
|
|
|
121
155
|
if (rule.isDescendant) {
|
|
122
156
|
if (rule.convertedClasses.length > 0) {
|
|
123
157
|
allDescendantRules.push(rule);
|
|
124
|
-
|
|
158
|
+
utilitiesGenerated += rule.declarations.length;
|
|
125
159
|
}
|
|
126
160
|
}
|
|
127
161
|
else if (rule.convertedClasses.length > 0 && rule.className) {
|
|
@@ -132,7 +166,7 @@ async function transformFiles(files, options) {
|
|
|
132
166
|
else {
|
|
133
167
|
cssClassMap[rule.className] = buildClassInfoFromRule(rule, file.path);
|
|
134
168
|
}
|
|
135
|
-
|
|
169
|
+
utilitiesGenerated += rule.declarations.length;
|
|
136
170
|
}
|
|
137
171
|
});
|
|
138
172
|
fileWarnings.push(...internalResult.warnings);
|
|
@@ -144,30 +178,48 @@ async function transformFiles(files, options) {
|
|
|
144
178
|
}
|
|
145
179
|
}
|
|
146
180
|
jsxFileResults.set(file.path, {
|
|
181
|
+
path: file.path,
|
|
147
182
|
content: originalContent,
|
|
148
183
|
newContent: content,
|
|
149
|
-
hasChanges
|
|
184
|
+
hasChanges,
|
|
185
|
+
warnings: fileWarnings,
|
|
186
|
+
utilitiesGenerated,
|
|
187
|
+
classesReplaced
|
|
150
188
|
});
|
|
151
|
-
|
|
189
|
+
stats.warnings += fileWarnings.length;
|
|
152
190
|
fileWarnings.forEach(warning => {
|
|
153
191
|
logger_1.logger.verbose(`ā ļø ${file.path}: ${warning}`);
|
|
154
192
|
});
|
|
155
193
|
}
|
|
156
194
|
catch (error) {
|
|
195
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
157
196
|
logger_1.logger.error(`Failed to process ${file.path}:`, error);
|
|
158
|
-
|
|
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++;
|
|
159
208
|
}
|
|
160
209
|
}
|
|
161
210
|
if (Object.keys(cssClassMap).length > 0) {
|
|
162
211
|
logger_1.logger.info('\nš Phase 3: Replacing className references...');
|
|
163
212
|
for (const [filePath, fileResult] of jsxFileResults) {
|
|
213
|
+
if (fileResult.error)
|
|
214
|
+
continue;
|
|
164
215
|
let content = fileResult.newContent;
|
|
165
216
|
let hasChanges = fileResult.hasChanges;
|
|
166
217
|
const replacementResult = replaceClassNameReferences(content, cssClassMap);
|
|
167
218
|
if (replacementResult.hasChanges) {
|
|
168
219
|
content = replacementResult.code;
|
|
169
220
|
hasChanges = true;
|
|
170
|
-
|
|
221
|
+
fileResult.classesReplaced += replacementResult.replacements;
|
|
222
|
+
stats.classesReplaced += replacementResult.replacements;
|
|
171
223
|
logger_1.logger.verbose(`Replaced ${replacementResult.replacements} class references in ${path_1.default.basename(filePath)}`);
|
|
172
224
|
}
|
|
173
225
|
jsxFileResults.set(filePath, {
|
|
@@ -180,17 +232,20 @@ async function transformFiles(files, options) {
|
|
|
180
232
|
if (allDescendantRules.length > 0) {
|
|
181
233
|
logger_1.logger.info('\nš³ Phase 3.5: Applying descendant selector rules...');
|
|
182
234
|
for (const [filePath, fileResult] of jsxFileResults) {
|
|
235
|
+
if (fileResult.error)
|
|
236
|
+
continue;
|
|
183
237
|
let content = fileResult.newContent;
|
|
184
238
|
let hasChanges = fileResult.hasChanges;
|
|
185
239
|
const descendantResult = (0, jsxDescendantTransformer_1.transformDescendantSelectors)(content, allDescendantRules);
|
|
186
240
|
if (descendantResult.hasChanges) {
|
|
187
241
|
content = descendantResult.code;
|
|
188
242
|
hasChanges = true;
|
|
189
|
-
|
|
243
|
+
fileResult.classesReplaced += descendantResult.transformations;
|
|
244
|
+
stats.classesReplaced += descendantResult.transformations;
|
|
190
245
|
logger_1.logger.verbose(`Applied ${descendantResult.transformations} descendant transformations in ${path_1.default.basename(filePath)}`);
|
|
191
246
|
}
|
|
192
247
|
if (descendantResult.warnings.length > 0) {
|
|
193
|
-
|
|
248
|
+
stats.warnings += descendantResult.warnings.length;
|
|
194
249
|
descendantResult.warnings.forEach(warning => {
|
|
195
250
|
logger_1.logger.verbose(`ā ļø ${filePath}: ${warning}`);
|
|
196
251
|
});
|
|
@@ -202,47 +257,69 @@ async function transformFiles(files, options) {
|
|
|
202
257
|
});
|
|
203
258
|
}
|
|
204
259
|
}
|
|
205
|
-
logger_1.logger.info('\nš¾ Phase 4: Writing changes...');
|
|
206
260
|
for (const [filePath, fileResult] of jsxFileResults) {
|
|
207
|
-
if (fileResult.
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
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
|
|
211
284
|
}
|
|
285
|
+
});
|
|
286
|
+
if (hasChanges) {
|
|
287
|
+
stats.filesModified++;
|
|
288
|
+
}
|
|
289
|
+
else {
|
|
290
|
+
stats.filesUnchanged++;
|
|
212
291
|
}
|
|
213
292
|
}
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
logger_1.logger.info(`š ${path_1.default.basename(filePath)}: converted ${convertedCount}/${totalCount} rules (unconverted properties kept)`);
|
|
241
|
-
}
|
|
242
|
-
}
|
|
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++;
|
|
243
319
|
}
|
|
244
320
|
}
|
|
245
|
-
|
|
321
|
+
stats.utilitiesGenerated = stats.classesReplaced + stats.utilitiesGenerated;
|
|
322
|
+
return { fileResults, stats };
|
|
246
323
|
}
|
|
247
324
|
function buildClassInfoFromRule(rule, sourceFile) {
|
|
248
325
|
return {
|
|
@@ -255,7 +332,7 @@ function buildClassInfoFromRule(rule, sourceFile) {
|
|
|
255
332
|
originalSelector: rule.selector
|
|
256
333
|
})),
|
|
257
334
|
sourceFile,
|
|
258
|
-
fullyConvertible:
|
|
335
|
+
fullyConvertible: rule.fullyConverted
|
|
259
336
|
};
|
|
260
337
|
}
|
|
261
338
|
function mergeRuleIntoClassInfo(info, rule) {
|
|
@@ -280,32 +357,58 @@ function replaceClassNameReferences(code, classMap) {
|
|
|
280
357
|
let replacements = 0;
|
|
281
358
|
let modifiedCode = code;
|
|
282
359
|
Object.entries(classMap).forEach(([oldClass, info]) => {
|
|
283
|
-
if (
|
|
360
|
+
if (info.utilities.length === 0) {
|
|
284
361
|
return;
|
|
285
362
|
}
|
|
286
363
|
const tailwindClassString = assembleTailwindClasses(info);
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
364
|
+
if (info.fullyConvertible) {
|
|
365
|
+
const pattern1 = new RegExp(`className="${oldClass}"`, 'g');
|
|
366
|
+
if (pattern1.test(modifiedCode)) {
|
|
367
|
+
modifiedCode = modifiedCode.replace(pattern1, `className="${tailwindClassString}"`);
|
|
368
|
+
hasChanges = true;
|
|
369
|
+
replacements++;
|
|
370
|
+
logger_1.logger.verbose(`Replaced className="${oldClass}" with "${tailwindClassString}"`);
|
|
371
|
+
}
|
|
372
|
+
const pattern2 = new RegExp(`className=\\{"${oldClass}"\\}`, 'g');
|
|
373
|
+
if (pattern2.test(modifiedCode)) {
|
|
374
|
+
modifiedCode = modifiedCode.replace(pattern2, `className="${tailwindClassString}"`);
|
|
375
|
+
hasChanges = true;
|
|
376
|
+
replacements++;
|
|
377
|
+
logger_1.logger.verbose(`Replaced className={"${oldClass}"} with "${tailwindClassString}"`);
|
|
378
|
+
}
|
|
379
|
+
const pattern3 = new RegExp(`className=\\{\`\\s*${oldClass}\\s*\`\\}`, 'g');
|
|
380
|
+
if (pattern3.test(modifiedCode)) {
|
|
381
|
+
modifiedCode = modifiedCode.replace(pattern3, `className="${tailwindClassString}"`);
|
|
382
|
+
hasChanges = true;
|
|
383
|
+
replacements++;
|
|
384
|
+
logger_1.logger.verbose(`Replaced className={\`${oldClass}\`} with "${tailwindClassString}"`);
|
|
385
|
+
}
|
|
300
386
|
}
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
387
|
+
else {
|
|
388
|
+
const combinedClassString = `${oldClass} ${tailwindClassString}`;
|
|
389
|
+
const pattern1 = new RegExp(`className="${oldClass}"`, 'g');
|
|
390
|
+
if (pattern1.test(modifiedCode)) {
|
|
391
|
+
modifiedCode = modifiedCode.replace(pattern1, `className="${combinedClassString}"`);
|
|
392
|
+
hasChanges = true;
|
|
393
|
+
replacements++;
|
|
394
|
+
logger_1.logger.verbose(`Appended to className="${oldClass}" ā "${combinedClassString}"`);
|
|
395
|
+
}
|
|
396
|
+
const pattern2 = new RegExp(`className=\\{"${oldClass}"\\}`, 'g');
|
|
397
|
+
if (pattern2.test(modifiedCode)) {
|
|
398
|
+
modifiedCode = modifiedCode.replace(pattern2, `className="${combinedClassString}"`);
|
|
399
|
+
hasChanges = true;
|
|
400
|
+
replacements++;
|
|
401
|
+
logger_1.logger.verbose(`Appended to className={"${oldClass}"} ā "${combinedClassString}"`);
|
|
402
|
+
}
|
|
403
|
+
const pattern3 = new RegExp(`className=\\{\`\\s*${oldClass}\\s*\`\\}`, 'g');
|
|
404
|
+
if (pattern3.test(modifiedCode)) {
|
|
405
|
+
modifiedCode = modifiedCode.replace(pattern3, `className="${combinedClassString}"`);
|
|
406
|
+
hasChanges = true;
|
|
407
|
+
replacements++;
|
|
408
|
+
logger_1.logger.verbose(`Appended to className={\`${oldClass}\`} ā "${combinedClassString}"`);
|
|
409
|
+
}
|
|
307
410
|
}
|
|
308
411
|
});
|
|
309
412
|
return { code: modifiedCode, hasChanges, replacements };
|
|
310
413
|
}
|
|
311
|
-
//# 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.fullyConverted && 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          } else if (rule.partialConversion) {\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        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: true\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.fullyConvertible) {\n      return;\n    }\n\n    const tailwindClassString = assembleTailwindClasses(info);\n    \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  });\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"]}
|