tailwindcss 3.4.1 → 4.0.0-alpha.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/README.md +5 -6
- package/dist/lib.d.mts +324 -0
- package/dist/lib.d.ts +324 -0
- package/dist/lib.js +11 -0
- package/dist/lib.mjs +11 -0
- package/index.css +5 -0
- package/package.json +29 -107
- package/preflight.css +355 -0
- package/theme.css +465 -0
- package/CHANGELOG.md +0 -2571
- package/base.css +0 -1
- package/colors.d.ts +0 -3
- package/colors.js +0 -2
- package/components.css +0 -1
- package/defaultConfig.d.ts +0 -3
- package/defaultConfig.js +0 -2
- package/defaultTheme.d.ts +0 -4
- package/defaultTheme.js +0 -2
- package/lib/cli/build/deps.js +0 -62
- package/lib/cli/build/index.js +0 -54
- package/lib/cli/build/plugin.js +0 -378
- package/lib/cli/build/utils.js +0 -88
- package/lib/cli/build/watching.js +0 -182
- package/lib/cli/help/index.js +0 -73
- package/lib/cli/index.js +0 -230
- package/lib/cli/init/index.js +0 -63
- package/lib/cli-peer-dependencies.js +0 -36
- package/lib/cli.js +0 -7
- package/lib/corePluginList.js +0 -190
- package/lib/corePlugins.js +0 -4282
- package/lib/css/LICENSE +0 -25
- package/lib/css/preflight.css +0 -385
- package/lib/featureFlags.js +0 -83
- package/lib/index.js +0 -2
- package/lib/lib/cacheInvalidation.js +0 -92
- package/lib/lib/collapseAdjacentRules.js +0 -61
- package/lib/lib/collapseDuplicateDeclarations.js +0 -85
- package/lib/lib/content.js +0 -181
- package/lib/lib/defaultExtractor.js +0 -251
- package/lib/lib/detectNesting.js +0 -45
- package/lib/lib/evaluateTailwindFunctions.js +0 -238
- package/lib/lib/expandApplyAtRules.js +0 -540
- package/lib/lib/expandTailwindAtRules.js +0 -291
- package/lib/lib/findAtConfigPath.js +0 -46
- package/lib/lib/generateRules.js +0 -904
- package/lib/lib/getModuleDependencies.js +0 -99
- package/lib/lib/load-config.js +0 -53
- package/lib/lib/normalizeTailwindDirectives.js +0 -89
- package/lib/lib/offsets.js +0 -306
- package/lib/lib/partitionApplyAtRules.js +0 -58
- package/lib/lib/regex.js +0 -74
- package/lib/lib/remap-bitfield.js +0 -89
- package/lib/lib/resolveDefaultsAtRules.js +0 -165
- package/lib/lib/setupContextUtils.js +0 -1294
- package/lib/lib/setupTrackingContext.js +0 -166
- package/lib/lib/sharedState.js +0 -87
- package/lib/lib/substituteScreenAtRules.js +0 -31
- package/lib/oxide/cli/build/deps.js +0 -89
- package/lib/oxide/cli/build/index.js +0 -53
- package/lib/oxide/cli/build/plugin.js +0 -375
- package/lib/oxide/cli/build/utils.js +0 -87
- package/lib/oxide/cli/build/watching.js +0 -179
- package/lib/oxide/cli/help/index.js +0 -72
- package/lib/oxide/cli/index.js +0 -214
- package/lib/oxide/cli/init/index.js +0 -52
- package/lib/oxide/cli.js +0 -5
- package/lib/oxide/postcss-plugin.js +0 -2
- package/lib/plugin.js +0 -98
- package/lib/postcss-plugins/nesting/README.md +0 -42
- package/lib/postcss-plugins/nesting/index.js +0 -21
- package/lib/postcss-plugins/nesting/plugin.js +0 -89
- package/lib/processTailwindFeatures.js +0 -64
- package/lib/public/colors.js +0 -355
- package/lib/public/create-plugin.js +0 -17
- package/lib/public/default-config.js +0 -18
- package/lib/public/default-theme.js +0 -18
- package/lib/public/load-config.js +0 -12
- package/lib/public/resolve-config.js +0 -24
- package/lib/util/applyImportantSelector.js +0 -36
- package/lib/util/bigSign.js +0 -13
- package/lib/util/buildMediaQuery.js +0 -27
- package/lib/util/cloneDeep.js +0 -22
- package/lib/util/cloneNodes.js +0 -54
- package/lib/util/color.js +0 -116
- package/lib/util/colorNames.js +0 -752
- package/lib/util/configurePlugins.js +0 -23
- package/lib/util/createPlugin.js +0 -32
- package/lib/util/createUtilityPlugin.js +0 -53
- package/lib/util/dataTypes.js +0 -415
- package/lib/util/defaults.js +0 -27
- package/lib/util/escapeClassName.js +0 -24
- package/lib/util/escapeCommas.js +0 -13
- package/lib/util/flattenColorPalette.js +0 -18
- package/lib/util/formatVariantSelector.js +0 -270
- package/lib/util/getAllConfigs.js +0 -50
- package/lib/util/hashConfig.js +0 -21
- package/lib/util/isKeyframeRule.js +0 -13
- package/lib/util/isPlainObject.js +0 -17
- package/lib/util/isSyntacticallyValidPropertyValue.js +0 -74
- package/lib/util/log.js +0 -61
- package/lib/util/nameClass.js +0 -49
- package/lib/util/negateValue.js +0 -36
- package/lib/util/normalizeConfig.js +0 -282
- package/lib/util/normalizeScreens.js +0 -178
- package/lib/util/parseAnimationValue.js +0 -93
- package/lib/util/parseBoxShadowValue.js +0 -88
- package/lib/util/parseDependency.js +0 -47
- package/lib/util/parseGlob.js +0 -36
- package/lib/util/parseObjectStyles.js +0 -36
- package/lib/util/pluginUtils.js +0 -289
- package/lib/util/prefixSelector.js +0 -39
- package/lib/util/pseudoElements.js +0 -212
- package/lib/util/removeAlphaVariables.js +0 -31
- package/lib/util/resolveConfig.js +0 -256
- package/lib/util/resolveConfigPath.js +0 -70
- package/lib/util/responsive.js +0 -24
- package/lib/util/splitAtTopLevelOnly.js +0 -51
- package/lib/util/tap.js +0 -14
- package/lib/util/toColorValue.js +0 -13
- package/lib/util/toPath.js +0 -32
- package/lib/util/transformThemeValue.js +0 -73
- package/lib/util/validateConfig.js +0 -37
- package/lib/util/validateFormalSyntax.js +0 -26
- package/lib/util/withAlphaVariable.js +0 -79
- package/lib/value-parser/LICENSE +0 -22
- package/lib/value-parser/README.md +0 -3
- package/lib/value-parser/index.d.js +0 -2
- package/lib/value-parser/index.js +0 -22
- package/lib/value-parser/parse.js +0 -259
- package/lib/value-parser/stringify.js +0 -38
- package/lib/value-parser/unit.js +0 -86
- package/lib/value-parser/walk.js +0 -16
- package/loadConfig.d.ts +0 -4
- package/loadConfig.js +0 -2
- package/nesting/index.d.ts +0 -4
- package/nesting/index.js +0 -2
- package/peers/index.js +0 -96624
- package/plugin.d.ts +0 -11
- package/plugin.js +0 -2
- package/prettier.config.js +0 -19
- package/resolveConfig.d.ts +0 -31
- package/resolveConfig.js +0 -2
- package/screens.css +0 -1
- package/scripts/create-plugin-list.js +0 -10
- package/scripts/generate-types.js +0 -104
- package/scripts/release-channel.js +0 -18
- package/scripts/release-notes.js +0 -21
- package/scripts/swap-engines.js +0 -40
- package/scripts/type-utils.js +0 -27
- package/src/cli/build/deps.js +0 -56
- package/src/cli/build/index.js +0 -49
- package/src/cli/build/plugin.js +0 -444
- package/src/cli/build/utils.js +0 -76
- package/src/cli/build/watching.js +0 -229
- package/src/cli/help/index.js +0 -70
- package/src/cli/index.js +0 -216
- package/src/cli/init/index.js +0 -79
- package/src/cli-peer-dependencies.js +0 -15
- package/src/cli.js +0 -7
- package/src/corePluginList.js +0 -1
- package/src/corePlugins.js +0 -2943
- package/src/css/LICENSE +0 -25
- package/src/css/preflight.css +0 -385
- package/src/featureFlags.js +0 -66
- package/src/index.js +0 -1
- package/src/lib/cacheInvalidation.js +0 -52
- package/src/lib/collapseAdjacentRules.js +0 -58
- package/src/lib/collapseDuplicateDeclarations.js +0 -93
- package/src/lib/content.js +0 -208
- package/src/lib/defaultExtractor.js +0 -230
- package/src/lib/detectNesting.js +0 -47
- package/src/lib/evaluateTailwindFunctions.js +0 -272
- package/src/lib/expandApplyAtRules.js +0 -620
- package/src/lib/expandTailwindAtRules.js +0 -300
- package/src/lib/findAtConfigPath.js +0 -48
- package/src/lib/generateRules.js +0 -951
- package/src/lib/getModuleDependencies.js +0 -79
- package/src/lib/load-config.ts +0 -39
- package/src/lib/normalizeTailwindDirectives.js +0 -84
- package/src/lib/offsets.js +0 -373
- package/src/lib/partitionApplyAtRules.js +0 -52
- package/src/lib/regex.js +0 -74
- package/src/lib/remap-bitfield.js +0 -82
- package/src/lib/resolveDefaultsAtRules.js +0 -163
- package/src/lib/setupContextUtils.js +0 -1366
- package/src/lib/setupTrackingContext.js +0 -169
- package/src/lib/sharedState.js +0 -61
- package/src/lib/substituteScreenAtRules.js +0 -19
- package/src/oxide/cli/build/deps.ts +0 -91
- package/src/oxide/cli/build/index.ts +0 -47
- package/src/oxide/cli/build/plugin.ts +0 -442
- package/src/oxide/cli/build/utils.ts +0 -74
- package/src/oxide/cli/build/watching.ts +0 -225
- package/src/oxide/cli/help/index.ts +0 -69
- package/src/oxide/cli/index.ts +0 -204
- package/src/oxide/cli/init/index.ts +0 -59
- package/src/oxide/cli.ts +0 -1
- package/src/oxide/postcss-plugin.ts +0 -1
- package/src/plugin.js +0 -107
- package/src/postcss-plugins/nesting/README.md +0 -42
- package/src/postcss-plugins/nesting/index.js +0 -13
- package/src/postcss-plugins/nesting/plugin.js +0 -80
- package/src/processTailwindFeatures.js +0 -59
- package/src/public/colors.js +0 -322
- package/src/public/create-plugin.js +0 -2
- package/src/public/default-config.js +0 -4
- package/src/public/default-theme.js +0 -4
- package/src/public/load-config.js +0 -2
- package/src/public/resolve-config.js +0 -7
- package/src/util/applyImportantSelector.js +0 -27
- package/src/util/bigSign.js +0 -3
- package/src/util/buildMediaQuery.js +0 -22
- package/src/util/cloneDeep.js +0 -11
- package/src/util/cloneNodes.js +0 -49
- package/src/util/color.js +0 -88
- package/src/util/colorNames.js +0 -150
- package/src/util/configurePlugins.js +0 -23
- package/src/util/createPlugin.js +0 -27
- package/src/util/createUtilityPlugin.js +0 -37
- package/src/util/dataTypes.js +0 -406
- package/src/util/defaults.js +0 -17
- package/src/util/escapeClassName.js +0 -8
- package/src/util/escapeCommas.js +0 -3
- package/src/util/flattenColorPalette.js +0 -13
- package/src/util/formatVariantSelector.js +0 -324
- package/src/util/getAllConfigs.js +0 -38
- package/src/util/hashConfig.js +0 -5
- package/src/util/isKeyframeRule.js +0 -3
- package/src/util/isPlainObject.js +0 -8
- package/src/util/isSyntacticallyValidPropertyValue.js +0 -61
- package/src/util/log.js +0 -29
- package/src/util/nameClass.js +0 -30
- package/src/util/negateValue.js +0 -24
- package/src/util/normalizeConfig.js +0 -301
- package/src/util/normalizeScreens.js +0 -140
- package/src/util/parseAnimationValue.js +0 -68
- package/src/util/parseBoxShadowValue.js +0 -72
- package/src/util/parseDependency.js +0 -44
- package/src/util/parseGlob.js +0 -24
- package/src/util/parseObjectStyles.js +0 -19
- package/src/util/pluginUtils.js +0 -307
- package/src/util/prefixSelector.js +0 -33
- package/src/util/pseudoElements.js +0 -171
- package/src/util/removeAlphaVariables.js +0 -24
- package/src/util/resolveConfig.js +0 -277
- package/src/util/resolveConfigPath.js +0 -66
- package/src/util/responsive.js +0 -10
- package/src/util/splitAtTopLevelOnly.js +0 -52
- package/src/util/tap.js +0 -4
- package/src/util/toColorValue.js +0 -3
- package/src/util/toPath.js +0 -26
- package/src/util/transformThemeValue.js +0 -62
- package/src/util/validateConfig.js +0 -26
- package/src/util/validateFormalSyntax.js +0 -34
- package/src/util/withAlphaVariable.js +0 -49
- package/src/value-parser/LICENSE +0 -22
- package/src/value-parser/README.md +0 -3
- package/src/value-parser/index.d.ts +0 -177
- package/src/value-parser/index.js +0 -28
- package/src/value-parser/parse.js +0 -303
- package/src/value-parser/stringify.js +0 -41
- package/src/value-parser/unit.js +0 -118
- package/src/value-parser/walk.js +0 -18
- package/stubs/.gitignore +0 -1
- package/stubs/.prettierrc.json +0 -6
- package/stubs/config.full.js +0 -1062
- package/stubs/config.simple.js +0 -7
- package/stubs/postcss.config.cjs +0 -6
- package/stubs/postcss.config.js +0 -6
- package/stubs/tailwind.config.cjs +0 -2
- package/stubs/tailwind.config.js +0 -2
- package/stubs/tailwind.config.ts +0 -3
- package/tailwind.css +0 -5
- package/types/config.d.ts +0 -376
- package/types/generated/.gitkeep +0 -0
- package/types/generated/colors.d.ts +0 -298
- package/types/generated/corePluginList.d.ts +0 -1
- package/types/generated/default-theme.d.ts +0 -397
- package/types/index.d.ts +0 -11
- package/variants.css +0 -1
@@ -1,291 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", {
|
3
|
-
value: true
|
4
|
-
});
|
5
|
-
Object.defineProperty(exports, "default", {
|
6
|
-
enumerable: true,
|
7
|
-
get: function() {
|
8
|
-
return expandTailwindAtRules;
|
9
|
-
}
|
10
|
-
});
|
11
|
-
const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
|
12
|
-
const _quicklru = /*#__PURE__*/ _interop_require_default(require("@alloc/quick-lru"));
|
13
|
-
const _sharedState = /*#__PURE__*/ _interop_require_wildcard(require("./sharedState"));
|
14
|
-
const _generateRules = require("./generateRules");
|
15
|
-
const _log = /*#__PURE__*/ _interop_require_default(require("../util/log"));
|
16
|
-
const _cloneNodes = /*#__PURE__*/ _interop_require_default(require("../util/cloneNodes"));
|
17
|
-
const _defaultExtractor = require("./defaultExtractor");
|
18
|
-
function _interop_require_default(obj) {
|
19
|
-
return obj && obj.__esModule ? obj : {
|
20
|
-
default: obj
|
21
|
-
};
|
22
|
-
}
|
23
|
-
function _getRequireWildcardCache(nodeInterop) {
|
24
|
-
if (typeof WeakMap !== "function") return null;
|
25
|
-
var cacheBabelInterop = new WeakMap();
|
26
|
-
var cacheNodeInterop = new WeakMap();
|
27
|
-
return (_getRequireWildcardCache = function(nodeInterop) {
|
28
|
-
return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
|
29
|
-
})(nodeInterop);
|
30
|
-
}
|
31
|
-
function _interop_require_wildcard(obj, nodeInterop) {
|
32
|
-
if (!nodeInterop && obj && obj.__esModule) {
|
33
|
-
return obj;
|
34
|
-
}
|
35
|
-
if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
|
36
|
-
return {
|
37
|
-
default: obj
|
38
|
-
};
|
39
|
-
}
|
40
|
-
var cache = _getRequireWildcardCache(nodeInterop);
|
41
|
-
if (cache && cache.has(obj)) {
|
42
|
-
return cache.get(obj);
|
43
|
-
}
|
44
|
-
var newObj = {};
|
45
|
-
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
|
46
|
-
for(var key in obj){
|
47
|
-
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
|
48
|
-
var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
|
49
|
-
if (desc && (desc.get || desc.set)) {
|
50
|
-
Object.defineProperty(newObj, key, desc);
|
51
|
-
} else {
|
52
|
-
newObj[key] = obj[key];
|
53
|
-
}
|
54
|
-
}
|
55
|
-
}
|
56
|
-
newObj.default = obj;
|
57
|
-
if (cache) {
|
58
|
-
cache.set(obj, newObj);
|
59
|
-
}
|
60
|
-
return newObj;
|
61
|
-
}
|
62
|
-
let env = _sharedState.env;
|
63
|
-
const builtInExtractors = {
|
64
|
-
DEFAULT: _defaultExtractor.defaultExtractor
|
65
|
-
};
|
66
|
-
const builtInTransformers = {
|
67
|
-
DEFAULT: (content)=>content,
|
68
|
-
svelte: (content)=>content.replace(/(?:^|\s)class:/g, " ")
|
69
|
-
};
|
70
|
-
function getExtractor(context, fileExtension) {
|
71
|
-
let extractors = context.tailwindConfig.content.extract;
|
72
|
-
return extractors[fileExtension] || extractors.DEFAULT || builtInExtractors[fileExtension] || builtInExtractors.DEFAULT(context);
|
73
|
-
}
|
74
|
-
function getTransformer(tailwindConfig, fileExtension) {
|
75
|
-
let transformers = tailwindConfig.content.transform;
|
76
|
-
return transformers[fileExtension] || transformers.DEFAULT || builtInTransformers[fileExtension] || builtInTransformers.DEFAULT;
|
77
|
-
}
|
78
|
-
let extractorCache = new WeakMap();
|
79
|
-
// Scans template contents for possible classes. This is a hot path on initial build but
|
80
|
-
// not too important for subsequent builds. The faster the better though — if we can speed
|
81
|
-
// up these regexes by 50% that could cut initial build time by like 20%.
|
82
|
-
function getClassCandidates(content, extractor, candidates, seen) {
|
83
|
-
if (!extractorCache.has(extractor)) {
|
84
|
-
extractorCache.set(extractor, new _quicklru.default({
|
85
|
-
maxSize: 25000
|
86
|
-
}));
|
87
|
-
}
|
88
|
-
for (let line of content.split("\n")){
|
89
|
-
line = line.trim();
|
90
|
-
if (seen.has(line)) {
|
91
|
-
continue;
|
92
|
-
}
|
93
|
-
seen.add(line);
|
94
|
-
if (extractorCache.get(extractor).has(line)) {
|
95
|
-
for (let match of extractorCache.get(extractor).get(line)){
|
96
|
-
candidates.add(match);
|
97
|
-
}
|
98
|
-
} else {
|
99
|
-
let extractorMatches = extractor(line).filter((s)=>s !== "!*");
|
100
|
-
let lineMatchesSet = new Set(extractorMatches);
|
101
|
-
for (let match of lineMatchesSet){
|
102
|
-
candidates.add(match);
|
103
|
-
}
|
104
|
-
extractorCache.get(extractor).set(line, lineMatchesSet);
|
105
|
-
}
|
106
|
-
}
|
107
|
-
}
|
108
|
-
/**
|
109
|
-
*
|
110
|
-
* @param {[import('./offsets.js').RuleOffset, import('postcss').Node][]} rules
|
111
|
-
* @param {*} context
|
112
|
-
*/ function buildStylesheet(rules, context) {
|
113
|
-
let sortedRules = context.offsets.sort(rules);
|
114
|
-
let returnValue = {
|
115
|
-
base: new Set(),
|
116
|
-
defaults: new Set(),
|
117
|
-
components: new Set(),
|
118
|
-
utilities: new Set(),
|
119
|
-
variants: new Set()
|
120
|
-
};
|
121
|
-
for (let [sort, rule] of sortedRules){
|
122
|
-
returnValue[sort.layer].add(rule);
|
123
|
-
}
|
124
|
-
return returnValue;
|
125
|
-
}
|
126
|
-
function expandTailwindAtRules(context) {
|
127
|
-
return async (root)=>{
|
128
|
-
let layerNodes = {
|
129
|
-
base: null,
|
130
|
-
components: null,
|
131
|
-
utilities: null,
|
132
|
-
variants: null
|
133
|
-
};
|
134
|
-
root.walkAtRules((rule)=>{
|
135
|
-
// Make sure this file contains Tailwind directives. If not, we can save
|
136
|
-
// a lot of work and bail early. Also we don't have to register our touch
|
137
|
-
// file as a dependency since the output of this CSS does not depend on
|
138
|
-
// the source of any templates. Think Vue <style> blocks for example.
|
139
|
-
if (rule.name === "tailwind") {
|
140
|
-
if (Object.keys(layerNodes).includes(rule.params)) {
|
141
|
-
layerNodes[rule.params] = rule;
|
142
|
-
}
|
143
|
-
}
|
144
|
-
});
|
145
|
-
if (Object.values(layerNodes).every((n)=>n === null)) {
|
146
|
-
return root;
|
147
|
-
}
|
148
|
-
var _context_candidates;
|
149
|
-
// ---
|
150
|
-
// Find potential rules in changed files
|
151
|
-
let candidates = new Set([
|
152
|
-
...(_context_candidates = context.candidates) !== null && _context_candidates !== void 0 ? _context_candidates : [],
|
153
|
-
_sharedState.NOT_ON_DEMAND
|
154
|
-
]);
|
155
|
-
let seen = new Set();
|
156
|
-
env.DEBUG && console.time("Reading changed files");
|
157
|
-
if (false) {
|
158
|
-
// TODO: Pass through or implement `extractor`
|
159
|
-
for (let candidate of require("@tailwindcss/oxide").parseCandidateStringsFromFiles(context.changedContent)){
|
160
|
-
candidates.add(candidate);
|
161
|
-
}
|
162
|
-
// for (let { file, content, extension } of context.changedContent) {
|
163
|
-
// let transformer = getTransformer(context.tailwindConfig, extension)
|
164
|
-
// let extractor = getExtractor(context, extension)
|
165
|
-
// getClassCandidatesOxide(file, transformer(content), extractor, candidates, seen)
|
166
|
-
// }
|
167
|
-
} else {
|
168
|
-
/** @type {[item: {file?: string, content?: string}, meta: {transformer: any, extractor: any}][]} */ let regexParserContent = [];
|
169
|
-
for (let item of context.changedContent){
|
170
|
-
let transformer = getTransformer(context.tailwindConfig, item.extension);
|
171
|
-
let extractor = getExtractor(context, item.extension);
|
172
|
-
regexParserContent.push([
|
173
|
-
item,
|
174
|
-
{
|
175
|
-
transformer,
|
176
|
-
extractor
|
177
|
-
}
|
178
|
-
]);
|
179
|
-
}
|
180
|
-
const BATCH_SIZE = 500;
|
181
|
-
for(let i = 0; i < regexParserContent.length; i += BATCH_SIZE){
|
182
|
-
let batch = regexParserContent.slice(i, i + BATCH_SIZE);
|
183
|
-
await Promise.all(batch.map(async ([{ file , content }, { transformer , extractor }])=>{
|
184
|
-
content = file ? await _fs.default.promises.readFile(file, "utf8") : content;
|
185
|
-
getClassCandidates(transformer(content), extractor, candidates, seen);
|
186
|
-
}));
|
187
|
-
}
|
188
|
-
}
|
189
|
-
env.DEBUG && console.timeEnd("Reading changed files");
|
190
|
-
// ---
|
191
|
-
// Generate the actual CSS
|
192
|
-
let classCacheCount = context.classCache.size;
|
193
|
-
env.DEBUG && console.time("Generate rules");
|
194
|
-
env.DEBUG && console.time("Sorting candidates");
|
195
|
-
let sortedCandidates = false ? candidates : new Set([
|
196
|
-
...candidates
|
197
|
-
].sort((a, z)=>{
|
198
|
-
if (a === z) return 0;
|
199
|
-
if (a < z) return -1;
|
200
|
-
return 1;
|
201
|
-
}));
|
202
|
-
env.DEBUG && console.timeEnd("Sorting candidates");
|
203
|
-
(0, _generateRules.generateRules)(sortedCandidates, context);
|
204
|
-
env.DEBUG && console.timeEnd("Generate rules");
|
205
|
-
// We only ever add to the classCache, so if it didn't grow, there is nothing new.
|
206
|
-
env.DEBUG && console.time("Build stylesheet");
|
207
|
-
if (context.stylesheetCache === null || context.classCache.size !== classCacheCount) {
|
208
|
-
context.stylesheetCache = buildStylesheet([
|
209
|
-
...context.ruleCache
|
210
|
-
], context);
|
211
|
-
}
|
212
|
-
env.DEBUG && console.timeEnd("Build stylesheet");
|
213
|
-
let { defaults: defaultNodes , base: baseNodes , components: componentNodes , utilities: utilityNodes , variants: screenNodes } = context.stylesheetCache;
|
214
|
-
// ---
|
215
|
-
// Replace any Tailwind directives with generated CSS
|
216
|
-
if (layerNodes.base) {
|
217
|
-
layerNodes.base.before((0, _cloneNodes.default)([
|
218
|
-
...baseNodes,
|
219
|
-
...defaultNodes
|
220
|
-
], layerNodes.base.source, {
|
221
|
-
layer: "base"
|
222
|
-
}));
|
223
|
-
layerNodes.base.remove();
|
224
|
-
}
|
225
|
-
if (layerNodes.components) {
|
226
|
-
layerNodes.components.before((0, _cloneNodes.default)([
|
227
|
-
...componentNodes
|
228
|
-
], layerNodes.components.source, {
|
229
|
-
layer: "components"
|
230
|
-
}));
|
231
|
-
layerNodes.components.remove();
|
232
|
-
}
|
233
|
-
if (layerNodes.utilities) {
|
234
|
-
layerNodes.utilities.before((0, _cloneNodes.default)([
|
235
|
-
...utilityNodes
|
236
|
-
], layerNodes.utilities.source, {
|
237
|
-
layer: "utilities"
|
238
|
-
}));
|
239
|
-
layerNodes.utilities.remove();
|
240
|
-
}
|
241
|
-
// We do post-filtering to not alter the emitted order of the variants
|
242
|
-
const variantNodes = Array.from(screenNodes).filter((node)=>{
|
243
|
-
var _node_raws_tailwind;
|
244
|
-
const parentLayer = (_node_raws_tailwind = node.raws.tailwind) === null || _node_raws_tailwind === void 0 ? void 0 : _node_raws_tailwind.parentLayer;
|
245
|
-
if (parentLayer === "components") {
|
246
|
-
return layerNodes.components !== null;
|
247
|
-
}
|
248
|
-
if (parentLayer === "utilities") {
|
249
|
-
return layerNodes.utilities !== null;
|
250
|
-
}
|
251
|
-
return true;
|
252
|
-
});
|
253
|
-
if (layerNodes.variants) {
|
254
|
-
layerNodes.variants.before((0, _cloneNodes.default)(variantNodes, layerNodes.variants.source, {
|
255
|
-
layer: "variants"
|
256
|
-
}));
|
257
|
-
layerNodes.variants.remove();
|
258
|
-
} else if (variantNodes.length > 0) {
|
259
|
-
root.append((0, _cloneNodes.default)(variantNodes, root.source, {
|
260
|
-
layer: "variants"
|
261
|
-
}));
|
262
|
-
}
|
263
|
-
var _root_source_end;
|
264
|
-
// TODO: Why is the root node having no source location for `end` possible?
|
265
|
-
root.source.end = (_root_source_end = root.source.end) !== null && _root_source_end !== void 0 ? _root_source_end : root.source.start;
|
266
|
-
// If we've got a utility layer and no utilities are generated there's likely something wrong
|
267
|
-
const hasUtilityVariants = variantNodes.some((node)=>{
|
268
|
-
var _node_raws_tailwind;
|
269
|
-
return ((_node_raws_tailwind = node.raws.tailwind) === null || _node_raws_tailwind === void 0 ? void 0 : _node_raws_tailwind.parentLayer) === "utilities";
|
270
|
-
});
|
271
|
-
if (layerNodes.utilities && utilityNodes.size === 0 && !hasUtilityVariants) {
|
272
|
-
_log.default.warn("content-problems", [
|
273
|
-
"No utility classes were detected in your source files. If this is unexpected, double-check the `content` option in your Tailwind CSS configuration.",
|
274
|
-
"https://tailwindcss.com/docs/content-configuration"
|
275
|
-
]);
|
276
|
-
}
|
277
|
-
// ---
|
278
|
-
if (env.DEBUG) {
|
279
|
-
console.log("Potential classes: ", candidates.size);
|
280
|
-
console.log("Active contexts: ", _sharedState.contextSourcesMap.size);
|
281
|
-
}
|
282
|
-
// Clear the cache for the changed files
|
283
|
-
context.changedContent = [];
|
284
|
-
// Cleanup any leftover @layer atrules
|
285
|
-
root.walkAtRules("layer", (rule)=>{
|
286
|
-
if (Object.keys(layerNodes).includes(rule.params)) {
|
287
|
-
rule.remove();
|
288
|
-
}
|
289
|
-
});
|
290
|
-
};
|
291
|
-
}
|
@@ -1,46 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", {
|
3
|
-
value: true
|
4
|
-
});
|
5
|
-
Object.defineProperty(exports, "findAtConfigPath", {
|
6
|
-
enumerable: true,
|
7
|
-
get: function() {
|
8
|
-
return findAtConfigPath;
|
9
|
-
}
|
10
|
-
});
|
11
|
-
const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
|
12
|
-
const _path = /*#__PURE__*/ _interop_require_default(require("path"));
|
13
|
-
function _interop_require_default(obj) {
|
14
|
-
return obj && obj.__esModule ? obj : {
|
15
|
-
default: obj
|
16
|
-
};
|
17
|
-
}
|
18
|
-
function findAtConfigPath(root, result) {
|
19
|
-
let configPath = null;
|
20
|
-
let relativeTo = null;
|
21
|
-
root.walkAtRules("config", (rule)=>{
|
22
|
-
var _rule_source;
|
23
|
-
var _rule_source_input_file, _ref;
|
24
|
-
relativeTo = (_ref = (_rule_source_input_file = (_rule_source = rule.source) === null || _rule_source === void 0 ? void 0 : _rule_source.input.file) !== null && _rule_source_input_file !== void 0 ? _rule_source_input_file : result.opts.from) !== null && _ref !== void 0 ? _ref : null;
|
25
|
-
if (relativeTo === null) {
|
26
|
-
throw rule.error("The `@config` directive cannot be used without setting `from` in your PostCSS config.");
|
27
|
-
}
|
28
|
-
if (configPath) {
|
29
|
-
throw rule.error("Only one `@config` directive is allowed per file.");
|
30
|
-
}
|
31
|
-
let matches = rule.params.match(/(['"])(.*?)\1/);
|
32
|
-
if (!matches) {
|
33
|
-
throw rule.error("A path is required when using the `@config` directive.");
|
34
|
-
}
|
35
|
-
let inputPath = matches[2];
|
36
|
-
if (_path.default.isAbsolute(inputPath)) {
|
37
|
-
throw rule.error("The `@config` directive cannot be used with an absolute path.");
|
38
|
-
}
|
39
|
-
configPath = _path.default.resolve(_path.default.dirname(relativeTo), inputPath);
|
40
|
-
if (!_fs.default.existsSync(configPath)) {
|
41
|
-
throw rule.error(`The config file at "${inputPath}" does not exist. Make sure the path is correct and the file exists.`);
|
42
|
-
}
|
43
|
-
rule.remove();
|
44
|
-
});
|
45
|
-
return configPath ? configPath : null;
|
46
|
-
}
|