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,169 +0,0 @@
|
|
|
1
|
-
// @ts-check
|
|
2
|
-
|
|
3
|
-
import fs from 'fs'
|
|
4
|
-
import LRU from '@alloc/quick-lru'
|
|
5
|
-
|
|
6
|
-
import hash from '../util/hashConfig'
|
|
7
|
-
import resolveConfig from '../public/resolve-config'
|
|
8
|
-
import resolveConfigPath from '../util/resolveConfigPath'
|
|
9
|
-
import { getContext, getFileModifiedMap } from './setupContextUtils'
|
|
10
|
-
import parseDependency from '../util/parseDependency'
|
|
11
|
-
import { validateConfig } from '../util/validateConfig.js'
|
|
12
|
-
import { parseCandidateFiles, resolvedChangedContent } from './content.js'
|
|
13
|
-
import { loadConfig } from '../lib/load-config'
|
|
14
|
-
import getModuleDependencies from './getModuleDependencies'
|
|
15
|
-
|
|
16
|
-
let configPathCache = new LRU({ maxSize: 100 })
|
|
17
|
-
|
|
18
|
-
let candidateFilesCache = new WeakMap()
|
|
19
|
-
|
|
20
|
-
function getCandidateFiles(context, tailwindConfig) {
|
|
21
|
-
if (candidateFilesCache.has(context)) {
|
|
22
|
-
return candidateFilesCache.get(context)
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
let candidateFiles = parseCandidateFiles(context, tailwindConfig)
|
|
26
|
-
|
|
27
|
-
return candidateFilesCache.set(context, candidateFiles).get(context)
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
// Get the config object based on a path
|
|
31
|
-
function getTailwindConfig(configOrPath) {
|
|
32
|
-
let userConfigPath = resolveConfigPath(configOrPath)
|
|
33
|
-
|
|
34
|
-
if (userConfigPath !== null) {
|
|
35
|
-
let [prevConfig, prevConfigHash, prevDeps, prevModified] =
|
|
36
|
-
configPathCache.get(userConfigPath) || []
|
|
37
|
-
|
|
38
|
-
let newDeps = getModuleDependencies(userConfigPath)
|
|
39
|
-
|
|
40
|
-
let modified = false
|
|
41
|
-
let newModified = new Map()
|
|
42
|
-
for (let file of newDeps) {
|
|
43
|
-
let time = fs.statSync(file).mtimeMs
|
|
44
|
-
newModified.set(file, time)
|
|
45
|
-
if (!prevModified || !prevModified.has(file) || time > prevModified.get(file)) {
|
|
46
|
-
modified = true
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
// It hasn't changed (based on timestamps)
|
|
51
|
-
if (!modified) {
|
|
52
|
-
return [prevConfig, userConfigPath, prevConfigHash, prevDeps]
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
// It has changed (based on timestamps), or first run
|
|
56
|
-
for (let file of newDeps) {
|
|
57
|
-
delete require.cache[file]
|
|
58
|
-
}
|
|
59
|
-
let newConfig = validateConfig(resolveConfig(loadConfig(userConfigPath)))
|
|
60
|
-
let newHash = hash(newConfig)
|
|
61
|
-
configPathCache.set(userConfigPath, [newConfig, newHash, newDeps, newModified])
|
|
62
|
-
return [newConfig, userConfigPath, newHash, newDeps]
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
// It's a plain object, not a path
|
|
66
|
-
let newConfig = resolveConfig(configOrPath?.config ?? configOrPath ?? {})
|
|
67
|
-
|
|
68
|
-
newConfig = validateConfig(newConfig)
|
|
69
|
-
|
|
70
|
-
return [newConfig, null, hash(newConfig), []]
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
// DISABLE_TOUCH = TRUE
|
|
74
|
-
|
|
75
|
-
// Retrieve an existing context from cache if possible (since contexts are unique per
|
|
76
|
-
// source path), or set up a new one (including setting up watchers and registering
|
|
77
|
-
// plugins) then return it
|
|
78
|
-
export default function setupTrackingContext(configOrPath) {
|
|
79
|
-
return ({ tailwindDirectives, registerDependency }) => {
|
|
80
|
-
return (root, result) => {
|
|
81
|
-
let [tailwindConfig, userConfigPath, tailwindConfigHash, configDependencies] =
|
|
82
|
-
getTailwindConfig(configOrPath)
|
|
83
|
-
|
|
84
|
-
let contextDependencies = new Set(configDependencies)
|
|
85
|
-
|
|
86
|
-
// If there are no @tailwind or @apply rules, we don't consider this CSS
|
|
87
|
-
// file or its dependencies to be dependencies of the context. Can reuse
|
|
88
|
-
// the context even if they change. We may want to think about `@layer`
|
|
89
|
-
// being part of this trigger too, but it's tough because it's impossible
|
|
90
|
-
// for a layer in one file to end up in the actual @tailwind rule in
|
|
91
|
-
// another file since independent sources are effectively isolated.
|
|
92
|
-
if (tailwindDirectives.size > 0) {
|
|
93
|
-
// Add current css file as a context dependencies.
|
|
94
|
-
contextDependencies.add(result.opts.from)
|
|
95
|
-
|
|
96
|
-
// Add all css @import dependencies as context dependencies.
|
|
97
|
-
for (let message of result.messages) {
|
|
98
|
-
if (message.type === 'dependency') {
|
|
99
|
-
contextDependencies.add(message.file)
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
let [context, , mTimesToCommit] = getContext(
|
|
105
|
-
root,
|
|
106
|
-
result,
|
|
107
|
-
tailwindConfig,
|
|
108
|
-
userConfigPath,
|
|
109
|
-
tailwindConfigHash,
|
|
110
|
-
contextDependencies
|
|
111
|
-
)
|
|
112
|
-
|
|
113
|
-
let fileModifiedMap = getFileModifiedMap(context)
|
|
114
|
-
|
|
115
|
-
let candidateFiles = getCandidateFiles(context, tailwindConfig)
|
|
116
|
-
|
|
117
|
-
// If there are no @tailwind or @apply rules, we don't consider this CSS file or it's
|
|
118
|
-
// dependencies to be dependencies of the context. Can reuse the context even if they change.
|
|
119
|
-
// We may want to think about `@layer` being part of this trigger too, but it's tough
|
|
120
|
-
// because it's impossible for a layer in one file to end up in the actual @tailwind rule
|
|
121
|
-
// in another file since independent sources are effectively isolated.
|
|
122
|
-
if (tailwindDirectives.size > 0) {
|
|
123
|
-
// Add template paths as postcss dependencies.
|
|
124
|
-
for (let contentPath of candidateFiles) {
|
|
125
|
-
for (let dependency of parseDependency(contentPath)) {
|
|
126
|
-
registerDependency(dependency)
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
let [changedContent, contentMTimesToCommit] = resolvedChangedContent(
|
|
131
|
-
context,
|
|
132
|
-
candidateFiles,
|
|
133
|
-
fileModifiedMap
|
|
134
|
-
)
|
|
135
|
-
|
|
136
|
-
for (let content of changedContent) {
|
|
137
|
-
context.changedContent.push(content)
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
// Add the mtimes of the content files to the commit list
|
|
141
|
-
// We can overwrite the existing values because unconditionally
|
|
142
|
-
// This is because:
|
|
143
|
-
// 1. Most of the files here won't be in the map yet
|
|
144
|
-
// 2. If they are that means it's a context dependency
|
|
145
|
-
// and we're reading this after the context. This means
|
|
146
|
-
// that the mtime we just read is strictly >= the context
|
|
147
|
-
// mtime. Unless the user / os is doing something weird
|
|
148
|
-
// in which the mtime would be going backwards. If that
|
|
149
|
-
// happens there's already going to be problems.
|
|
150
|
-
for (let [path, mtime] of contentMTimesToCommit.entries()) {
|
|
151
|
-
mTimesToCommit.set(path, mtime)
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
for (let file of configDependencies) {
|
|
156
|
-
registerDependency({ type: 'dependency', file })
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
// "commit" the new modified time for all context deps
|
|
160
|
-
// We do this here because we want content tracking to
|
|
161
|
-
// read the "old" mtime even when it's a context dependency.
|
|
162
|
-
for (let [path, mtime] of mTimesToCommit.entries()) {
|
|
163
|
-
fileModifiedMap.set(path, mtime)
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
return context
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
}
|
package/src/lib/sharedState.js
DELETED
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
export const env =
|
|
2
|
-
typeof process !== 'undefined'
|
|
3
|
-
? {
|
|
4
|
-
NODE_ENV: process.env.NODE_ENV,
|
|
5
|
-
DEBUG: resolveDebug(process.env.DEBUG),
|
|
6
|
-
}
|
|
7
|
-
: {
|
|
8
|
-
NODE_ENV: 'production',
|
|
9
|
-
DEBUG: false,
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export const contextMap = new Map()
|
|
13
|
-
export const configContextMap = new Map()
|
|
14
|
-
export const contextSourcesMap = new Map()
|
|
15
|
-
export const sourceHashMap = new Map()
|
|
16
|
-
export const NOT_ON_DEMAND = new String('*')
|
|
17
|
-
|
|
18
|
-
export const NONE = Symbol('__NONE__')
|
|
19
|
-
|
|
20
|
-
export function resolveDebug(debug) {
|
|
21
|
-
if (debug === undefined) {
|
|
22
|
-
return false
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
// Environment variables are strings, so convert to boolean
|
|
26
|
-
if (debug === 'true' || debug === '1') {
|
|
27
|
-
return true
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
if (debug === 'false' || debug === '0') {
|
|
31
|
-
return false
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
// Keep the debug convention into account:
|
|
35
|
-
// DEBUG=* -> This enables all debug modes
|
|
36
|
-
// DEBUG=projectA,projectB,projectC -> This enables debug for projectA, projectB and projectC
|
|
37
|
-
// DEBUG=projectA:* -> This enables all debug modes for projectA (if you have sub-types)
|
|
38
|
-
// DEBUG=projectA,-projectB -> This enables debug for projectA and explicitly disables it for projectB
|
|
39
|
-
|
|
40
|
-
if (debug === '*') {
|
|
41
|
-
return true
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
let debuggers = debug.split(',').map((d) => d.split(':')[0])
|
|
45
|
-
|
|
46
|
-
// Ignoring tailwindcss
|
|
47
|
-
if (debuggers.includes('-tailwindcss')) {
|
|
48
|
-
return false
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
// Including tailwindcss
|
|
52
|
-
if (debuggers.includes('tailwindcss')) {
|
|
53
|
-
return true
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
return false
|
|
57
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { normalizeScreens } from '../util/normalizeScreens'
|
|
2
|
-
import buildMediaQuery from '../util/buildMediaQuery'
|
|
3
|
-
|
|
4
|
-
export default function ({ tailwindConfig: { theme } }) {
|
|
5
|
-
return function (css) {
|
|
6
|
-
css.walkAtRules('screen', (atRule) => {
|
|
7
|
-
let screen = atRule.params
|
|
8
|
-
let screens = normalizeScreens(theme.screens)
|
|
9
|
-
let screenDefinition = screens.find(({ name }) => name === screen)
|
|
10
|
-
|
|
11
|
-
if (!screenDefinition) {
|
|
12
|
-
throw atRule.error(`No \`${screen}\` screen found.`)
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
atRule.name = 'media'
|
|
16
|
-
atRule.params = buildMediaQuery(screenDefinition)
|
|
17
|
-
})
|
|
18
|
-
}
|
|
19
|
-
}
|
package/src/plugin.js
DELETED
|
@@ -1,124 +0,0 @@
|
|
|
1
|
-
import postcss from 'postcss'
|
|
2
|
-
import lightningcss from 'lightningcss'
|
|
3
|
-
import browserslist from 'browserslist'
|
|
4
|
-
import setupTrackingContext from './lib/setupTrackingContext'
|
|
5
|
-
import processTailwindFeatures from './processTailwindFeatures'
|
|
6
|
-
import { env } from './lib/sharedState'
|
|
7
|
-
import { findAtConfigPath } from './lib/findAtConfigPath'
|
|
8
|
-
import { handleImportAtRules } from './lib/handleImportAtRules'
|
|
9
|
-
|
|
10
|
-
module.exports = function tailwindcss(configOrPath) {
|
|
11
|
-
return {
|
|
12
|
-
postcssPlugin: 'tailwindcss',
|
|
13
|
-
plugins: [
|
|
14
|
-
env.DEBUG &&
|
|
15
|
-
function (root) {
|
|
16
|
-
console.log('\n')
|
|
17
|
-
console.time('JIT TOTAL')
|
|
18
|
-
return root
|
|
19
|
-
},
|
|
20
|
-
...handleImportAtRules(),
|
|
21
|
-
function (root, result) {
|
|
22
|
-
// Use the path for the `@config` directive if it exists, otherwise use the
|
|
23
|
-
// path for the file being processed
|
|
24
|
-
configOrPath = findAtConfigPath(root, result) ?? configOrPath
|
|
25
|
-
|
|
26
|
-
let context = setupTrackingContext(configOrPath)
|
|
27
|
-
|
|
28
|
-
if (root.type === 'document') {
|
|
29
|
-
let roots = root.nodes.filter((node) => node.type === 'root')
|
|
30
|
-
|
|
31
|
-
for (const root of roots) {
|
|
32
|
-
if (root.type === 'root') {
|
|
33
|
-
processTailwindFeatures(context)(root, result)
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
return
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
processTailwindFeatures(context)(root, result)
|
|
41
|
-
},
|
|
42
|
-
function lightningCssPlugin(_root, result) {
|
|
43
|
-
let map = result.map ?? result.opts.map
|
|
44
|
-
|
|
45
|
-
let intermediateResult = result.root.toResult({
|
|
46
|
-
map: map ? { inline: true } : false,
|
|
47
|
-
})
|
|
48
|
-
let intermediateMap = intermediateResult.map?.toJSON?.() ?? map
|
|
49
|
-
|
|
50
|
-
try {
|
|
51
|
-
let transformed = lightningcss.transform({
|
|
52
|
-
filename: result.opts.from,
|
|
53
|
-
code: Buffer.from(intermediateResult.css),
|
|
54
|
-
minify: false,
|
|
55
|
-
sourceMap: !!intermediateMap,
|
|
56
|
-
targets:
|
|
57
|
-
typeof process !== 'undefined' && process.env.JEST_WORKER_ID
|
|
58
|
-
? { chrome: 111 << 16 }
|
|
59
|
-
: lightningcss.browserslistToTargets(
|
|
60
|
-
browserslist(require('../package.json').browserslist)
|
|
61
|
-
),
|
|
62
|
-
drafts: {
|
|
63
|
-
nesting: true,
|
|
64
|
-
customMedia: true,
|
|
65
|
-
},
|
|
66
|
-
nonStandard: {
|
|
67
|
-
deepSelectorCombinator: true,
|
|
68
|
-
},
|
|
69
|
-
})
|
|
70
|
-
|
|
71
|
-
let code = transformed.code.toString()
|
|
72
|
-
|
|
73
|
-
// https://postcss.org/api/#sourcemapoptions
|
|
74
|
-
if (intermediateMap && transformed.map != null) {
|
|
75
|
-
let prev = transformed.map.toString()
|
|
76
|
-
|
|
77
|
-
if (typeof intermediateMap === 'object') {
|
|
78
|
-
intermediateMap.prev = prev
|
|
79
|
-
} else {
|
|
80
|
-
code = `${code}\n/*# sourceMappingURL=data:application/json;base64,${Buffer.from(
|
|
81
|
-
prev
|
|
82
|
-
).toString('base64')} */`
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
result.root = postcss.parse(code, {
|
|
87
|
-
...result.opts,
|
|
88
|
-
map: intermediateMap,
|
|
89
|
-
})
|
|
90
|
-
} catch (err) {
|
|
91
|
-
if (err.source && typeof process !== 'undefined' && process.env.JEST_WORKER_ID) {
|
|
92
|
-
let lines = err.source.split('\n')
|
|
93
|
-
err = new Error(
|
|
94
|
-
[
|
|
95
|
-
'Error formatting using Lightning CSS:',
|
|
96
|
-
'',
|
|
97
|
-
...[
|
|
98
|
-
'```css',
|
|
99
|
-
...lines.slice(Math.max(err.loc.line - 3, 0), err.loc.line),
|
|
100
|
-
' '.repeat(err.loc.column - 1) + '^-- ' + err.toString(),
|
|
101
|
-
...lines.slice(err.loc.line, err.loc.line + 2),
|
|
102
|
-
'```',
|
|
103
|
-
],
|
|
104
|
-
].join('\n')
|
|
105
|
-
)
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
if (Error.captureStackTrace) {
|
|
109
|
-
Error.captureStackTrace(err, lightningCssPlugin)
|
|
110
|
-
}
|
|
111
|
-
throw err
|
|
112
|
-
}
|
|
113
|
-
},
|
|
114
|
-
env.DEBUG &&
|
|
115
|
-
function (root) {
|
|
116
|
-
console.timeEnd('JIT TOTAL')
|
|
117
|
-
console.log('\n')
|
|
118
|
-
return root
|
|
119
|
-
},
|
|
120
|
-
].filter(Boolean),
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
module.exports.postcss = true
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
# tailwindcss/nesting
|
|
2
|
-
|
|
3
|
-
This is a PostCSS plugin that wraps [postcss-nested](https://github.com/postcss/postcss-nested) or [postcss-nesting](https://github.com/csstools/postcss-plugins/tree/main/plugins/postcss-nesting) and acts as a compatibility layer to make sure your nesting plugin of choice properly understands Tailwind's custom syntax like `@apply` and `@screen`.
|
|
4
|
-
|
|
5
|
-
Add it to your PostCSS configuration, somewhere before Tailwind itself:
|
|
6
|
-
|
|
7
|
-
```js
|
|
8
|
-
// postcss.config.js
|
|
9
|
-
module.exports = {
|
|
10
|
-
plugins: [
|
|
11
|
-
require('postcss-import'),
|
|
12
|
-
require('tailwindcss/nesting'),
|
|
13
|
-
require('tailwindcss'),
|
|
14
|
-
require('autoprefixer'),
|
|
15
|
-
]
|
|
16
|
-
}
|
|
17
|
-
```
|
|
18
|
-
|
|
19
|
-
By default, it uses the [postcss-nested](https://github.com/postcss/postcss-nested) plugin under the hood, which uses a Sass-like syntax and is the plugin that powers nesting support in the [Tailwind CSS plugin API](https://tailwindcss.com/docs/plugins#css-in-js-syntax).
|
|
20
|
-
|
|
21
|
-
If you'd rather use [postcss-nesting](https://github.com/csstools/postcss-plugins/tree/main/plugins/postcss-nesting) (which is based on the work-in-progress [CSS Nesting](https://drafts.csswg.org/css-nesting-1/) specification), first install the plugin alongside:
|
|
22
|
-
|
|
23
|
-
```shell
|
|
24
|
-
npm install postcss-nesting
|
|
25
|
-
```
|
|
26
|
-
|
|
27
|
-
Then pass the plugin itself as an argument to `tailwindcss/nesting` in your PostCSS configuration:
|
|
28
|
-
|
|
29
|
-
```js
|
|
30
|
-
// postcss.config.js
|
|
31
|
-
module.exports = {
|
|
32
|
-
plugins: [
|
|
33
|
-
require('postcss-import'),
|
|
34
|
-
require('tailwindcss/nesting')(require('postcss-nesting')),
|
|
35
|
-
require('tailwindcss'),
|
|
36
|
-
require('autoprefixer'),
|
|
37
|
-
]
|
|
38
|
-
}
|
|
39
|
-
```
|
|
40
|
-
|
|
41
|
-
This can also be helpful if for whatever reason you need to use a very specific version of `postcss-nested` and want to override the version we bundle with `tailwindcss/nesting` itself.
|
|
42
|
-
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import postcss from 'postcss'
|
|
2
|
-
import postcssNested from 'postcss-nested'
|
|
3
|
-
|
|
4
|
-
export function nesting(opts = postcssNested) {
|
|
5
|
-
return (root, result) => {
|
|
6
|
-
root.walkAtRules('screen', (rule) => {
|
|
7
|
-
rule.name = 'media'
|
|
8
|
-
rule.params = `screen(${rule.params})`
|
|
9
|
-
})
|
|
10
|
-
|
|
11
|
-
root.walkAtRules('apply', (rule) => {
|
|
12
|
-
rule.before(postcss.decl({ prop: '__apply', value: rule.params, source: rule.source }))
|
|
13
|
-
rule.remove()
|
|
14
|
-
})
|
|
15
|
-
|
|
16
|
-
let plugin = (() => {
|
|
17
|
-
if (
|
|
18
|
-
typeof opts === 'function' ||
|
|
19
|
-
(typeof opts === 'object' && opts?.hasOwnProperty?.('postcssPlugin'))
|
|
20
|
-
) {
|
|
21
|
-
return opts
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
if (typeof opts === 'string') {
|
|
25
|
-
return require(opts)
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
if (Object.keys(opts).length <= 0) {
|
|
29
|
-
return postcssNested
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
throw new Error('tailwindcss/nesting should be loaded with a nesting plugin.')
|
|
33
|
-
})()
|
|
34
|
-
|
|
35
|
-
postcss([plugin]).process(root, result.opts).sync()
|
|
36
|
-
|
|
37
|
-
root.walkDecls('__apply', (decl) => {
|
|
38
|
-
decl.before(postcss.atRule({ name: 'apply', params: decl.value, source: decl.source }))
|
|
39
|
-
decl.remove()
|
|
40
|
-
})
|
|
41
|
-
|
|
42
|
-
/**
|
|
43
|
-
* Use a private PostCSS API to remove the "clean" flag from the entire AST.
|
|
44
|
-
* This is done because running process() on the AST will set the "clean"
|
|
45
|
-
* flag on all nodes, which we don't want.
|
|
46
|
-
*
|
|
47
|
-
* This causes downstream plugins using the visitor API to be skipped.
|
|
48
|
-
*
|
|
49
|
-
* This is guarded because the PostCSS API is not public
|
|
50
|
-
* and may change in future versions of PostCSS.
|
|
51
|
-
*
|
|
52
|
-
* See https://github.com/postcss/postcss/issues/1712 for more details
|
|
53
|
-
*
|
|
54
|
-
* @param {import('postcss').Node} node
|
|
55
|
-
*/
|
|
56
|
-
function markDirty(node) {
|
|
57
|
-
if (!('markDirty' in node)) {
|
|
58
|
-
return
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
// Traverse the tree down to the leaf nodes
|
|
62
|
-
if (node.nodes) {
|
|
63
|
-
node.nodes.forEach((n) => markDirty(n))
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// If it's a leaf node mark it as dirty
|
|
67
|
-
// We do this here because marking a node as dirty
|
|
68
|
-
// will walk up the tree and mark all parents as dirty
|
|
69
|
-
// resulting in a lot of unnecessary work if we did this
|
|
70
|
-
// for every single node
|
|
71
|
-
if (!node.nodes) {
|
|
72
|
-
node.markDirty()
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
markDirty(root)
|
|
77
|
-
|
|
78
|
-
return root
|
|
79
|
-
}
|
|
80
|
-
}
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
import normalizeTailwindDirectives from './lib/normalizeTailwindDirectives'
|
|
2
|
-
import expandTailwindAtRules from './lib/expandTailwindAtRules'
|
|
3
|
-
import expandApplyAtRules from './lib/expandApplyAtRules'
|
|
4
|
-
import evaluateTailwindFunctions from './lib/evaluateTailwindFunctions'
|
|
5
|
-
import substituteScreenAtRules from './lib/substituteScreenAtRules'
|
|
6
|
-
import resolveDefaultsAtRules from './lib/resolveDefaultsAtRules'
|
|
7
|
-
import collapseAdjacentRules from './lib/collapseAdjacentRules'
|
|
8
|
-
import collapseDuplicateDeclarations from './lib/collapseDuplicateDeclarations'
|
|
9
|
-
import partitionApplyAtRules from './lib/partitionApplyAtRules'
|
|
10
|
-
import detectNesting from './lib/detectNesting'
|
|
11
|
-
import { createContext } from './lib/setupContextUtils'
|
|
12
|
-
import { issueFlagNotices } from './featureFlags'
|
|
13
|
-
|
|
14
|
-
export default function processTailwindFeatures(setupContext) {
|
|
15
|
-
return function (root, result) {
|
|
16
|
-
let { tailwindDirectives, applyDirectives } = normalizeTailwindDirectives(root)
|
|
17
|
-
|
|
18
|
-
detectNesting()(root, result)
|
|
19
|
-
|
|
20
|
-
// Partition apply rules that are found in the css
|
|
21
|
-
// itself.
|
|
22
|
-
partitionApplyAtRules()(root, result)
|
|
23
|
-
|
|
24
|
-
let context = setupContext({
|
|
25
|
-
tailwindDirectives,
|
|
26
|
-
applyDirectives,
|
|
27
|
-
registerDependency(dependency) {
|
|
28
|
-
result.messages.push({
|
|
29
|
-
plugin: 'tailwindcss',
|
|
30
|
-
parent: result.opts.from,
|
|
31
|
-
...dependency,
|
|
32
|
-
})
|
|
33
|
-
},
|
|
34
|
-
createContext(tailwindConfig, changedContent) {
|
|
35
|
-
return createContext(tailwindConfig, changedContent, root)
|
|
36
|
-
},
|
|
37
|
-
})(root, result)
|
|
38
|
-
|
|
39
|
-
if (context.tailwindConfig.separator === '-') {
|
|
40
|
-
throw new Error(
|
|
41
|
-
"The '-' character cannot be used as a custom separator in JIT mode due to parsing ambiguity. Please use another character like '_' instead."
|
|
42
|
-
)
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
issueFlagNotices(context.tailwindConfig)
|
|
46
|
-
|
|
47
|
-
expandTailwindAtRules(context)(root, result)
|
|
48
|
-
// Partition apply rules that are generated by
|
|
49
|
-
// addComponents, addUtilities and so on.
|
|
50
|
-
partitionApplyAtRules()(root, result)
|
|
51
|
-
expandApplyAtRules(context)(root, result)
|
|
52
|
-
evaluateTailwindFunctions(context)(root, result)
|
|
53
|
-
substituteScreenAtRules(context)(root, result)
|
|
54
|
-
resolveDefaultsAtRules(context)(root, result)
|
|
55
|
-
collapseAdjacentRules(context)(root, result)
|
|
56
|
-
collapseDuplicateDeclarations(context)(root, result)
|
|
57
|
-
}
|
|
58
|
-
}
|