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,307 +0,0 @@
1
- import escapeCommas from './escapeCommas'
2
- import { withAlphaValue } from './withAlphaVariable'
3
- import {
4
- normalize,
5
- length,
6
- number,
7
- percentage,
8
- url,
9
- color as validateColor,
10
- genericName,
11
- familyName,
12
- image,
13
- absoluteSize,
14
- relativeSize,
15
- position,
16
- lineWidth,
17
- shadow,
18
- } from './dataTypes'
19
- import negateValue from './negateValue'
20
- import { backgroundSize } from './validateFormalSyntax'
21
- import { flagEnabled } from '../featureFlags.js'
22
-
23
- /**
24
- * @param {import('postcss-selector-parser').Container} selectors
25
- * @param {(className: string) => string} updateClass
26
- * @returns {string}
27
- */
28
- export function updateAllClasses(selectors, updateClass) {
29
- selectors.walkClasses((sel) => {
30
- sel.value = updateClass(sel.value)
31
-
32
- if (sel.raws && sel.raws.value) {
33
- sel.raws.value = escapeCommas(sel.raws.value)
34
- }
35
- })
36
- }
37
-
38
- function resolveArbitraryValue(modifier, validate) {
39
- if (!isArbitraryValue(modifier)) {
40
- return undefined
41
- }
42
-
43
- let value = modifier.slice(1, -1)
44
-
45
- if (!validate(value)) {
46
- return undefined
47
- }
48
-
49
- return normalize(value)
50
- }
51
-
52
- function asNegativeValue(modifier, lookup = {}, validate) {
53
- let positiveValue = lookup[modifier]
54
-
55
- if (positiveValue !== undefined) {
56
- return negateValue(positiveValue)
57
- }
58
-
59
- if (isArbitraryValue(modifier)) {
60
- let resolved = resolveArbitraryValue(modifier, validate)
61
-
62
- if (resolved === undefined) {
63
- return undefined
64
- }
65
-
66
- return negateValue(resolved)
67
- }
68
- }
69
-
70
- export function asValue(modifier, options = {}, { validate = () => true } = {}) {
71
- let value = options.values?.[modifier]
72
-
73
- if (value !== undefined) {
74
- return value
75
- }
76
-
77
- if (options.supportsNegativeValues && modifier.startsWith('-')) {
78
- return asNegativeValue(modifier.slice(1), options.values, validate)
79
- }
80
-
81
- return resolveArbitraryValue(modifier, validate)
82
- }
83
-
84
- function isArbitraryValue(input) {
85
- return input.startsWith('[') && input.endsWith(']')
86
- }
87
-
88
- function splitUtilityModifier(modifier) {
89
- let slashIdx = modifier.lastIndexOf('/')
90
-
91
- // If the `/` is inside an arbitrary, we want to find the previous one if any
92
- // This logic probably isn't perfect but it should work for most cases
93
- let arbitraryStartIdx = modifier.lastIndexOf('[', slashIdx)
94
- let arbitraryEndIdx = modifier.indexOf(']', slashIdx)
95
-
96
- let isNextToArbitrary = modifier[slashIdx - 1] === ']' || modifier[slashIdx + 1] === '['
97
-
98
- // Backtrack to the previous `/` if the one we found was inside an arbitrary
99
- if (!isNextToArbitrary) {
100
- if (arbitraryStartIdx !== -1 && arbitraryEndIdx !== -1) {
101
- if (arbitraryStartIdx < slashIdx && slashIdx < arbitraryEndIdx) {
102
- slashIdx = modifier.lastIndexOf('/', arbitraryStartIdx)
103
- }
104
- }
105
- }
106
-
107
- if (slashIdx === -1 || slashIdx === modifier.length - 1) {
108
- return [modifier, undefined]
109
- }
110
-
111
- let arbitrary = isArbitraryValue(modifier)
112
-
113
- // The modifier could be of the form `[foo]/[bar]`
114
- // We want to handle this case properly
115
- // without affecting `[foo/bar]`
116
- if (arbitrary && !modifier.includes(']/[')) {
117
- return [modifier, undefined]
118
- }
119
-
120
- return [modifier.slice(0, slashIdx), modifier.slice(slashIdx + 1)]
121
- }
122
-
123
- export function parseColorFormat(value) {
124
- if (typeof value === 'string' && value.includes('<alpha-value>')) {
125
- let oldValue = value
126
-
127
- return ({ opacityValue = 1 }) => oldValue.replace('<alpha-value>', opacityValue)
128
- }
129
-
130
- return value
131
- }
132
-
133
- function unwrapArbitraryModifier(modifier) {
134
- return normalize(modifier.slice(1, -1))
135
- }
136
-
137
- export function asColor(modifier, options = {}, { tailwindConfig = {} } = {}) {
138
- if (options.values?.[modifier] !== undefined) {
139
- return parseColorFormat(options.values?.[modifier])
140
- }
141
-
142
- // TODO: Hoist this up to getMatchingTypes or something
143
- // We do this here because we need the alpha value (if any)
144
- let [color, alpha] = splitUtilityModifier(modifier)
145
-
146
- if (alpha !== undefined) {
147
- let normalizedColor =
148
- options.values?.[color] ?? (isArbitraryValue(color) ? color.slice(1, -1) : undefined)
149
-
150
- if (normalizedColor === undefined) {
151
- return undefined
152
- }
153
-
154
- normalizedColor = parseColorFormat(normalizedColor)
155
-
156
- if (isArbitraryValue(alpha)) {
157
- return withAlphaValue(normalizedColor, unwrapArbitraryModifier(alpha))
158
- }
159
-
160
- if (tailwindConfig.theme?.opacity?.[alpha] === undefined) {
161
- return undefined
162
- }
163
-
164
- return withAlphaValue(normalizedColor, tailwindConfig.theme.opacity[alpha])
165
- }
166
-
167
- return asValue(modifier, options, { validate: validateColor })
168
- }
169
-
170
- export function asLookupValue(modifier, options = {}) {
171
- return options.values?.[modifier]
172
- }
173
-
174
- function guess(validate) {
175
- return (modifier, options) => {
176
- return asValue(modifier, options, { validate })
177
- }
178
- }
179
-
180
- export let typeMap = {
181
- any: asValue,
182
- color: asColor,
183
- url: guess(url),
184
- image: guess(image),
185
- length: guess(length),
186
- percentage: guess(percentage),
187
- position: guess(position),
188
- lookup: asLookupValue,
189
- 'generic-name': guess(genericName),
190
- 'family-name': guess(familyName),
191
- number: guess(number),
192
- 'line-width': guess(lineWidth),
193
- 'absolute-size': guess(absoluteSize),
194
- 'relative-size': guess(relativeSize),
195
- shadow: guess(shadow),
196
- size: guess(backgroundSize),
197
- }
198
-
199
- let supportedTypes = Object.keys(typeMap)
200
-
201
- function splitAtFirst(input, delim) {
202
- let idx = input.indexOf(delim)
203
- if (idx === -1) return [undefined, input]
204
- return [input.slice(0, idx), input.slice(idx + 1)]
205
- }
206
-
207
- export function coerceValue(types, modifier, options, tailwindConfig) {
208
- if (options.values && modifier in options.values) {
209
- for (let { type } of types ?? []) {
210
- let result = typeMap[type](modifier, options, {
211
- tailwindConfig,
212
- })
213
-
214
- if (result === undefined) {
215
- continue
216
- }
217
-
218
- return [result, type, null]
219
- }
220
- }
221
-
222
- if (isArbitraryValue(modifier)) {
223
- let arbitraryValue = modifier.slice(1, -1)
224
- let [explicitType, value] = splitAtFirst(arbitraryValue, ':')
225
-
226
- // It could be that this resolves to `url(https` which is not a valid
227
- // identifier. We currently only support "simple" words with dashes or
228
- // underscores. E.g.: family-name
229
- if (!/^[\w-_]+$/g.test(explicitType)) {
230
- value = arbitraryValue
231
- }
232
-
233
- //
234
- else if (explicitType !== undefined && !supportedTypes.includes(explicitType)) {
235
- return []
236
- }
237
-
238
- if (value.length > 0 && supportedTypes.includes(explicitType)) {
239
- return [asValue(`[${value}]`, options), explicitType, null]
240
- }
241
- }
242
-
243
- let matches = getMatchingTypes(types, modifier, options, tailwindConfig)
244
-
245
- // Find first matching type
246
- for (let match of matches) {
247
- return match
248
- }
249
-
250
- return []
251
- }
252
-
253
- /**
254
- *
255
- * @param {{type: string}[]} types
256
- * @param {string} rawModifier
257
- * @param {any} options
258
- * @param {any} tailwindConfig
259
- * @returns {Iterator<[value: string, type: string, modifier: string | null]>}
260
- */
261
- export function* getMatchingTypes(types, rawModifier, options, tailwindConfig) {
262
- let modifiersEnabled = flagEnabled(tailwindConfig, 'generalizedModifiers')
263
-
264
- let [modifier, utilityModifier] = splitUtilityModifier(rawModifier)
265
-
266
- let canUseUtilityModifier =
267
- modifiersEnabled &&
268
- options.modifiers != null &&
269
- (options.modifiers === 'any' ||
270
- (typeof options.modifiers === 'object' &&
271
- ((utilityModifier && isArbitraryValue(utilityModifier)) ||
272
- utilityModifier in options.modifiers)))
273
-
274
- if (!canUseUtilityModifier) {
275
- modifier = rawModifier
276
- utilityModifier = undefined
277
- }
278
-
279
- if (utilityModifier !== undefined && modifier === '') {
280
- modifier = 'DEFAULT'
281
- }
282
-
283
- // Check the full value first
284
- // TODO: Move to asValue… somehow
285
- if (utilityModifier !== undefined) {
286
- if (typeof options.modifiers === 'object') {
287
- let configValue = options.modifiers?.[utilityModifier] ?? null
288
- if (configValue !== null) {
289
- utilityModifier = configValue
290
- } else if (isArbitraryValue(utilityModifier)) {
291
- utilityModifier = unwrapArbitraryModifier(utilityModifier)
292
- }
293
- }
294
- }
295
-
296
- for (let { type } of types ?? []) {
297
- let result = typeMap[type](modifier, options, {
298
- tailwindConfig,
299
- })
300
-
301
- if (result === undefined) {
302
- continue
303
- }
304
-
305
- yield [result, type, utilityModifier ?? null]
306
- }
307
- }
@@ -1,33 +0,0 @@
1
- import parser from 'postcss-selector-parser'
2
-
3
- /**
4
- * @template {string | import('postcss-selector-parser').Root} T
5
- *
6
- * Prefix all classes in the selector with the given prefix
7
- *
8
- * It can take either a string or a selector AST and will return the same type
9
- *
10
- * @param {string} prefix
11
- * @param {T} selector
12
- * @param {boolean} prependNegative
13
- * @returns {T}
14
- */
15
- export default function (prefix, selector, prependNegative = false) {
16
- if (prefix === '') {
17
- return selector
18
- }
19
-
20
- /** @type {import('postcss-selector-parser').Root} */
21
- let ast = typeof selector === 'string' ? parser().astSync(selector) : selector
22
-
23
- ast.walkClasses((classSelector) => {
24
- let baseClass = classSelector.value
25
- let shouldPlaceNegativeBeforePrefix = prependNegative && baseClass.startsWith('-')
26
-
27
- classSelector.value = shouldPlaceNegativeBeforePrefix
28
- ? `-${prefix}${baseClass.slice(1)}`
29
- : `${prefix}${baseClass}`
30
- })
31
-
32
- return typeof selector === 'string' ? ast.toString() : ast
33
- }
@@ -1,167 +0,0 @@
1
- /** @typedef {import('postcss-selector-parser').Root} Root */
2
- /** @typedef {import('postcss-selector-parser').Selector} Selector */
3
- /** @typedef {import('postcss-selector-parser').Pseudo} Pseudo */
4
- /** @typedef {import('postcss-selector-parser').Node} Node */
5
-
6
- // There are some pseudo-elements that may or may not be:
7
-
8
- // **Actionable**
9
- // Zero or more user-action pseudo-classes may be attached to the pseudo-element itself
10
- // structural-pseudo-classes are NOT allowed but we don't make
11
- // The spec is not clear on whether this is allowed or not — but in practice it is.
12
-
13
- // **Terminal**
14
- // It MUST be placed at the end of a selector
15
- //
16
- // This is the required in the spec. However, some pseudo elements are not "terminal" because
17
- // they represent a "boundary piercing" that is compiled out by a build step.
18
-
19
- // **Jumpable**
20
- // Any terminal element may "jump" over combinators when moving to the end of the selector
21
- //
22
- // This is a backwards-compat quirk of pseudo element variants from earlier versions of Tailwind CSS.
23
-
24
- /** @typedef {'terminal' | 'actionable' | 'jumpable'} PseudoProperty */
25
-
26
- /** @type {Record<string, PseudoProperty[]>} */
27
- let elementProperties = {
28
- // Pseudo elements from the spec
29
- '::after': ['terminal', 'jumpable'],
30
- '::backdrop': ['terminal', 'jumpable'],
31
- '::before': ['terminal', 'jumpable'],
32
- '::cue': ['terminal'],
33
- '::cue-region': ['terminal'],
34
- '::first-letter': ['terminal', 'jumpable'],
35
- '::first-line': ['terminal', 'jumpable'],
36
- '::grammar-error': ['terminal'],
37
- '::marker': ['terminal', 'jumpable'],
38
- '::part': ['terminal', 'actionable'],
39
- '::placeholder': ['terminal', 'jumpable'],
40
- '::selection': ['terminal', 'jumpable'],
41
- '::slotted': ['terminal'],
42
- '::spelling-error': ['terminal'],
43
- '::target-text': ['terminal'],
44
-
45
- // Pseudo elements from the spec with special rules
46
- '::file-selector-button': ['terminal', 'actionable'],
47
-
48
- // Library-specific pseudo elements used by component libraries
49
- // These are Shadow DOM-like
50
- '::deep': ['actionable'],
51
- '::v-deep': ['actionable'],
52
- '::ng-deep': ['actionable'],
53
-
54
- // Note: As a rule, double colons (::) should be used instead of a single colon
55
- // (:). This distinguishes pseudo-classes from pseudo-elements. However, since
56
- // this distinction was not present in older versions of the W3C spec, most
57
- // browsers support both syntaxes for the original pseudo-elements.
58
- ':after': ['terminal', 'jumpable'],
59
- ':before': ['terminal', 'jumpable'],
60
- ':first-letter': ['terminal', 'jumpable'],
61
- ':first-line': ['terminal', 'jumpable'],
62
-
63
- // The default value is used when the pseudo-element is not recognized
64
- // Because it's not recognized, we don't know if it's terminal or not
65
- // So we assume it can be moved AND can have user-action pseudo classes attached to it
66
- __default__: ['terminal', 'actionable'],
67
- }
68
-
69
- /**
70
- * @param {Selector} sel
71
- * @returns {Selector}
72
- */
73
- export function movePseudos(sel) {
74
- let [pseudos] = movablePseudos(sel)
75
-
76
- // Remove all pseudo elements from their respective selectors
77
- pseudos.forEach(([sel, pseudo]) => sel.removeChild(pseudo))
78
-
79
- // Re-add them to the end of the selector in the correct order.
80
- // This moves terminal pseudo elements to the end of the
81
- // selector otherwise the selector will not be valid.
82
- //
83
- // Examples:
84
- // - `before:hover:text-center` would result in `.before\:hover\:text-center:hover::before`
85
- // - `hover:before:text-center` would result in `.hover\:before\:text-center:hover::before`
86
- //
87
- // The selector `::before:hover` does not work but we
88
- // can make it work for you by flipping the order.
89
- sel.nodes.push(...pseudos.map(([, pseudo]) => pseudo))
90
-
91
- return sel
92
- }
93
-
94
- /** @typedef {[sel: Selector, pseudo: Pseudo, attachedTo: Pseudo | null]} MovablePseudo */
95
- /** @typedef {[pseudos: MovablePseudo[], lastSeenElement: Pseudo | null]} MovablePseudosResult */
96
-
97
- /**
98
- * @param {Selector} sel
99
- * @returns {MovablePseudosResult}
100
- */
101
- function movablePseudos(sel) {
102
- /** @type {MovablePseudo[]} */
103
- let buffer = []
104
-
105
- /** @type {Pseudo | null} */
106
- let lastSeenElement = null
107
-
108
- for (let node of sel.nodes) {
109
- if (node.type === 'combinator') {
110
- buffer = buffer.filter(([, node]) => propertiesForPseudo(node).includes('jumpable'))
111
- lastSeenElement = null
112
- } else if (node.type === 'pseudo') {
113
- if (isMovablePseudoElement(node)) {
114
- lastSeenElement = node
115
- buffer.push([sel, node, null])
116
- } else if (lastSeenElement && isAttachablePseudoClass(node, lastSeenElement)) {
117
- buffer.push([sel, node, lastSeenElement])
118
- } else {
119
- lastSeenElement = null
120
- }
121
-
122
- for (let sub of node.nodes ?? []) {
123
- let [movable, lastSeenElementInSub] = movablePseudos(sub)
124
- lastSeenElement = lastSeenElementInSub || lastSeenElement
125
- buffer.push(...movable)
126
- }
127
- }
128
- }
129
-
130
- return [buffer, lastSeenElement]
131
- }
132
-
133
- /**
134
- * @param {Node} node
135
- * @returns {boolean}
136
- */
137
- function isPseudoElement(node) {
138
- return node.value.startsWith('::') || elementProperties[node.value] !== undefined
139
- }
140
-
141
- /**
142
- * @param {Node} node
143
- * @returns {boolean}
144
- */
145
- function isMovablePseudoElement(node) {
146
- return isPseudoElement(node) && propertiesForPseudo(node).includes('terminal')
147
- }
148
-
149
- /**
150
- * @param {Node} node
151
- * @param {Pseudo} pseudo
152
- * @returns {boolean}
153
- */
154
- function isAttachablePseudoClass(node, pseudo) {
155
- if (node.type !== 'pseudo') return false
156
- if (isPseudoElement(node)) return false
157
-
158
- return propertiesForPseudo(pseudo).includes('actionable')
159
- }
160
-
161
- /**
162
- * @param {Pseudo} pseudo
163
- * @returns {PseudoProperty[]}
164
- */
165
- function propertiesForPseudo(pseudo) {
166
- return elementProperties[pseudo.value] ?? elementProperties.__default__
167
- }
@@ -1,24 +0,0 @@
1
- /**
2
- * This function removes any uses of CSS variables used as an alpha channel
3
- *
4
- * This is required for selectors like `:visited` which do not allow
5
- * changes in opacity or external control using CSS variables.
6
- *
7
- * @param {import('postcss').Container} container
8
- * @param {string[]} toRemove
9
- */
10
- export function removeAlphaVariables(container, toRemove) {
11
- container.walkDecls((decl) => {
12
- if (toRemove.includes(decl.prop)) {
13
- decl.remove()
14
-
15
- return
16
- }
17
-
18
- for (let varName of toRemove) {
19
- if (decl.value.includes(`/ var(${varName})`)) {
20
- decl.value = decl.value.replace(`/ var(${varName})`, '')
21
- }
22
- }
23
- })
24
- }