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,300 +0,0 @@
|
|
1
|
-
import fs from 'fs'
|
2
|
-
import LRU from '@alloc/quick-lru'
|
3
|
-
import * as sharedState from './sharedState'
|
4
|
-
import { generateRules } from './generateRules'
|
5
|
-
import log from '../util/log'
|
6
|
-
import cloneNodes from '../util/cloneNodes'
|
7
|
-
import { defaultExtractor } from './defaultExtractor'
|
8
|
-
|
9
|
-
let env = sharedState.env
|
10
|
-
|
11
|
-
const builtInExtractors = {
|
12
|
-
DEFAULT: defaultExtractor,
|
13
|
-
}
|
14
|
-
|
15
|
-
const builtInTransformers = {
|
16
|
-
DEFAULT: (content) => content,
|
17
|
-
svelte: (content) => content.replace(/(?:^|\s)class:/g, ' '),
|
18
|
-
}
|
19
|
-
|
20
|
-
function getExtractor(context, fileExtension) {
|
21
|
-
let extractors = context.tailwindConfig.content.extract
|
22
|
-
|
23
|
-
return (
|
24
|
-
extractors[fileExtension] ||
|
25
|
-
extractors.DEFAULT ||
|
26
|
-
builtInExtractors[fileExtension] ||
|
27
|
-
builtInExtractors.DEFAULT(context)
|
28
|
-
)
|
29
|
-
}
|
30
|
-
|
31
|
-
function getTransformer(tailwindConfig, fileExtension) {
|
32
|
-
let transformers = tailwindConfig.content.transform
|
33
|
-
|
34
|
-
return (
|
35
|
-
transformers[fileExtension] ||
|
36
|
-
transformers.DEFAULT ||
|
37
|
-
builtInTransformers[fileExtension] ||
|
38
|
-
builtInTransformers.DEFAULT
|
39
|
-
)
|
40
|
-
}
|
41
|
-
|
42
|
-
let extractorCache = new WeakMap()
|
43
|
-
|
44
|
-
// Scans template contents for possible classes. This is a hot path on initial build but
|
45
|
-
// not too important for subsequent builds. The faster the better though — if we can speed
|
46
|
-
// up these regexes by 50% that could cut initial build time by like 20%.
|
47
|
-
function getClassCandidates(content, extractor, candidates, seen) {
|
48
|
-
if (!extractorCache.has(extractor)) {
|
49
|
-
extractorCache.set(extractor, new LRU({ maxSize: 25000 }))
|
50
|
-
}
|
51
|
-
|
52
|
-
for (let line of content.split('\n')) {
|
53
|
-
line = line.trim()
|
54
|
-
|
55
|
-
if (seen.has(line)) {
|
56
|
-
continue
|
57
|
-
}
|
58
|
-
seen.add(line)
|
59
|
-
|
60
|
-
if (extractorCache.get(extractor).has(line)) {
|
61
|
-
for (let match of extractorCache.get(extractor).get(line)) {
|
62
|
-
candidates.add(match)
|
63
|
-
}
|
64
|
-
} else {
|
65
|
-
let extractorMatches = extractor(line).filter((s) => s !== '!*')
|
66
|
-
let lineMatchesSet = new Set(extractorMatches)
|
67
|
-
|
68
|
-
for (let match of lineMatchesSet) {
|
69
|
-
candidates.add(match)
|
70
|
-
}
|
71
|
-
|
72
|
-
extractorCache.get(extractor).set(line, lineMatchesSet)
|
73
|
-
}
|
74
|
-
}
|
75
|
-
}
|
76
|
-
|
77
|
-
/**
|
78
|
-
*
|
79
|
-
* @param {[import('./offsets.js').RuleOffset, import('postcss').Node][]} rules
|
80
|
-
* @param {*} context
|
81
|
-
*/
|
82
|
-
function buildStylesheet(rules, context) {
|
83
|
-
let sortedRules = context.offsets.sort(rules)
|
84
|
-
|
85
|
-
let returnValue = {
|
86
|
-
base: new Set(),
|
87
|
-
defaults: new Set(),
|
88
|
-
components: new Set(),
|
89
|
-
utilities: new Set(),
|
90
|
-
variants: new Set(),
|
91
|
-
}
|
92
|
-
|
93
|
-
for (let [sort, rule] of sortedRules) {
|
94
|
-
returnValue[sort.layer].add(rule)
|
95
|
-
}
|
96
|
-
|
97
|
-
return returnValue
|
98
|
-
}
|
99
|
-
|
100
|
-
export default function expandTailwindAtRules(context) {
|
101
|
-
return async (root) => {
|
102
|
-
let layerNodes = {
|
103
|
-
base: null,
|
104
|
-
components: null,
|
105
|
-
utilities: null,
|
106
|
-
variants: null,
|
107
|
-
}
|
108
|
-
|
109
|
-
root.walkAtRules((rule) => {
|
110
|
-
// Make sure this file contains Tailwind directives. If not, we can save
|
111
|
-
// a lot of work and bail early. Also we don't have to register our touch
|
112
|
-
// file as a dependency since the output of this CSS does not depend on
|
113
|
-
// the source of any templates. Think Vue <style> blocks for example.
|
114
|
-
if (rule.name === 'tailwind') {
|
115
|
-
if (Object.keys(layerNodes).includes(rule.params)) {
|
116
|
-
layerNodes[rule.params] = rule
|
117
|
-
}
|
118
|
-
}
|
119
|
-
})
|
120
|
-
|
121
|
-
if (Object.values(layerNodes).every((n) => n === null)) {
|
122
|
-
return root
|
123
|
-
}
|
124
|
-
|
125
|
-
// ---
|
126
|
-
|
127
|
-
// Find potential rules in changed files
|
128
|
-
let candidates = new Set([...(context.candidates ?? []), sharedState.NOT_ON_DEMAND])
|
129
|
-
let seen = new Set()
|
130
|
-
|
131
|
-
env.DEBUG && console.time('Reading changed files')
|
132
|
-
|
133
|
-
if (__OXIDE__) {
|
134
|
-
// TODO: Pass through or implement `extractor`
|
135
|
-
for (let candidate of require('@tailwindcss/oxide').parseCandidateStringsFromFiles(
|
136
|
-
context.changedContent
|
137
|
-
// Object.assign({}, builtInTransformers, context.tailwindConfig.content.transform)
|
138
|
-
)) {
|
139
|
-
candidates.add(candidate)
|
140
|
-
}
|
141
|
-
|
142
|
-
// for (let { file, content, extension } of context.changedContent) {
|
143
|
-
// let transformer = getTransformer(context.tailwindConfig, extension)
|
144
|
-
// let extractor = getExtractor(context, extension)
|
145
|
-
// getClassCandidatesOxide(file, transformer(content), extractor, candidates, seen)
|
146
|
-
// }
|
147
|
-
} else {
|
148
|
-
/** @type {[item: {file?: string, content?: string}, meta: {transformer: any, extractor: any}][]} */
|
149
|
-
let regexParserContent = []
|
150
|
-
|
151
|
-
for (let item of context.changedContent) {
|
152
|
-
let transformer = getTransformer(context.tailwindConfig, item.extension)
|
153
|
-
let extractor = getExtractor(context, item.extension)
|
154
|
-
regexParserContent.push([item, { transformer, extractor }])
|
155
|
-
}
|
156
|
-
|
157
|
-
const BATCH_SIZE = 500
|
158
|
-
|
159
|
-
for (let i = 0; i < regexParserContent.length; i += BATCH_SIZE) {
|
160
|
-
let batch = regexParserContent.slice(i, i + BATCH_SIZE)
|
161
|
-
await Promise.all(
|
162
|
-
batch.map(async ([{ file, content }, { transformer, extractor }]) => {
|
163
|
-
content = file ? await fs.promises.readFile(file, 'utf8') : content
|
164
|
-
getClassCandidates(transformer(content), extractor, candidates, seen)
|
165
|
-
})
|
166
|
-
)
|
167
|
-
}
|
168
|
-
}
|
169
|
-
|
170
|
-
env.DEBUG && console.timeEnd('Reading changed files')
|
171
|
-
|
172
|
-
// ---
|
173
|
-
|
174
|
-
// Generate the actual CSS
|
175
|
-
let classCacheCount = context.classCache.size
|
176
|
-
|
177
|
-
env.DEBUG && console.time('Generate rules')
|
178
|
-
env.DEBUG && console.time('Sorting candidates')
|
179
|
-
let sortedCandidates = __OXIDE__
|
180
|
-
? candidates
|
181
|
-
: new Set(
|
182
|
-
[...candidates].sort((a, z) => {
|
183
|
-
if (a === z) return 0
|
184
|
-
if (a < z) return -1
|
185
|
-
return 1
|
186
|
-
})
|
187
|
-
)
|
188
|
-
env.DEBUG && console.timeEnd('Sorting candidates')
|
189
|
-
generateRules(sortedCandidates, context)
|
190
|
-
env.DEBUG && console.timeEnd('Generate rules')
|
191
|
-
|
192
|
-
// We only ever add to the classCache, so if it didn't grow, there is nothing new.
|
193
|
-
env.DEBUG && console.time('Build stylesheet')
|
194
|
-
if (context.stylesheetCache === null || context.classCache.size !== classCacheCount) {
|
195
|
-
context.stylesheetCache = buildStylesheet([...context.ruleCache], context)
|
196
|
-
}
|
197
|
-
env.DEBUG && console.timeEnd('Build stylesheet')
|
198
|
-
|
199
|
-
let {
|
200
|
-
defaults: defaultNodes,
|
201
|
-
base: baseNodes,
|
202
|
-
components: componentNodes,
|
203
|
-
utilities: utilityNodes,
|
204
|
-
variants: screenNodes,
|
205
|
-
} = context.stylesheetCache
|
206
|
-
|
207
|
-
// ---
|
208
|
-
|
209
|
-
// Replace any Tailwind directives with generated CSS
|
210
|
-
|
211
|
-
if (layerNodes.base) {
|
212
|
-
layerNodes.base.before(
|
213
|
-
cloneNodes([...baseNodes, ...defaultNodes], layerNodes.base.source, {
|
214
|
-
layer: 'base',
|
215
|
-
})
|
216
|
-
)
|
217
|
-
layerNodes.base.remove()
|
218
|
-
}
|
219
|
-
|
220
|
-
if (layerNodes.components) {
|
221
|
-
layerNodes.components.before(
|
222
|
-
cloneNodes([...componentNodes], layerNodes.components.source, {
|
223
|
-
layer: 'components',
|
224
|
-
})
|
225
|
-
)
|
226
|
-
layerNodes.components.remove()
|
227
|
-
}
|
228
|
-
|
229
|
-
if (layerNodes.utilities) {
|
230
|
-
layerNodes.utilities.before(
|
231
|
-
cloneNodes([...utilityNodes], layerNodes.utilities.source, {
|
232
|
-
layer: 'utilities',
|
233
|
-
})
|
234
|
-
)
|
235
|
-
layerNodes.utilities.remove()
|
236
|
-
}
|
237
|
-
|
238
|
-
// We do post-filtering to not alter the emitted order of the variants
|
239
|
-
const variantNodes = Array.from(screenNodes).filter((node) => {
|
240
|
-
const parentLayer = node.raws.tailwind?.parentLayer
|
241
|
-
|
242
|
-
if (parentLayer === 'components') {
|
243
|
-
return layerNodes.components !== null
|
244
|
-
}
|
245
|
-
|
246
|
-
if (parentLayer === 'utilities') {
|
247
|
-
return layerNodes.utilities !== null
|
248
|
-
}
|
249
|
-
|
250
|
-
return true
|
251
|
-
})
|
252
|
-
|
253
|
-
if (layerNodes.variants) {
|
254
|
-
layerNodes.variants.before(
|
255
|
-
cloneNodes(variantNodes, layerNodes.variants.source, {
|
256
|
-
layer: 'variants',
|
257
|
-
})
|
258
|
-
)
|
259
|
-
layerNodes.variants.remove()
|
260
|
-
} else if (variantNodes.length > 0) {
|
261
|
-
root.append(
|
262
|
-
cloneNodes(variantNodes, root.source, {
|
263
|
-
layer: 'variants',
|
264
|
-
})
|
265
|
-
)
|
266
|
-
}
|
267
|
-
|
268
|
-
// TODO: Why is the root node having no source location for `end` possible?
|
269
|
-
root.source.end = root.source.end ?? root.source.start
|
270
|
-
|
271
|
-
// If we've got a utility layer and no utilities are generated there's likely something wrong
|
272
|
-
const hasUtilityVariants = variantNodes.some(
|
273
|
-
(node) => node.raws.tailwind?.parentLayer === 'utilities'
|
274
|
-
)
|
275
|
-
|
276
|
-
if (layerNodes.utilities && utilityNodes.size === 0 && !hasUtilityVariants) {
|
277
|
-
log.warn('content-problems', [
|
278
|
-
'No utility classes were detected in your source files. If this is unexpected, double-check the `content` option in your Tailwind CSS configuration.',
|
279
|
-
'https://tailwindcss.com/docs/content-configuration',
|
280
|
-
])
|
281
|
-
}
|
282
|
-
|
283
|
-
// ---
|
284
|
-
|
285
|
-
if (env.DEBUG) {
|
286
|
-
console.log('Potential classes: ', candidates.size)
|
287
|
-
console.log('Active contexts: ', sharedState.contextSourcesMap.size)
|
288
|
-
}
|
289
|
-
|
290
|
-
// Clear the cache for the changed files
|
291
|
-
context.changedContent = []
|
292
|
-
|
293
|
-
// Cleanup any leftover @layer atrules
|
294
|
-
root.walkAtRules('layer', (rule) => {
|
295
|
-
if (Object.keys(layerNodes).includes(rule.params)) {
|
296
|
-
rule.remove()
|
297
|
-
}
|
298
|
-
})
|
299
|
-
}
|
300
|
-
}
|
@@ -1,48 +0,0 @@
|
|
1
|
-
import fs from 'fs'
|
2
|
-
import path from 'path'
|
3
|
-
|
4
|
-
/**
|
5
|
-
* Find the @config at-rule in the given CSS AST and return the relative path to the config file
|
6
|
-
*
|
7
|
-
* @param {import('postcss').Root} root
|
8
|
-
* @param {import('postcss').Result} result
|
9
|
-
*/
|
10
|
-
export function findAtConfigPath(root, result) {
|
11
|
-
let configPath = null
|
12
|
-
let relativeTo = null
|
13
|
-
|
14
|
-
root.walkAtRules('config', (rule) => {
|
15
|
-
relativeTo = rule.source?.input.file ?? result.opts.from ?? null
|
16
|
-
|
17
|
-
if (relativeTo === null) {
|
18
|
-
throw rule.error(
|
19
|
-
'The `@config` directive cannot be used without setting `from` in your PostCSS config.'
|
20
|
-
)
|
21
|
-
}
|
22
|
-
|
23
|
-
if (configPath) {
|
24
|
-
throw rule.error('Only one `@config` directive is allowed per file.')
|
25
|
-
}
|
26
|
-
|
27
|
-
let matches = rule.params.match(/(['"])(.*?)\1/)
|
28
|
-
if (!matches) {
|
29
|
-
throw rule.error('A path is required when using the `@config` directive.')
|
30
|
-
}
|
31
|
-
|
32
|
-
let inputPath = matches[2]
|
33
|
-
if (path.isAbsolute(inputPath)) {
|
34
|
-
throw rule.error('The `@config` directive cannot be used with an absolute path.')
|
35
|
-
}
|
36
|
-
|
37
|
-
configPath = path.resolve(path.dirname(relativeTo), inputPath)
|
38
|
-
if (!fs.existsSync(configPath)) {
|
39
|
-
throw rule.error(
|
40
|
-
`The config file at "${inputPath}" does not exist. Make sure the path is correct and the file exists.`
|
41
|
-
)
|
42
|
-
}
|
43
|
-
|
44
|
-
rule.remove()
|
45
|
-
})
|
46
|
-
|
47
|
-
return configPath ? configPath : null
|
48
|
-
}
|