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,301 +0,0 @@
|
|
1
|
-
import { flagEnabled } from '../featureFlags'
|
2
|
-
import log, { dim } from './log'
|
3
|
-
|
4
|
-
export function normalizeConfig(config) {
|
5
|
-
// Quick structure validation
|
6
|
-
/**
|
7
|
-
* type FilePath = string
|
8
|
-
* type RawFile = { raw: string, extension?: string }
|
9
|
-
* type ExtractorFn = (content: string) => Array<string>
|
10
|
-
* type TransformerFn = (content: string) => string
|
11
|
-
*
|
12
|
-
* type Content =
|
13
|
-
* | Array<FilePath | RawFile>
|
14
|
-
* | {
|
15
|
-
* files: Array<FilePath | RawFile>,
|
16
|
-
* extract?: ExtractorFn | { [extension: string]: ExtractorFn }
|
17
|
-
* transform?: TransformerFn | { [extension: string]: TransformerFn }
|
18
|
-
* }
|
19
|
-
*/
|
20
|
-
let valid = (() => {
|
21
|
-
// `config.purge` should not exist anymore
|
22
|
-
if (config.purge) {
|
23
|
-
return false
|
24
|
-
}
|
25
|
-
|
26
|
-
// `config.content` should exist
|
27
|
-
if (!config.content) {
|
28
|
-
return false
|
29
|
-
}
|
30
|
-
|
31
|
-
// `config.content` should be an object or an array
|
32
|
-
if (
|
33
|
-
!Array.isArray(config.content) &&
|
34
|
-
!(typeof config.content === 'object' && config.content !== null)
|
35
|
-
) {
|
36
|
-
return false
|
37
|
-
}
|
38
|
-
|
39
|
-
// When `config.content` is an array, it should consist of FilePaths or RawFiles
|
40
|
-
if (Array.isArray(config.content)) {
|
41
|
-
return config.content.every((path) => {
|
42
|
-
// `path` can be a string
|
43
|
-
if (typeof path === 'string') return true
|
44
|
-
|
45
|
-
// `path` can be an object { raw: string, extension?: string }
|
46
|
-
// `raw` must be a string
|
47
|
-
if (typeof path?.raw !== 'string') return false
|
48
|
-
|
49
|
-
// `extension` (if provided) should also be a string
|
50
|
-
if (path?.extension && typeof path?.extension !== 'string') {
|
51
|
-
return false
|
52
|
-
}
|
53
|
-
|
54
|
-
return true
|
55
|
-
})
|
56
|
-
}
|
57
|
-
|
58
|
-
// When `config.content` is an object
|
59
|
-
if (typeof config.content === 'object' && config.content !== null) {
|
60
|
-
// Only `files`, `relative`, `extract`, and `transform` can exist in `config.content`
|
61
|
-
if (
|
62
|
-
Object.keys(config.content).some(
|
63
|
-
(key) => !['files', 'relative', 'extract', 'transform'].includes(key)
|
64
|
-
)
|
65
|
-
) {
|
66
|
-
return false
|
67
|
-
}
|
68
|
-
|
69
|
-
// `config.content.files` should exist of FilePaths or RawFiles
|
70
|
-
if (Array.isArray(config.content.files)) {
|
71
|
-
if (
|
72
|
-
!config.content.files.every((path) => {
|
73
|
-
// `path` can be a string
|
74
|
-
if (typeof path === 'string') return true
|
75
|
-
|
76
|
-
// `path` can be an object { raw: string, extension?: string }
|
77
|
-
// `raw` must be a string
|
78
|
-
if (typeof path?.raw !== 'string') return false
|
79
|
-
|
80
|
-
// `extension` (if provided) should also be a string
|
81
|
-
if (path?.extension && typeof path?.extension !== 'string') {
|
82
|
-
return false
|
83
|
-
}
|
84
|
-
|
85
|
-
return true
|
86
|
-
})
|
87
|
-
) {
|
88
|
-
return false
|
89
|
-
}
|
90
|
-
|
91
|
-
// `config.content.extract` is optional, and can be a Function or a Record<String, Function>
|
92
|
-
if (typeof config.content.extract === 'object') {
|
93
|
-
for (let value of Object.values(config.content.extract)) {
|
94
|
-
if (typeof value !== 'function') {
|
95
|
-
return false
|
96
|
-
}
|
97
|
-
}
|
98
|
-
} else if (
|
99
|
-
!(config.content.extract === undefined || typeof config.content.extract === 'function')
|
100
|
-
) {
|
101
|
-
return false
|
102
|
-
}
|
103
|
-
|
104
|
-
// `config.content.transform` is optional, and can be a Function or a Record<String, Function>
|
105
|
-
if (typeof config.content.transform === 'object') {
|
106
|
-
for (let value of Object.values(config.content.transform)) {
|
107
|
-
if (typeof value !== 'function') {
|
108
|
-
return false
|
109
|
-
}
|
110
|
-
}
|
111
|
-
} else if (
|
112
|
-
!(
|
113
|
-
config.content.transform === undefined || typeof config.content.transform === 'function'
|
114
|
-
)
|
115
|
-
) {
|
116
|
-
return false
|
117
|
-
}
|
118
|
-
|
119
|
-
// `config.content.relative` is optional and can be a boolean
|
120
|
-
if (
|
121
|
-
typeof config.content.relative !== 'boolean' &&
|
122
|
-
typeof config.content.relative !== 'undefined'
|
123
|
-
) {
|
124
|
-
return false
|
125
|
-
}
|
126
|
-
}
|
127
|
-
|
128
|
-
return true
|
129
|
-
}
|
130
|
-
|
131
|
-
return false
|
132
|
-
})()
|
133
|
-
|
134
|
-
if (!valid) {
|
135
|
-
log.warn('purge-deprecation', [
|
136
|
-
'The `purge`/`content` options have changed in Tailwind CSS v3.0.',
|
137
|
-
'Update your configuration file to eliminate this warning.',
|
138
|
-
'https://tailwindcss.com/docs/upgrade-guide#configure-content-sources',
|
139
|
-
])
|
140
|
-
}
|
141
|
-
|
142
|
-
// Normalize the `safelist`
|
143
|
-
config.safelist = (() => {
|
144
|
-
let { content, purge, safelist } = config
|
145
|
-
|
146
|
-
if (Array.isArray(safelist)) return safelist
|
147
|
-
if (Array.isArray(content?.safelist)) return content.safelist
|
148
|
-
if (Array.isArray(purge?.safelist)) return purge.safelist
|
149
|
-
if (Array.isArray(purge?.options?.safelist)) return purge.options.safelist
|
150
|
-
|
151
|
-
return []
|
152
|
-
})()
|
153
|
-
|
154
|
-
// Normalize the `blocklist`
|
155
|
-
config.blocklist = (() => {
|
156
|
-
let { blocklist } = config
|
157
|
-
|
158
|
-
if (Array.isArray(blocklist)) {
|
159
|
-
if (blocklist.every((item) => typeof item === 'string')) {
|
160
|
-
return blocklist
|
161
|
-
}
|
162
|
-
|
163
|
-
log.warn('blocklist-invalid', [
|
164
|
-
'The `blocklist` option must be an array of strings.',
|
165
|
-
'https://tailwindcss.com/docs/content-configuration#discarding-classes',
|
166
|
-
])
|
167
|
-
}
|
168
|
-
|
169
|
-
return []
|
170
|
-
})()
|
171
|
-
|
172
|
-
// Normalize prefix option
|
173
|
-
if (typeof config.prefix === 'function') {
|
174
|
-
log.warn('prefix-function', [
|
175
|
-
'As of Tailwind CSS v3.0, `prefix` cannot be a function.',
|
176
|
-
'Update `prefix` in your configuration to be a string to eliminate this warning.',
|
177
|
-
'https://tailwindcss.com/docs/upgrade-guide#prefix-cannot-be-a-function',
|
178
|
-
])
|
179
|
-
config.prefix = ''
|
180
|
-
} else {
|
181
|
-
config.prefix = config.prefix ?? ''
|
182
|
-
}
|
183
|
-
|
184
|
-
// Normalize the `content`
|
185
|
-
config.content = {
|
186
|
-
relative: (() => {
|
187
|
-
let { content } = config
|
188
|
-
|
189
|
-
if (content?.relative) {
|
190
|
-
return content.relative
|
191
|
-
}
|
192
|
-
|
193
|
-
return flagEnabled(config, 'relativeContentPathsByDefault')
|
194
|
-
})(),
|
195
|
-
|
196
|
-
files: (() => {
|
197
|
-
let { content, purge } = config
|
198
|
-
|
199
|
-
if (Array.isArray(purge)) return purge
|
200
|
-
if (Array.isArray(purge?.content)) return purge.content
|
201
|
-
if (Array.isArray(content)) return content
|
202
|
-
if (Array.isArray(content?.content)) return content.content
|
203
|
-
if (Array.isArray(content?.files)) return content.files
|
204
|
-
|
205
|
-
return []
|
206
|
-
})(),
|
207
|
-
|
208
|
-
extract: (() => {
|
209
|
-
let extract = (() => {
|
210
|
-
if (config.purge?.extract) return config.purge.extract
|
211
|
-
if (config.content?.extract) return config.content.extract
|
212
|
-
|
213
|
-
if (config.purge?.extract?.DEFAULT) return config.purge.extract.DEFAULT
|
214
|
-
if (config.content?.extract?.DEFAULT) return config.content.extract.DEFAULT
|
215
|
-
|
216
|
-
if (config.purge?.options?.extractors) return config.purge.options.extractors
|
217
|
-
if (config.content?.options?.extractors) return config.content.options.extractors
|
218
|
-
|
219
|
-
return {}
|
220
|
-
})()
|
221
|
-
|
222
|
-
let extractors = {}
|
223
|
-
|
224
|
-
let defaultExtractor = (() => {
|
225
|
-
if (config.purge?.options?.defaultExtractor) {
|
226
|
-
return config.purge.options.defaultExtractor
|
227
|
-
}
|
228
|
-
|
229
|
-
if (config.content?.options?.defaultExtractor) {
|
230
|
-
return config.content.options.defaultExtractor
|
231
|
-
}
|
232
|
-
|
233
|
-
return undefined
|
234
|
-
})()
|
235
|
-
|
236
|
-
if (defaultExtractor !== undefined) {
|
237
|
-
extractors.DEFAULT = defaultExtractor
|
238
|
-
}
|
239
|
-
|
240
|
-
// Functions
|
241
|
-
if (typeof extract === 'function') {
|
242
|
-
extractors.DEFAULT = extract
|
243
|
-
}
|
244
|
-
|
245
|
-
// Arrays
|
246
|
-
else if (Array.isArray(extract)) {
|
247
|
-
for (let { extensions, extractor } of extract ?? []) {
|
248
|
-
for (let extension of extensions) {
|
249
|
-
extractors[extension] = extractor
|
250
|
-
}
|
251
|
-
}
|
252
|
-
}
|
253
|
-
|
254
|
-
// Objects
|
255
|
-
else if (typeof extract === 'object' && extract !== null) {
|
256
|
-
Object.assign(extractors, extract)
|
257
|
-
}
|
258
|
-
|
259
|
-
return extractors
|
260
|
-
})(),
|
261
|
-
|
262
|
-
transform: (() => {
|
263
|
-
let transform = (() => {
|
264
|
-
if (config.purge?.transform) return config.purge.transform
|
265
|
-
if (config.content?.transform) return config.content.transform
|
266
|
-
|
267
|
-
if (config.purge?.transform?.DEFAULT) return config.purge.transform.DEFAULT
|
268
|
-
if (config.content?.transform?.DEFAULT) return config.content.transform.DEFAULT
|
269
|
-
|
270
|
-
return {}
|
271
|
-
})()
|
272
|
-
|
273
|
-
let transformers = {}
|
274
|
-
|
275
|
-
if (typeof transform === 'function') {
|
276
|
-
transformers.DEFAULT = transform
|
277
|
-
}
|
278
|
-
|
279
|
-
if (typeof transform === 'object' && transform !== null) {
|
280
|
-
Object.assign(transformers, transform)
|
281
|
-
}
|
282
|
-
|
283
|
-
return transformers
|
284
|
-
})(),
|
285
|
-
}
|
286
|
-
|
287
|
-
// Validate globs to prevent bogus globs.
|
288
|
-
// E.g.: `./src/*.{html}` is invalid, the `{html}` should just be `html`
|
289
|
-
for (let file of config.content.files) {
|
290
|
-
if (typeof file === 'string' && /{([^,]*?)}/g.test(file)) {
|
291
|
-
log.warn('invalid-glob-braces', [
|
292
|
-
`The glob pattern ${dim(file)} in your Tailwind CSS configuration is invalid.`,
|
293
|
-
`Update it to ${dim(file.replace(/{([^,]*?)}/g, '$1'))} to silence this warning.`,
|
294
|
-
// TODO: Add https://tw.wtf/invalid-glob-braces
|
295
|
-
])
|
296
|
-
break
|
297
|
-
}
|
298
|
-
}
|
299
|
-
|
300
|
-
return config
|
301
|
-
}
|
@@ -1,140 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* @typedef {object} ScreenValue
|
3
|
-
* @property {number|undefined} min
|
4
|
-
* @property {number|undefined} max
|
5
|
-
* @property {string|undefined} raw
|
6
|
-
*/
|
7
|
-
|
8
|
-
/**
|
9
|
-
* @typedef {object} Screen
|
10
|
-
* @property {string} name
|
11
|
-
* @property {boolean} not
|
12
|
-
* @property {ScreenValue[]} values
|
13
|
-
*/
|
14
|
-
|
15
|
-
/**
|
16
|
-
* A function that normalizes the various forms that the screens object can be
|
17
|
-
* provided in.
|
18
|
-
*
|
19
|
-
* Input(s):
|
20
|
-
* - ['100px', '200px'] // Raw strings
|
21
|
-
* - { sm: '100px', md: '200px' } // Object with string values
|
22
|
-
* - { sm: { min: '100px' }, md: { max: '100px' } } // Object with object values
|
23
|
-
* - { sm: [{ min: '100px' }, { max: '200px' }] } // Object with object array (multiple values)
|
24
|
-
*
|
25
|
-
* Output(s):
|
26
|
-
* - [{ name: 'sm', values: [{ min: '100px', max: '200px' }] }] // List of objects, that contains multiple values
|
27
|
-
*
|
28
|
-
* @returns {Screen[]}
|
29
|
-
*/
|
30
|
-
export function normalizeScreens(screens, root = true) {
|
31
|
-
if (Array.isArray(screens)) {
|
32
|
-
return screens.map((screen) => {
|
33
|
-
if (root && Array.isArray(screen)) {
|
34
|
-
throw new Error('The tuple syntax is not supported for `screens`.')
|
35
|
-
}
|
36
|
-
|
37
|
-
if (typeof screen === 'string') {
|
38
|
-
return { name: screen.toString(), not: false, values: [{ min: screen, max: undefined }] }
|
39
|
-
}
|
40
|
-
|
41
|
-
let [name, options] = screen
|
42
|
-
name = name.toString()
|
43
|
-
|
44
|
-
if (typeof options === 'string') {
|
45
|
-
return { name, not: false, values: [{ min: options, max: undefined }] }
|
46
|
-
}
|
47
|
-
|
48
|
-
if (Array.isArray(options)) {
|
49
|
-
return { name, not: false, values: options.map((option) => resolveValue(option)) }
|
50
|
-
}
|
51
|
-
|
52
|
-
return { name, not: false, values: [resolveValue(options)] }
|
53
|
-
})
|
54
|
-
}
|
55
|
-
|
56
|
-
return normalizeScreens(Object.entries(screens ?? {}), false)
|
57
|
-
}
|
58
|
-
|
59
|
-
/**
|
60
|
-
* @param {Screen} screen
|
61
|
-
* @returns {{result: false, reason: string} | {result: true, reason: null}}
|
62
|
-
*/
|
63
|
-
export function isScreenSortable(screen) {
|
64
|
-
if (screen.values.length !== 1) {
|
65
|
-
return { result: false, reason: 'multiple-values' }
|
66
|
-
} else if (screen.values[0].raw !== undefined) {
|
67
|
-
return { result: false, reason: 'raw-values' }
|
68
|
-
} else if (screen.values[0].min !== undefined && screen.values[0].max !== undefined) {
|
69
|
-
return { result: false, reason: 'min-and-max' }
|
70
|
-
}
|
71
|
-
|
72
|
-
return { result: true, reason: null }
|
73
|
-
}
|
74
|
-
|
75
|
-
/**
|
76
|
-
* @param {'min' | 'max'} type
|
77
|
-
* @param {Screen | 'string'} a
|
78
|
-
* @param {Screen | 'string'} z
|
79
|
-
* @returns {number}
|
80
|
-
*/
|
81
|
-
export function compareScreens(type, a, z) {
|
82
|
-
let aScreen = toScreen(a, type)
|
83
|
-
let zScreen = toScreen(z, type)
|
84
|
-
|
85
|
-
let aSorting = isScreenSortable(aScreen)
|
86
|
-
let bSorting = isScreenSortable(zScreen)
|
87
|
-
|
88
|
-
// These cases should never happen and indicate a bug in Tailwind CSS itself
|
89
|
-
if (aSorting.reason === 'multiple-values' || bSorting.reason === 'multiple-values') {
|
90
|
-
throw new Error(
|
91
|
-
'Attempted to sort a screen with multiple values. This should never happen. Please open a bug report.'
|
92
|
-
)
|
93
|
-
} else if (aSorting.reason === 'raw-values' || bSorting.reason === 'raw-values') {
|
94
|
-
throw new Error(
|
95
|
-
'Attempted to sort a screen with raw values. This should never happen. Please open a bug report.'
|
96
|
-
)
|
97
|
-
} else if (aSorting.reason === 'min-and-max' || bSorting.reason === 'min-and-max') {
|
98
|
-
throw new Error(
|
99
|
-
'Attempted to sort a screen with both min and max values. This should never happen. Please open a bug report.'
|
100
|
-
)
|
101
|
-
}
|
102
|
-
|
103
|
-
// Let the sorting begin
|
104
|
-
let { min: aMin, max: aMax } = aScreen.values[0]
|
105
|
-
let { min: zMin, max: zMax } = zScreen.values[0]
|
106
|
-
|
107
|
-
// Negating screens flip their behavior. Basically `not min-width` is `max-width`
|
108
|
-
if (a.not) [aMin, aMax] = [aMax, aMin]
|
109
|
-
if (z.not) [zMin, zMax] = [zMax, zMin]
|
110
|
-
|
111
|
-
aMin = aMin === undefined ? aMin : parseFloat(aMin)
|
112
|
-
aMax = aMax === undefined ? aMax : parseFloat(aMax)
|
113
|
-
zMin = zMin === undefined ? zMin : parseFloat(zMin)
|
114
|
-
zMax = zMax === undefined ? zMax : parseFloat(zMax)
|
115
|
-
|
116
|
-
let [aValue, zValue] = type === 'min' ? [aMin, zMin] : [zMax, aMax]
|
117
|
-
|
118
|
-
return aValue - zValue
|
119
|
-
}
|
120
|
-
|
121
|
-
/**
|
122
|
-
*
|
123
|
-
* @param {PartialScreen> | string} value
|
124
|
-
* @param {'min' | 'max'} type
|
125
|
-
* @returns {Screen}
|
126
|
-
*/
|
127
|
-
export function toScreen(value, type) {
|
128
|
-
if (typeof value === 'object') {
|
129
|
-
return value
|
130
|
-
}
|
131
|
-
|
132
|
-
return {
|
133
|
-
name: 'arbitrary-screen',
|
134
|
-
values: [{ [type]: value }],
|
135
|
-
}
|
136
|
-
}
|
137
|
-
|
138
|
-
function resolveValue({ 'min-width': _minWidth, min = _minWidth, max, raw } = {}) {
|
139
|
-
return { min, max, raw }
|
140
|
-
}
|
@@ -1,68 +0,0 @@
|
|
1
|
-
const DIRECTIONS = new Set(['normal', 'reverse', 'alternate', 'alternate-reverse'])
|
2
|
-
const PLAY_STATES = new Set(['running', 'paused'])
|
3
|
-
const FILL_MODES = new Set(['none', 'forwards', 'backwards', 'both'])
|
4
|
-
const ITERATION_COUNTS = new Set(['infinite'])
|
5
|
-
const TIMINGS = new Set([
|
6
|
-
'linear',
|
7
|
-
'ease',
|
8
|
-
'ease-in',
|
9
|
-
'ease-out',
|
10
|
-
'ease-in-out',
|
11
|
-
'step-start',
|
12
|
-
'step-end',
|
13
|
-
])
|
14
|
-
const TIMING_FNS = ['cubic-bezier', 'steps']
|
15
|
-
|
16
|
-
const COMMA = /\,(?![^(]*\))/g // Comma separator that is not located between brackets. E.g.: `cubiz-bezier(a, b, c)` these don't count.
|
17
|
-
const SPACE = /\ +(?![^(]*\))/g // Similar to the one above, but with spaces instead.
|
18
|
-
const TIME = /^(-?[\d.]+m?s)$/
|
19
|
-
const DIGIT = /^(\d+)$/
|
20
|
-
|
21
|
-
export default function parseAnimationValue(input) {
|
22
|
-
let animations = input.split(COMMA)
|
23
|
-
return animations.map((animation) => {
|
24
|
-
let value = animation.trim()
|
25
|
-
let result = { value }
|
26
|
-
let parts = value.split(SPACE)
|
27
|
-
let seen = new Set()
|
28
|
-
|
29
|
-
for (let part of parts) {
|
30
|
-
if (!seen.has('DIRECTIONS') && DIRECTIONS.has(part)) {
|
31
|
-
result.direction = part
|
32
|
-
seen.add('DIRECTIONS')
|
33
|
-
} else if (!seen.has('PLAY_STATES') && PLAY_STATES.has(part)) {
|
34
|
-
result.playState = part
|
35
|
-
seen.add('PLAY_STATES')
|
36
|
-
} else if (!seen.has('FILL_MODES') && FILL_MODES.has(part)) {
|
37
|
-
result.fillMode = part
|
38
|
-
seen.add('FILL_MODES')
|
39
|
-
} else if (
|
40
|
-
!seen.has('ITERATION_COUNTS') &&
|
41
|
-
(ITERATION_COUNTS.has(part) || DIGIT.test(part))
|
42
|
-
) {
|
43
|
-
result.iterationCount = part
|
44
|
-
seen.add('ITERATION_COUNTS')
|
45
|
-
} else if (!seen.has('TIMING_FUNCTION') && TIMINGS.has(part)) {
|
46
|
-
result.timingFunction = part
|
47
|
-
seen.add('TIMING_FUNCTION')
|
48
|
-
} else if (!seen.has('TIMING_FUNCTION') && TIMING_FNS.some((f) => part.startsWith(`${f}(`))) {
|
49
|
-
result.timingFunction = part
|
50
|
-
seen.add('TIMING_FUNCTION')
|
51
|
-
} else if (!seen.has('DURATION') && TIME.test(part)) {
|
52
|
-
result.duration = part
|
53
|
-
seen.add('DURATION')
|
54
|
-
} else if (!seen.has('DELAY') && TIME.test(part)) {
|
55
|
-
result.delay = part
|
56
|
-
seen.add('DELAY')
|
57
|
-
} else if (!seen.has('NAME')) {
|
58
|
-
result.name = part
|
59
|
-
seen.add('NAME')
|
60
|
-
} else {
|
61
|
-
if (!result.unknown) result.unknown = []
|
62
|
-
result.unknown.push(part)
|
63
|
-
}
|
64
|
-
}
|
65
|
-
|
66
|
-
return result
|
67
|
-
})
|
68
|
-
}
|
@@ -1,72 +0,0 @@
|
|
1
|
-
import { splitAtTopLevelOnly } from './splitAtTopLevelOnly'
|
2
|
-
|
3
|
-
let KEYWORDS = new Set(['inset', 'inherit', 'initial', 'revert', 'unset'])
|
4
|
-
let SPACE = /\ +(?![^(]*\))/g // Similar to the one above, but with spaces instead.
|
5
|
-
let LENGTH = /^-?(\d+|\.\d+)(.*?)$/g
|
6
|
-
|
7
|
-
export function parseBoxShadowValue(input) {
|
8
|
-
let shadows = splitAtTopLevelOnly(input, ',')
|
9
|
-
return shadows.map((shadow) => {
|
10
|
-
let value = shadow.trim()
|
11
|
-
let result = { raw: value }
|
12
|
-
let parts = value.split(SPACE)
|
13
|
-
let seen = new Set()
|
14
|
-
|
15
|
-
for (let part of parts) {
|
16
|
-
// Reset index, since the regex is stateful.
|
17
|
-
LENGTH.lastIndex = 0
|
18
|
-
|
19
|
-
// Keyword
|
20
|
-
if (!seen.has('KEYWORD') && KEYWORDS.has(part)) {
|
21
|
-
result.keyword = part
|
22
|
-
seen.add('KEYWORD')
|
23
|
-
}
|
24
|
-
|
25
|
-
// Length value
|
26
|
-
else if (LENGTH.test(part)) {
|
27
|
-
if (!seen.has('X')) {
|
28
|
-
result.x = part
|
29
|
-
seen.add('X')
|
30
|
-
} else if (!seen.has('Y')) {
|
31
|
-
result.y = part
|
32
|
-
seen.add('Y')
|
33
|
-
} else if (!seen.has('BLUR')) {
|
34
|
-
result.blur = part
|
35
|
-
seen.add('BLUR')
|
36
|
-
} else if (!seen.has('SPREAD')) {
|
37
|
-
result.spread = part
|
38
|
-
seen.add('SPREAD')
|
39
|
-
}
|
40
|
-
}
|
41
|
-
|
42
|
-
// Color or unknown
|
43
|
-
else {
|
44
|
-
if (!result.color) {
|
45
|
-
result.color = part
|
46
|
-
} else {
|
47
|
-
if (!result.unknown) result.unknown = []
|
48
|
-
result.unknown.push(part)
|
49
|
-
}
|
50
|
-
}
|
51
|
-
}
|
52
|
-
|
53
|
-
// Check if valid
|
54
|
-
result.valid = result.x !== undefined && result.y !== undefined
|
55
|
-
|
56
|
-
return result
|
57
|
-
})
|
58
|
-
}
|
59
|
-
|
60
|
-
export function formatBoxShadowValue(shadows) {
|
61
|
-
return shadows
|
62
|
-
.map((shadow) => {
|
63
|
-
if (!shadow.valid) {
|
64
|
-
return shadow.raw
|
65
|
-
}
|
66
|
-
|
67
|
-
return [shadow.keyword, shadow.x, shadow.y, shadow.blur, shadow.spread, shadow.color]
|
68
|
-
.filter(Boolean)
|
69
|
-
.join(' ')
|
70
|
-
})
|
71
|
-
.join(', ')
|
72
|
-
}
|
@@ -1,44 +0,0 @@
|
|
1
|
-
// @ts-check
|
2
|
-
|
3
|
-
/**
|
4
|
-
* @typedef {{type: 'dependency', file: string} | {type: 'dir-dependency', dir: string, glob: string}} Dependency
|
5
|
-
*/
|
6
|
-
|
7
|
-
/**
|
8
|
-
*
|
9
|
-
* @param {import('../lib/content.js').ContentPath} contentPath
|
10
|
-
* @returns {Dependency[]}
|
11
|
-
*/
|
12
|
-
export default function parseDependency(contentPath) {
|
13
|
-
if (contentPath.ignore) {
|
14
|
-
return []
|
15
|
-
}
|
16
|
-
|
17
|
-
if (!contentPath.glob) {
|
18
|
-
return [
|
19
|
-
{
|
20
|
-
type: 'dependency',
|
21
|
-
file: contentPath.base,
|
22
|
-
},
|
23
|
-
]
|
24
|
-
}
|
25
|
-
|
26
|
-
if (process.env.ROLLUP_WATCH === 'true') {
|
27
|
-
// rollup-plugin-postcss does not support dir-dependency messages
|
28
|
-
// but directories can be watched in the same way as files
|
29
|
-
return [
|
30
|
-
{
|
31
|
-
type: 'dependency',
|
32
|
-
file: contentPath.base,
|
33
|
-
},
|
34
|
-
]
|
35
|
-
}
|
36
|
-
|
37
|
-
return [
|
38
|
-
{
|
39
|
-
type: 'dir-dependency',
|
40
|
-
dir: contentPath.base,
|
41
|
-
glob: contentPath.glob,
|
42
|
-
},
|
43
|
-
]
|
44
|
-
}
|
package/src/util/parseGlob.js
DELETED
@@ -1,24 +0,0 @@
|
|
1
|
-
import globParent from 'glob-parent'
|
2
|
-
|
3
|
-
// Based on `glob-base`
|
4
|
-
// https://github.com/micromatch/glob-base/blob/master/index.js
|
5
|
-
export function parseGlob(pattern) {
|
6
|
-
let glob = pattern
|
7
|
-
let base = globParent(pattern)
|
8
|
-
|
9
|
-
if (base !== '.') {
|
10
|
-
glob = pattern.substr(base.length)
|
11
|
-
if (glob.charAt(0) === '/') {
|
12
|
-
glob = glob.substr(1)
|
13
|
-
}
|
14
|
-
}
|
15
|
-
|
16
|
-
if (glob.substr(0, 2) === './') {
|
17
|
-
glob = glob.substr(2)
|
18
|
-
}
|
19
|
-
if (glob.charAt(0) === '/') {
|
20
|
-
glob = glob.substr(1)
|
21
|
-
}
|
22
|
-
|
23
|
-
return { base, glob }
|
24
|
-
}
|
@@ -1,19 +0,0 @@
|
|
1
|
-
import postcss from 'postcss'
|
2
|
-
import postcssNested from 'postcss-nested'
|
3
|
-
import postcssJs from 'postcss-js'
|
4
|
-
|
5
|
-
export default function parseObjectStyles(styles) {
|
6
|
-
if (!Array.isArray(styles)) {
|
7
|
-
return parseObjectStyles([styles])
|
8
|
-
}
|
9
|
-
|
10
|
-
return styles.flatMap((style) => {
|
11
|
-
return postcss([
|
12
|
-
postcssNested({
|
13
|
-
bubble: ['screen'],
|
14
|
-
}),
|
15
|
-
]).process(style, {
|
16
|
-
parser: postcssJs,
|
17
|
-
}).root.nodes
|
18
|
-
})
|
19
|
-
}
|