tailwindcss 3.4.0 → 4.0.0-alpha.1

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.
Files changed (285) hide show
  1. package/dist/chunk-GNCUPSHB.mjs +5886 -0
  2. package/dist/cli.d.mts +1 -0
  3. package/dist/cli.d.ts +1 -0
  4. package/dist/cli.js +6309 -0
  5. package/dist/cli.mjs +432 -0
  6. package/dist/lib.d.mts +324 -0
  7. package/dist/lib.d.ts +324 -0
  8. package/dist/lib.js +5884 -0
  9. package/dist/lib.mjs +1 -0
  10. package/index.css +5 -0
  11. package/package.json +35 -104
  12. package/preflight.css +355 -0
  13. package/theme.css +465 -0
  14. package/CHANGELOG.md +0 -2552
  15. package/README.md +0 -41
  16. package/base.css +0 -1
  17. package/colors.d.ts +0 -3
  18. package/colors.js +0 -2
  19. package/components.css +0 -1
  20. package/defaultConfig.d.ts +0 -3
  21. package/defaultConfig.js +0 -2
  22. package/defaultTheme.d.ts +0 -4
  23. package/defaultTheme.js +0 -2
  24. package/lib/cli/build/deps.js +0 -62
  25. package/lib/cli/build/index.js +0 -54
  26. package/lib/cli/build/plugin.js +0 -378
  27. package/lib/cli/build/utils.js +0 -88
  28. package/lib/cli/build/watching.js +0 -182
  29. package/lib/cli/help/index.js +0 -73
  30. package/lib/cli/index.js +0 -230
  31. package/lib/cli/init/index.js +0 -63
  32. package/lib/cli-peer-dependencies.js +0 -36
  33. package/lib/cli.js +0 -7
  34. package/lib/corePluginList.js +0 -190
  35. package/lib/corePlugins.js +0 -4244
  36. package/lib/css/LICENSE +0 -25
  37. package/lib/css/preflight.css +0 -385
  38. package/lib/featureFlags.js +0 -83
  39. package/lib/index.js +0 -2
  40. package/lib/lib/cacheInvalidation.js +0 -92
  41. package/lib/lib/collapseAdjacentRules.js +0 -61
  42. package/lib/lib/collapseDuplicateDeclarations.js +0 -85
  43. package/lib/lib/content.js +0 -181
  44. package/lib/lib/defaultExtractor.js +0 -251
  45. package/lib/lib/detectNesting.js +0 -45
  46. package/lib/lib/evaluateTailwindFunctions.js +0 -238
  47. package/lib/lib/expandApplyAtRules.js +0 -540
  48. package/lib/lib/expandTailwindAtRules.js +0 -291
  49. package/lib/lib/findAtConfigPath.js +0 -46
  50. package/lib/lib/generateRules.js +0 -896
  51. package/lib/lib/getModuleDependencies.js +0 -99
  52. package/lib/lib/load-config.js +0 -53
  53. package/lib/lib/normalizeTailwindDirectives.js +0 -89
  54. package/lib/lib/offsets.js +0 -306
  55. package/lib/lib/partitionApplyAtRules.js +0 -58
  56. package/lib/lib/regex.js +0 -74
  57. package/lib/lib/remap-bitfield.js +0 -89
  58. package/lib/lib/resolveDefaultsAtRules.js +0 -165
  59. package/lib/lib/setupContextUtils.js +0 -1278
  60. package/lib/lib/setupTrackingContext.js +0 -166
  61. package/lib/lib/sharedState.js +0 -87
  62. package/lib/lib/substituteScreenAtRules.js +0 -31
  63. package/lib/oxide/cli/build/deps.js +0 -89
  64. package/lib/oxide/cli/build/index.js +0 -53
  65. package/lib/oxide/cli/build/plugin.js +0 -375
  66. package/lib/oxide/cli/build/utils.js +0 -87
  67. package/lib/oxide/cli/build/watching.js +0 -179
  68. package/lib/oxide/cli/help/index.js +0 -72
  69. package/lib/oxide/cli/index.js +0 -214
  70. package/lib/oxide/cli/init/index.js +0 -52
  71. package/lib/oxide/cli.js +0 -5
  72. package/lib/oxide/postcss-plugin.js +0 -2
  73. package/lib/plugin.js +0 -98
  74. package/lib/postcss-plugins/nesting/README.md +0 -42
  75. package/lib/postcss-plugins/nesting/index.js +0 -21
  76. package/lib/postcss-plugins/nesting/plugin.js +0 -89
  77. package/lib/processTailwindFeatures.js +0 -64
  78. package/lib/public/colors.js +0 -355
  79. package/lib/public/create-plugin.js +0 -17
  80. package/lib/public/default-config.js +0 -18
  81. package/lib/public/default-theme.js +0 -18
  82. package/lib/public/load-config.js +0 -12
  83. package/lib/public/resolve-config.js +0 -24
  84. package/lib/util/applyImportantSelector.js +0 -36
  85. package/lib/util/bigSign.js +0 -13
  86. package/lib/util/buildMediaQuery.js +0 -27
  87. package/lib/util/cloneDeep.js +0 -22
  88. package/lib/util/cloneNodes.js +0 -54
  89. package/lib/util/color.js +0 -116
  90. package/lib/util/colorNames.js +0 -752
  91. package/lib/util/configurePlugins.js +0 -23
  92. package/lib/util/createPlugin.js +0 -32
  93. package/lib/util/createUtilityPlugin.js +0 -53
  94. package/lib/util/dataTypes.js +0 -405
  95. package/lib/util/defaults.js +0 -27
  96. package/lib/util/escapeClassName.js +0 -24
  97. package/lib/util/escapeCommas.js +0 -13
  98. package/lib/util/flattenColorPalette.js +0 -18
  99. package/lib/util/formatVariantSelector.js +0 -270
  100. package/lib/util/getAllConfigs.js +0 -50
  101. package/lib/util/hashConfig.js +0 -21
  102. package/lib/util/isKeyframeRule.js +0 -13
  103. package/lib/util/isPlainObject.js +0 -17
  104. package/lib/util/isSyntacticallyValidPropertyValue.js +0 -74
  105. package/lib/util/log.js +0 -61
  106. package/lib/util/nameClass.js +0 -49
  107. package/lib/util/negateValue.js +0 -36
  108. package/lib/util/normalizeConfig.js +0 -282
  109. package/lib/util/normalizeScreens.js +0 -178
  110. package/lib/util/parseAnimationValue.js +0 -93
  111. package/lib/util/parseBoxShadowValue.js +0 -88
  112. package/lib/util/parseDependency.js +0 -47
  113. package/lib/util/parseGlob.js +0 -36
  114. package/lib/util/parseObjectStyles.js +0 -36
  115. package/lib/util/pluginUtils.js +0 -289
  116. package/lib/util/prefixSelector.js +0 -39
  117. package/lib/util/pseudoElements.js +0 -209
  118. package/lib/util/removeAlphaVariables.js +0 -31
  119. package/lib/util/resolveConfig.js +0 -256
  120. package/lib/util/resolveConfigPath.js +0 -70
  121. package/lib/util/responsive.js +0 -24
  122. package/lib/util/splitAtTopLevelOnly.js +0 -51
  123. package/lib/util/tap.js +0 -14
  124. package/lib/util/toColorValue.js +0 -13
  125. package/lib/util/toPath.js +0 -32
  126. package/lib/util/transformThemeValue.js +0 -73
  127. package/lib/util/validateConfig.js +0 -37
  128. package/lib/util/validateFormalSyntax.js +0 -26
  129. package/lib/util/withAlphaVariable.js +0 -79
  130. package/lib/value-parser/LICENSE +0 -22
  131. package/lib/value-parser/README.md +0 -3
  132. package/lib/value-parser/index.d.js +0 -2
  133. package/lib/value-parser/index.js +0 -22
  134. package/lib/value-parser/parse.js +0 -259
  135. package/lib/value-parser/stringify.js +0 -38
  136. package/lib/value-parser/unit.js +0 -86
  137. package/lib/value-parser/walk.js +0 -16
  138. package/loadConfig.d.ts +0 -4
  139. package/loadConfig.js +0 -2
  140. package/nesting/index.d.ts +0 -4
  141. package/nesting/index.js +0 -2
  142. package/peers/index.js +0 -96624
  143. package/plugin.d.ts +0 -11
  144. package/plugin.js +0 -2
  145. package/prettier.config.js +0 -19
  146. package/resolveConfig.d.ts +0 -31
  147. package/resolveConfig.js +0 -2
  148. package/screens.css +0 -1
  149. package/scripts/create-plugin-list.js +0 -10
  150. package/scripts/generate-types.js +0 -104
  151. package/scripts/release-channel.js +0 -18
  152. package/scripts/release-notes.js +0 -21
  153. package/scripts/swap-engines.js +0 -40
  154. package/scripts/type-utils.js +0 -27
  155. package/src/cli/build/deps.js +0 -56
  156. package/src/cli/build/index.js +0 -49
  157. package/src/cli/build/plugin.js +0 -444
  158. package/src/cli/build/utils.js +0 -76
  159. package/src/cli/build/watching.js +0 -229
  160. package/src/cli/help/index.js +0 -70
  161. package/src/cli/index.js +0 -216
  162. package/src/cli/init/index.js +0 -79
  163. package/src/cli-peer-dependencies.js +0 -15
  164. package/src/cli.js +0 -7
  165. package/src/corePluginList.js +0 -1
  166. package/src/corePlugins.js +0 -2904
  167. package/src/css/LICENSE +0 -25
  168. package/src/css/preflight.css +0 -385
  169. package/src/featureFlags.js +0 -66
  170. package/src/index.js +0 -1
  171. package/src/lib/cacheInvalidation.js +0 -52
  172. package/src/lib/collapseAdjacentRules.js +0 -58
  173. package/src/lib/collapseDuplicateDeclarations.js +0 -93
  174. package/src/lib/content.js +0 -208
  175. package/src/lib/defaultExtractor.js +0 -230
  176. package/src/lib/detectNesting.js +0 -47
  177. package/src/lib/evaluateTailwindFunctions.js +0 -272
  178. package/src/lib/expandApplyAtRules.js +0 -620
  179. package/src/lib/expandTailwindAtRules.js +0 -300
  180. package/src/lib/findAtConfigPath.js +0 -48
  181. package/src/lib/generateRules.js +0 -941
  182. package/src/lib/getModuleDependencies.js +0 -79
  183. package/src/lib/load-config.ts +0 -39
  184. package/src/lib/normalizeTailwindDirectives.js +0 -84
  185. package/src/lib/offsets.js +0 -373
  186. package/src/lib/partitionApplyAtRules.js +0 -52
  187. package/src/lib/regex.js +0 -74
  188. package/src/lib/remap-bitfield.js +0 -82
  189. package/src/lib/resolveDefaultsAtRules.js +0 -163
  190. package/src/lib/setupContextUtils.js +0 -1345
  191. package/src/lib/setupTrackingContext.js +0 -169
  192. package/src/lib/sharedState.js +0 -61
  193. package/src/lib/substituteScreenAtRules.js +0 -19
  194. package/src/oxide/cli/build/deps.ts +0 -91
  195. package/src/oxide/cli/build/index.ts +0 -47
  196. package/src/oxide/cli/build/plugin.ts +0 -442
  197. package/src/oxide/cli/build/utils.ts +0 -74
  198. package/src/oxide/cli/build/watching.ts +0 -225
  199. package/src/oxide/cli/help/index.ts +0 -69
  200. package/src/oxide/cli/index.ts +0 -204
  201. package/src/oxide/cli/init/index.ts +0 -59
  202. package/src/oxide/cli.ts +0 -1
  203. package/src/oxide/postcss-plugin.ts +0 -1
  204. package/src/plugin.js +0 -107
  205. package/src/postcss-plugins/nesting/README.md +0 -42
  206. package/src/postcss-plugins/nesting/index.js +0 -13
  207. package/src/postcss-plugins/nesting/plugin.js +0 -80
  208. package/src/processTailwindFeatures.js +0 -59
  209. package/src/public/colors.js +0 -322
  210. package/src/public/create-plugin.js +0 -2
  211. package/src/public/default-config.js +0 -4
  212. package/src/public/default-theme.js +0 -4
  213. package/src/public/load-config.js +0 -2
  214. package/src/public/resolve-config.js +0 -7
  215. package/src/util/applyImportantSelector.js +0 -27
  216. package/src/util/bigSign.js +0 -3
  217. package/src/util/buildMediaQuery.js +0 -22
  218. package/src/util/cloneDeep.js +0 -11
  219. package/src/util/cloneNodes.js +0 -49
  220. package/src/util/color.js +0 -88
  221. package/src/util/colorNames.js +0 -150
  222. package/src/util/configurePlugins.js +0 -23
  223. package/src/util/createPlugin.js +0 -27
  224. package/src/util/createUtilityPlugin.js +0 -37
  225. package/src/util/dataTypes.js +0 -394
  226. package/src/util/defaults.js +0 -17
  227. package/src/util/escapeClassName.js +0 -8
  228. package/src/util/escapeCommas.js +0 -3
  229. package/src/util/flattenColorPalette.js +0 -13
  230. package/src/util/formatVariantSelector.js +0 -324
  231. package/src/util/getAllConfigs.js +0 -38
  232. package/src/util/hashConfig.js +0 -5
  233. package/src/util/isKeyframeRule.js +0 -3
  234. package/src/util/isPlainObject.js +0 -8
  235. package/src/util/isSyntacticallyValidPropertyValue.js +0 -61
  236. package/src/util/log.js +0 -29
  237. package/src/util/nameClass.js +0 -30
  238. package/src/util/negateValue.js +0 -24
  239. package/src/util/normalizeConfig.js +0 -301
  240. package/src/util/normalizeScreens.js +0 -140
  241. package/src/util/parseAnimationValue.js +0 -68
  242. package/src/util/parseBoxShadowValue.js +0 -72
  243. package/src/util/parseDependency.js +0 -44
  244. package/src/util/parseGlob.js +0 -24
  245. package/src/util/parseObjectStyles.js +0 -19
  246. package/src/util/pluginUtils.js +0 -307
  247. package/src/util/prefixSelector.js +0 -33
  248. package/src/util/pseudoElements.js +0 -167
  249. package/src/util/removeAlphaVariables.js +0 -24
  250. package/src/util/resolveConfig.js +0 -277
  251. package/src/util/resolveConfigPath.js +0 -66
  252. package/src/util/responsive.js +0 -10
  253. package/src/util/splitAtTopLevelOnly.js +0 -52
  254. package/src/util/tap.js +0 -4
  255. package/src/util/toColorValue.js +0 -3
  256. package/src/util/toPath.js +0 -26
  257. package/src/util/transformThemeValue.js +0 -62
  258. package/src/util/validateConfig.js +0 -26
  259. package/src/util/validateFormalSyntax.js +0 -34
  260. package/src/util/withAlphaVariable.js +0 -49
  261. package/src/value-parser/LICENSE +0 -22
  262. package/src/value-parser/README.md +0 -3
  263. package/src/value-parser/index.d.ts +0 -177
  264. package/src/value-parser/index.js +0 -28
  265. package/src/value-parser/parse.js +0 -303
  266. package/src/value-parser/stringify.js +0 -41
  267. package/src/value-parser/unit.js +0 -118
  268. package/src/value-parser/walk.js +0 -18
  269. package/stubs/.gitignore +0 -1
  270. package/stubs/.prettierrc.json +0 -6
  271. package/stubs/config.full.js +0 -1062
  272. package/stubs/config.simple.js +0 -7
  273. package/stubs/postcss.config.cjs +0 -6
  274. package/stubs/postcss.config.js +0 -6
  275. package/stubs/tailwind.config.cjs +0 -2
  276. package/stubs/tailwind.config.js +0 -2
  277. package/stubs/tailwind.config.ts +0 -3
  278. package/tailwind.css +0 -5
  279. package/types/config.d.ts +0 -369
  280. package/types/generated/.gitkeep +0 -0
  281. package/types/generated/colors.d.ts +0 -298
  282. package/types/generated/corePluginList.d.ts +0 -1
  283. package/types/generated/default-theme.d.ts +0 -397
  284. package/types/index.d.ts +0 -11
  285. 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
- }
@@ -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
- }