css-to-tailwind-react 0.1.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/README.md +303 -0
- package/bin/index.js +11 -0
- package/dist/cli.d.ts +1 -0
- package/dist/cli.js +80 -0
- package/dist/cssParser.d.ts +41 -0
- package/dist/cssParser.js +215 -0
- package/dist/fileWriter.d.ts +14 -0
- package/dist/fileWriter.js +128 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.js +21 -0
- package/dist/jsxParser.d.ts +26 -0
- package/dist/jsxParser.js +273 -0
- package/dist/scanner.d.ts +5 -0
- package/dist/scanner.js +55 -0
- package/dist/tailwindMapper.d.ts +35 -0
- package/dist/tailwindMapper.js +428 -0
- package/dist/transformer.d.ts +19 -0
- package/dist/transformer.js +259 -0
- package/dist/utils/config.d.ts +14 -0
- package/dist/utils/config.js +139 -0
- package/dist/utils/logger.d.ts +14 -0
- package/dist/utils/logger.js +56 -0
- package/package.json +73 -0
|
@@ -0,0 +1,428 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TailwindMapper = void 0;
|
|
4
|
+
const logger_1 = require("./utils/logger");
|
|
5
|
+
class TailwindMapper {
|
|
6
|
+
constructor(config) {
|
|
7
|
+
this.config = config;
|
|
8
|
+
this.spacingScale = this.buildSpacingScale();
|
|
9
|
+
}
|
|
10
|
+
buildSpacingScale() {
|
|
11
|
+
const scale = new Map();
|
|
12
|
+
const spacing = this.config.theme?.spacing || {};
|
|
13
|
+
Object.entries(spacing).forEach(([key, value]) => {
|
|
14
|
+
// Convert rem to pixels for comparison (assuming 1rem = 16px)
|
|
15
|
+
const remMatch = value.match(/([\d.]+)rem/);
|
|
16
|
+
if (remMatch) {
|
|
17
|
+
const pixels = parseFloat(remMatch[1]) * 16;
|
|
18
|
+
scale.set(Math.round(pixels), key);
|
|
19
|
+
}
|
|
20
|
+
// Also handle pixel values
|
|
21
|
+
const pxMatch = value.match(/([\d.]+)px/);
|
|
22
|
+
if (pxMatch) {
|
|
23
|
+
scale.set(Math.round(parseFloat(pxMatch[1])), key);
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
return scale;
|
|
27
|
+
}
|
|
28
|
+
pxToSpacing(px) {
|
|
29
|
+
// Try exact match first
|
|
30
|
+
if (this.spacingScale.has(px)) {
|
|
31
|
+
return this.spacingScale.get(px);
|
|
32
|
+
}
|
|
33
|
+
// Find closest match
|
|
34
|
+
let closestKey = null;
|
|
35
|
+
let closestDiff = Infinity;
|
|
36
|
+
this.spacingScale.forEach((_, key) => {
|
|
37
|
+
const diff = Math.abs(key - px);
|
|
38
|
+
if (diff < closestDiff) {
|
|
39
|
+
closestKey = key;
|
|
40
|
+
closestDiff = diff;
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
// Only accept if within reasonable tolerance (20%)
|
|
44
|
+
if (closestKey !== null && closestDiff / px < 0.2) {
|
|
45
|
+
return this.spacingScale.get(closestKey) || null;
|
|
46
|
+
}
|
|
47
|
+
return null;
|
|
48
|
+
}
|
|
49
|
+
extractPx(value) {
|
|
50
|
+
const pxMatch = value.match(/^([\d.]+)px$/);
|
|
51
|
+
if (pxMatch) {
|
|
52
|
+
return parseFloat(pxMatch[1]);
|
|
53
|
+
}
|
|
54
|
+
// Handle rem values
|
|
55
|
+
const remMatch = value.match(/^([\d.]+)rem$/);
|
|
56
|
+
if (remMatch) {
|
|
57
|
+
return parseFloat(remMatch[1]) * 16;
|
|
58
|
+
}
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
convertProperty(property, value) {
|
|
62
|
+
const normalizedProp = property.toLowerCase().trim();
|
|
63
|
+
const normalizedValue = value.toLowerCase().trim();
|
|
64
|
+
logger_1.logger.verbose(`Converting: ${normalizedProp}: ${normalizedValue}`);
|
|
65
|
+
// Display properties
|
|
66
|
+
if (normalizedProp === 'display') {
|
|
67
|
+
return this.convertDisplay(normalizedValue);
|
|
68
|
+
}
|
|
69
|
+
// Position properties
|
|
70
|
+
if (normalizedProp === 'position') {
|
|
71
|
+
return { className: normalizedValue, skipped: false };
|
|
72
|
+
}
|
|
73
|
+
// Margin properties
|
|
74
|
+
if (normalizedProp.startsWith('margin')) {
|
|
75
|
+
return this.convertMargin(normalizedProp, normalizedValue);
|
|
76
|
+
}
|
|
77
|
+
// Padding properties
|
|
78
|
+
if (normalizedProp.startsWith('padding')) {
|
|
79
|
+
return this.convertPadding(normalizedProp, normalizedValue);
|
|
80
|
+
}
|
|
81
|
+
// Font properties
|
|
82
|
+
if (normalizedProp === 'font-weight') {
|
|
83
|
+
return this.convertFontWeight(normalizedValue);
|
|
84
|
+
}
|
|
85
|
+
if (normalizedProp === 'font-size') {
|
|
86
|
+
return this.convertFontSize(normalizedValue);
|
|
87
|
+
}
|
|
88
|
+
// Text properties
|
|
89
|
+
if (normalizedProp === 'text-align') {
|
|
90
|
+
return { className: `text-${normalizedValue}`, skipped: false };
|
|
91
|
+
}
|
|
92
|
+
// Flexbox properties
|
|
93
|
+
if (normalizedProp.startsWith('flex') ||
|
|
94
|
+
normalizedProp.startsWith('justify') ||
|
|
95
|
+
normalizedProp.startsWith('align')) {
|
|
96
|
+
return this.convertFlexbox(normalizedProp, normalizedValue);
|
|
97
|
+
}
|
|
98
|
+
// Gap properties
|
|
99
|
+
if (normalizedProp === 'gap') {
|
|
100
|
+
return this.convertGap(normalizedValue);
|
|
101
|
+
}
|
|
102
|
+
// Width and Height
|
|
103
|
+
if (normalizedProp === 'width') {
|
|
104
|
+
return this.convertWidth(normalizedValue);
|
|
105
|
+
}
|
|
106
|
+
if (normalizedProp === 'height') {
|
|
107
|
+
return this.convertHeight(normalizedValue);
|
|
108
|
+
}
|
|
109
|
+
// Colors
|
|
110
|
+
if (normalizedProp === 'background-color') {
|
|
111
|
+
return this.convertBackgroundColor(normalizedValue);
|
|
112
|
+
}
|
|
113
|
+
if (normalizedProp === 'color') {
|
|
114
|
+
return this.convertTextColor(normalizedValue);
|
|
115
|
+
}
|
|
116
|
+
// Border radius
|
|
117
|
+
if (normalizedProp === 'border-radius') {
|
|
118
|
+
return this.convertBorderRadius(normalizedValue);
|
|
119
|
+
}
|
|
120
|
+
// Unsupported properties
|
|
121
|
+
return {
|
|
122
|
+
className: null,
|
|
123
|
+
skipped: true,
|
|
124
|
+
reason: `Unsupported property: ${property}`
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
convertDisplay(value) {
|
|
128
|
+
const displayMap = {
|
|
129
|
+
'flex': 'flex',
|
|
130
|
+
'block': 'block',
|
|
131
|
+
'inline': 'inline',
|
|
132
|
+
'inline-block': 'inline-block',
|
|
133
|
+
'grid': 'grid',
|
|
134
|
+
'none': 'hidden',
|
|
135
|
+
'contents': 'contents',
|
|
136
|
+
'table': 'table',
|
|
137
|
+
'table-cell': 'table-cell'
|
|
138
|
+
};
|
|
139
|
+
if (displayMap[value]) {
|
|
140
|
+
return { className: displayMap[value], skipped: false };
|
|
141
|
+
}
|
|
142
|
+
return { className: null, skipped: true, reason: `Unknown display value: ${value}` };
|
|
143
|
+
}
|
|
144
|
+
convertMargin(prop, value) {
|
|
145
|
+
const px = this.extractPx(value);
|
|
146
|
+
if (px === null) {
|
|
147
|
+
return { className: null, skipped: true, reason: `Non-pixel margin value: ${value}` };
|
|
148
|
+
}
|
|
149
|
+
const spacing = this.pxToSpacing(px);
|
|
150
|
+
if (!spacing) {
|
|
151
|
+
return { className: null, skipped: true, reason: `No matching spacing for: ${value}` };
|
|
152
|
+
}
|
|
153
|
+
const sideMap = {
|
|
154
|
+
'margin': 'm',
|
|
155
|
+
'margin-top': 'mt',
|
|
156
|
+
'margin-right': 'mr',
|
|
157
|
+
'margin-bottom': 'mb',
|
|
158
|
+
'margin-left': 'ml',
|
|
159
|
+
'margin-x': 'mx',
|
|
160
|
+
'margin-y': 'my'
|
|
161
|
+
};
|
|
162
|
+
const prefix = sideMap[prop] || 'm';
|
|
163
|
+
return { className: `${prefix}-${spacing}`, skipped: false };
|
|
164
|
+
}
|
|
165
|
+
convertPadding(prop, value) {
|
|
166
|
+
const px = this.extractPx(value);
|
|
167
|
+
if (px === null) {
|
|
168
|
+
return { className: null, skipped: true, reason: `Non-pixel padding value: ${value}` };
|
|
169
|
+
}
|
|
170
|
+
const spacing = this.pxToSpacing(px);
|
|
171
|
+
if (!spacing) {
|
|
172
|
+
return { className: null, skipped: true, reason: `No matching spacing for: ${value}` };
|
|
173
|
+
}
|
|
174
|
+
const sideMap = {
|
|
175
|
+
'padding': 'p',
|
|
176
|
+
'padding-top': 'pt',
|
|
177
|
+
'padding-right': 'pr',
|
|
178
|
+
'padding-bottom': 'pb',
|
|
179
|
+
'padding-left': 'pl',
|
|
180
|
+
'padding-x': 'px',
|
|
181
|
+
'padding-y': 'py'
|
|
182
|
+
};
|
|
183
|
+
const prefix = sideMap[prop] || 'p';
|
|
184
|
+
return { className: `${prefix}-${spacing}`, skipped: false };
|
|
185
|
+
}
|
|
186
|
+
convertFontWeight(value) {
|
|
187
|
+
const weightMap = {
|
|
188
|
+
'100': 'font-thin',
|
|
189
|
+
'200': 'font-extralight',
|
|
190
|
+
'300': 'font-light',
|
|
191
|
+
'400': 'font-normal',
|
|
192
|
+
'500': 'font-medium',
|
|
193
|
+
'600': 'font-semibold',
|
|
194
|
+
'700': 'font-bold',
|
|
195
|
+
'800': 'font-extrabold',
|
|
196
|
+
'900': 'font-black',
|
|
197
|
+
'normal': 'font-normal',
|
|
198
|
+
'bold': 'font-bold'
|
|
199
|
+
};
|
|
200
|
+
if (weightMap[value]) {
|
|
201
|
+
return { className: weightMap[value], skipped: false };
|
|
202
|
+
}
|
|
203
|
+
return { className: null, skipped: true, reason: `Unknown font-weight: ${value}` };
|
|
204
|
+
}
|
|
205
|
+
convertFontSize(value) {
|
|
206
|
+
const px = this.extractPx(value);
|
|
207
|
+
if (px !== null) {
|
|
208
|
+
// Map common font sizes
|
|
209
|
+
const sizeMap = {
|
|
210
|
+
12: 'text-xs',
|
|
211
|
+
14: 'text-sm',
|
|
212
|
+
16: 'text-base',
|
|
213
|
+
18: 'text-lg',
|
|
214
|
+
20: 'text-xl',
|
|
215
|
+
24: 'text-2xl',
|
|
216
|
+
30: 'text-3xl',
|
|
217
|
+
36: 'text-4xl',
|
|
218
|
+
48: 'text-5xl'
|
|
219
|
+
};
|
|
220
|
+
const closest = Object.keys(sizeMap)
|
|
221
|
+
.map(Number)
|
|
222
|
+
.reduce((prev, curr) => Math.abs(curr - px) < Math.abs(prev - px) ? curr : prev);
|
|
223
|
+
if (Math.abs(closest - px) / px < 0.15) {
|
|
224
|
+
return { className: sizeMap[closest], skipped: false };
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
return { className: null, skipped: true, reason: `Non-standard font-size: ${value}` };
|
|
228
|
+
}
|
|
229
|
+
convertFlexbox(prop, value) {
|
|
230
|
+
// Flex direction
|
|
231
|
+
if (prop === 'flex-direction') {
|
|
232
|
+
const dirMap = {
|
|
233
|
+
'row': 'flex-row',
|
|
234
|
+
'row-reverse': 'flex-row-reverse',
|
|
235
|
+
'column': 'flex-col',
|
|
236
|
+
'column-reverse': 'flex-col-reverse'
|
|
237
|
+
};
|
|
238
|
+
return { className: dirMap[value] || null, skipped: !dirMap[value] };
|
|
239
|
+
}
|
|
240
|
+
// Flex wrap
|
|
241
|
+
if (prop === 'flex-wrap') {
|
|
242
|
+
const wrapMap = {
|
|
243
|
+
'wrap': 'flex-wrap',
|
|
244
|
+
'nowrap': 'flex-nowrap',
|
|
245
|
+
'wrap-reverse': 'flex-wrap-reverse'
|
|
246
|
+
};
|
|
247
|
+
return { className: wrapMap[value] || null, skipped: !wrapMap[value] };
|
|
248
|
+
}
|
|
249
|
+
// Justify content
|
|
250
|
+
if (prop === 'justify-content') {
|
|
251
|
+
const justifyMap = {
|
|
252
|
+
'flex-start': 'justify-start',
|
|
253
|
+
'flex-end': 'justify-end',
|
|
254
|
+
'center': 'justify-center',
|
|
255
|
+
'space-between': 'justify-between',
|
|
256
|
+
'space-around': 'justify-around',
|
|
257
|
+
'space-evenly': 'justify-evenly'
|
|
258
|
+
};
|
|
259
|
+
return { className: justifyMap[value] || null, skipped: !justifyMap[value] };
|
|
260
|
+
}
|
|
261
|
+
// Align items
|
|
262
|
+
if (prop === 'align-items') {
|
|
263
|
+
const alignMap = {
|
|
264
|
+
'flex-start': 'items-start',
|
|
265
|
+
'flex-end': 'items-end',
|
|
266
|
+
'center': 'items-center',
|
|
267
|
+
'baseline': 'items-baseline',
|
|
268
|
+
'stretch': 'items-stretch'
|
|
269
|
+
};
|
|
270
|
+
return { className: alignMap[value] || null, skipped: !alignMap[value] };
|
|
271
|
+
}
|
|
272
|
+
return { className: null, skipped: true, reason: `Unsupported flexbox property: ${prop}` };
|
|
273
|
+
}
|
|
274
|
+
convertGap(value) {
|
|
275
|
+
const px = this.extractPx(value);
|
|
276
|
+
if (px === null) {
|
|
277
|
+
return { className: null, skipped: true, reason: `Non-pixel gap value: ${value}` };
|
|
278
|
+
}
|
|
279
|
+
const spacing = this.pxToSpacing(px);
|
|
280
|
+
if (!spacing) {
|
|
281
|
+
return { className: null, skipped: true, reason: `No matching spacing for: ${value}` };
|
|
282
|
+
}
|
|
283
|
+
return { className: `gap-${spacing}`, skipped: false };
|
|
284
|
+
}
|
|
285
|
+
convertWidth(value) {
|
|
286
|
+
// Handle percentage values
|
|
287
|
+
if (value === '100%') {
|
|
288
|
+
return { className: 'w-full', skipped: false };
|
|
289
|
+
}
|
|
290
|
+
if (value === '50%') {
|
|
291
|
+
return { className: 'w-1/2', skipped: false };
|
|
292
|
+
}
|
|
293
|
+
if (value === '33.333%' || value === '33.33%') {
|
|
294
|
+
return { className: 'w-1/3', skipped: false };
|
|
295
|
+
}
|
|
296
|
+
if (value === '66.666%' || value === '66.67%') {
|
|
297
|
+
return { className: 'w-2/3', skipped: false };
|
|
298
|
+
}
|
|
299
|
+
if (value === '25%') {
|
|
300
|
+
return { className: 'w-1/4', skipped: false };
|
|
301
|
+
}
|
|
302
|
+
if (value === '75%') {
|
|
303
|
+
return { className: 'w-3/4', skipped: false };
|
|
304
|
+
}
|
|
305
|
+
// Handle pixel values
|
|
306
|
+
const px = this.extractPx(value);
|
|
307
|
+
if (px !== null) {
|
|
308
|
+
const spacing = this.pxToSpacing(px);
|
|
309
|
+
if (spacing) {
|
|
310
|
+
return { className: `w-${spacing}`, skipped: false };
|
|
311
|
+
}
|
|
312
|
+
// Try arbitrary values for larger sizes
|
|
313
|
+
return { className: `w-[${value}]`, skipped: false };
|
|
314
|
+
}
|
|
315
|
+
return { className: null, skipped: true, reason: `Complex width value: ${value}` };
|
|
316
|
+
}
|
|
317
|
+
convertHeight(value) {
|
|
318
|
+
// Handle percentage values
|
|
319
|
+
if (value === '100%') {
|
|
320
|
+
return { className: 'h-full', skipped: false };
|
|
321
|
+
}
|
|
322
|
+
if (value === '50%') {
|
|
323
|
+
return { className: 'h-1/2', skipped: false };
|
|
324
|
+
}
|
|
325
|
+
// Handle pixel values
|
|
326
|
+
const px = this.extractPx(value);
|
|
327
|
+
if (px !== null) {
|
|
328
|
+
const spacing = this.pxToSpacing(px);
|
|
329
|
+
if (spacing) {
|
|
330
|
+
return { className: `h-${spacing}`, skipped: false };
|
|
331
|
+
}
|
|
332
|
+
return { className: `h-[${value}]`, skipped: false };
|
|
333
|
+
}
|
|
334
|
+
return { className: null, skipped: true, reason: `Complex height value: ${value}` };
|
|
335
|
+
}
|
|
336
|
+
convertBackgroundColor(value) {
|
|
337
|
+
// Handle named colors and hex
|
|
338
|
+
const colorMap = {
|
|
339
|
+
'transparent': 'bg-transparent',
|
|
340
|
+
'white': 'bg-white',
|
|
341
|
+
'black': 'bg-black',
|
|
342
|
+
'red': 'bg-red-500',
|
|
343
|
+
'blue': 'bg-blue-500',
|
|
344
|
+
'green': 'bg-green-500',
|
|
345
|
+
'gray': 'bg-gray-500'
|
|
346
|
+
};
|
|
347
|
+
if (colorMap[value]) {
|
|
348
|
+
return { className: colorMap[value], skipped: false };
|
|
349
|
+
}
|
|
350
|
+
// Handle hex colors - use arbitrary values
|
|
351
|
+
if (value.startsWith('#')) {
|
|
352
|
+
return { className: `bg-[${value}]`, skipped: false };
|
|
353
|
+
}
|
|
354
|
+
// Handle rgb/rgba
|
|
355
|
+
if (value.startsWith('rgb')) {
|
|
356
|
+
return { className: `bg-[${value}]`, skipped: false };
|
|
357
|
+
}
|
|
358
|
+
return { className: null, skipped: true, reason: `Complex background-color: ${value}` };
|
|
359
|
+
}
|
|
360
|
+
convertTextColor(value) {
|
|
361
|
+
const colorMap = {
|
|
362
|
+
'transparent': 'text-transparent',
|
|
363
|
+
'white': 'text-white',
|
|
364
|
+
'black': 'text-black',
|
|
365
|
+
'red': 'text-red-500',
|
|
366
|
+
'blue': 'text-blue-500',
|
|
367
|
+
'green': 'text-green-500',
|
|
368
|
+
'gray': 'text-gray-500'
|
|
369
|
+
};
|
|
370
|
+
if (colorMap[value]) {
|
|
371
|
+
return { className: colorMap[value], skipped: false };
|
|
372
|
+
}
|
|
373
|
+
if (value.startsWith('#')) {
|
|
374
|
+
return { className: `text-[${value}]`, skipped: false };
|
|
375
|
+
}
|
|
376
|
+
if (value.startsWith('rgb')) {
|
|
377
|
+
return { className: `text-[${value}]`, skipped: false };
|
|
378
|
+
}
|
|
379
|
+
return { className: null, skipped: true, reason: `Complex color: ${value}` };
|
|
380
|
+
}
|
|
381
|
+
convertBorderRadius(value) {
|
|
382
|
+
const px = this.extractPx(value);
|
|
383
|
+
if (px === null) {
|
|
384
|
+
// Handle named values
|
|
385
|
+
if (value === '50%') {
|
|
386
|
+
return { className: 'rounded-full', skipped: false };
|
|
387
|
+
}
|
|
388
|
+
return { className: null, skipped: true, reason: `Complex border-radius: ${value}` };
|
|
389
|
+
}
|
|
390
|
+
// Map to Tailwind radius scale
|
|
391
|
+
const radiusMap = {
|
|
392
|
+
0: 'rounded-none',
|
|
393
|
+
2: 'rounded-sm',
|
|
394
|
+
4: 'rounded',
|
|
395
|
+
6: 'rounded-md',
|
|
396
|
+
8: 'rounded-lg',
|
|
397
|
+
12: 'rounded-xl',
|
|
398
|
+
16: 'rounded-2xl',
|
|
399
|
+
24: 'rounded-3xl'
|
|
400
|
+
};
|
|
401
|
+
const closest = Object.keys(radiusMap)
|
|
402
|
+
.map(Number)
|
|
403
|
+
.reduce((prev, curr) => Math.abs(curr - px) < Math.abs(prev - px) ? curr : prev);
|
|
404
|
+
if (Math.abs(closest - px) / (px || 1) < 0.2) {
|
|
405
|
+
return { className: radiusMap[closest], skipped: false };
|
|
406
|
+
}
|
|
407
|
+
// Use arbitrary value
|
|
408
|
+
return { className: `rounded-[${value}]`, skipped: false };
|
|
409
|
+
}
|
|
410
|
+
convertMultiple(properties) {
|
|
411
|
+
const classes = [];
|
|
412
|
+
const warnings = [];
|
|
413
|
+
properties.forEach(({ property, value }) => {
|
|
414
|
+
const result = this.convertProperty(property, value);
|
|
415
|
+
if (result.skipped) {
|
|
416
|
+
warnings.push(result.reason || `Skipped: ${property}: ${value}`);
|
|
417
|
+
logger_1.logger.verbose(`Skipped: ${property}: ${value} - ${result.reason}`);
|
|
418
|
+
}
|
|
419
|
+
else if (result.className) {
|
|
420
|
+
classes.push(result.className);
|
|
421
|
+
logger_1.logger.verbose(`Converted: ${property}: ${value} → ${result.className}`);
|
|
422
|
+
}
|
|
423
|
+
});
|
|
424
|
+
return { classes, warnings };
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
exports.TailwindMapper = TailwindMapper;
|
|
428
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tailwindMapper.js","sourceRoot":"","sources":["../src/tailwindMapper.ts"],"names":[],"mappings":";;;AACA,2CAAwC;AAaxC,MAAa,cAAc;IAIzB,YAAY,MAAsB;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC/C,CAAC;IAEO,iBAAiB;QACvB,MAAM,KAAK,GAAG,IAAI,GAAG,EAAkB,CAAC;QACxC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,OAAO,IAAI,EAAE,CAAC;QAEjD,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;YAC/C,8DAA8D;YAC9D,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YAC5C,IAAI,QAAQ,EAAE,CAAC;gBACb,MAAM,MAAM,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;gBAC5C,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,CAAC;YACrC,CAAC;YAED,2BAA2B;YAC3B,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YAC1C,IAAI,OAAO,EAAE,CAAC;gBACZ,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;YACrD,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,WAAW,CAAC,EAAU;QAC5B,wBAAwB;QACxB,IAAI,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,CAAE,CAAC;QACpC,CAAC;QAED,qBAAqB;QACrB,IAAI,UAAU,GAAkB,IAAI,CAAC;QACrC,IAAI,WAAW,GAAW,QAAQ,CAAC;QAEnC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YACnC,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC;YAChC,IAAI,IAAI,GAAG,WAAW,EAAE,CAAC;gBACvB,UAAU,GAAG,GAAG,CAAC;gBACjB,WAAW,GAAG,IAAI,CAAC;YACrB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,mDAAmD;QACnD,IAAI,UAAU,KAAK,IAAI,IAAI,WAAW,GAAG,EAAE,GAAG,GAAG,EAAE,CAAC;YAClD,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC;QACnD,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,SAAS,CAAC,KAAa;QAC7B,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;QAC5C,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,CAAC;QAED,oBAAoB;QACpB,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;QAC9C,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;QACtC,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,eAAe,CAAC,QAAgB,EAAE,KAAa;QAC7C,MAAM,cAAc,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC;QACrD,MAAM,eAAe,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC;QAEnD,eAAM,CAAC,OAAO,CAAC,eAAe,cAAc,KAAK,eAAe,EAAE,CAAC,CAAC;QAEpE,qBAAqB;QACrB,IAAI,cAAc,KAAK,SAAS,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;QAC9C,CAAC;QAED,sBAAsB;QACtB,IAAI,cAAc,KAAK,UAAU,EAAE,CAAC;YAClC,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACxD,CAAC;QAED,oBAAoB;QACpB,IAAI,cAAc,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;QAC7D,CAAC;QAED,qBAAqB;QACrB,IAAI,cAAc,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YACzC,OAAO,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;QAC9D,CAAC;QAED,kBAAkB;QAClB,IAAI,cAAc,KAAK,aAAa,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC;QACjD,CAAC;QAED,IAAI,cAAc,KAAK,WAAW,EAAE,CAAC;YACnC,OAAO,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;QAC/C,CAAC;QAED,kBAAkB;QAClB,IAAI,cAAc,KAAK,YAAY,EAAE,CAAC;YACpC,OAAO,EAAE,SAAS,EAAE,QAAQ,eAAe,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAClE,CAAC;QAED,qBAAqB;QACrB,IAAI,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC;YACjC,cAAc,CAAC,UAAU,CAAC,SAAS,CAAC;YACpC,cAAc,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;YACvC,OAAO,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;QAC9D,CAAC;QAED,iBAAiB;QACjB,IAAI,cAAc,KAAK,KAAK,EAAE,CAAC;YAC7B,OAAO,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;QAC1C,CAAC;QAED,mBAAmB;QACnB,IAAI,cAAc,KAAK,OAAO,EAAE,CAAC;YAC/B,OAAO,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC;QAC5C,CAAC;QAED,IAAI,cAAc,KAAK,QAAQ,EAAE,CAAC;YAChC,OAAO,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;QAC7C,CAAC;QAED,SAAS;QACT,IAAI,cAAc,KAAK,kBAAkB,EAAE,CAAC;YAC1C,OAAO,IAAI,CAAC,sBAAsB,CAAC,eAAe,CAAC,CAAC;QACtD,CAAC;QAED,IAAI,cAAc,KAAK,OAAO,EAAE,CAAC;YAC/B,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;QAChD,CAAC;QAED,gBAAgB;QAChB,IAAI,cAAc,KAAK,eAAe,EAAE,CAAC;YACvC,OAAO,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC,CAAC;QACnD,CAAC;QAED,yBAAyB;QACzB,OAAO;YACL,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,IAAI;YACb,MAAM,EAAE,yBAAyB,QAAQ,EAAE;SAC5C,CAAC;IACJ,CAAC;IAEO,cAAc,CAAC,KAAa;QAClC,MAAM,UAAU,GAA2B;YACzC,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,QAAQ;YAClB,cAAc,EAAE,cAAc;YAC9B,MAAM,EAAE,MAAM;YACd,MAAM,EAAE,QAAQ;YAChB,UAAU,EAAE,UAAU;YACtB,OAAO,EAAE,OAAO;YAChB,YAAY,EAAE,YAAY;SAC3B,CAAC;QAEF,IAAI,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;YACtB,OAAO,EAAE,SAAS,EAAE,UAAU,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAC1D,CAAC;QAED,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,0BAA0B,KAAK,EAAE,EAAE,CAAC;IACvF,CAAC;IAEO,aAAa,CAAC,IAAY,EAAE,KAAa;QAC/C,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;YAChB,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,2BAA2B,KAAK,EAAE,EAAE,CAAC;QACxF,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,4BAA4B,KAAK,EAAE,EAAE,CAAC;QACzF,CAAC;QAED,MAAM,OAAO,GAA2B;YACtC,QAAQ,EAAE,GAAG;YACb,YAAY,EAAE,IAAI;YAClB,cAAc,EAAE,IAAI;YACpB,eAAe,EAAE,IAAI;YACrB,aAAa,EAAE,IAAI;YACnB,UAAU,EAAE,IAAI;YAChB,UAAU,EAAE,IAAI;SACjB,CAAC;QAEF,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;QACpC,OAAO,EAAE,SAAS,EAAE,GAAG,MAAM,IAAI,OAAO,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IAC/D,CAAC;IAEO,cAAc,CAAC,IAAY,EAAE,KAAa;QAChD,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;YAChB,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,4BAA4B,KAAK,EAAE,EAAE,CAAC;QACzF,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,4BAA4B,KAAK,EAAE,EAAE,CAAC;QACzF,CAAC;QAED,MAAM,OAAO,GAA2B;YACtC,SAAS,EAAE,GAAG;YACd,aAAa,EAAE,IAAI;YACnB,eAAe,EAAE,IAAI;YACrB,gBAAgB,EAAE,IAAI;YACtB,cAAc,EAAE,IAAI;YACpB,WAAW,EAAE,IAAI;YACjB,WAAW,EAAE,IAAI;SAClB,CAAC;QAEF,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;QACpC,OAAO,EAAE,SAAS,EAAE,GAAG,MAAM,IAAI,OAAO,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IAC/D,CAAC;IAEO,iBAAiB,CAAC,KAAa;QACrC,MAAM,SAAS,GAA2B;YACxC,KAAK,EAAE,WAAW;YAClB,KAAK,EAAE,iBAAiB;YACxB,KAAK,EAAE,YAAY;YACnB,KAAK,EAAE,aAAa;YACpB,KAAK,EAAE,aAAa;YACpB,KAAK,EAAE,eAAe;YACtB,KAAK,EAAE,WAAW;YAClB,KAAK,EAAE,gBAAgB;YACvB,KAAK,EAAE,YAAY;YACnB,QAAQ,EAAE,aAAa;YACvB,MAAM,EAAE,WAAW;SACpB,CAAC;QAEF,IAAI,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;YACrB,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACzD,CAAC;QAED,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,wBAAwB,KAAK,EAAE,EAAE,CAAC;IACrF,CAAC;IAEO,eAAe,CAAC,KAAa;QACnC,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;YAChB,wBAAwB;YACxB,MAAM,OAAO,GAA2B;gBACtC,EAAE,EAAE,SAAS;gBACb,EAAE,EAAE,SAAS;gBACb,EAAE,EAAE,WAAW;gBACf,EAAE,EAAE,SAAS;gBACb,EAAE,EAAE,SAAS;gBACb,EAAE,EAAE,UAAU;gBACd,EAAE,EAAE,UAAU;gBACd,EAAE,EAAE,UAAU;gBACd,EAAE,EAAE,UAAU;aACf,CAAC;YAEF,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;iBACjC,GAAG,CAAC,MAAM,CAAC;iBACX,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CACrB,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CACxD,CAAC;YAEJ,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC;gBACvC,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;YACzD,CAAC;QACH,CAAC;QAED,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,2BAA2B,KAAK,EAAE,EAAE,CAAC;IACxF,CAAC;IAEO,cAAc,CAAC,IAAY,EAAE,KAAa;QAChD,iBAAiB;QACjB,IAAI,IAAI,KAAK,gBAAgB,EAAE,CAAC;YAC9B,MAAM,MAAM,GAA2B;gBACrC,KAAK,EAAE,UAAU;gBACjB,aAAa,EAAE,kBAAkB;gBACjC,QAAQ,EAAE,UAAU;gBACpB,gBAAgB,EAAE,kBAAkB;aACrC,CAAC;YACF,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,OAAO,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;QACvE,CAAC;QAED,YAAY;QACZ,IAAI,IAAI,KAAK,WAAW,EAAE,CAAC;YACzB,MAAM,OAAO,GAA2B;gBACtC,MAAM,EAAE,WAAW;gBACnB,QAAQ,EAAE,aAAa;gBACvB,cAAc,EAAE,mBAAmB;aACpC,CAAC;YACF,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACzE,CAAC;QAED,kBAAkB;QAClB,IAAI,IAAI,KAAK,iBAAiB,EAAE,CAAC;YAC/B,MAAM,UAAU,GAA2B;gBACzC,YAAY,EAAE,eAAe;gBAC7B,UAAU,EAAE,aAAa;gBACzB,QAAQ,EAAE,gBAAgB;gBAC1B,eAAe,EAAE,iBAAiB;gBAClC,cAAc,EAAE,gBAAgB;gBAChC,cAAc,EAAE,gBAAgB;aACjC,CAAC;YACF,OAAO,EAAE,SAAS,EAAE,UAAU,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,OAAO,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;QAC/E,CAAC;QAED,cAAc;QACd,IAAI,IAAI,KAAK,aAAa,EAAE,CAAC;YAC3B,MAAM,QAAQ,GAA2B;gBACvC,YAAY,EAAE,aAAa;gBAC3B,UAAU,EAAE,WAAW;gBACvB,QAAQ,EAAE,cAAc;gBACxB,UAAU,EAAE,gBAAgB;gBAC5B,SAAS,EAAE,eAAe;aAC3B,CAAC;YACF,OAAO,EAAE,SAAS,EAAE,QAAQ,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,OAAO,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;QAC3E,CAAC;QAED,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,iCAAiC,IAAI,EAAE,EAAE,CAAC;IAC7F,CAAC;IAEO,UAAU,CAAC,KAAa;QAC9B,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;YAChB,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,wBAAwB,KAAK,EAAE,EAAE,CAAC;QACrF,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,4BAA4B,KAAK,EAAE,EAAE,CAAC;QACzF,CAAC;QAED,OAAO,EAAE,SAAS,EAAE,OAAO,OAAO,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IACzD,CAAC;IAEO,YAAY,CAAC,KAAa;QAChC,2BAA2B;QAC3B,IAAI,KAAK,KAAK,MAAM,EAAE,CAAC;YACrB,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACjD,CAAC;QACD,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;YACpB,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAChD,CAAC;QACD,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9C,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAChD,CAAC;QACD,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9C,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAChD,CAAC;QACD,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;YACpB,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAChD,CAAC;QACD,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;YACpB,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAChD,CAAC;QAED,sBAAsB;QACtB,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;YAChB,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YACrC,IAAI,OAAO,EAAE,CAAC;gBACZ,OAAO,EAAE,SAAS,EAAE,KAAK,OAAO,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;YACvD,CAAC;YACD,wCAAwC;YACxC,OAAO,EAAE,SAAS,EAAE,MAAM,KAAK,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACvD,CAAC;QAED,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,wBAAwB,KAAK,EAAE,EAAE,CAAC;IACrF,CAAC;IAEO,aAAa,CAAC,KAAa;QACjC,2BAA2B;QAC3B,IAAI,KAAK,KAAK,MAAM,EAAE,CAAC;YACrB,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACjD,CAAC;QACD,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;YACpB,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAChD,CAAC;QAED,sBAAsB;QACtB,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;YAChB,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YACrC,IAAI,OAAO,EAAE,CAAC;gBACZ,OAAO,EAAE,SAAS,EAAE,KAAK,OAAO,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;YACvD,CAAC;YACD,OAAO,EAAE,SAAS,EAAE,MAAM,KAAK,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACvD,CAAC;QAED,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,yBAAyB,KAAK,EAAE,EAAE,CAAC;IACtF,CAAC;IAEO,sBAAsB,CAAC,KAAa;QAC1C,8BAA8B;QAC9B,MAAM,QAAQ,GAA2B;YACvC,aAAa,EAAE,gBAAgB;YAC/B,OAAO,EAAE,UAAU;YACnB,OAAO,EAAE,UAAU;YACnB,KAAK,EAAE,YAAY;YACnB,MAAM,EAAE,aAAa;YACrB,OAAO,EAAE,cAAc;YACvB,MAAM,EAAE,aAAa;SACtB,CAAC;QAEF,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YACpB,OAAO,EAAE,SAAS,EAAE,QAAQ,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACxD,CAAC;QAED,2CAA2C;QAC3C,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1B,OAAO,EAAE,SAAS,EAAE,OAAO,KAAK,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACxD,CAAC;QAED,kBAAkB;QAClB,IAAI,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5B,OAAO,EAAE,SAAS,EAAE,OAAO,KAAK,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACxD,CAAC;QAED,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,6BAA6B,KAAK,EAAE,EAAE,CAAC;IAC1F,CAAC;IAEO,gBAAgB,CAAC,KAAa;QACpC,MAAM,QAAQ,GAA2B;YACvC,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,OAAO,EAAE,YAAY;YACrB,KAAK,EAAE,cAAc;YACrB,MAAM,EAAE,eAAe;YACvB,OAAO,EAAE,gBAAgB;YACzB,MAAM,EAAE,eAAe;SACxB,CAAC;QAEF,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YACpB,OAAO,EAAE,SAAS,EAAE,QAAQ,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACxD,CAAC;QAED,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1B,OAAO,EAAE,SAAS,EAAE,SAAS,KAAK,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAC1D,CAAC;QAED,IAAI,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5B,OAAO,EAAE,SAAS,EAAE,SAAS,KAAK,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAC1D,CAAC;QAED,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,kBAAkB,KAAK,EAAE,EAAE,CAAC;IAC/E,CAAC;IAEO,mBAAmB,CAAC,KAAa;QACvC,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAEjC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;YAChB,sBAAsB;YACtB,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;gBACpB,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;YACvD,CAAC;YACD,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,0BAA0B,KAAK,EAAE,EAAE,CAAC;QACvF,CAAC;QAED,+BAA+B;QAC/B,MAAM,SAAS,GAA2B;YACxC,CAAC,EAAE,cAAc;YACjB,CAAC,EAAE,YAAY;YACf,CAAC,EAAE,SAAS;YACZ,CAAC,EAAE,YAAY;YACf,CAAC,EAAE,YAAY;YACf,EAAE,EAAE,YAAY;YAChB,EAAE,EAAE,aAAa;YACjB,EAAE,EAAE,aAAa;SAClB,CAAC;QAEF,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;aACnC,GAAG,CAAC,MAAM,CAAC;aACX,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CACrB,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CACxD,CAAC;QAEJ,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC;YAC7C,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QAC3D,CAAC;QAED,sBAAsB;QACtB,OAAO,EAAE,SAAS,EAAE,YAAY,KAAK,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IAC7D,CAAC;IAED,eAAe,CAAC,UAAyB;QACvC,MAAM,OAAO,GAAa,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAa,EAAE,CAAC;QAE9B,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,EAAE;YACzC,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;YAErD,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;gBACnB,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,YAAY,QAAQ,KAAK,KAAK,EAAE,CAAC,CAAC;gBACjE,eAAM,CAAC,OAAO,CAAC,YAAY,QAAQ,KAAK,KAAK,MAAM,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;YACtE,CAAC;iBAAM,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;gBAC5B,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;gBAC/B,eAAM,CAAC,OAAO,CAAC,cAAc,QAAQ,KAAK,KAAK,MAAM,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;YAC3E,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;IAC/B,CAAC;CACF;AA5fD,wCA4fC","sourcesContent":["import { TailwindConfig } from './utils/config';\nimport { logger } from './utils/logger';\n\nexport interface CSSProperty {\n  property: string;\n  value: string;\n}\n\nexport interface ConversionResult {\n  className: string | null;\n  skipped: boolean;\n  reason?: string;\n}\n\nexport class TailwindMapper {\n  private config: TailwindConfig;\n  private spacingScale: Map<number, string>;\n\n  constructor(config: TailwindConfig) {\n    this.config = config;\n    this.spacingScale = this.buildSpacingScale();\n  }\n\n  private buildSpacingScale(): Map<number, string> {\n    const scale = new Map<number, string>();\n    const spacing = this.config.theme?.spacing || {};\n\n    Object.entries(spacing).forEach(([key, value]) => {\n      // Convert rem to pixels for comparison (assuming 1rem = 16px)\n      const remMatch = value.match(/([\\d.]+)rem/);\n      if (remMatch) {\n        const pixels = parseFloat(remMatch[1]) * 16;\n        scale.set(Math.round(pixels), key);\n      }\n\n      // Also handle pixel values\n      const pxMatch = value.match(/([\\d.]+)px/);\n      if (pxMatch) {\n        scale.set(Math.round(parseFloat(pxMatch[1])), key);\n      }\n    });\n\n    return scale;\n  }\n\n  private pxToSpacing(px: number): string | null {\n    // Try exact match first\n    if (this.spacingScale.has(px)) {\n      return this.spacingScale.get(px)!;\n    }\n\n    // Find closest match\n    let closestKey: number | null = null;\n    let closestDiff: number = Infinity;\n    \n    this.spacingScale.forEach((_, key) => {\n      const diff = Math.abs(key - px);\n      if (diff < closestDiff) {\n        closestKey = key;\n        closestDiff = diff;\n      }\n    });\n\n    // Only accept if within reasonable tolerance (20%)\n    if (closestKey !== null && closestDiff / px < 0.2) {\n      return this.spacingScale.get(closestKey) || null;\n    }\n\n    return null;\n  }\n\n  private extractPx(value: string): number | null {\n    const pxMatch = value.match(/^([\\d.]+)px$/);\n    if (pxMatch) {\n      return parseFloat(pxMatch[1]);\n    }\n\n    // Handle rem values\n    const remMatch = value.match(/^([\\d.]+)rem$/);\n    if (remMatch) {\n      return parseFloat(remMatch[1]) * 16;\n    }\n\n    return null;\n  }\n\n  convertProperty(property: string, value: string): ConversionResult {\n    const normalizedProp = property.toLowerCase().trim();\n    const normalizedValue = value.toLowerCase().trim();\n\n    logger.verbose(`Converting: ${normalizedProp}: ${normalizedValue}`);\n\n    // Display properties\n    if (normalizedProp === 'display') {\n      return this.convertDisplay(normalizedValue);\n    }\n\n    // Position properties\n    if (normalizedProp === 'position') {\n      return { className: normalizedValue, skipped: false };\n    }\n\n    // Margin properties\n    if (normalizedProp.startsWith('margin')) {\n      return this.convertMargin(normalizedProp, normalizedValue);\n    }\n\n    // Padding properties\n    if (normalizedProp.startsWith('padding')) {\n      return this.convertPadding(normalizedProp, normalizedValue);\n    }\n\n    // Font properties\n    if (normalizedProp === 'font-weight') {\n      return this.convertFontWeight(normalizedValue);\n    }\n\n    if (normalizedProp === 'font-size') {\n      return this.convertFontSize(normalizedValue);\n    }\n\n    // Text properties\n    if (normalizedProp === 'text-align') {\n      return { className: `text-${normalizedValue}`, skipped: false };\n    }\n\n    // Flexbox properties\n    if (normalizedProp.startsWith('flex') || \n        normalizedProp.startsWith('justify') || \n        normalizedProp.startsWith('align')) {\n      return this.convertFlexbox(normalizedProp, normalizedValue);\n    }\n\n    // Gap properties\n    if (normalizedProp === 'gap') {\n      return this.convertGap(normalizedValue);\n    }\n\n    // Width and Height\n    if (normalizedProp === 'width') {\n      return this.convertWidth(normalizedValue);\n    }\n\n    if (normalizedProp === 'height') {\n      return this.convertHeight(normalizedValue);\n    }\n\n    // Colors\n    if (normalizedProp === 'background-color') {\n      return this.convertBackgroundColor(normalizedValue);\n    }\n\n    if (normalizedProp === 'color') {\n      return this.convertTextColor(normalizedValue);\n    }\n\n    // Border radius\n    if (normalizedProp === 'border-radius') {\n      return this.convertBorderRadius(normalizedValue);\n    }\n\n    // Unsupported properties\n    return {\n      className: null,\n      skipped: true,\n      reason: `Unsupported property: ${property}`\n    };\n  }\n\n  private convertDisplay(value: string): ConversionResult {\n    const displayMap: Record<string, string> = {\n      'flex': 'flex',\n      'block': 'block',\n      'inline': 'inline',\n      'inline-block': 'inline-block',\n      'grid': 'grid',\n      'none': 'hidden',\n      'contents': 'contents',\n      'table': 'table',\n      'table-cell': 'table-cell'\n    };\n\n    if (displayMap[value]) {\n      return { className: displayMap[value], skipped: false };\n    }\n\n    return { className: null, skipped: true, reason: `Unknown display value: ${value}` };\n  }\n\n  private convertMargin(prop: string, value: string): ConversionResult {\n    const px = this.extractPx(value);\n    if (px === null) {\n      return { className: null, skipped: true, reason: `Non-pixel margin value: ${value}` };\n    }\n\n    const spacing = this.pxToSpacing(px);\n    if (!spacing) {\n      return { className: null, skipped: true, reason: `No matching spacing for: ${value}` };\n    }\n\n    const sideMap: Record<string, string> = {\n      'margin': 'm',\n      'margin-top': 'mt',\n      'margin-right': 'mr',\n      'margin-bottom': 'mb',\n      'margin-left': 'ml',\n      'margin-x': 'mx',\n      'margin-y': 'my'\n    };\n\n    const prefix = sideMap[prop] || 'm';\n    return { className: `${prefix}-${spacing}`, skipped: false };\n  }\n\n  private convertPadding(prop: string, value: string): ConversionResult {\n    const px = this.extractPx(value);\n    if (px === null) {\n      return { className: null, skipped: true, reason: `Non-pixel padding value: ${value}` };\n    }\n\n    const spacing = this.pxToSpacing(px);\n    if (!spacing) {\n      return { className: null, skipped: true, reason: `No matching spacing for: ${value}` };\n    }\n\n    const sideMap: Record<string, string> = {\n      'padding': 'p',\n      'padding-top': 'pt',\n      'padding-right': 'pr',\n      'padding-bottom': 'pb',\n      'padding-left': 'pl',\n      'padding-x': 'px',\n      'padding-y': 'py'\n    };\n\n    const prefix = sideMap[prop] || 'p';\n    return { className: `${prefix}-${spacing}`, skipped: false };\n  }\n\n  private convertFontWeight(value: string): ConversionResult {\n    const weightMap: Record<string, string> = {\n      '100': 'font-thin',\n      '200': 'font-extralight',\n      '300': 'font-light',\n      '400': 'font-normal',\n      '500': 'font-medium',\n      '600': 'font-semibold',\n      '700': 'font-bold',\n      '800': 'font-extrabold',\n      '900': 'font-black',\n      'normal': 'font-normal',\n      'bold': 'font-bold'\n    };\n\n    if (weightMap[value]) {\n      return { className: weightMap[value], skipped: false };\n    }\n\n    return { className: null, skipped: true, reason: `Unknown font-weight: ${value}` };\n  }\n\n  private convertFontSize(value: string): ConversionResult {\n    const px = this.extractPx(value);\n    if (px !== null) {\n      // Map common font sizes\n      const sizeMap: Record<number, string> = {\n        12: 'text-xs',\n        14: 'text-sm',\n        16: 'text-base',\n        18: 'text-lg',\n        20: 'text-xl',\n        24: 'text-2xl',\n        30: 'text-3xl',\n        36: 'text-4xl',\n        48: 'text-5xl'\n      };\n\n      const closest = Object.keys(sizeMap)\n        .map(Number)\n        .reduce((prev, curr) => \n          Math.abs(curr - px) < Math.abs(prev - px) ? curr : prev\n        );\n\n      if (Math.abs(closest - px) / px < 0.15) {\n        return { className: sizeMap[closest], skipped: false };\n      }\n    }\n\n    return { className: null, skipped: true, reason: `Non-standard font-size: ${value}` };\n  }\n\n  private convertFlexbox(prop: string, value: string): ConversionResult {\n    // Flex direction\n    if (prop === 'flex-direction') {\n      const dirMap: Record<string, string> = {\n        'row': 'flex-row',\n        'row-reverse': 'flex-row-reverse',\n        'column': 'flex-col',\n        'column-reverse': 'flex-col-reverse'\n      };\n      return { className: dirMap[value] || null, skipped: !dirMap[value] };\n    }\n\n    // Flex wrap\n    if (prop === 'flex-wrap') {\n      const wrapMap: Record<string, string> = {\n        'wrap': 'flex-wrap',\n        'nowrap': 'flex-nowrap',\n        'wrap-reverse': 'flex-wrap-reverse'\n      };\n      return { className: wrapMap[value] || null, skipped: !wrapMap[value] };\n    }\n\n    // Justify content\n    if (prop === 'justify-content') {\n      const justifyMap: Record<string, string> = {\n        'flex-start': 'justify-start',\n        'flex-end': 'justify-end',\n        'center': 'justify-center',\n        'space-between': 'justify-between',\n        'space-around': 'justify-around',\n        'space-evenly': 'justify-evenly'\n      };\n      return { className: justifyMap[value] || null, skipped: !justifyMap[value] };\n    }\n\n    // Align items\n    if (prop === 'align-items') {\n      const alignMap: Record<string, string> = {\n        'flex-start': 'items-start',\n        'flex-end': 'items-end',\n        'center': 'items-center',\n        'baseline': 'items-baseline',\n        'stretch': 'items-stretch'\n      };\n      return { className: alignMap[value] || null, skipped: !alignMap[value] };\n    }\n\n    return { className: null, skipped: true, reason: `Unsupported flexbox property: ${prop}` };\n  }\n\n  private convertGap(value: string): ConversionResult {\n    const px = this.extractPx(value);\n    if (px === null) {\n      return { className: null, skipped: true, reason: `Non-pixel gap value: ${value}` };\n    }\n\n    const spacing = this.pxToSpacing(px);\n    if (!spacing) {\n      return { className: null, skipped: true, reason: `No matching spacing for: ${value}` };\n    }\n\n    return { className: `gap-${spacing}`, skipped: false };\n  }\n\n  private convertWidth(value: string): ConversionResult {\n    // Handle percentage values\n    if (value === '100%') {\n      return { className: 'w-full', skipped: false };\n    }\n    if (value === '50%') {\n      return { className: 'w-1/2', skipped: false };\n    }\n    if (value === '33.333%' || value === '33.33%') {\n      return { className: 'w-1/3', skipped: false };\n    }\n    if (value === '66.666%' || value === '66.67%') {\n      return { className: 'w-2/3', skipped: false };\n    }\n    if (value === '25%') {\n      return { className: 'w-1/4', skipped: false };\n    }\n    if (value === '75%') {\n      return { className: 'w-3/4', skipped: false };\n    }\n\n    // Handle pixel values\n    const px = this.extractPx(value);\n    if (px !== null) {\n      const spacing = this.pxToSpacing(px);\n      if (spacing) {\n        return { className: `w-${spacing}`, skipped: false };\n      }\n      // Try arbitrary values for larger sizes\n      return { className: `w-[${value}]`, skipped: false };\n    }\n\n    return { className: null, skipped: true, reason: `Complex width value: ${value}` };\n  }\n\n  private convertHeight(value: string): ConversionResult {\n    // Handle percentage values\n    if (value === '100%') {\n      return { className: 'h-full', skipped: false };\n    }\n    if (value === '50%') {\n      return { className: 'h-1/2', skipped: false };\n    }\n\n    // Handle pixel values\n    const px = this.extractPx(value);\n    if (px !== null) {\n      const spacing = this.pxToSpacing(px);\n      if (spacing) {\n        return { className: `h-${spacing}`, skipped: false };\n      }\n      return { className: `h-[${value}]`, skipped: false };\n    }\n\n    return { className: null, skipped: true, reason: `Complex height value: ${value}` };\n  }\n\n  private convertBackgroundColor(value: string): ConversionResult {\n    // Handle named colors and hex\n    const colorMap: Record<string, string> = {\n      'transparent': 'bg-transparent',\n      'white': 'bg-white',\n      'black': 'bg-black',\n      'red': 'bg-red-500',\n      'blue': 'bg-blue-500',\n      'green': 'bg-green-500',\n      'gray': 'bg-gray-500'\n    };\n\n    if (colorMap[value]) {\n      return { className: colorMap[value], skipped: false };\n    }\n\n    // Handle hex colors - use arbitrary values\n    if (value.startsWith('#')) {\n      return { className: `bg-[${value}]`, skipped: false };\n    }\n\n    // Handle rgb/rgba\n    if (value.startsWith('rgb')) {\n      return { className: `bg-[${value}]`, skipped: false };\n    }\n\n    return { className: null, skipped: true, reason: `Complex background-color: ${value}` };\n  }\n\n  private convertTextColor(value: string): ConversionResult {\n    const colorMap: Record<string, string> = {\n      'transparent': 'text-transparent',\n      'white': 'text-white',\n      'black': 'text-black',\n      'red': 'text-red-500',\n      'blue': 'text-blue-500',\n      'green': 'text-green-500',\n      'gray': 'text-gray-500'\n    };\n\n    if (colorMap[value]) {\n      return { className: colorMap[value], skipped: false };\n    }\n\n    if (value.startsWith('#')) {\n      return { className: `text-[${value}]`, skipped: false };\n    }\n\n    if (value.startsWith('rgb')) {\n      return { className: `text-[${value}]`, skipped: false };\n    }\n\n    return { className: null, skipped: true, reason: `Complex color: ${value}` };\n  }\n\n  private convertBorderRadius(value: string): ConversionResult {\n    const px = this.extractPx(value);\n    \n    if (px === null) {\n      // Handle named values\n      if (value === '50%') {\n        return { className: 'rounded-full', skipped: false };\n      }\n      return { className: null, skipped: true, reason: `Complex border-radius: ${value}` };\n    }\n\n    // Map to Tailwind radius scale\n    const radiusMap: Record<number, string> = {\n      0: 'rounded-none',\n      2: 'rounded-sm',\n      4: 'rounded',\n      6: 'rounded-md',\n      8: 'rounded-lg',\n      12: 'rounded-xl',\n      16: 'rounded-2xl',\n      24: 'rounded-3xl'\n    };\n\n    const closest = Object.keys(radiusMap)\n      .map(Number)\n      .reduce((prev, curr) => \n        Math.abs(curr - px) < Math.abs(prev - px) ? curr : prev\n      );\n\n    if (Math.abs(closest - px) / (px || 1) < 0.2) {\n      return { className: radiusMap[closest], skipped: false };\n    }\n\n    // Use arbitrary value\n    return { className: `rounded-[${value}]`, skipped: false };\n  }\n\n  convertMultiple(properties: CSSProperty[]): { classes: string[]; warnings: string[] } {\n    const classes: string[] = [];\n    const warnings: string[] = [];\n\n    properties.forEach(({ property, value }) => {\n      const result = this.convertProperty(property, value);\n      \n      if (result.skipped) {\n        warnings.push(result.reason || `Skipped: ${property}: ${value}`);\n        logger.verbose(`Skipped: ${property}: ${value} - ${result.reason}`);\n      } else if (result.className) {\n        classes.push(result.className);\n        logger.verbose(`Converted: ${property}: ${value} → ${result.className}`);\n      }\n    });\n\n    return { classes, warnings };\n  }\n}\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ScannedFile } from './scanner';
|
|
2
|
+
import { TailwindConfig } from './utils/config';
|
|
3
|
+
export interface TransformOptions {
|
|
4
|
+
dryRun: boolean;
|
|
5
|
+
deleteCss: boolean;
|
|
6
|
+
skipExternal: boolean;
|
|
7
|
+
skipInline: boolean;
|
|
8
|
+
skipInternal: boolean;
|
|
9
|
+
tailwindConfig: TailwindConfig | null;
|
|
10
|
+
projectRoot: string;
|
|
11
|
+
}
|
|
12
|
+
export interface TransformResults {
|
|
13
|
+
filesScanned: number;
|
|
14
|
+
filesModified: number;
|
|
15
|
+
stylesConverted: number;
|
|
16
|
+
classesReplaced: number;
|
|
17
|
+
warnings: number;
|
|
18
|
+
}
|
|
19
|
+
export declare function transformFiles(files: ScannedFile[], options: TransformOptions): Promise<TransformResults>;
|