tailwindcss 0.0.0-insiders.eb8d929 → 0.0.0-insiders.ec0049a
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/chunk-AZANAYY2.mjs +1 -0
- package/dist/chunk-CH45MXZF.mjs +10 -0
- package/dist/chunk-V2K3XTS4.mjs +1 -0
- package/dist/colors-b_6i0Oi7.d.ts +295 -0
- package/dist/colors.d.mts +295 -0
- package/dist/colors.d.ts +5 -0
- package/dist/colors.js +1 -0
- package/dist/colors.mjs +1 -0
- package/dist/default-theme.d.mts +1147 -0
- package/dist/default-theme.d.ts +1147 -0
- package/dist/default-theme.js +1 -0
- package/dist/default-theme.mjs +1 -0
- package/dist/flatten-color-palette.d.mts +6 -0
- package/dist/flatten-color-palette.d.ts +6 -0
- package/dist/flatten-color-palette.js +1 -0
- package/dist/flatten-color-palette.mjs +1 -0
- package/dist/lib.d.mts +260 -0
- package/dist/lib.d.ts +3 -0
- package/dist/lib.js +33 -0
- package/dist/lib.mjs +24 -0
- package/dist/plugin.d.mts +11 -0
- package/dist/plugin.d.ts +104 -0
- package/dist/plugin.js +1 -0
- package/dist/plugin.mjs +1 -0
- package/dist/resolve-config-BIFUA2FY.d.ts +29 -0
- package/dist/resolve-config-QUZ9b-Gn.d.mts +190 -0
- package/dist/types-B254mqw1.d.mts +98 -0
- package/index.css +863 -3
- package/package.json +73 -102
- package/preflight.css +383 -0
- package/theme.css +453 -0
- 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/index.js +0 -57
- package/lib/cli/build/plugin.js +0 -381
- 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 -231
- package/lib/cli/init/index.js +0 -63
- package/lib/cli.js +0 -3
- package/lib/corePluginList.js +0 -188
- package/lib/corePlugins.js +0 -4197
- package/lib/css/LICENSE +0 -25
- package/lib/css/preflight.css +0 -375
- package/lib/featureFlags.js +0 -84
- 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 -207
- package/lib/lib/defaultExtractor.js +0 -243
- package/lib/lib/detectNesting.js +0 -45
- package/lib/lib/evaluateTailwindFunctions.js +0 -238
- package/lib/lib/expandApplyAtRules.js +0 -534
- package/lib/lib/expandTailwindAtRules.js +0 -314
- package/lib/lib/findAtConfigPath.js +0 -46
- package/lib/lib/generateRules.js +0 -879
- package/lib/lib/getModuleDependencies.js +0 -99
- package/lib/lib/handleImportAtRules.js +0 -50
- package/lib/lib/load-config.js +0 -42
- package/lib/lib/normalizeTailwindDirectives.js +0 -74
- 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 -1245
- package/lib/lib/setupTrackingContext.js +0 -166
- package/lib/lib/sharedState.js +0 -79
- package/lib/lib/substituteScreenAtRules.js +0 -31
- package/lib/plugin.js +0 -116
- 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 -34
- 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 -304
- 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 -263
- 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 -78
- package/lib/util/nameClass.js +0 -49
- package/lib/util/negateValue.js +0 -36
- package/lib/util/normalizeConfig.js +0 -308
- 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 -274
- package/lib/util/prefixSelector.js +0 -39
- package/lib/util/pseudoElements.js +0 -229
- 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 -48
- 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.js +0 -2
- package/plugin.d.ts +0 -11
- package/plugin.js +0 -2
- package/prettier.config.js +0 -19
- package/resolveConfig.d.ts +0 -12
- package/resolveConfig.js +0 -2
- package/screens.css +0 -1
- package/scripts/create-plugin-list.js +0 -10
- package/scripts/generate-types.js +0 -105
- package/scripts/release-channel.js +0 -18
- package/scripts/release-notes.js +0 -21
- package/scripts/type-utils.js +0 -27
- package/src/cli/build/index.js +0 -53
- package/src/cli/build/plugin.js +0 -457
- 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 -217
- package/src/cli/init/index.js +0 -79
- package/src/cli.js +0 -3
- package/src/corePluginList.js +0 -1
- package/src/corePlugins.js +0 -2877
- package/src/css/LICENSE +0 -25
- package/src/css/preflight.css +0 -375
- package/src/featureFlags.js +0 -68
- 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 -240
- package/src/lib/defaultExtractor.js +0 -217
- package/src/lib/detectNesting.js +0 -47
- package/src/lib/evaluateTailwindFunctions.js +0 -272
- package/src/lib/expandApplyAtRules.js +0 -613
- package/src/lib/expandTailwindAtRules.js +0 -315
- package/src/lib/findAtConfigPath.js +0 -48
- package/src/lib/generateRules.js +0 -923
- package/src/lib/getModuleDependencies.js +0 -79
- package/src/lib/handleImportAtRules.js +0 -34
- package/src/lib/load-config.ts +0 -31
- package/src/lib/normalizeTailwindDirectives.js +0 -57
- 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 -1318
- package/src/lib/setupTrackingContext.js +0 -169
- package/src/lib/sharedState.js +0 -57
- package/src/lib/substituteScreenAtRules.js +0 -19
- package/src/plugin.js +0 -124
- 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 -58
- 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 -28
- 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 -292
- 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 -316
- 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 -53
- package/src/util/nameClass.js +0 -30
- package/src/util/negateValue.js +0 -24
- package/src/util/normalizeConfig.js +0 -328
- 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 -287
- package/src/util/prefixSelector.js +0 -32
- package/src/util/pseudoElements.js +0 -170
- 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 -36
- 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 -1003
- package/stubs/config.simple.js +0 -7
- package/stubs/postcss.config.cjs +0 -5
- package/stubs/postcss.config.js +0 -5
- 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 -369
- 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 -372
- package/types/index.d.ts +0 -7
- package/variants.css +0 -1
|
@@ -1,315 +0,0 @@
|
|
|
1
|
-
import fs from 'fs'
|
|
2
|
-
import LRU from '@alloc/quick-lru'
|
|
3
|
-
import { parseCandidateStrings, IO, Parsing } from '@tailwindcss/oxide'
|
|
4
|
-
import * as sharedState from './sharedState'
|
|
5
|
-
import { generateRules } from './generateRules'
|
|
6
|
-
import log from '../util/log'
|
|
7
|
-
import cloneNodes from '../util/cloneNodes'
|
|
8
|
-
import { defaultExtractor } from './defaultExtractor'
|
|
9
|
-
import { flagEnabled } from '../featureFlags'
|
|
10
|
-
|
|
11
|
-
let env = sharedState.env
|
|
12
|
-
|
|
13
|
-
const builtInExtractors = {
|
|
14
|
-
DEFAULT: defaultExtractor,
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
const builtInTransformers = {
|
|
18
|
-
DEFAULT: (content) => content,
|
|
19
|
-
svelte: (content) => content.replace(/(?:^|\s)class:/g, ' '),
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
function getExtractor(context, fileExtension) {
|
|
23
|
-
let extractors = context.tailwindConfig.content.extract
|
|
24
|
-
|
|
25
|
-
return (
|
|
26
|
-
extractors[fileExtension] ||
|
|
27
|
-
extractors.DEFAULT ||
|
|
28
|
-
builtInExtractors[fileExtension] ||
|
|
29
|
-
// Because we call `DEFAULT(context)`, the returning function is always a new function without a
|
|
30
|
-
// stable identity. Marking it with `DEFAULT_EXTRACTOR` allows us to check if it is the default
|
|
31
|
-
// extractor without relying on the function identity.
|
|
32
|
-
Object.assign(builtInExtractors.DEFAULT(context), { DEFAULT_EXTRACTOR: true })
|
|
33
|
-
)
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
function getTransformer(tailwindConfig, fileExtension) {
|
|
37
|
-
let transformers = tailwindConfig.content.transform
|
|
38
|
-
|
|
39
|
-
return (
|
|
40
|
-
transformers[fileExtension] ||
|
|
41
|
-
transformers.DEFAULT ||
|
|
42
|
-
builtInTransformers[fileExtension] ||
|
|
43
|
-
builtInTransformers.DEFAULT
|
|
44
|
-
)
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
let extractorCache = new WeakMap()
|
|
48
|
-
|
|
49
|
-
// Scans template contents for possible classes. This is a hot path on initial build but
|
|
50
|
-
// not too important for subsequent builds. The faster the better though — if we can speed
|
|
51
|
-
// up these regexes by 50% that could cut initial build time by like 20%.
|
|
52
|
-
function getClassCandidates(content, extractor, candidates, seen) {
|
|
53
|
-
if (!extractorCache.has(extractor)) {
|
|
54
|
-
extractorCache.set(extractor, new LRU({ maxSize: 25000 }))
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
for (let line of content.split('\n')) {
|
|
58
|
-
line = line.trim()
|
|
59
|
-
|
|
60
|
-
if (seen.has(line)) {
|
|
61
|
-
continue
|
|
62
|
-
}
|
|
63
|
-
seen.add(line)
|
|
64
|
-
|
|
65
|
-
if (extractorCache.get(extractor).has(line)) {
|
|
66
|
-
for (let match of extractorCache.get(extractor).get(line)) {
|
|
67
|
-
candidates.add(match)
|
|
68
|
-
}
|
|
69
|
-
} else {
|
|
70
|
-
let extractorMatches = extractor(line).filter((s) => s !== '!*')
|
|
71
|
-
let lineMatchesSet = new Set(extractorMatches)
|
|
72
|
-
|
|
73
|
-
for (let match of lineMatchesSet) {
|
|
74
|
-
candidates.add(match)
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
extractorCache.get(extractor).set(line, lineMatchesSet)
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
*
|
|
84
|
-
* @param {[import('./offsets.js').RuleOffset, import('postcss').Node][]} rules
|
|
85
|
-
* @param {*} context
|
|
86
|
-
*/
|
|
87
|
-
function buildStylesheet(rules, context) {
|
|
88
|
-
let sortedRules = context.offsets.sort(rules)
|
|
89
|
-
|
|
90
|
-
let returnValue = {
|
|
91
|
-
base: new Set(),
|
|
92
|
-
defaults: new Set(),
|
|
93
|
-
components: new Set(),
|
|
94
|
-
utilities: new Set(),
|
|
95
|
-
variants: new Set(),
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
for (let [sort, rule] of sortedRules) {
|
|
99
|
-
returnValue[sort.layer].add(rule)
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
return returnValue
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
export default function expandTailwindAtRules(context) {
|
|
106
|
-
return (root) => {
|
|
107
|
-
let layerNodes = {
|
|
108
|
-
base: null,
|
|
109
|
-
components: null,
|
|
110
|
-
utilities: null,
|
|
111
|
-
variants: null,
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
root.walkAtRules((rule) => {
|
|
115
|
-
// Make sure this file contains Tailwind directives. If not, we can save
|
|
116
|
-
// a lot of work and bail early. Also we don't have to register our touch
|
|
117
|
-
// file as a dependency since the output of this CSS does not depend on
|
|
118
|
-
// the source of any templates. Think Vue <style> blocks for example.
|
|
119
|
-
if (rule.name === 'tailwind') {
|
|
120
|
-
if (Object.keys(layerNodes).includes(rule.params)) {
|
|
121
|
-
layerNodes[rule.params] = rule
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
})
|
|
125
|
-
|
|
126
|
-
if (Object.values(layerNodes).every((n) => n === null)) {
|
|
127
|
-
return root
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
// ---
|
|
131
|
-
|
|
132
|
-
// Find potential rules in changed files
|
|
133
|
-
let candidates = new Set([...(context.candidates ?? []), sharedState.NOT_ON_DEMAND])
|
|
134
|
-
let seen = new Set()
|
|
135
|
-
|
|
136
|
-
env.DEBUG && console.time('Reading changed files')
|
|
137
|
-
|
|
138
|
-
if (flagEnabled(context.tailwindConfig, 'oxideParser')) {
|
|
139
|
-
let rustParserContent = []
|
|
140
|
-
let regexParserContent = []
|
|
141
|
-
|
|
142
|
-
for (let item of context.changedContent) {
|
|
143
|
-
let transformer = getTransformer(context.tailwindConfig, item.extension)
|
|
144
|
-
let extractor = getExtractor(context, item.extension)
|
|
145
|
-
|
|
146
|
-
if (transformer === builtInTransformers.DEFAULT && extractor?.DEFAULT_EXTRACTOR === true) {
|
|
147
|
-
rustParserContent.push(item)
|
|
148
|
-
} else {
|
|
149
|
-
regexParserContent.push([item, { transformer, extractor }])
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
if (rustParserContent.length > 0) {
|
|
154
|
-
for (let candidate of parseCandidateStrings(
|
|
155
|
-
rustParserContent,
|
|
156
|
-
IO.Parallel | Parsing.Parallel
|
|
157
|
-
)) {
|
|
158
|
-
candidates.add(candidate)
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
if (regexParserContent.length > 0) {
|
|
163
|
-
for (let [{ file, content }, { transformer, extractor }] of regexParserContent) {
|
|
164
|
-
content = file ? fs.readFileSync(file, 'utf8') : content
|
|
165
|
-
getClassCandidates(transformer(content), extractor, candidates, seen)
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
} else {
|
|
169
|
-
for (let { file, content, extension } of context.changedContent) {
|
|
170
|
-
let transformer = getTransformer(context.tailwindConfig, extension)
|
|
171
|
-
let extractor = getExtractor(context, extension)
|
|
172
|
-
content = file ? fs.readFileSync(file, 'utf8') : content
|
|
173
|
-
getClassCandidates(transformer(content), extractor, candidates, seen)
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
env.DEBUG && console.timeEnd('Reading changed files')
|
|
178
|
-
|
|
179
|
-
// ---
|
|
180
|
-
|
|
181
|
-
// Generate the actual CSS
|
|
182
|
-
let classCacheCount = context.classCache.size
|
|
183
|
-
|
|
184
|
-
env.DEBUG && console.time('Generate rules')
|
|
185
|
-
env.DEBUG && console.time('Sorting candidates')
|
|
186
|
-
// TODO: only sort if we are not using the oxide parser (flagEnabled(context.tailwindConfig,
|
|
187
|
-
// 'oxideParser')) AND if we got all the candidates form the oxideParser alone. This will not
|
|
188
|
-
// be the case currently if you have custom transformers / extractors.
|
|
189
|
-
let sortedCandidates = new Set(
|
|
190
|
-
[...candidates].sort((a, z) => {
|
|
191
|
-
if (a === z) return 0
|
|
192
|
-
if (a < z) return -1
|
|
193
|
-
return 1
|
|
194
|
-
})
|
|
195
|
-
)
|
|
196
|
-
env.DEBUG && console.timeEnd('Sorting candidates')
|
|
197
|
-
generateRules(sortedCandidates, context)
|
|
198
|
-
env.DEBUG && console.timeEnd('Generate rules')
|
|
199
|
-
|
|
200
|
-
// We only ever add to the classCache, so if it didn't grow, there is nothing new.
|
|
201
|
-
env.DEBUG && console.time('Build stylesheet')
|
|
202
|
-
if (context.stylesheetCache === null || context.classCache.size !== classCacheCount) {
|
|
203
|
-
context.stylesheetCache = buildStylesheet([...context.ruleCache], context)
|
|
204
|
-
}
|
|
205
|
-
env.DEBUG && console.timeEnd('Build stylesheet')
|
|
206
|
-
|
|
207
|
-
let {
|
|
208
|
-
defaults: defaultNodes,
|
|
209
|
-
base: baseNodes,
|
|
210
|
-
components: componentNodes,
|
|
211
|
-
utilities: utilityNodes,
|
|
212
|
-
variants: screenNodes,
|
|
213
|
-
} = context.stylesheetCache
|
|
214
|
-
|
|
215
|
-
// ---
|
|
216
|
-
|
|
217
|
-
// Replace any Tailwind directives with generated CSS
|
|
218
|
-
|
|
219
|
-
if (layerNodes.base) {
|
|
220
|
-
layerNodes.base.before(
|
|
221
|
-
cloneNodes([...baseNodes, ...defaultNodes], layerNodes.base.source, {
|
|
222
|
-
layer: 'base',
|
|
223
|
-
})
|
|
224
|
-
)
|
|
225
|
-
layerNodes.base.remove()
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
if (layerNodes.components) {
|
|
229
|
-
layerNodes.components.before(
|
|
230
|
-
cloneNodes([...componentNodes], layerNodes.components.source, {
|
|
231
|
-
layer: 'components',
|
|
232
|
-
})
|
|
233
|
-
)
|
|
234
|
-
layerNodes.components.remove()
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
if (layerNodes.utilities) {
|
|
238
|
-
layerNodes.utilities.before(
|
|
239
|
-
cloneNodes([...utilityNodes], layerNodes.utilities.source, {
|
|
240
|
-
layer: 'utilities',
|
|
241
|
-
})
|
|
242
|
-
)
|
|
243
|
-
layerNodes.utilities.remove()
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
// We do post-filtering to not alter the emitted order of the variants
|
|
247
|
-
const variantNodes = Array.from(screenNodes).filter((node) => {
|
|
248
|
-
const parentLayer = node.raws.tailwind?.parentLayer
|
|
249
|
-
|
|
250
|
-
if (parentLayer === 'components') {
|
|
251
|
-
return layerNodes.components !== null
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
if (parentLayer === 'utilities') {
|
|
255
|
-
return layerNodes.utilities !== null
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
return true
|
|
259
|
-
})
|
|
260
|
-
|
|
261
|
-
if (layerNodes.variants) {
|
|
262
|
-
layerNodes.variants.before(
|
|
263
|
-
cloneNodes(variantNodes, layerNodes.variants.source, {
|
|
264
|
-
layer: 'variants',
|
|
265
|
-
})
|
|
266
|
-
)
|
|
267
|
-
layerNodes.variants.remove()
|
|
268
|
-
} else if (variantNodes.length > 0) {
|
|
269
|
-
let cloned = cloneNodes(variantNodes, undefined, {
|
|
270
|
-
layer: 'variants',
|
|
271
|
-
})
|
|
272
|
-
|
|
273
|
-
cloned.forEach((node) => {
|
|
274
|
-
let parentLayer = node.raws.tailwind?.parentLayer ?? null
|
|
275
|
-
|
|
276
|
-
node.walk((n) => {
|
|
277
|
-
if (!n.source) {
|
|
278
|
-
n.source = layerNodes[parentLayer].source
|
|
279
|
-
}
|
|
280
|
-
})
|
|
281
|
-
})
|
|
282
|
-
|
|
283
|
-
root.append(cloned)
|
|
284
|
-
}
|
|
285
|
-
|
|
286
|
-
// If we've got a utility layer and no utilities are generated there's likely something wrong
|
|
287
|
-
const hasUtilityVariants = variantNodes.some(
|
|
288
|
-
(node) => node.raws.tailwind?.parentLayer === 'utilities'
|
|
289
|
-
)
|
|
290
|
-
|
|
291
|
-
if (layerNodes.utilities && utilityNodes.size === 0 && !hasUtilityVariants) {
|
|
292
|
-
log.warn('content-problems', [
|
|
293
|
-
'No utility classes were detected in your source files. If this is unexpected, double-check the `content` option in your Tailwind CSS configuration.',
|
|
294
|
-
'https://tailwindcss.com/docs/content-configuration',
|
|
295
|
-
])
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
// ---
|
|
299
|
-
|
|
300
|
-
if (env.DEBUG) {
|
|
301
|
-
console.log('Potential classes: ', candidates.size)
|
|
302
|
-
console.log('Active contexts: ', sharedState.contextSourcesMap.size)
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
// Clear the cache for the changed files
|
|
306
|
-
context.changedContent = []
|
|
307
|
-
|
|
308
|
-
// Cleanup any leftover @layer atrules
|
|
309
|
-
root.walkAtRules('layer', (rule) => {
|
|
310
|
-
if (Object.keys(layerNodes).includes(rule.params)) {
|
|
311
|
-
rule.remove()
|
|
312
|
-
}
|
|
313
|
-
})
|
|
314
|
-
}
|
|
315
|
-
}
|
|
@@ -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
|
-
}
|