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.
Files changed (277) hide show
  1. package/README.md +5 -6
  2. package/dist/chunk-AZANAYY2.mjs +1 -0
  3. package/dist/chunk-CH45MXZF.mjs +10 -0
  4. package/dist/chunk-V2K3XTS4.mjs +1 -0
  5. package/dist/colors-b_6i0Oi7.d.ts +295 -0
  6. package/dist/colors.d.mts +295 -0
  7. package/dist/colors.d.ts +5 -0
  8. package/dist/colors.js +1 -0
  9. package/dist/colors.mjs +1 -0
  10. package/dist/default-theme.d.mts +1147 -0
  11. package/dist/default-theme.d.ts +1147 -0
  12. package/dist/default-theme.js +1 -0
  13. package/dist/default-theme.mjs +1 -0
  14. package/dist/flatten-color-palette.d.mts +6 -0
  15. package/dist/flatten-color-palette.d.ts +6 -0
  16. package/dist/flatten-color-palette.js +1 -0
  17. package/dist/flatten-color-palette.mjs +1 -0
  18. package/dist/lib.d.mts +260 -0
  19. package/dist/lib.d.ts +3 -0
  20. package/dist/lib.js +33 -0
  21. package/dist/lib.mjs +24 -0
  22. package/dist/plugin.d.mts +11 -0
  23. package/dist/plugin.d.ts +104 -0
  24. package/dist/plugin.js +1 -0
  25. package/dist/plugin.mjs +1 -0
  26. package/dist/resolve-config-BIFUA2FY.d.ts +29 -0
  27. package/dist/resolve-config-QUZ9b-Gn.d.mts +190 -0
  28. package/dist/types-B254mqw1.d.mts +98 -0
  29. package/index.css +863 -3
  30. package/package.json +73 -102
  31. package/preflight.css +383 -0
  32. package/theme.css +453 -0
  33. package/base.css +0 -1
  34. package/colors.d.ts +0 -3
  35. package/colors.js +0 -2
  36. package/components.css +0 -1
  37. package/defaultConfig.d.ts +0 -3
  38. package/defaultConfig.js +0 -2
  39. package/defaultTheme.d.ts +0 -4
  40. package/defaultTheme.js +0 -2
  41. package/lib/cli/build/index.js +0 -57
  42. package/lib/cli/build/plugin.js +0 -381
  43. package/lib/cli/build/utils.js +0 -88
  44. package/lib/cli/build/watching.js +0 -182
  45. package/lib/cli/help/index.js +0 -73
  46. package/lib/cli/index.js +0 -231
  47. package/lib/cli/init/index.js +0 -63
  48. package/lib/cli.js +0 -3
  49. package/lib/corePluginList.js +0 -188
  50. package/lib/corePlugins.js +0 -4197
  51. package/lib/css/LICENSE +0 -25
  52. package/lib/css/preflight.css +0 -375
  53. package/lib/featureFlags.js +0 -84
  54. package/lib/index.js +0 -2
  55. package/lib/lib/cacheInvalidation.js +0 -92
  56. package/lib/lib/collapseAdjacentRules.js +0 -61
  57. package/lib/lib/collapseDuplicateDeclarations.js +0 -85
  58. package/lib/lib/content.js +0 -207
  59. package/lib/lib/defaultExtractor.js +0 -243
  60. package/lib/lib/detectNesting.js +0 -45
  61. package/lib/lib/evaluateTailwindFunctions.js +0 -238
  62. package/lib/lib/expandApplyAtRules.js +0 -534
  63. package/lib/lib/expandTailwindAtRules.js +0 -314
  64. package/lib/lib/findAtConfigPath.js +0 -46
  65. package/lib/lib/generateRules.js +0 -879
  66. package/lib/lib/getModuleDependencies.js +0 -99
  67. package/lib/lib/handleImportAtRules.js +0 -50
  68. package/lib/lib/load-config.js +0 -42
  69. package/lib/lib/normalizeTailwindDirectives.js +0 -74
  70. package/lib/lib/offsets.js +0 -306
  71. package/lib/lib/partitionApplyAtRules.js +0 -58
  72. package/lib/lib/regex.js +0 -74
  73. package/lib/lib/remap-bitfield.js +0 -89
  74. package/lib/lib/resolveDefaultsAtRules.js +0 -165
  75. package/lib/lib/setupContextUtils.js +0 -1245
  76. package/lib/lib/setupTrackingContext.js +0 -166
  77. package/lib/lib/sharedState.js +0 -79
  78. package/lib/lib/substituteScreenAtRules.js +0 -31
  79. package/lib/plugin.js +0 -116
  80. package/lib/postcss-plugins/nesting/README.md +0 -42
  81. package/lib/postcss-plugins/nesting/index.js +0 -21
  82. package/lib/postcss-plugins/nesting/plugin.js +0 -89
  83. package/lib/processTailwindFeatures.js +0 -64
  84. package/lib/public/colors.js +0 -355
  85. package/lib/public/create-plugin.js +0 -17
  86. package/lib/public/default-config.js +0 -18
  87. package/lib/public/default-theme.js +0 -18
  88. package/lib/public/load-config.js +0 -12
  89. package/lib/public/resolve-config.js +0 -24
  90. package/lib/util/applyImportantSelector.js +0 -36
  91. package/lib/util/bigSign.js +0 -13
  92. package/lib/util/buildMediaQuery.js +0 -27
  93. package/lib/util/cloneDeep.js +0 -22
  94. package/lib/util/cloneNodes.js +0 -34
  95. package/lib/util/color.js +0 -116
  96. package/lib/util/colorNames.js +0 -752
  97. package/lib/util/configurePlugins.js +0 -23
  98. package/lib/util/createPlugin.js +0 -32
  99. package/lib/util/createUtilityPlugin.js +0 -53
  100. package/lib/util/dataTypes.js +0 -304
  101. package/lib/util/defaults.js +0 -27
  102. package/lib/util/escapeClassName.js +0 -24
  103. package/lib/util/escapeCommas.js +0 -13
  104. package/lib/util/flattenColorPalette.js +0 -18
  105. package/lib/util/formatVariantSelector.js +0 -263
  106. package/lib/util/getAllConfigs.js +0 -50
  107. package/lib/util/hashConfig.js +0 -21
  108. package/lib/util/isKeyframeRule.js +0 -13
  109. package/lib/util/isPlainObject.js +0 -17
  110. package/lib/util/isSyntacticallyValidPropertyValue.js +0 -74
  111. package/lib/util/log.js +0 -78
  112. package/lib/util/nameClass.js +0 -49
  113. package/lib/util/negateValue.js +0 -36
  114. package/lib/util/normalizeConfig.js +0 -308
  115. package/lib/util/normalizeScreens.js +0 -178
  116. package/lib/util/parseAnimationValue.js +0 -93
  117. package/lib/util/parseBoxShadowValue.js +0 -88
  118. package/lib/util/parseDependency.js +0 -47
  119. package/lib/util/parseGlob.js +0 -36
  120. package/lib/util/parseObjectStyles.js +0 -36
  121. package/lib/util/pluginUtils.js +0 -274
  122. package/lib/util/prefixSelector.js +0 -39
  123. package/lib/util/pseudoElements.js +0 -229
  124. package/lib/util/removeAlphaVariables.js +0 -31
  125. package/lib/util/resolveConfig.js +0 -256
  126. package/lib/util/resolveConfigPath.js +0 -70
  127. package/lib/util/responsive.js +0 -24
  128. package/lib/util/splitAtTopLevelOnly.js +0 -51
  129. package/lib/util/tap.js +0 -14
  130. package/lib/util/toColorValue.js +0 -13
  131. package/lib/util/toPath.js +0 -32
  132. package/lib/util/transformThemeValue.js +0 -73
  133. package/lib/util/validateConfig.js +0 -48
  134. package/lib/util/validateFormalSyntax.js +0 -26
  135. package/lib/util/withAlphaVariable.js +0 -79
  136. package/lib/value-parser/LICENSE +0 -22
  137. package/lib/value-parser/README.md +0 -3
  138. package/lib/value-parser/index.d.js +0 -2
  139. package/lib/value-parser/index.js +0 -22
  140. package/lib/value-parser/parse.js +0 -259
  141. package/lib/value-parser/stringify.js +0 -38
  142. package/lib/value-parser/unit.js +0 -86
  143. package/lib/value-parser/walk.js +0 -16
  144. package/loadConfig.d.ts +0 -4
  145. package/loadConfig.js +0 -2
  146. package/nesting/index.js +0 -2
  147. package/plugin.d.ts +0 -11
  148. package/plugin.js +0 -2
  149. package/prettier.config.js +0 -19
  150. package/resolveConfig.d.ts +0 -12
  151. package/resolveConfig.js +0 -2
  152. package/screens.css +0 -1
  153. package/scripts/create-plugin-list.js +0 -10
  154. package/scripts/generate-types.js +0 -105
  155. package/scripts/release-channel.js +0 -18
  156. package/scripts/release-notes.js +0 -21
  157. package/scripts/type-utils.js +0 -27
  158. package/src/cli/build/index.js +0 -53
  159. package/src/cli/build/plugin.js +0 -457
  160. package/src/cli/build/utils.js +0 -76
  161. package/src/cli/build/watching.js +0 -229
  162. package/src/cli/help/index.js +0 -70
  163. package/src/cli/index.js +0 -217
  164. package/src/cli/init/index.js +0 -79
  165. package/src/cli.js +0 -3
  166. package/src/corePluginList.js +0 -1
  167. package/src/corePlugins.js +0 -2877
  168. package/src/css/LICENSE +0 -25
  169. package/src/css/preflight.css +0 -375
  170. package/src/featureFlags.js +0 -68
  171. package/src/index.js +0 -1
  172. package/src/lib/cacheInvalidation.js +0 -52
  173. package/src/lib/collapseAdjacentRules.js +0 -58
  174. package/src/lib/collapseDuplicateDeclarations.js +0 -93
  175. package/src/lib/content.js +0 -240
  176. package/src/lib/defaultExtractor.js +0 -217
  177. package/src/lib/detectNesting.js +0 -47
  178. package/src/lib/evaluateTailwindFunctions.js +0 -272
  179. package/src/lib/expandApplyAtRules.js +0 -613
  180. package/src/lib/expandTailwindAtRules.js +0 -315
  181. package/src/lib/findAtConfigPath.js +0 -48
  182. package/src/lib/generateRules.js +0 -923
  183. package/src/lib/getModuleDependencies.js +0 -79
  184. package/src/lib/handleImportAtRules.js +0 -34
  185. package/src/lib/load-config.ts +0 -31
  186. package/src/lib/normalizeTailwindDirectives.js +0 -57
  187. package/src/lib/offsets.js +0 -373
  188. package/src/lib/partitionApplyAtRules.js +0 -52
  189. package/src/lib/regex.js +0 -74
  190. package/src/lib/remap-bitfield.js +0 -82
  191. package/src/lib/resolveDefaultsAtRules.js +0 -163
  192. package/src/lib/setupContextUtils.js +0 -1318
  193. package/src/lib/setupTrackingContext.js +0 -169
  194. package/src/lib/sharedState.js +0 -57
  195. package/src/lib/substituteScreenAtRules.js +0 -19
  196. package/src/plugin.js +0 -124
  197. package/src/postcss-plugins/nesting/README.md +0 -42
  198. package/src/postcss-plugins/nesting/index.js +0 -13
  199. package/src/postcss-plugins/nesting/plugin.js +0 -80
  200. package/src/processTailwindFeatures.js +0 -58
  201. package/src/public/colors.js +0 -322
  202. package/src/public/create-plugin.js +0 -2
  203. package/src/public/default-config.js +0 -4
  204. package/src/public/default-theme.js +0 -4
  205. package/src/public/load-config.js +0 -2
  206. package/src/public/resolve-config.js +0 -7
  207. package/src/util/applyImportantSelector.js +0 -27
  208. package/src/util/bigSign.js +0 -3
  209. package/src/util/buildMediaQuery.js +0 -22
  210. package/src/util/cloneDeep.js +0 -11
  211. package/src/util/cloneNodes.js +0 -28
  212. package/src/util/color.js +0 -88
  213. package/src/util/colorNames.js +0 -150
  214. package/src/util/configurePlugins.js +0 -23
  215. package/src/util/createPlugin.js +0 -27
  216. package/src/util/createUtilityPlugin.js +0 -37
  217. package/src/util/dataTypes.js +0 -292
  218. package/src/util/defaults.js +0 -17
  219. package/src/util/escapeClassName.js +0 -8
  220. package/src/util/escapeCommas.js +0 -3
  221. package/src/util/flattenColorPalette.js +0 -13
  222. package/src/util/formatVariantSelector.js +0 -316
  223. package/src/util/getAllConfigs.js +0 -38
  224. package/src/util/hashConfig.js +0 -5
  225. package/src/util/isKeyframeRule.js +0 -3
  226. package/src/util/isPlainObject.js +0 -8
  227. package/src/util/isSyntacticallyValidPropertyValue.js +0 -61
  228. package/src/util/log.js +0 -53
  229. package/src/util/nameClass.js +0 -30
  230. package/src/util/negateValue.js +0 -24
  231. package/src/util/normalizeConfig.js +0 -328
  232. package/src/util/normalizeScreens.js +0 -140
  233. package/src/util/parseAnimationValue.js +0 -68
  234. package/src/util/parseBoxShadowValue.js +0 -72
  235. package/src/util/parseDependency.js +0 -44
  236. package/src/util/parseGlob.js +0 -24
  237. package/src/util/parseObjectStyles.js +0 -19
  238. package/src/util/pluginUtils.js +0 -287
  239. package/src/util/prefixSelector.js +0 -32
  240. package/src/util/pseudoElements.js +0 -170
  241. package/src/util/removeAlphaVariables.js +0 -24
  242. package/src/util/resolveConfig.js +0 -277
  243. package/src/util/resolveConfigPath.js +0 -66
  244. package/src/util/responsive.js +0 -10
  245. package/src/util/splitAtTopLevelOnly.js +0 -52
  246. package/src/util/tap.js +0 -4
  247. package/src/util/toColorValue.js +0 -3
  248. package/src/util/toPath.js +0 -26
  249. package/src/util/transformThemeValue.js +0 -62
  250. package/src/util/validateConfig.js +0 -36
  251. package/src/util/validateFormalSyntax.js +0 -34
  252. package/src/util/withAlphaVariable.js +0 -49
  253. package/src/value-parser/LICENSE +0 -22
  254. package/src/value-parser/README.md +0 -3
  255. package/src/value-parser/index.d.ts +0 -177
  256. package/src/value-parser/index.js +0 -28
  257. package/src/value-parser/parse.js +0 -303
  258. package/src/value-parser/stringify.js +0 -41
  259. package/src/value-parser/unit.js +0 -118
  260. package/src/value-parser/walk.js +0 -18
  261. package/stubs/.gitignore +0 -1
  262. package/stubs/.prettierrc.json +0 -6
  263. package/stubs/config.full.js +0 -1003
  264. package/stubs/config.simple.js +0 -7
  265. package/stubs/postcss.config.cjs +0 -5
  266. package/stubs/postcss.config.js +0 -5
  267. package/stubs/tailwind.config.cjs +0 -2
  268. package/stubs/tailwind.config.js +0 -2
  269. package/stubs/tailwind.config.ts +0 -3
  270. package/tailwind.css +0 -5
  271. package/types/config.d.ts +0 -369
  272. package/types/generated/.gitkeep +0 -0
  273. package/types/generated/colors.d.ts +0 -298
  274. package/types/generated/corePluginList.d.ts +0 -1
  275. package/types/generated/default-theme.d.ts +0 -372
  276. package/types/index.d.ts +0 -7
  277. package/variants.css +0 -1
