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.
@@ -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":"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","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>;