css-to-tailwind-react 0.1.2 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cssParser.d.ts +16 -1
- package/dist/cssParser.js +161 -33
- package/dist/index.d.ts +3 -1
- package/dist/index.js +11 -2
- package/dist/jsxDescendantTransformer.d.ts +16 -0
- package/dist/jsxDescendantTransformer.js +335 -0
- package/dist/transformer.js +59 -21
- package/dist/utils/conflictResolver.d.ts +39 -0
- package/dist/utils/conflictResolver.js +140 -0
- package/dist/utils/descendantSelectorResolver.d.ts +20 -0
- package/dist/utils/descendantSelectorResolver.js +186 -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,186 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isHtmlElement = isHtmlElement;
|
|
4
|
+
exports.parseDescendantSelector = parseDescendantSelector;
|
|
5
|
+
exports.isDescendantSelector = isDescendantSelector;
|
|
6
|
+
exports.isSimpleSelector = isSimpleSelector;
|
|
7
|
+
exports.processDescendantSelector = processDescendantSelector;
|
|
8
|
+
const logger_1 = require("./logger");
|
|
9
|
+
const HTML_ELEMENTS = new Set([
|
|
10
|
+
'a', 'abbr', 'address', 'article', 'aside', 'audio',
|
|
11
|
+
'b', 'blockquote', 'body', 'br', 'button',
|
|
12
|
+
'canvas', 'caption', 'cite', 'code', 'col', 'colgroup',
|
|
13
|
+
'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt',
|
|
14
|
+
'em', 'embed',
|
|
15
|
+
'fieldset', 'figcaption', 'figure', 'footer', 'form',
|
|
16
|
+
'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html',
|
|
17
|
+
'i', 'iframe', 'img', 'input', 'ins',
|
|
18
|
+
'kbd',
|
|
19
|
+
'label', 'legend', 'li', 'link',
|
|
20
|
+
'main', 'map', 'mark', 'menu', 'meta', 'meter',
|
|
21
|
+
'nav', 'noscript',
|
|
22
|
+
'object', 'ol', 'optgroup', 'option', 'output',
|
|
23
|
+
'p', 'param', 'picture', 'pre', 'progress',
|
|
24
|
+
'q',
|
|
25
|
+
'rp', 'rt', 'ruby',
|
|
26
|
+
's', 'samp', 'script', 'search', 'section', 'select', 'slot', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'svg',
|
|
27
|
+
'table', 'tbody', 'td', 'template', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track',
|
|
28
|
+
'u', 'ul',
|
|
29
|
+
'var', 'video',
|
|
30
|
+
'wbr'
|
|
31
|
+
]);
|
|
32
|
+
function isHtmlElement(name) {
|
|
33
|
+
return HTML_ELEMENTS.has(name.toLowerCase());
|
|
34
|
+
}
|
|
35
|
+
function parseSelectorPart(part) {
|
|
36
|
+
const trimmed = part.trim();
|
|
37
|
+
if (!trimmed)
|
|
38
|
+
return null;
|
|
39
|
+
if (trimmed.startsWith('.')) {
|
|
40
|
+
const className = trimmed.slice(1);
|
|
41
|
+
if (!className || !/^[a-zA-Z_-][a-zA-Z0-9_-]*$/.test(className)) {
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
return { type: 'class', name: className };
|
|
45
|
+
}
|
|
46
|
+
if (/^[a-zA-Z][a-zA-Z0-9]*$/.test(trimmed)) {
|
|
47
|
+
return { type: 'element', name: trimmed.toLowerCase() };
|
|
48
|
+
}
|
|
49
|
+
return null;
|
|
50
|
+
}
|
|
51
|
+
function parseDescendantSelector(selector) {
|
|
52
|
+
const trimmed = selector.trim();
|
|
53
|
+
if (trimmed.includes(',')) {
|
|
54
|
+
return {
|
|
55
|
+
parent: undefined,
|
|
56
|
+
target: { type: 'element', name: '' },
|
|
57
|
+
isComplex: true,
|
|
58
|
+
reason: `Skipped comma-separated selector (${selector})`
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
if (trimmed.includes('>')) {
|
|
62
|
+
return {
|
|
63
|
+
parent: undefined,
|
|
64
|
+
target: { type: 'element', name: '' },
|
|
65
|
+
isComplex: true,
|
|
66
|
+
reason: `Skipped child combinator selector (${selector})`
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
if (trimmed.includes('+')) {
|
|
70
|
+
return {
|
|
71
|
+
parent: undefined,
|
|
72
|
+
target: { type: 'element', name: '' },
|
|
73
|
+
isComplex: true,
|
|
74
|
+
reason: `Skipped adjacent sibling selector (${selector})`
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
if (trimmed.includes('~')) {
|
|
78
|
+
return {
|
|
79
|
+
parent: undefined,
|
|
80
|
+
target: { type: 'element', name: '' },
|
|
81
|
+
isComplex: true,
|
|
82
|
+
reason: `Skipped general sibling selector (${selector})`
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
if (trimmed.includes(':not') || trimmed.includes(':has') || trimmed.includes(':is') || trimmed.includes(':where')) {
|
|
86
|
+
return {
|
|
87
|
+
parent: undefined,
|
|
88
|
+
target: { type: 'element', name: '' },
|
|
89
|
+
isComplex: true,
|
|
90
|
+
reason: `Skipped pseudo-class with argument (${selector})`
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
if (trimmed.includes('[') && trimmed.includes(']')) {
|
|
94
|
+
return {
|
|
95
|
+
parent: undefined,
|
|
96
|
+
target: { type: 'element', name: '' },
|
|
97
|
+
isComplex: true,
|
|
98
|
+
reason: `Skipped attribute selector (${selector})`
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
if (trimmed.includes(':')) {
|
|
102
|
+
const colonCount = (trimmed.match(/:/g) || []).length;
|
|
103
|
+
if (colonCount > 2 || trimmed.includes('::before') || trimmed.includes('::after')) {
|
|
104
|
+
return {
|
|
105
|
+
parent: undefined,
|
|
106
|
+
target: { type: 'element', name: '' },
|
|
107
|
+
isComplex: true,
|
|
108
|
+
reason: `Skipped selector with pseudo (${selector})`
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
const parts = trimmed.split(/\s+/).filter(Boolean);
|
|
113
|
+
if (parts.length === 1) {
|
|
114
|
+
const part = parseSelectorPart(parts[0]);
|
|
115
|
+
if (!part) {
|
|
116
|
+
return {
|
|
117
|
+
parent: undefined,
|
|
118
|
+
target: { type: 'element', name: '' },
|
|
119
|
+
isComplex: true,
|
|
120
|
+
reason: `Invalid selector part (${parts[0]})`
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
return {
|
|
124
|
+
parent: undefined,
|
|
125
|
+
target: part,
|
|
126
|
+
isComplex: false
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
if (parts.length === 2) {
|
|
130
|
+
const parentPart = parseSelectorPart(parts[0]);
|
|
131
|
+
const targetPart = parseSelectorPart(parts[1]);
|
|
132
|
+
if (!parentPart || !targetPart) {
|
|
133
|
+
return {
|
|
134
|
+
parent: undefined,
|
|
135
|
+
target: { type: 'element', name: '' },
|
|
136
|
+
isComplex: true,
|
|
137
|
+
reason: `Invalid selector part in (${selector})`
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
return {
|
|
141
|
+
parent: parentPart,
|
|
142
|
+
target: targetPart,
|
|
143
|
+
isComplex: false
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
if (parts.length > 2) {
|
|
147
|
+
return {
|
|
148
|
+
parent: undefined,
|
|
149
|
+
target: { type: 'element', name: '' },
|
|
150
|
+
isComplex: true,
|
|
151
|
+
reason: `Skipped multi-level descendant selector (${selector})`
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
return {
|
|
155
|
+
parent: undefined,
|
|
156
|
+
target: { type: 'element', name: '' },
|
|
157
|
+
isComplex: true,
|
|
158
|
+
reason: `Unable to parse selector (${selector})`
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
function isDescendantSelector(selector) {
|
|
162
|
+
const parsed = parseDescendantSelector(selector);
|
|
163
|
+
return !parsed.isComplex && parsed.parent !== undefined;
|
|
164
|
+
}
|
|
165
|
+
function isSimpleSelector(selector) {
|
|
166
|
+
const parsed = parseDescendantSelector(selector);
|
|
167
|
+
return !parsed.isComplex && parsed.parent === undefined;
|
|
168
|
+
}
|
|
169
|
+
function processDescendantSelector(selector) {
|
|
170
|
+
const parsed = parseDescendantSelector(selector);
|
|
171
|
+
if (parsed.isComplex) {
|
|
172
|
+
logger_1.logger.verbose(parsed.reason || `Skipped complex selector: ${selector}`);
|
|
173
|
+
return { parsed: null, skipped: true, reason: parsed.reason };
|
|
174
|
+
}
|
|
175
|
+
if (parsed.parent) {
|
|
176
|
+
const parentDesc = parsed.parent.type === 'class'
|
|
177
|
+
? `.${parsed.parent.name}`
|
|
178
|
+
: parsed.parent.name;
|
|
179
|
+
const targetDesc = parsed.target.type === 'class'
|
|
180
|
+
? `.${parsed.target.name}`
|
|
181
|
+
: parsed.target.name;
|
|
182
|
+
logger_1.logger.verbose(`Parsed descendant selector: ${parentDesc} ${targetDesc}`);
|
|
183
|
+
}
|
|
184
|
+
return { parsed, skipped: false };
|
|
185
|
+
}
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"descendantSelectorResolver.js","sourceRoot":"","sources":["../../src/utils/descendantSelectorResolver.ts"],"names":[],"mappings":"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","sourcesContent":["import { logger } from './logger';\n\nexport type SelectorType = 'class' | 'element';\n\nexport interface SelectorPart {\n  type: SelectorType;\n  name: string;\n}\n\nexport interface DescendantSelector {\n  parent?: SelectorPart;\n  target: SelectorPart;\n  isComplex: boolean;\n  reason?: string;\n}\n\nconst HTML_ELEMENTS = new Set([\n  'a', 'abbr', 'address', 'article', 'aside', 'audio',\n  'b', 'blockquote', 'body', 'br', 'button',\n  'canvas', 'caption', 'cite', 'code', 'col', 'colgroup',\n  'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt',\n  'em', 'embed',\n  'fieldset', 'figcaption', 'figure', 'footer', 'form',\n  'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html',\n  'i', 'iframe', 'img', 'input', 'ins',\n  'kbd',\n  'label', 'legend', 'li', 'link',\n  'main', 'map', 'mark', 'menu', 'meta', 'meter',\n  'nav', 'noscript',\n  'object', 'ol', 'optgroup', 'option', 'output',\n  'p', 'param', 'picture', 'pre', 'progress',\n  'q',\n  'rp', 'rt', 'ruby',\n  's', 'samp', 'script', 'search', 'section', 'select', 'slot', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'svg',\n  'table', 'tbody', 'td', 'template', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track',\n  'u', 'ul',\n  'var', 'video',\n  'wbr'\n]);\n\nexport function isHtmlElement(name: string): boolean {\n  return HTML_ELEMENTS.has(name.toLowerCase());\n}\n\nfunction parseSelectorPart(part: string): SelectorPart | null {\n  const trimmed = part.trim();\n  if (!trimmed) return null;\n  \n  if (trimmed.startsWith('.')) {\n    const className = trimmed.slice(1);\n    if (!className || !/^[a-zA-Z_-][a-zA-Z0-9_-]*$/.test(className)) {\n      return null;\n    }\n    return { type: 'class', name: className };\n  }\n  \n  if (/^[a-zA-Z][a-zA-Z0-9]*$/.test(trimmed)) {\n    return { type: 'element', name: trimmed.toLowerCase() };\n  }\n  \n  return null;\n}\n\nexport function parseDescendantSelector(selector: string): DescendantSelector {\n  const trimmed = selector.trim();\n  \n  if (trimmed.includes(',')) {\n    return {\n      parent: undefined,\n      target: { type: 'element', name: '' },\n      isComplex: true,\n      reason: `Skipped comma-separated selector (${selector})`\n    };\n  }\n  \n  if (trimmed.includes('>')) {\n    return {\n      parent: undefined,\n      target: { type: 'element', name: '' },\n      isComplex: true,\n      reason: `Skipped child combinator selector (${selector})`\n    };\n  }\n  \n  if (trimmed.includes('+')) {\n    return {\n      parent: undefined,\n      target: { type: 'element', name: '' },\n      isComplex: true,\n      reason: `Skipped adjacent sibling selector (${selector})`\n    };\n  }\n  \n  if (trimmed.includes('~')) {\n    return {\n      parent: undefined,\n      target: { type: 'element', name: '' },\n      isComplex: true,\n      reason: `Skipped general sibling selector (${selector})`\n    };\n  }\n  \n  if (trimmed.includes(':not') || trimmed.includes(':has') || trimmed.includes(':is') || trimmed.includes(':where')) {\n    return {\n      parent: undefined,\n      target: { type: 'element', name: '' },\n      isComplex: true,\n      reason: `Skipped pseudo-class with argument (${selector})`\n    };\n  }\n  \n  if (trimmed.includes('[') && trimmed.includes(']')) {\n    return {\n      parent: undefined,\n      target: { type: 'element', name: '' },\n      isComplex: true,\n      reason: `Skipped attribute selector (${selector})`\n    };\n  }\n  \n  if (trimmed.includes(':')) {\n    const colonCount = (trimmed.match(/:/g) || []).length;\n    if (colonCount > 2 || trimmed.includes('::before') || trimmed.includes('::after')) {\n      return {\n        parent: undefined,\n        target: { type: 'element', name: '' },\n        isComplex: true,\n        reason: `Skipped selector with pseudo (${selector})`\n      };\n    }\n  }\n  \n  const parts = trimmed.split(/\\s+/).filter(Boolean);\n  \n  if (parts.length === 1) {\n    const part = parseSelectorPart(parts[0]);\n    if (!part) {\n      return {\n        parent: undefined,\n        target: { type: 'element', name: '' },\n        isComplex: true,\n        reason: `Invalid selector part (${parts[0]})`\n      };\n    }\n    \n    return {\n      parent: undefined,\n      target: part,\n      isComplex: false\n    };\n  }\n  \n  if (parts.length === 2) {\n    const parentPart = parseSelectorPart(parts[0]);\n    const targetPart = parseSelectorPart(parts[1]);\n    \n    if (!parentPart || !targetPart) {\n      return {\n        parent: undefined,\n        target: { type: 'element', name: '' },\n        isComplex: true,\n        reason: `Invalid selector part in (${selector})`\n      };\n    }\n    \n    return {\n      parent: parentPart,\n      target: targetPart,\n      isComplex: false\n    };\n  }\n  \n  if (parts.length > 2) {\n    return {\n      parent: undefined,\n      target: { type: 'element', name: '' },\n      isComplex: true,\n      reason: `Skipped multi-level descendant selector (${selector})`\n    };\n  }\n  \n  return {\n    parent: undefined,\n    target: { type: 'element', name: '' },\n    isComplex: true,\n    reason: `Unable to parse selector (${selector})`\n  };\n}\n\nexport function isDescendantSelector(selector: string): boolean {\n  const parsed = parseDescendantSelector(selector);\n  return !parsed.isComplex && parsed.parent !== undefined;\n}\n\nexport function isSimpleSelector(selector: string): boolean {\n  const parsed = parseDescendantSelector(selector);\n  return !parsed.isComplex && parsed.parent === undefined;\n}\n\nexport function processDescendantSelector(selector: string): {\n  parsed: DescendantSelector | null;\n  skipped: boolean;\n  reason?: string;\n} {\n  const parsed = parseDescendantSelector(selector);\n  \n  if (parsed.isComplex) {\n    logger.verbose(parsed.reason || `Skipped complex selector: ${selector}`);\n    return { parsed: null, skipped: true, reason: parsed.reason };\n  }\n  \n  if (parsed.parent) {\n    const parentDesc = parsed.parent.type === 'class' \n      ? `.${parsed.parent.name}` \n      : parsed.parent.name;\n    const targetDesc = parsed.target.type === 'class' \n      ? `.${parsed.target.name}` \n      : parsed.target.name;\n    logger.verbose(`Parsed descendant selector: ${parentDesc} ${targetDesc}`);\n  }\n  \n  return { parsed, skipped: false };\n}"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export declare function getPropertyForUtility(utility: string): string;
|
|
2
|
+
export declare function isTextFontSizeUtility(utility: string): boolean;
|
|
3
|
+
export declare function isTextColorUtility(utility: string): boolean;
|
|
4
|
+
export declare function getPropertiesForUtilities(utilities: string[]): Map<string, string[]>;
|
|
5
|
+
export declare const PROPERTY_CONFLICT_GROUPS: Record<string, string[]>;
|
|
6
|
+
export declare function getConflictGroup(property: string): string | null;
|
|
7
|
+
export declare function propertiesConflict(prop1: string, prop2: string): boolean;
|
|
@@ -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;
|