@@ -1,328 +0,0 @@
1
- import { flagEnabled, featureFlags } 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
- if (config.content === 'auto') {
22
- return true
23
- }
24
-
25
- // `config.purge` should not exist anymore
26
- if (config.purge) {
27
- return false
28
- }
29
-
30
- // `config.content` should exist
31
- if (!config.content) {
32
- return false
33
- }
34
-
35
- // `config.content` should be an object or an array
36
- if (
37
- !Array.isArray(config.content) &&
38
- !(typeof config.content === 'object' && config.content !== null)
39
- ) {
40
- return false
41
- }
42
-
43
- // When `config.content` is an array, it should consist of FilePaths or RawFiles
44
- if (Array.isArray(config.content)) {
45
- return config.content.every((path) => {
46
- // `path` can be a string
47
- if (typeof path === 'string') return true
48
-
49
- // `path` can be an object { raw: string, extension?: string }
50
- // `raw` must be a string
51
- if (typeof path?.raw !== 'string') return false
52
-
53
- // `extension` (if provided) should also be a string
54
- if (path?.extension && typeof path?.extension !== 'string') {
55
- return false
56
- }
57
-
58
- return true
59
- })
60
- }
61
-
62
- // When `config.content` is an object
63
- if (typeof config.content === 'object' && config.content !== null) {
64
- // Only `files`, `relative`, `extract`, and `transform` can exist in `config.content`
65
- if (
66
- Object.keys(config.content).some(
67
- (key) => !['files', 'relative', 'extract', 'transform'].includes(key)
68
- )
69
- ) {
70
- return false
71
- }
72
-
73
- // `config.content.files` should exist of FilePaths or RawFiles
74
- if (Array.isArray(config.content.files)) {
75
- if (
76
- !config.content.files.every((path) => {
77
- // `path` can be a string
78
- if (typeof path === 'string') return true
79
-
80
- // `path` can be an object { raw: string, extension?: string }
81
- // `raw` must be a string
82
- if (typeof path?.raw !== 'string') return false
83
-
84
- // `extension` (if provided) should also be a string
85
- if (path?.extension && typeof path?.extension !== 'string') {
86
- return false
87
- }
88
-
89
- return true
90
- })
91
- ) {
92
- return false
93
- }
94
-
95
- // `config.content.extract` is optional, and can be a Function or a Record<String, Function>
96
- if (typeof config.content.extract === 'object') {
97
- for (let value of Object.values(config.content.extract)) {
98
- if (typeof value !== 'function') {
99
- return false
100
- }
101
- }
102
- } else if (
103
- !(config.content.extract === undefined || typeof config.content.extract === 'function')
104
- ) {
105
- return false
106
- }
107
-
108
- // `config.content.transform` is optional, and can be a Function or a Record<String, Function>
109
- if (typeof config.content.transform === 'object') {
110
- for (let value of Object.values(config.content.transform)) {
111
- if (typeof value !== 'function') {
112
- return false
113
- }
114
- }
115
- } else if (
116
- !(
117
- config.content.transform === undefined || typeof config.content.transform === 'function'
118
- )
119
- ) {
120
- return false
121
- }
122
-
123
- // `config.content.relative` is optional and can be a boolean
124
- if (
125
- typeof config.content.relative !== 'boolean' &&
126
- typeof config.content.relative !== 'undefined'
127
- ) {
128
- return false
129
- }
130
- }
131
-
132
- return true
133
- }
134
-
135
- return false
136
- })()
137
-
138
- if (!valid) {
139
- log.warn('purge-deprecation', [
140
- 'The `purge`/`content` options have changed in Tailwind CSS v3.0.',
141
- 'Update your configuration file to eliminate this warning.',
142
- 'https://tailwindcss.com/docs/upgrade-guide#configure-content-sources',
143
- ])
144
- }
145
-
146
- // Normalize the `safelist`
147
- config.safelist = (() => {
148
- let { content, purge, safelist } = config
149
-
150
- if (Array.isArray(safelist)) return safelist
151
- if (Array.isArray(content?.safelist)) return content.safelist
152
- if (Array.isArray(purge?.safelist)) return purge.safelist
153
- if (Array.isArray(purge?.options?.safelist)) return purge.options.safelist
154
-
155
- return []
156
- })()
157
-
158
- // Normalize the `blocklist`
159
- config.blocklist = (() => {
160
- let { blocklist } = config
161
-
162
- if (Array.isArray(blocklist)) {
163
- if (blocklist.every((item) => typeof item === 'string')) {
164
- return blocklist
165
- }
166
-
167
- log.warn('blocklist-invalid', [
168
- 'The `blocklist` option must be an array of strings.',
169
- 'https://tailwindcss.com/docs/content-configuration#discarding-classes',
170
- ])
171
- }
172
-
173
- return []
174
- })()
175
-
176
- // Normalize prefix option
177
- if (typeof config.prefix === 'function') {
178
- log.warn('prefix-function', [
179
- 'As of Tailwind CSS v3.0, `prefix` cannot be a function.',
180
- 'Update `prefix` in your configuration to be a string to eliminate this warning.',
181
- 'https://tailwindcss.com/docs/upgrade-guide#prefix-cannot-be-a-function',
182
- ])
183
- config.prefix = ''
184
- } else {
185
- config.prefix = config.prefix ?? ''
186
- }
187
-
188
- // Normalize the `content`
189
- config.content = {
190
- relative: (() => {
191
- let { content } = config
192
-
193
- if (content?.relative) {
194
- return content.relative
195
- }
196
-
197
- return flagEnabled(config, 'relativeContentPathsByDefault')
198
- })(),
199
-
200
- files: (() => {
201
- let { content, purge } = config
202
-
203
- if (content === undefined && purge === undefined) return []
204
- if (purge) {
205
- if (Array.isArray(purge)) return purge
206
- if (Array.isArray(purge?.content)) return purge.content
207
- return []
208
- }
209
-
210
- if (Array.isArray(content)) return content
211
- if (Array.isArray(content?.content)) return content.content
212
- if (Array.isArray(content?.files)) return content.files
213
- if (content === 'auto') return ['auto']
214
-
215
- return []
216
- })(),
217
-
218
- extract: (() => {
219
- let extract = (() => {
220
- if (config.purge?.extract) return config.purge.extract
221
- if (config.content?.extract) return config.content.extract
222
-
223
- if (config.purge?.extract?.DEFAULT) return config.purge.extract.DEFAULT
224
- if (config.content?.extract?.DEFAULT) return config.content.extract.DEFAULT
225
-
226
- if (config.purge?.options?.extractors) return config.purge.options.extractors
227
- if (config.content?.options?.extractors) return config.content.options.extractors
228
-
229
- return {}
230
- })()
231
-
232
- let extractors = {}
233
-
234
- let defaultExtractor = (() => {
235
- if (config.purge?.options?.defaultExtractor) {
236
- return config.purge.options.defaultExtractor
237
- }
238
-
239
- if (config.content?.options?.defaultExtractor) {
240
- return config.content.options.defaultExtractor
241
- }
242
-
243
- return undefined
244
- })()
245
-
246
- if (defaultExtractor !== undefined) {
247
- extractors.DEFAULT = defaultExtractor
248
- }
249
-
250
- // Functions
251
- if (typeof extract === 'function') {
252
- extractors.DEFAULT = extract
253
- }
254
-
255
- // Arrays
256
- else if (Array.isArray(extract)) {
257
- for (let { extensions, extractor } of extract ?? []) {
258
- for (let extension of extensions) {
259
- extractors[extension] = extractor
260
- }
261
- }
262
- }
263
-
264
- // Objects
265
- else if (typeof extract === 'object' && extract !== null) {
266
- Object.assign(extractors, extract)
267
- }
268
-
269
- return extractors
270
- })(),
271
-
272
- transform: (() => {
273
- let transform = (() => {
274
- if (config.purge?.transform) return config.purge.transform
275
- if (config.content?.transform) return config.content.transform
276
-
277
- if (config.purge?.transform?.DEFAULT) return config.purge.transform.DEFAULT
278
- if (config.content?.transform?.DEFAULT) return config.content.transform.DEFAULT
279
-
280
- return {}
281
- })()
282
-
283
- let transformers = {}
284
-
285
- if (typeof transform === 'function') {
286
- transformers.DEFAULT = transform
287
- }
288
-
289
- if (typeof transform === 'object' && transform !== null) {
290
- Object.assign(transformers, transform)
291
- }
292
-
293
- return transformers
294
- })(),
295
- }
296
-
297
- // Force disable the `oxideParser` feature flag when using unsupported features.
298
- // TODO: Remove once we have prefix or separator support in the oxide parser.
299
- if (config.prefix !== '' || config.separator !== ':') {
300
- if (config.experimental === 'all') {
301
- config.experimental = {}
302
- for (let key in featureFlags.experimental) {
303
- config.experimental[key] = true
304
- }
305
- } else {
306
- config.experimental = config.experimental ?? {}
307
- }
308
-
309
- config.experimental.oxideParser = false
310
- }
311
-
312
- // Validate globs to prevent bogus globs.
313
- // E.g.: `./src/*.{html}` is invalid, the `{html}` should just be `html`
314
- if (config.content.files !== 'auto') {
315
- for (let file of config.content.files) {
316
- if (typeof file === 'string' && /{([^,]*?)}/g.test(file)) {
317
- log.warn('invalid-glob-braces', [
318
- `The glob pattern ${dim(file)} in your Tailwind CSS configuration is invalid.`,
319
- `Update it to ${dim(file.replace(/{([^,]*?)}/g, '$1'))} to silence this warning.`,
320
- // TODO: Add https://tw.wtf/invalid-glob-braces
321
- ])
322
- break
323
- }
324
- }
325
- }
326
-
327
- return config
328
- }
@@ -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
- }