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,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":"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","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.1
|
|
3
|
+
"version": "0.2.1",
|
|
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",
|