css-to-tailwind-react 0.2.0 → 0.2.2
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/cssParser.d.ts +7 -0
- package/dist/cssParser.js +33 -12
- package/dist/jsxDescendantTransformer.d.ts +3 -5
- package/dist/jsxDescendantTransformer.js +16 -5
- package/dist/transformer.js +27 -24
- package/dist/utils/conflictResolver.d.ts +39 -0
- package/dist/utils/conflictResolver.js +140 -0
- package/dist/utils/propertyMapper.d.ts +7 -0
- package/dist/utils/propertyMapper.js +277 -0
- package/dist/utils/specificityCalculator.d.ts +25 -0
- package/dist/utils/specificityCalculator.js +150 -0
- package/package.json +1 -1
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PROPERTY_CONFLICT_GROUPS = void 0;
|
|
4
|
+
exports.getPropertyForUtility = getPropertyForUtility;
|
|
5
|
+
exports.isTextFontSizeUtility = isTextFontSizeUtility;
|
|
6
|
+
exports.isTextColorUtility = isTextColorUtility;
|
|
7
|
+
exports.getPropertiesForUtilities = getPropertiesForUtilities;
|
|
8
|
+
exports.getConflictGroup = getConflictGroup;
|
|
9
|
+
exports.propertiesConflict = propertiesConflict;
|
|
10
|
+
const PROPERTY_PREFIX_MAP = {
|
|
11
|
+
'color': ['text-'],
|
|
12
|
+
'background-color': ['bg-'],
|
|
13
|
+
'font-size': ['text-xs', 'text-sm', 'text-base', 'text-lg', 'text-xl', 'text-2xl', 'text-3xl', 'text-4xl', 'text-5xl', 'text-6xl', 'text-7xl', 'text-8xl', 'text-9xl', 'text-'],
|
|
14
|
+
'font-weight': ['font-thin', 'font-extralight', 'font-light', 'font-normal', 'font-medium', 'font-semibold', 'font-bold', 'font-extrabold', 'font-black'],
|
|
15
|
+
'display': ['block', 'inline-block', 'inline', 'flex', 'inline-flex', 'grid', 'inline-grid', 'hidden', 'contents', 'table', 'table-cell', 'table-row'],
|
|
16
|
+
'position': ['static', 'fixed', 'absolute', 'relative', 'sticky'],
|
|
17
|
+
'width': ['w-'],
|
|
18
|
+
'height': ['h-'],
|
|
19
|
+
'min-width': ['min-w-'],
|
|
20
|
+
'max-width': ['max-w-'],
|
|
21
|
+
'min-height': ['min-h-'],
|
|
22
|
+
'max-height': ['max-h-'],
|
|
23
|
+
'margin': ['m-'],
|
|
24
|
+
'margin-top': ['mt-'],
|
|
25
|
+
'margin-right': ['mr-'],
|
|
26
|
+
'margin-bottom': ['mb-'],
|
|
27
|
+
'margin-left': ['ml-'],
|
|
28
|
+
'margin-x': ['mx-'],
|
|
29
|
+
'margin-y': ['my-'],
|
|
30
|
+
'padding': ['p-'],
|
|
31
|
+
'padding-top': ['pt-'],
|
|
32
|
+
'padding-right': ['pr-'],
|
|
33
|
+
'padding-bottom': ['pb-'],
|
|
34
|
+
'padding-left': ['pl-'],
|
|
35
|
+
'padding-x': ['px-'],
|
|
36
|
+
'padding-y': ['py-'],
|
|
37
|
+
'gap': ['gap-'],
|
|
38
|
+
'border-radius': ['rounded-', 'rounded'],
|
|
39
|
+
'border-width': ['border-', 'border-t-', 'border-r-', 'border-b-', 'border-l-'],
|
|
40
|
+
'border-color': ['border-'],
|
|
41
|
+
'flex-direction': ['flex-row', 'flex-col', 'flex-row-reverse', 'flex-col-reverse'],
|
|
42
|
+
'flex-wrap': ['flex-wrap', 'flex-nowrap', 'flex-wrap-reverse'],
|
|
43
|
+
'justify-content': ['justify-'],
|
|
44
|
+
'align-items': ['items-'],
|
|
45
|
+
'align-content': ['content-'],
|
|
46
|
+
'align-self': ['self-'],
|
|
47
|
+
'text-align': ['text-left', 'text-center', 'text-right', 'text-justify', 'text-start', 'text-end'],
|
|
48
|
+
'overflow': ['overflow-'],
|
|
49
|
+
'overflow-x': ['overflow-x-'],
|
|
50
|
+
'overflow-y': ['overflow-y-'],
|
|
51
|
+
'z-index': ['z-'],
|
|
52
|
+
'opacity': ['opacity-'],
|
|
53
|
+
'cursor': ['cursor-'],
|
|
54
|
+
'pointer-events': ['pointer-events-'],
|
|
55
|
+
'user-select': ['select-'],
|
|
56
|
+
'box-shadow': ['shadow-'],
|
|
57
|
+
'transition': ['transition-'],
|
|
58
|
+
'transform': ['scale-', 'rotate-', 'translate-', 'skew-'],
|
|
59
|
+
'top': ['top-'],
|
|
60
|
+
'right': ['right-'],
|
|
61
|
+
'bottom': ['bottom-'],
|
|
62
|
+
'left': ['left-'],
|
|
63
|
+
'inset': ['inset-']
|
|
64
|
+
};
|
|
65
|
+
const UTILITY_TO_PROPERTY_MAP = {
|
|
66
|
+
'block': 'display',
|
|
67
|
+
'inline-block': 'display',
|
|
68
|
+
'inline': 'display',
|
|
69
|
+
'flex': 'display',
|
|
70
|
+
'inline-flex': 'display',
|
|
71
|
+
'grid': 'display',
|
|
72
|
+
'inline-grid': 'display',
|
|
73
|
+
'hidden': 'display',
|
|
74
|
+
'contents': 'display',
|
|
75
|
+
'static': 'position',
|
|
76
|
+
'fixed': 'position',
|
|
77
|
+
'absolute': 'position',
|
|
78
|
+
'relative': 'position',
|
|
79
|
+
'sticky': 'position',
|
|
80
|
+
'flex-row': 'flex-direction',
|
|
81
|
+
'flex-col': 'flex-direction',
|
|
82
|
+
'flex-row-reverse': 'flex-direction',
|
|
83
|
+
'flex-col-reverse': 'flex-direction',
|
|
84
|
+
'flex-wrap': 'flex-wrap',
|
|
85
|
+
'flex-nowrap': 'flex-wrap',
|
|
86
|
+
'flex-wrap-reverse': 'flex-wrap',
|
|
87
|
+
'text-left': 'text-align',
|
|
88
|
+
'text-center': 'text-align',
|
|
89
|
+
'text-right': 'text-align',
|
|
90
|
+
'text-justify': 'text-align',
|
|
91
|
+
'text-start': 'text-align',
|
|
92
|
+
'text-end': 'text-align',
|
|
93
|
+
'font-thin': 'font-weight',
|
|
94
|
+
'font-extralight': 'font-weight',
|
|
95
|
+
'font-light': 'font-weight',
|
|
96
|
+
'font-normal': 'font-weight',
|
|
97
|
+
'font-medium': 'font-weight',
|
|
98
|
+
'font-semibold': 'font-weight',
|
|
99
|
+
'font-bold': 'font-weight',
|
|
100
|
+
'font-extrabold': 'font-weight',
|
|
101
|
+
'font-black': 'font-weight',
|
|
102
|
+
'rounded': 'border-radius',
|
|
103
|
+
'rounded-none': 'border-radius',
|
|
104
|
+
'rounded-sm': 'border-radius',
|
|
105
|
+
'rounded-md': 'border-radius',
|
|
106
|
+
'rounded-lg': 'border-radius',
|
|
107
|
+
'rounded-xl': 'border-radius',
|
|
108
|
+
'rounded-2xl': 'border-radius',
|
|
109
|
+
'rounded-3xl': 'border-radius',
|
|
110
|
+
'rounded-full': 'border-radius'
|
|
111
|
+
};
|
|
112
|
+
const PREFIX_PROPERTY_MAP = {
|
|
113
|
+
'text-': 'color',
|
|
114
|
+
'bg-': 'background-color',
|
|
115
|
+
'w-': 'width',
|
|
116
|
+
'h-': 'height',
|
|
117
|
+
'min-w-': 'min-width',
|
|
118
|
+
'max-w-': 'max-width',
|
|
119
|
+
'min-h-': 'min-height',
|
|
120
|
+
'max-h-': 'max-height',
|
|
121
|
+
'm-': 'margin',
|
|
122
|
+
'mt-': 'margin-top',
|
|
123
|
+
'mr-': 'margin-right',
|
|
124
|
+
'mb-': 'margin-bottom',
|
|
125
|
+
'ml-': 'margin-left',
|
|
126
|
+
'mx-': 'margin-x',
|
|
127
|
+
'my-': 'margin-y',
|
|
128
|
+
'p-': 'padding',
|
|
129
|
+
'pt-': 'padding-top',
|
|
130
|
+
'pr-': 'padding-right',
|
|
131
|
+
'pb-': 'padding-bottom',
|
|
132
|
+
'pl-': 'padding-left',
|
|
133
|
+
'px-': 'padding-x',
|
|
134
|
+
'py-': 'padding-y',
|
|
135
|
+
'gap-': 'gap',
|
|
136
|
+
'rounded-': 'border-radius',
|
|
137
|
+
'justify-': 'justify-content',
|
|
138
|
+
'items-': 'align-items',
|
|
139
|
+
'content-': 'align-content',
|
|
140
|
+
'self-': 'align-self',
|
|
141
|
+
'overflow-': 'overflow',
|
|
142
|
+
'overflow-x-': 'overflow-x',
|
|
143
|
+
'overflow-y-': 'overflow-y',
|
|
144
|
+
'z-': 'z-index',
|
|
145
|
+
'opacity-': 'opacity',
|
|
146
|
+
'cursor-': 'cursor',
|
|
147
|
+
'shadow-': 'box-shadow',
|
|
148
|
+
'border-': 'border-width',
|
|
149
|
+
'border-t-': 'border-width',
|
|
150
|
+
'border-r-': 'border-width',
|
|
151
|
+
'border-b-': 'border-width',
|
|
152
|
+
'border-l-': 'border-width',
|
|
153
|
+
'top-': 'top',
|
|
154
|
+
'right-': 'right',
|
|
155
|
+
'bottom-': 'bottom',
|
|
156
|
+
'left-': 'left',
|
|
157
|
+
'inset-': 'inset'
|
|
158
|
+
};
|
|
159
|
+
const FONT_SIZE_UTILITIES = new Set([
|
|
160
|
+
'text-xs', 'text-sm', 'text-base', 'text-lg', 'text-xl',
|
|
161
|
+
'text-2xl', 'text-3xl', 'text-4xl', 'text-5xl', 'text-6xl',
|
|
162
|
+
'text-7xl', 'text-8xl', 'text-9xl'
|
|
163
|
+
]);
|
|
164
|
+
function getPropertyForUtility(utility) {
|
|
165
|
+
const strippedUtility = stripVariants(utility);
|
|
166
|
+
if (UTILITY_TO_PROPERTY_MAP[strippedUtility]) {
|
|
167
|
+
return UTILITY_TO_PROPERTY_MAP[strippedUtility];
|
|
168
|
+
}
|
|
169
|
+
if (FONT_SIZE_UTILITIES.has(strippedUtility)) {
|
|
170
|
+
return 'font-size';
|
|
171
|
+
}
|
|
172
|
+
if (strippedUtility.startsWith('text-') && !FONT_SIZE_UTILITIES.has(strippedUtility)) {
|
|
173
|
+
const value = strippedUtility.slice(5);
|
|
174
|
+
if (/^\d/.test(value) || value.startsWith('[')) {
|
|
175
|
+
return 'font-size';
|
|
176
|
+
}
|
|
177
|
+
return 'color';
|
|
178
|
+
}
|
|
179
|
+
const sortedPrefixes = Object.keys(PREFIX_PROPERTY_MAP).sort((a, b) => b.length - a.length);
|
|
180
|
+
for (const prefix of sortedPrefixes) {
|
|
181
|
+
if (strippedUtility.startsWith(prefix)) {
|
|
182
|
+
return PREFIX_PROPERTY_MAP[prefix];
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
return 'unknown';
|
|
186
|
+
}
|
|
187
|
+
function stripVariants(utility) {
|
|
188
|
+
const parts = utility.split(':');
|
|
189
|
+
return parts[parts.length - 1];
|
|
190
|
+
}
|
|
191
|
+
function isTextFontSizeUtility(utility) {
|
|
192
|
+
const stripped = stripVariants(utility);
|
|
193
|
+
return FONT_SIZE_UTILITIES.has(stripped) || (stripped.startsWith('text-') && /^\d/.test(stripped.slice(5)));
|
|
194
|
+
}
|
|
195
|
+
function isTextColorUtility(utility) {
|
|
196
|
+
const stripped = stripVariants(utility);
|
|
197
|
+
if (FONT_SIZE_UTILITIES.has(stripped)) {
|
|
198
|
+
return false;
|
|
199
|
+
}
|
|
200
|
+
if (stripped.startsWith('text-')) {
|
|
201
|
+
const value = stripped.slice(5);
|
|
202
|
+
if (/^\d/.test(value) || value.startsWith('[')) {
|
|
203
|
+
return false;
|
|
204
|
+
}
|
|
205
|
+
return true;
|
|
206
|
+
}
|
|
207
|
+
return false;
|
|
208
|
+
}
|
|
209
|
+
function getPropertiesForUtilities(utilities) {
|
|
210
|
+
const propertyMap = new Map();
|
|
211
|
+
for (const utility of utilities) {
|
|
212
|
+
const property = getPropertyForUtility(utility);
|
|
213
|
+
if (!propertyMap.has(property)) {
|
|
214
|
+
propertyMap.set(property, []);
|
|
215
|
+
}
|
|
216
|
+
propertyMap.get(property).push(utility);
|
|
217
|
+
}
|
|
218
|
+
return propertyMap;
|
|
219
|
+
}
|
|
220
|
+
exports.PROPERTY_CONFLICT_GROUPS = {
|
|
221
|
+
'display': ['display'],
|
|
222
|
+
'position': ['position'],
|
|
223
|
+
'width': ['width', 'min-width', 'max-width'],
|
|
224
|
+
'height': ['height', 'min-height', 'max-height'],
|
|
225
|
+
'margin': ['margin', 'margin-top', 'margin-right', 'margin-bottom', 'margin-left', 'margin-x', 'margin-y'],
|
|
226
|
+
'padding': ['padding', 'padding-top', 'padding-right', 'padding-bottom', 'padding-left', 'padding-x', 'padding-y'],
|
|
227
|
+
'flex-direction': ['flex-direction'],
|
|
228
|
+
'flex-wrap': ['flex-wrap'],
|
|
229
|
+
'justify-content': ['justify-content'],
|
|
230
|
+
'align-items': ['align-items'],
|
|
231
|
+
'text-align': ['text-align'],
|
|
232
|
+
'font-size': ['font-size'],
|
|
233
|
+
'font-weight': ['font-weight'],
|
|
234
|
+
'color': ['color'],
|
|
235
|
+
'background-color': ['background-color'],
|
|
236
|
+
'border-radius': ['border-radius'],
|
|
237
|
+
'border-width': ['border-width', 'border-top-width', 'border-right-width', 'border-bottom-width', 'border-left-width'],
|
|
238
|
+
'overflow': ['overflow', 'overflow-x', 'overflow-y'],
|
|
239
|
+
'z-index': ['z-index'],
|
|
240
|
+
'opacity': ['opacity'],
|
|
241
|
+
'gap': ['gap'],
|
|
242
|
+
'inset': ['inset', 'top', 'right', 'bottom', 'left']
|
|
243
|
+
};
|
|
244
|
+
function getConflictGroup(property) {
|
|
245
|
+
for (const [groupName, properties] of Object.entries(exports.PROPERTY_CONFLICT_GROUPS)) {
|
|
246
|
+
if (properties.includes(property)) {
|
|
247
|
+
return groupName;
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
return null;
|
|
251
|
+
}
|
|
252
|
+
function propertiesConflict(prop1, prop2) {
|
|
253
|
+
const group1 = getConflictGroup(prop1);
|
|
254
|
+
const group2 = getConflictGroup(prop2);
|
|
255
|
+
if (group1 && group2 && group1 === group2) {
|
|
256
|
+
if (prop1 === prop2) {
|
|
257
|
+
return true;
|
|
258
|
+
}
|
|
259
|
+
const group = exports.PROPERTY_CONFLICT_GROUPS[group1];
|
|
260
|
+
if (group.length === 1) {
|
|
261
|
+
return true;
|
|
262
|
+
}
|
|
263
|
+
if (group1 === 'margin' || group1 === 'padding') {
|
|
264
|
+
if (prop1 === group1 || prop2 === group1) {
|
|
265
|
+
return true;
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
if (group1 === 'inset') {
|
|
269
|
+
if (prop1 === 'inset' || prop2 === 'inset') {
|
|
270
|
+
return true;
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
return prop1 === prop2;
|
|
274
|
+
}
|
|
275
|
+
return prop1 === prop2;
|
|
276
|
+
}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"propertyMapper.js","sourceRoot":"","sources":["../../src/utils/propertyMapper.ts"],"names":[],"mappings":"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","sourcesContent":["const PROPERTY_PREFIX_MAP: Record<string, string[]> = {\n  'color': ['text-'],\n  'background-color': ['bg-'],\n  'font-size': ['text-xs', 'text-sm', 'text-base', 'text-lg', 'text-xl', 'text-2xl', 'text-3xl', 'text-4xl', 'text-5xl', 'text-6xl', 'text-7xl', 'text-8xl', 'text-9xl', 'text-'],\n  'font-weight': ['font-thin', 'font-extralight', 'font-light', 'font-normal', 'font-medium', 'font-semibold', 'font-bold', 'font-extrabold', 'font-black'],\n  'display': ['block', 'inline-block', 'inline', 'flex', 'inline-flex', 'grid', 'inline-grid', 'hidden', 'contents', 'table', 'table-cell', 'table-row'],\n  'position': ['static', 'fixed', 'absolute', 'relative', 'sticky'],\n  'width': ['w-'],\n  'height': ['h-'],\n  'min-width': ['min-w-'],\n  'max-width': ['max-w-'],\n  'min-height': ['min-h-'],\n  'max-height': ['max-h-'],\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  '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  'gap': ['gap-'],\n  'border-radius': ['rounded-', 'rounded'],\n  'border-width': ['border-', 'border-t-', 'border-r-', 'border-b-', 'border-l-'],\n  'border-color': ['border-'],\n  'flex-direction': ['flex-row', 'flex-col', 'flex-row-reverse', 'flex-col-reverse'],\n  'flex-wrap': ['flex-wrap', 'flex-nowrap', 'flex-wrap-reverse'],\n  'justify-content': ['justify-'],\n  'align-items': ['items-'],\n  'align-content': ['content-'],\n  'align-self': ['self-'],\n  'text-align': ['text-left', 'text-center', 'text-right', 'text-justify', 'text-start', 'text-end'],\n  'overflow': ['overflow-'],\n  'overflow-x': ['overflow-x-'],\n  'overflow-y': ['overflow-y-'],\n  'z-index': ['z-'],\n  'opacity': ['opacity-'],\n  'cursor': ['cursor-'],\n  'pointer-events': ['pointer-events-'],\n  'user-select': ['select-'],\n  'box-shadow': ['shadow-'],\n  'transition': ['transition-'],\n  'transform': ['scale-', 'rotate-', 'translate-', 'skew-'],\n  'top': ['top-'],\n  'right': ['right-'],\n  'bottom': ['bottom-'],\n  'left': ['left-'],\n  'inset': ['inset-']\n};\n\nconst UTILITY_TO_PROPERTY_MAP: Record<string, string> = {\n  'block': 'display',\n  'inline-block': 'display',\n  'inline': 'display',\n  'flex': 'display',\n  'inline-flex': 'display',\n  'grid': 'display',\n  'inline-grid': 'display',\n  'hidden': 'display',\n  'contents': 'display',\n  'static': 'position',\n  'fixed': 'position',\n  'absolute': 'position',\n  'relative': 'position',\n  'sticky': 'position',\n  'flex-row': 'flex-direction',\n  'flex-col': 'flex-direction',\n  'flex-row-reverse': 'flex-direction',\n  'flex-col-reverse': 'flex-direction',\n  'flex-wrap': 'flex-wrap',\n  'flex-nowrap': 'flex-wrap',\n  'flex-wrap-reverse': 'flex-wrap',\n  'text-left': 'text-align',\n  'text-center': 'text-align',\n  'text-right': 'text-align',\n  'text-justify': 'text-align',\n  'text-start': 'text-align',\n  'text-end': 'text-align',\n  'font-thin': 'font-weight',\n  'font-extralight': 'font-weight',\n  'font-light': 'font-weight',\n  'font-normal': 'font-weight',\n  'font-medium': 'font-weight',\n  'font-semibold': 'font-weight',\n  'font-bold': 'font-weight',\n  'font-extrabold': 'font-weight',\n  'font-black': 'font-weight',\n  'rounded': 'border-radius',\n  'rounded-none': 'border-radius',\n  'rounded-sm': 'border-radius',\n  'rounded-md': 'border-radius',\n  'rounded-lg': 'border-radius',\n  'rounded-xl': 'border-radius',\n  'rounded-2xl': 'border-radius',\n  'rounded-3xl': 'border-radius',\n  'rounded-full': 'border-radius'\n};\n\nconst PREFIX_PROPERTY_MAP: Record<string, string> = {\n  'text-': 'color',\n  'bg-': 'background-color',\n  'w-': 'width',\n  'h-': 'height',\n  'min-w-': 'min-width',\n  'max-w-': 'max-width',\n  'min-h-': 'min-height',\n  'max-h-': 'max-height',\n  'm-': 'margin',\n  'mt-': 'margin-top',\n  'mr-': 'margin-right',\n  'mb-': 'margin-bottom',\n  'ml-': 'margin-left',\n  'mx-': 'margin-x',\n  'my-': 'margin-y',\n  'p-': 'padding',\n  'pt-': 'padding-top',\n  'pr-': 'padding-right',\n  'pb-': 'padding-bottom',\n  'pl-': 'padding-left',\n  'px-': 'padding-x',\n  'py-': 'padding-y',\n  'gap-': 'gap',\n  'rounded-': 'border-radius',\n  'justify-': 'justify-content',\n  'items-': 'align-items',\n  'content-': 'align-content',\n  'self-': 'align-self',\n  'overflow-': 'overflow',\n  'overflow-x-': 'overflow-x',\n  'overflow-y-': 'overflow-y',\n  'z-': 'z-index',\n  'opacity-': 'opacity',\n  'cursor-': 'cursor',\n  'shadow-': 'box-shadow',\n  'border-': 'border-width',\n  'border-t-': 'border-width',\n  'border-r-': 'border-width',\n  'border-b-': 'border-width',\n  'border-l-': 'border-width',\n  'top-': 'top',\n  'right-': 'right',\n  'bottom-': 'bottom',\n  'left-': 'left',\n  'inset-': 'inset'\n};\n\nconst FONT_SIZE_UTILITIES = new Set([\n  'text-xs', 'text-sm', 'text-base', 'text-lg', 'text-xl',\n  'text-2xl', 'text-3xl', 'text-4xl', 'text-5xl', 'text-6xl',\n  'text-7xl', 'text-8xl', 'text-9xl'\n]);\n\nexport function getPropertyForUtility(utility: string): string {\n  const strippedUtility = stripVariants(utility);\n  \n  if (UTILITY_TO_PROPERTY_MAP[strippedUtility]) {\n    return UTILITY_TO_PROPERTY_MAP[strippedUtility];\n  }\n  \n  if (FONT_SIZE_UTILITIES.has(strippedUtility)) {\n    return 'font-size';\n  }\n  \n  if (strippedUtility.startsWith('text-') && !FONT_SIZE_UTILITIES.has(strippedUtility)) {\n    const value = strippedUtility.slice(5);\n    if (/^\\d/.test(value) || value.startsWith('[')) {\n      return 'font-size';\n    }\n    return 'color';\n  }\n  \n  const sortedPrefixes = Object.keys(PREFIX_PROPERTY_MAP).sort((a, b) => b.length - a.length);\n  \n  for (const prefix of sortedPrefixes) {\n    if (strippedUtility.startsWith(prefix)) {\n      return PREFIX_PROPERTY_MAP[prefix];\n    }\n  }\n  \n  return 'unknown';\n}\n\nfunction stripVariants(utility: string): string {\n  const parts = utility.split(':');\n  return parts[parts.length - 1];\n}\n\nexport function isTextFontSizeUtility(utility: string): boolean {\n  const stripped = stripVariants(utility);\n  return FONT_SIZE_UTILITIES.has(stripped) || (\n    stripped.startsWith('text-') && /^\\d/.test(stripped.slice(5))\n  );\n}\n\nexport function isTextColorUtility(utility: string): boolean {\n  const stripped = stripVariants(utility);\n  \n  if (FONT_SIZE_UTILITIES.has(stripped)) {\n    return false;\n  }\n  \n  if (stripped.startsWith('text-')) {\n    const value = stripped.slice(5);\n    if (/^\\d/.test(value) || value.startsWith('[')) {\n      return false;\n    }\n    return true;\n  }\n  \n  return false;\n}\n\nexport function getPropertiesForUtilities(utilities: string[]): Map<string, string[]> {\n  const propertyMap = new Map<string, string[]>();\n  \n  for (const utility of utilities) {\n    const property = getPropertyForUtility(utility);\n    \n    if (!propertyMap.has(property)) {\n      propertyMap.set(property, []);\n    }\n    \n    propertyMap.get(property)!.push(utility);\n  }\n  \n  return propertyMap;\n}\n\nexport const PROPERTY_CONFLICT_GROUPS: Record<string, string[]> = {\n  'display': ['display'],\n  'position': ['position'],\n  'width': ['width', 'min-width', 'max-width'],\n  'height': ['height', 'min-height', 'max-height'],\n  'margin': ['margin', 'margin-top', 'margin-right', 'margin-bottom', 'margin-left', 'margin-x', 'margin-y'],\n  'padding': ['padding', 'padding-top', 'padding-right', 'padding-bottom', 'padding-left', 'padding-x', 'padding-y'],\n  'flex-direction': ['flex-direction'],\n  'flex-wrap': ['flex-wrap'],\n  'justify-content': ['justify-content'],\n  'align-items': ['align-items'],\n  'text-align': ['text-align'],\n  'font-size': ['font-size'],\n  'font-weight': ['font-weight'],\n  'color': ['color'],\n  'background-color': ['background-color'],\n  'border-radius': ['border-radius'],\n  'border-width': ['border-width', 'border-top-width', 'border-right-width', 'border-bottom-width', 'border-left-width'],\n  'overflow': ['overflow', 'overflow-x', 'overflow-y'],\n  'z-index': ['z-index'],\n  'opacity': ['opacity'],\n  'gap': ['gap'],\n  'inset': ['inset', 'top', 'right', 'bottom', 'left']\n};\n\nexport function getConflictGroup(property: string): string | null {\n  for (const [groupName, properties] of Object.entries(PROPERTY_CONFLICT_GROUPS)) {\n    if (properties.includes(property)) {\n      return groupName;\n    }\n  }\n  return null;\n}\n\nexport function propertiesConflict(prop1: string, prop2: string): boolean {\n  const group1 = getConflictGroup(prop1);\n  const group2 = getConflictGroup(prop2);\n  \n  if (group1 && group2 && group1 === group2) {\n    if (prop1 === prop2) {\n      return true;\n    }\n    \n    const group = PROPERTY_CONFLICT_GROUPS[group1];\n    \n    if (group.length === 1) {\n      return true;\n    }\n    \n    if (group1 === 'margin' || group1 === 'padding') {\n      if (prop1 === group1 || prop2 === group1) {\n        return true;\n      }\n    }\n    \n    if (group1 === 'inset') {\n      if (prop1 === 'inset' || prop2 === 'inset') {\n        return true;\n      }\n    }\n    \n    return prop1 === prop2;\n  }\n  \n  return prop1 === prop2;\n}"]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export interface Specificity {
|
|
2
|
+
inline: number;
|
|
3
|
+
id: number;
|
|
4
|
+
class: number;
|
|
5
|
+
element: number;
|
|
6
|
+
}
|
|
7
|
+
export declare const ZERO_SPECIFICITY: Specificity;
|
|
8
|
+
export declare function createSpecificity(inline?: number, id?: number, cls?: number, element?: number): Specificity;
|
|
9
|
+
export declare function addSpecificity(a: Specificity, b: Specificity): Specificity;
|
|
10
|
+
export declare function compareSpecificity(a: Specificity, b: Specificity): number;
|
|
11
|
+
export declare function specificityToString(spec: Specificity): string;
|
|
12
|
+
export declare function calculateSelectorSpecificity(selector: string): Specificity;
|
|
13
|
+
export declare function calculateDescendantSpecificity(parentType: 'class' | 'element', parentName: string, targetType: 'class' | 'element', targetName: string): Specificity;
|
|
14
|
+
export declare function calculateSelectorSpecificityFromParts(parts: {
|
|
15
|
+
hasClass: boolean;
|
|
16
|
+
hasElement: boolean;
|
|
17
|
+
hasPseudo: boolean;
|
|
18
|
+
pseudoCount?: number;
|
|
19
|
+
isDescendant?: boolean;
|
|
20
|
+
parentType?: 'class' | 'element';
|
|
21
|
+
targetType?: 'class' | 'element';
|
|
22
|
+
}): Specificity;
|
|
23
|
+
export declare function isHigherSpecificity(a: Specificity, b: Specificity): boolean;
|
|
24
|
+
export declare function isEqualSpecificity(a: Specificity, b: Specificity): boolean;
|
|
25
|
+
export declare function getHigherSpecificity(a: Specificity, b: Specificity): Specificity;
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ZERO_SPECIFICITY = void 0;
|
|
4
|
+
exports.createSpecificity = createSpecificity;
|
|
5
|
+
exports.addSpecificity = addSpecificity;
|
|
6
|
+
exports.compareSpecificity = compareSpecificity;
|
|
7
|
+
exports.specificityToString = specificityToString;
|
|
8
|
+
exports.calculateSelectorSpecificity = calculateSelectorSpecificity;
|
|
9
|
+
exports.calculateDescendantSpecificity = calculateDescendantSpecificity;
|
|
10
|
+
exports.calculateSelectorSpecificityFromParts = calculateSelectorSpecificityFromParts;
|
|
11
|
+
exports.isHigherSpecificity = isHigherSpecificity;
|
|
12
|
+
exports.isEqualSpecificity = isEqualSpecificity;
|
|
13
|
+
exports.getHigherSpecificity = getHigherSpecificity;
|
|
14
|
+
const logger_1 = require("./logger");
|
|
15
|
+
exports.ZERO_SPECIFICITY = { inline: 0, id: 0, class: 0, element: 0 };
|
|
16
|
+
function createSpecificity(inline = 0, id = 0, cls = 0, element = 0) {
|
|
17
|
+
return { inline, id, class: cls, element };
|
|
18
|
+
}
|
|
19
|
+
function addSpecificity(a, b) {
|
|
20
|
+
return {
|
|
21
|
+
inline: a.inline + b.inline,
|
|
22
|
+
id: a.id + b.id,
|
|
23
|
+
class: a.class + b.class,
|
|
24
|
+
element: a.element + b.element
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
function compareSpecificity(a, b) {
|
|
28
|
+
if (a.inline !== b.inline)
|
|
29
|
+
return a.inline - b.inline;
|
|
30
|
+
if (a.id !== b.id)
|
|
31
|
+
return a.id - b.id;
|
|
32
|
+
if (a.class !== b.class)
|
|
33
|
+
return a.class - b.class;
|
|
34
|
+
return a.element - b.element;
|
|
35
|
+
}
|
|
36
|
+
function specificityToString(spec) {
|
|
37
|
+
return `(${spec.inline}, ${spec.id}, ${spec.class}, ${spec.element})`;
|
|
38
|
+
}
|
|
39
|
+
const ID_SELECTOR_REGEX = /#[a-zA-Z_-][a-zA-Z0-9_-]*/g;
|
|
40
|
+
const CLASS_SELECTOR_REGEX = /\.[a-zA-Z_-][a-zA-Z0-9_-]*/g;
|
|
41
|
+
const PSEUDO_CLASS_REGEX = /:[a-zA-Z-]+/g;
|
|
42
|
+
const ATTRIBUTE_SELECTOR_REGEX = /\[[^\]]+\]/g;
|
|
43
|
+
const ELEMENT_REGEX = /^[a-zA-Z][a-zA-Z0-9]*/;
|
|
44
|
+
const PSEUDO_ELEMENTS = new Set(['before', 'after', 'first-line', 'first-letter', 'selection', 'marker', 'placeholder']);
|
|
45
|
+
const PSEUDO_CLASSES_WITH_ARGS = new Set(['not', 'has', 'is', 'where', 'nth-child', 'nth-of-type', 'nth-last-child', 'nth-last-of-type']);
|
|
46
|
+
function countIds(selector) {
|
|
47
|
+
const matches = selector.match(ID_SELECTOR_REGEX);
|
|
48
|
+
return matches ? matches.length : 0;
|
|
49
|
+
}
|
|
50
|
+
function countClasses(selector) {
|
|
51
|
+
const matches = selector.match(CLASS_SELECTOR_REGEX);
|
|
52
|
+
return matches ? matches.length : 0;
|
|
53
|
+
}
|
|
54
|
+
function countAttributeSelectors(selector) {
|
|
55
|
+
const matches = selector.match(ATTRIBUTE_SELECTOR_REGEX);
|
|
56
|
+
return matches ? matches.length : 0;
|
|
57
|
+
}
|
|
58
|
+
function countPseudoClasses(selector) {
|
|
59
|
+
let count = 0;
|
|
60
|
+
const pseudoMatches = selector.match(PSEUDO_CLASS_REGEX);
|
|
61
|
+
if (pseudoMatches) {
|
|
62
|
+
for (const match of pseudoMatches) {
|
|
63
|
+
const pseudoName = match.slice(1);
|
|
64
|
+
if (PSEUDO_ELEMENTS.has(pseudoName)) {
|
|
65
|
+
continue;
|
|
66
|
+
}
|
|
67
|
+
if (PSEUDO_CLASSES_WITH_ARGS.has(pseudoName)) {
|
|
68
|
+
continue;
|
|
69
|
+
}
|
|
70
|
+
count++;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return count;
|
|
74
|
+
}
|
|
75
|
+
function countElements(selector) {
|
|
76
|
+
let count = 0;
|
|
77
|
+
const cleaned = selector
|
|
78
|
+
.replace(ID_SELECTOR_REGEX, ' ')
|
|
79
|
+
.replace(CLASS_SELECTOR_REGEX, ' ')
|
|
80
|
+
.replace(PSEUDO_CLASS_REGEX, ' ')
|
|
81
|
+
.replace(ATTRIBUTE_SELECTOR_REGEX, ' ')
|
|
82
|
+
.replace(/[>+~]/g, ' ')
|
|
83
|
+
.trim();
|
|
84
|
+
const parts = cleaned.split(/\s+/).filter(Boolean);
|
|
85
|
+
for (const part of parts) {
|
|
86
|
+
if (ELEMENT_REGEX.test(part)) {
|
|
87
|
+
if (!PSEUDO_ELEMENTS.has(part) && !PSEUDO_CLASSES_WITH_ARGS.has(part)) {
|
|
88
|
+
count++;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return count;
|
|
93
|
+
}
|
|
94
|
+
function calculateSelectorSpecificity(selector) {
|
|
95
|
+
const trimmed = selector.trim();
|
|
96
|
+
if (!trimmed) {
|
|
97
|
+
return exports.ZERO_SPECIFICITY;
|
|
98
|
+
}
|
|
99
|
+
if (trimmed.startsWith('style=')) {
|
|
100
|
+
return createSpecificity(1, 0, 0, 0);
|
|
101
|
+
}
|
|
102
|
+
try {
|
|
103
|
+
const idCount = countIds(trimmed);
|
|
104
|
+
const classCount = countClasses(trimmed);
|
|
105
|
+
const attrCount = countAttributeSelectors(trimmed);
|
|
106
|
+
const pseudoClassCount = countPseudoClasses(trimmed);
|
|
107
|
+
const elementCount = countElements(trimmed);
|
|
108
|
+
return createSpecificity(0, idCount, classCount + attrCount + pseudoClassCount, elementCount);
|
|
109
|
+
}
|
|
110
|
+
catch (error) {
|
|
111
|
+
logger_1.logger.verbose(`Failed to calculate specificity for: ${selector}`);
|
|
112
|
+
return exports.ZERO_SPECIFICITY;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
function calculateDescendantSpecificity(parentType, parentName, targetType, targetName) {
|
|
116
|
+
const parentSpec = parentType === 'class'
|
|
117
|
+
? createSpecificity(0, 0, 1, 0)
|
|
118
|
+
: createSpecificity(0, 0, 0, 1);
|
|
119
|
+
const targetSpec = targetType === 'class'
|
|
120
|
+
? createSpecificity(0, 0, 1, 0)
|
|
121
|
+
: createSpecificity(0, 0, 0, 1);
|
|
122
|
+
return addSpecificity(parentSpec, targetSpec);
|
|
123
|
+
}
|
|
124
|
+
function calculateSelectorSpecificityFromParts(parts) {
|
|
125
|
+
let spec = exports.ZERO_SPECIFICITY;
|
|
126
|
+
if (parts.hasClass) {
|
|
127
|
+
spec = addSpecificity(spec, createSpecificity(0, 0, 1, 0));
|
|
128
|
+
}
|
|
129
|
+
if (parts.hasElement) {
|
|
130
|
+
spec = addSpecificity(spec, createSpecificity(0, 0, 0, 1));
|
|
131
|
+
}
|
|
132
|
+
if (parts.hasPseudo) {
|
|
133
|
+
const pseudoCount = parts.pseudoCount || 1;
|
|
134
|
+
spec = addSpecificity(spec, createSpecificity(0, 0, pseudoCount, 0));
|
|
135
|
+
}
|
|
136
|
+
if (parts.isDescendant && parts.parentType && parts.targetType) {
|
|
137
|
+
spec = calculateDescendantSpecificity(parts.parentType, '', parts.targetType, '');
|
|
138
|
+
}
|
|
139
|
+
return spec;
|
|
140
|
+
}
|
|
141
|
+
function isHigherSpecificity(a, b) {
|
|
142
|
+
return compareSpecificity(a, b) > 0;
|
|
143
|
+
}
|
|
144
|
+
function isEqualSpecificity(a, b) {
|
|
145
|
+
return compareSpecificity(a, b) === 0;
|
|
146
|
+
}
|
|
147
|
+
function getHigherSpecificity(a, b) {
|
|
148
|
+
return compareSpecificity(a, b) >= 0 ? a : b;
|
|
149
|
+
}
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"specificityCalculator.js","sourceRoot":"","sources":["../../src/utils/specificityCalculator.ts"],"names":[],"mappings":";;;AAWA,8CAEC;AAED,wCAOC;AAED,gDAKC;AAED,kDAEC;AAyED,oEA4BC;AAED,wEAeC;AAED,sFA6BC;AAED,kDAEC;AAED,gDAEC;AAED,oDAEC;AAlMD,qCAAkC;AASrB,QAAA,gBAAgB,GAAgB,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;AAExF,SAAgB,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,OAAO,GAAG,CAAC;IACxE,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC;AAC7C,CAAC;AAED,SAAgB,cAAc,CAAC,CAAc,EAAE,CAAc;IAC3D,OAAO;QACL,MAAM,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM;QAC3B,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE;QACf,KAAK,EAAE,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK;QACxB,OAAO,EAAE,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,OAAO;KAC/B,CAAC;AACJ,CAAC;AAED,SAAgB,kBAAkB,CAAC,CAAc,EAAE,CAAc;IAC/D,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM;QAAE,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC;IACtD,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE;QAAE,OAAO,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC;IACtC,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,KAAK;QAAE,OAAO,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;IAClD,OAAO,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,OAAO,CAAC;AAC/B,CAAC;AAED,SAAgB,mBAAmB,CAAC,IAAiB;IACnD,OAAO,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,OAAO,GAAG,CAAC;AACxE,CAAC;AAED,MAAM,iBAAiB,GAAG,4BAA4B,CAAC;AACvD,MAAM,oBAAoB,GAAG,6BAA6B,CAAC;AAC3D,MAAM,kBAAkB,GAAG,cAAc,CAAC;AAC1C,MAAM,wBAAwB,GAAG,aAAa,CAAC;AAC/C,MAAM,aAAa,GAAG,uBAAuB,CAAC;AAE9C,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,WAAW,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC;AACzH,MAAM,wBAAwB,GAAG,IAAI,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,gBAAgB,EAAE,kBAAkB,CAAC,CAAC,CAAC;AAE1I,SAAS,QAAQ,CAAC,QAAgB;IAChC,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;IAClD,OAAO,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AACtC,CAAC;AAED,SAAS,YAAY,CAAC,QAAgB;IACpC,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;IACrD,OAAO,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AACtC,CAAC;AAED,SAAS,uBAAuB,CAAC,QAAgB;IAC/C,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC;IACzD,OAAO,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AACtC,CAAC;AAED,SAAS,kBAAkB,CAAC,QAAgB;IAC1C,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,MAAM,aAAa,GAAG,QAAQ,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;IAEzD,IAAI,aAAa,EAAE,CAAC;QAClB,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE,CAAC;YAClC,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAElC,IAAI,eAAe,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC;gBACpC,SAAS;YACX,CAAC;YAED,IAAI,wBAAwB,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC7C,SAAS;YACX,CAAC;YAED,KAAK,EAAE,CAAC;QACV,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,aAAa,CAAC,QAAgB;IACrC,IAAI,KAAK,GAAG,CAAC,CAAC;IAEd,MAAM,OAAO,GAAG,QAAQ;SACrB,OAAO,CAAC,iBAAiB,EAAE,GAAG,CAAC;SAC/B,OAAO,CAAC,oBAAoB,EAAE,GAAG,CAAC;SAClC,OAAO,CAAC,kBAAkB,EAAE,GAAG,CAAC;SAChC,OAAO,CAAC,wBAAwB,EAAE,GAAG,CAAC;SACtC,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC;SACtB,IAAI,EAAE,CAAC;IAEV,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAEnD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YAC7B,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;gBACtE,KAAK,EAAE,CAAC;YACV,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAgB,4BAA4B,CAAC,QAAgB;IAC3D,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,EAAE,CAAC;IAEhC,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,wBAAgB,CAAC;IAC1B,CAAC;IAED,IAAI,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QACjC,OAAO,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IACvC,CAAC;IAED,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC;QAClC,MAAM,UAAU,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC;QACzC,MAAM,SAAS,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;QACnD,MAAM,gBAAgB,GAAG,kBAAkB,CAAC,OAAO,CAAC,CAAC;QACrD,MAAM,YAAY,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC;QAE5C,OAAO,iBAAiB,CACtB,CAAC,EACD,OAAO,EACP,UAAU,GAAG,SAAS,GAAG,gBAAgB,EACzC,YAAY,CACb,CAAC;IACJ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,eAAM,CAAC,OAAO,CAAC,wCAAwC,QAAQ,EAAE,CAAC,CAAC;QACnE,OAAO,wBAAgB,CAAC;IAC1B,CAAC;AACH,CAAC;AAED,SAAgB,8BAA8B,CAC5C,UAA+B,EAC/B,UAAkB,EAClB,UAA+B,EAC/B,UAAkB;IAElB,MAAM,UAAU,GAAG,UAAU,KAAK,OAAO;QACvC,CAAC,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QAC/B,CAAC,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAElC,MAAM,UAAU,GAAG,UAAU,KAAK,OAAO;QACvC,CAAC,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QAC/B,CAAC,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAElC,OAAO,cAAc,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;AAChD,CAAC;AAED,SAAgB,qCAAqC,CAAC,KAQrD;IACC,IAAI,IAAI,GAAG,wBAAgB,CAAC;IAE5B,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;QACnB,IAAI,GAAG,cAAc,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC;IAED,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;QACrB,IAAI,GAAG,cAAc,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC;IAED,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;QACpB,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,IAAI,CAAC,CAAC;QAC3C,IAAI,GAAG,cAAc,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,IAAI,KAAK,CAAC,YAAY,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;QAC/D,IAAI,GAAG,8BAA8B,CAAC,KAAK,CAAC,UAAU,EAAE,EAAE,EAAE,KAAK,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IACpF,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAgB,mBAAmB,CAAC,CAAc,EAAE,CAAc;IAChE,OAAO,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACtC,CAAC;AAED,SAAgB,kBAAkB,CAAC,CAAc,EAAE,CAAc;IAC/D,OAAO,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;AACxC,CAAC;AAED,SAAgB,oBAAoB,CAAC,CAAc,EAAE,CAAc;IACjE,OAAO,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC/C,CAAC","sourcesContent":["import { logger } from './logger';\n\nexport interface Specificity {\n  inline: number;\n  id: number;\n  class: number;\n  element: number;\n}\n\nexport const ZERO_SPECIFICITY: Specificity = { inline: 0, id: 0, class: 0, element: 0 };\n\nexport function createSpecificity(inline = 0, id = 0, cls = 0, element = 0): Specificity {\n  return { inline, id, class: cls, element };\n}\n\nexport function addSpecificity(a: Specificity, b: Specificity): Specificity {\n  return {\n    inline: a.inline + b.inline,\n    id: a.id + b.id,\n    class: a.class + b.class,\n    element: a.element + b.element\n  };\n}\n\nexport function compareSpecificity(a: Specificity, b: Specificity): number {\n  if (a.inline !== b.inline) return a.inline - b.inline;\n  if (a.id !== b.id) return a.id - b.id;\n  if (a.class !== b.class) return a.class - b.class;\n  return a.element - b.element;\n}\n\nexport function specificityToString(spec: Specificity): string {\n  return `(${spec.inline}, ${spec.id}, ${spec.class}, ${spec.element})`;\n}\n\nconst ID_SELECTOR_REGEX = /#[a-zA-Z_-][a-zA-Z0-9_-]*/g;\nconst CLASS_SELECTOR_REGEX = /\\.[a-zA-Z_-][a-zA-Z0-9_-]*/g;\nconst PSEUDO_CLASS_REGEX = /:[a-zA-Z-]+/g;\nconst ATTRIBUTE_SELECTOR_REGEX = /\\[[^\\]]+\\]/g;\nconst ELEMENT_REGEX = /^[a-zA-Z][a-zA-Z0-9]*/;\n\nconst PSEUDO_ELEMENTS = new Set(['before', 'after', 'first-line', 'first-letter', 'selection', 'marker', 'placeholder']);\nconst PSEUDO_CLASSES_WITH_ARGS = new Set(['not', 'has', 'is', 'where', 'nth-child', 'nth-of-type', 'nth-last-child', 'nth-last-of-type']);\n\nfunction countIds(selector: string): number {\n  const matches = selector.match(ID_SELECTOR_REGEX);\n  return matches ? matches.length : 0;\n}\n\nfunction countClasses(selector: string): number {\n  const matches = selector.match(CLASS_SELECTOR_REGEX);\n  return matches ? matches.length : 0;\n}\n\nfunction countAttributeSelectors(selector: string): number {\n  const matches = selector.match(ATTRIBUTE_SELECTOR_REGEX);\n  return matches ? matches.length : 0;\n}\n\nfunction countPseudoClasses(selector: string): number {\n  let count = 0;\n  const pseudoMatches = selector.match(PSEUDO_CLASS_REGEX);\n  \n  if (pseudoMatches) {\n    for (const match of pseudoMatches) {\n      const pseudoName = match.slice(1);\n      \n      if (PSEUDO_ELEMENTS.has(pseudoName)) {\n        continue;\n      }\n      \n      if (PSEUDO_CLASSES_WITH_ARGS.has(pseudoName)) {\n        continue;\n      }\n      \n      count++;\n    }\n  }\n  \n  return count;\n}\n\nfunction countElements(selector: string): number {\n  let count = 0;\n  \n  const cleaned = selector\n    .replace(ID_SELECTOR_REGEX, ' ')\n    .replace(CLASS_SELECTOR_REGEX, ' ')\n    .replace(PSEUDO_CLASS_REGEX, ' ')\n    .replace(ATTRIBUTE_SELECTOR_REGEX, ' ')\n    .replace(/[>+~]/g, ' ')\n    .trim();\n  \n  const parts = cleaned.split(/\\s+/).filter(Boolean);\n  \n  for (const part of parts) {\n    if (ELEMENT_REGEX.test(part)) {\n      if (!PSEUDO_ELEMENTS.has(part) && !PSEUDO_CLASSES_WITH_ARGS.has(part)) {\n        count++;\n      }\n    }\n  }\n  \n  return count;\n}\n\nexport function calculateSelectorSpecificity(selector: string): Specificity {\n  const trimmed = selector.trim();\n  \n  if (!trimmed) {\n    return ZERO_SPECIFICITY;\n  }\n  \n  if (trimmed.startsWith('style=')) {\n    return createSpecificity(1, 0, 0, 0);\n  }\n  \n  try {\n    const idCount = countIds(trimmed);\n    const classCount = countClasses(trimmed);\n    const attrCount = countAttributeSelectors(trimmed);\n    const pseudoClassCount = countPseudoClasses(trimmed);\n    const elementCount = countElements(trimmed);\n    \n    return createSpecificity(\n      0,\n      idCount,\n      classCount + attrCount + pseudoClassCount,\n      elementCount\n    );\n  } catch (error) {\n    logger.verbose(`Failed to calculate specificity for: ${selector}`);\n    return ZERO_SPECIFICITY;\n  }\n}\n\nexport function calculateDescendantSpecificity(\n  parentType: 'class' | 'element',\n  parentName: string,\n  targetType: 'class' | 'element',\n  targetName: string\n): Specificity {\n  const parentSpec = parentType === 'class'\n    ? createSpecificity(0, 0, 1, 0)\n    : createSpecificity(0, 0, 0, 1);\n  \n  const targetSpec = targetType === 'class'\n    ? createSpecificity(0, 0, 1, 0)\n    : createSpecificity(0, 0, 0, 1);\n  \n  return addSpecificity(parentSpec, targetSpec);\n}\n\nexport function calculateSelectorSpecificityFromParts(parts: {\n  hasClass: boolean;\n  hasElement: boolean;\n  hasPseudo: boolean;\n  pseudoCount?: number;\n  isDescendant?: boolean;\n  parentType?: 'class' | 'element';\n  targetType?: 'class' | 'element';\n}): Specificity {\n  let spec = ZERO_SPECIFICITY;\n  \n  if (parts.hasClass) {\n    spec = addSpecificity(spec, createSpecificity(0, 0, 1, 0));\n  }\n  \n  if (parts.hasElement) {\n    spec = addSpecificity(spec, createSpecificity(0, 0, 0, 1));\n  }\n  \n  if (parts.hasPseudo) {\n    const pseudoCount = parts.pseudoCount || 1;\n    spec = addSpecificity(spec, createSpecificity(0, 0, pseudoCount, 0));\n  }\n  \n  if (parts.isDescendant && parts.parentType && parts.targetType) {\n    spec = calculateDescendantSpecificity(parts.parentType, '', parts.targetType, '');\n  }\n  \n  return spec;\n}\n\nexport function isHigherSpecificity(a: Specificity, b: Specificity): boolean {\n  return compareSpecificity(a, b) > 0;\n}\n\nexport function isEqualSpecificity(a: Specificity, b: Specificity): boolean {\n  return compareSpecificity(a, b) === 0;\n}\n\nexport function getHigherSpecificity(a: Specificity, b: Specificity): Specificity {\n  return compareSpecificity(a, b) >= 0 ? a : b;\n}"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "css-to-tailwind-react",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.2",
|
|
4
4
|
"description": "Convert traditional CSS (inline, internal, and external) into Tailwind CSS utility classes for React-based frameworks",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"module": "dist/index.mjs",
|