tailwindcss 0.0.0-insiders.ff2c25f → 0.0.0-internal.b2586d4e

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 (248) hide show
  1. package/README.md +5 -6
  2. package/dist/lib.d.mts +339 -0
  3. package/dist/lib.d.ts +339 -0
  4. package/dist/lib.js +17 -0
  5. package/dist/lib.mjs +17 -0
  6. package/index.css +5 -0
  7. package/package.json +36 -107
  8. package/preflight.css +334 -0
  9. package/theme.css +463 -0
  10. package/base.css +0 -1
  11. package/colors.d.ts +0 -3
  12. package/colors.js +0 -2
  13. package/components.css +0 -1
  14. package/defaultConfig.d.ts +0 -3
  15. package/defaultConfig.js +0 -2
  16. package/defaultTheme.d.ts +0 -4
  17. package/defaultTheme.js +0 -2
  18. package/lib/cli/build/deps.js +0 -54
  19. package/lib/cli/build/index.js +0 -48
  20. package/lib/cli/build/plugin.js +0 -367
  21. package/lib/cli/build/utils.js +0 -78
  22. package/lib/cli/build/watching.js +0 -178
  23. package/lib/cli/help/index.js +0 -71
  24. package/lib/cli/index.js +0 -239
  25. package/lib/cli/init/index.js +0 -46
  26. package/lib/cli-peer-dependencies.js +0 -28
  27. package/lib/cli.js +0 -7
  28. package/lib/constants.js +0 -44
  29. package/lib/corePluginList.js +0 -181
  30. package/lib/corePlugins.js +0 -4062
  31. package/lib/css/LICENSE +0 -25
  32. package/lib/css/preflight.css +0 -367
  33. package/lib/featureFlags.js +0 -71
  34. package/lib/index.js +0 -6
  35. package/lib/lib/cacheInvalidation.js +0 -90
  36. package/lib/lib/collapseAdjacentRules.js +0 -59
  37. package/lib/lib/collapseDuplicateDeclarations.js +0 -83
  38. package/lib/lib/content.js +0 -177
  39. package/lib/lib/defaultExtractor.js +0 -241
  40. package/lib/lib/detectNesting.js +0 -43
  41. package/lib/lib/evaluateTailwindFunctions.js +0 -234
  42. package/lib/lib/expandApplyAtRules.js +0 -526
  43. package/lib/lib/expandTailwindAtRules.js +0 -273
  44. package/lib/lib/findAtConfigPath.js +0 -44
  45. package/lib/lib/generateRules.js +0 -866
  46. package/lib/lib/getModuleDependencies.js +0 -51
  47. package/lib/lib/normalizeTailwindDirectives.js +0 -87
  48. package/lib/lib/offsets.js +0 -299
  49. package/lib/lib/partitionApplyAtRules.js +0 -56
  50. package/lib/lib/regex.js +0 -60
  51. package/lib/lib/remap-bitfield.js +0 -87
  52. package/lib/lib/resolveDefaultsAtRules.js +0 -161
  53. package/lib/lib/setupContextUtils.js +0 -1218
  54. package/lib/lib/setupTrackingContext.js +0 -163
  55. package/lib/lib/sharedState.js +0 -78
  56. package/lib/lib/substituteScreenAtRules.js +0 -29
  57. package/lib/oxide/cli/build/deps.js +0 -81
  58. package/lib/oxide/cli/build/index.js +0 -47
  59. package/lib/oxide/cli/build/plugin.js +0 -364
  60. package/lib/oxide/cli/build/utils.js +0 -77
  61. package/lib/oxide/cli/build/watching.js +0 -177
  62. package/lib/oxide/cli/help/index.js +0 -70
  63. package/lib/oxide/cli/index.js +0 -220
  64. package/lib/oxide/cli/init/index.js +0 -35
  65. package/lib/oxide/cli.js +0 -5
  66. package/lib/oxide/postcss-plugin.js +0 -2
  67. package/lib/plugin.js +0 -48
  68. package/lib/postcss-plugins/nesting/README.md +0 -42
  69. package/lib/postcss-plugins/nesting/index.js +0 -19
  70. package/lib/postcss-plugins/nesting/plugin.js +0 -87
  71. package/lib/processTailwindFeatures.js +0 -62
  72. package/lib/public/colors.js +0 -331
  73. package/lib/public/create-plugin.js +0 -15
  74. package/lib/public/default-config.js +0 -16
  75. package/lib/public/default-theme.js +0 -16
  76. package/lib/public/resolve-config.js +0 -22
  77. package/lib/util/bigSign.js +0 -11
  78. package/lib/util/buildMediaQuery.js +0 -25
  79. package/lib/util/cloneDeep.js +0 -20
  80. package/lib/util/cloneNodes.js +0 -32
  81. package/lib/util/color.js +0 -98
  82. package/lib/util/configurePlugins.js +0 -21
  83. package/lib/util/createPlugin.js +0 -30
  84. package/lib/util/createUtilityPlugin.js +0 -51
  85. package/lib/util/dataTypes.js +0 -266
  86. package/lib/util/defaults.js +0 -25
  87. package/lib/util/escapeClassName.js +0 -22
  88. package/lib/util/escapeCommas.js +0 -11
  89. package/lib/util/flattenColorPalette.js +0 -16
  90. package/lib/util/formatVariantSelector.js +0 -351
  91. package/lib/util/getAllConfigs.js +0 -48
  92. package/lib/util/hashConfig.js +0 -19
  93. package/lib/util/isKeyframeRule.js +0 -11
  94. package/lib/util/isPlainObject.js +0 -15
  95. package/lib/util/isSyntacticallyValidPropertyValue.js +0 -72
  96. package/lib/util/log.js +0 -57
  97. package/lib/util/nameClass.js +0 -43
  98. package/lib/util/negateValue.js +0 -34
  99. package/lib/util/normalizeConfig.js +0 -281
  100. package/lib/util/normalizeScreens.js +0 -170
  101. package/lib/util/parseAnimationValue.js +0 -91
  102. package/lib/util/parseBoxShadowValue.js +0 -84
  103. package/lib/util/parseDependency.js +0 -45
  104. package/lib/util/parseGlob.js +0 -34
  105. package/lib/util/parseObjectStyles.js +0 -34
  106. package/lib/util/pluginUtils.js +0 -283
  107. package/lib/util/prefixSelector.js +0 -37
  108. package/lib/util/removeAlphaVariables.js +0 -29
  109. package/lib/util/resolveConfig.js +0 -254
  110. package/lib/util/resolveConfigPath.js +0 -54
  111. package/lib/util/responsive.js +0 -22
  112. package/lib/util/splitAtTopLevelOnly.js +0 -43
  113. package/lib/util/tap.js +0 -12
  114. package/lib/util/toColorValue.js +0 -11
  115. package/lib/util/toPath.js +0 -30
  116. package/lib/util/transformThemeValue.js +0 -71
  117. package/lib/util/validateConfig.js +0 -24
  118. package/lib/util/validateFormalSyntax.js +0 -24
  119. package/lib/util/withAlphaVariable.js +0 -75
  120. package/nesting/index.js +0 -2
  121. package/oxide-node-api-shim/index.js +0 -21
  122. package/oxide-node-api-shim/package.json +0 -5
  123. package/peers/index.js +0 -79461
  124. package/plugin.d.ts +0 -11
  125. package/plugin.js +0 -2
  126. package/prettier.config.js +0 -19
  127. package/resolveConfig.d.ts +0 -12
  128. package/resolveConfig.js +0 -2
  129. package/screens.css +0 -1
  130. package/scripts/create-plugin-list.js +0 -10
  131. package/scripts/generate-types.js +0 -105
  132. package/scripts/release-channel.js +0 -18
  133. package/scripts/release-notes.js +0 -21
  134. package/scripts/swap-engines.js +0 -40
  135. package/scripts/type-utils.js +0 -27
  136. package/src/cli/build/deps.js +0 -56
  137. package/src/cli/build/index.js +0 -49
  138. package/src/cli/build/plugin.js +0 -439
  139. package/src/cli/build/utils.js +0 -76
  140. package/src/cli/build/watching.js +0 -227
  141. package/src/cli/help/index.js +0 -70
  142. package/src/cli/index.js +0 -234
  143. package/src/cli/init/index.js +0 -50
  144. package/src/cli-peer-dependencies.js +0 -15
  145. package/src/cli.js +0 -7
  146. package/src/constants.js +0 -17
  147. package/src/corePluginList.js +0 -1
  148. package/src/corePlugins.js +0 -2744
  149. package/src/css/LICENSE +0 -25
  150. package/src/css/preflight.css +0 -367
  151. package/src/featureFlags.js +0 -64
  152. package/src/index.js +0 -5
  153. package/src/lib/cacheInvalidation.js +0 -52
  154. package/src/lib/collapseAdjacentRules.js +0 -58
  155. package/src/lib/collapseDuplicateDeclarations.js +0 -93
  156. package/src/lib/content.js +0 -208
  157. package/src/lib/defaultExtractor.js +0 -217
  158. package/src/lib/detectNesting.js +0 -47
  159. package/src/lib/evaluateTailwindFunctions.js +0 -269
  160. package/src/lib/expandApplyAtRules.js +0 -606
  161. package/src/lib/expandTailwindAtRules.js +0 -285
  162. package/src/lib/findAtConfigPath.js +0 -48
  163. package/src/lib/generateRules.js +0 -899
  164. package/src/lib/getModuleDependencies.js +0 -39
  165. package/src/lib/normalizeTailwindDirectives.js +0 -84
  166. package/src/lib/offsets.js +0 -367
  167. package/src/lib/partitionApplyAtRules.js +0 -52
  168. package/src/lib/regex.js +0 -74
  169. package/src/lib/remap-bitfield.js +0 -82
  170. package/src/lib/resolveDefaultsAtRules.js +0 -163
  171. package/src/lib/setupContextUtils.js +0 -1308
  172. package/src/lib/setupTrackingContext.js +0 -171
  173. package/src/lib/sharedState.js +0 -67
  174. package/src/lib/substituteScreenAtRules.js +0 -19
  175. package/src/oxide/cli/build/deps.ts +0 -91
  176. package/src/oxide/cli/build/index.ts +0 -47
  177. package/src/oxide/cli/build/plugin.ts +0 -436
  178. package/src/oxide/cli/build/utils.ts +0 -74
  179. package/src/oxide/cli/build/watching.ts +0 -225
  180. package/src/oxide/cli/help/index.ts +0 -69
  181. package/src/oxide/cli/index.ts +0 -212
  182. package/src/oxide/cli/init/index.ts +0 -32
  183. package/src/oxide/cli.ts +0 -1
  184. package/src/oxide/postcss-plugin.ts +0 -1
  185. package/src/plugin.js +0 -47
  186. package/src/postcss-plugins/nesting/README.md +0 -42
  187. package/src/postcss-plugins/nesting/index.js +0 -13
  188. package/src/postcss-plugins/nesting/plugin.js +0 -80
  189. package/src/processTailwindFeatures.js +0 -58
  190. package/src/public/colors.js +0 -300
  191. package/src/public/create-plugin.js +0 -2
  192. package/src/public/default-config.js +0 -4
  193. package/src/public/default-theme.js +0 -4
  194. package/src/public/resolve-config.js +0 -7
  195. package/src/util/bigSign.js +0 -3
  196. package/src/util/buildMediaQuery.js +0 -22
  197. package/src/util/cloneDeep.js +0 -11
  198. package/src/util/cloneNodes.js +0 -28
  199. package/src/util/color.js +0 -73
  200. package/src/util/configurePlugins.js +0 -23
  201. package/src/util/createPlugin.js +0 -27
  202. package/src/util/createUtilityPlugin.js +0 -37
  203. package/src/util/dataTypes.js +0 -281
  204. package/src/util/defaults.js +0 -17
  205. package/src/util/escapeClassName.js +0 -8
  206. package/src/util/escapeCommas.js +0 -3
  207. package/src/util/flattenColorPalette.js +0 -13
  208. package/src/util/formatVariantSelector.js +0 -412
  209. package/src/util/getAllConfigs.js +0 -38
  210. package/src/util/hashConfig.js +0 -5
  211. package/src/util/isKeyframeRule.js +0 -3
  212. package/src/util/isPlainObject.js +0 -8
  213. package/src/util/isSyntacticallyValidPropertyValue.js +0 -61
  214. package/src/util/log.js +0 -29
  215. package/src/util/nameClass.js +0 -30
  216. package/src/util/negateValue.js +0 -24
  217. package/src/util/normalizeConfig.js +0 -300
  218. package/src/util/normalizeScreens.js +0 -140
  219. package/src/util/parseAnimationValue.js +0 -68
  220. package/src/util/parseBoxShadowValue.js +0 -72
  221. package/src/util/parseDependency.js +0 -44
  222. package/src/util/parseGlob.js +0 -24
  223. package/src/util/parseObjectStyles.js +0 -19
  224. package/src/util/pluginUtils.js +0 -314
  225. package/src/util/prefixSelector.js +0 -32
  226. package/src/util/removeAlphaVariables.js +0 -24
  227. package/src/util/resolveConfig.js +0 -277
  228. package/src/util/resolveConfigPath.js +0 -55
  229. package/src/util/responsive.js +0 -10
  230. package/src/util/splitAtTopLevelOnly.js +0 -45
  231. package/src/util/tap.js +0 -4
  232. package/src/util/toColorValue.js +0 -3
  233. package/src/util/toPath.js +0 -26
  234. package/src/util/transformThemeValue.js +0 -62
  235. package/src/util/validateConfig.js +0 -13
  236. package/src/util/validateFormalSyntax.js +0 -34
  237. package/src/util/withAlphaVariable.js +0 -49
  238. package/stubs/defaultConfig.stub.js +0 -956
  239. package/stubs/defaultPostCssConfig.stub.js +0 -6
  240. package/stubs/simpleConfig.stub.js +0 -8
  241. package/tailwind.css +0 -5
  242. package/types/config.d.ts +0 -367
  243. package/types/generated/.gitkeep +0 -0
  244. package/types/generated/colors.d.ts +0 -276
  245. package/types/generated/corePluginList.d.ts +0 -1
  246. package/types/generated/default-theme.d.ts +0 -345
  247. package/types/index.d.ts +0 -7
  248. package/variants.css +0 -1
@@ -1,412 +0,0 @@
1
- import selectorParser from 'postcss-selector-parser'
2
- import unescape from 'postcss-selector-parser/dist/util/unesc'
3
- import escapeClassName from '../util/escapeClassName'
4
- import prefixSelector from '../util/prefixSelector'
5
-
6
- /** @typedef {import('postcss-selector-parser').Root} Root */
7
- /** @typedef {import('postcss-selector-parser').Selector} Selector */
8
- /** @typedef {import('postcss-selector-parser').Pseudo} Pseudo */
9
- /** @typedef {import('postcss-selector-parser').Node} Node */
10
-
11
- /** @typedef {{format: string, isArbitraryVariant: boolean}[]} RawFormats */
12
- /** @typedef {import('postcss-selector-parser').Root} ParsedFormats */
13
- /** @typedef {RawFormats | ParsedFormats} AcceptedFormats */
14
-
15
- let MERGE = ':merge'
16
-
17
- /**
18
- * @param {RawFormats} formats
19
- * @param {{context: any, candidate: string, base: string | null}} options
20
- * @returns {ParsedFormats | null}
21
- */
22
- export function formatVariantSelector(formats, { context, candidate }) {
23
- let prefix = context?.tailwindConfig.prefix ?? ''
24
-
25
- // Parse the format selector into an AST
26
- let parsedFormats = formats.map((format) => {
27
- let ast = selectorParser().astSync(format.format)
28
-
29
- return {
30
- ...format,
31
- ast: format.isArbitraryVariant ? ast : prefixSelector(prefix, ast),
32
- }
33
- })
34
-
35
- // We start with the candidate selector
36
- let formatAst = selectorParser.root({
37
- nodes: [
38
- selectorParser.selector({
39
- nodes: [selectorParser.className({ value: escapeClassName(candidate) })],
40
- }),
41
- ],
42
- })
43
-
44
- // And iteratively merge each format selector into the candidate selector
45
- for (let { ast } of parsedFormats) {
46
- // 1. Handle :merge() special pseudo-class
47
- ;[formatAst, ast] = handleMergePseudo(formatAst, ast)
48
-
49
- // 2. Merge the format selector into the current selector AST
50
- ast.walkNesting((nesting) => nesting.replaceWith(...formatAst.nodes[0].nodes))
51
-
52
- // 3. Keep going!
53
- formatAst = ast
54
- }
55
-
56
- return formatAst
57
- }
58
-
59
- /**
60
- * Given any node in a selector this gets the "simple" selector it's a part of
61
- * A simple selector is just a list of nodes without any combinators
62
- * Technically :is(), :not(), :has(), etc… can have combinators but those are nested
63
- * inside the relevant node and won't be picked up so they're fine to ignore
64
- *
65
- * @param {Node} node
66
- * @returns {Node[]}
67
- **/
68
- function simpleSelectorForNode(node) {
69
- /** @type {Node[]} */
70
- let nodes = []
71
-
72
- // Walk backwards until we hit a combinator node (or the start)
73
- while (node.prev() && node.prev().type !== 'combinator') {
74
- node = node.prev()
75
- }
76
-
77
- // Now record all non-combinator nodes until we hit one (or the end)
78
- while (node && node.type !== 'combinator') {
79
- nodes.push(node)
80
- node = node.next()
81
- }
82
-
83
- return nodes
84
- }
85
-
86
- /**
87
- * Resorts the nodes in a selector to ensure they're in the correct order
88
- * Tags go before classes, and pseudo classes go after classes
89
- *
90
- * @param {Selector} sel
91
- * @returns {Selector}
92
- **/
93
- function resortSelector(sel) {
94
- sel.sort((a, b) => {
95
- if (a.type === 'tag' && b.type === 'class') {
96
- return -1
97
- } else if (a.type === 'class' && b.type === 'tag') {
98
- return 1
99
- } else if (a.type === 'class' && b.type === 'pseudo' && b.value.startsWith('::')) {
100
- return -1
101
- } else if (a.type === 'pseudo' && a.value.startsWith('::') && b.type === 'class') {
102
- return 1
103
- }
104
-
105
- return sel.index(a) - sel.index(b)
106
- })
107
-
108
- return sel
109
- }
110
-
111
- /**
112
- * Remove extraneous selectors that do not include the base class/candidate
113
- *
114
- * Example:
115
- * Given the utility `.a, .b { color: red}`
116
- * Given the candidate `sm:b`
117
- *
118
- * The final selector should be `.sm\:b` and not `.a, .sm\:b`
119
- *
120
- * @param {Selector} ast
121
- * @param {string} base
122
- */
123
- function eliminateIrrelevantSelectors(sel, base) {
124
- let hasClassesMatchingCandidate = false
125
-
126
- sel.walk((child) => {
127
- if (child.type === 'class' && child.value === base) {
128
- hasClassesMatchingCandidate = true
129
- return false // Stop walking
130
- }
131
- })
132
-
133
- if (!hasClassesMatchingCandidate) {
134
- sel.remove()
135
- }
136
-
137
- // We do NOT recursively eliminate sub selectors that don't have the base class
138
- // as this is NOT a safe operation. For example, if we have:
139
- // `.space-x-2 > :not([hidden]) ~ :not([hidden])`
140
- // We cannot remove the [hidden] from the :not() because it would change the
141
- // meaning of the selector.
142
-
143
- // TODO: Can we do this for :matches, :is, and :where?
144
- }
145
-
146
- /**
147
- * @param {string} current
148
- * @param {AcceptedFormats} formats
149
- * @param {{context: any, candidate: string, base: string | null}} options
150
- * @returns {string}
151
- */
152
- export function finalizeSelector(current, formats, { context, candidate, base }) {
153
- let separator = context?.tailwindConfig?.separator ?? ':'
154
-
155
- // Split by the separator, but ignore the separator inside square brackets:
156
- //
157
- // E.g.: dark:lg:hover:[paint-order:markers]
158
- // ┬ ┬ ┬ ┬
159
- // │ │ │ ╰── We will not split here
160
- // ╰──┴─────┴─────────────── We will split here
161
- //
162
- base = base ?? candidate.split(new RegExp(`\\${separator}(?![^[]*\\])`)).pop()
163
-
164
- // Parse the selector into an AST
165
- let selector = selectorParser().astSync(current)
166
-
167
- // Normalize escaped classes, e.g.:
168
- //
169
- // The idea would be to replace the escaped `base` in the selector with the
170
- // `format`. However, in css you can escape the same selector in a few
171
- // different ways. This would result in different strings and therefore we
172
- // can't replace it properly.
173
- //
174
- // base: bg-[rgb(255,0,0)]
175
- // base in selector: bg-\\[rgb\\(255\\,0\\,0\\)\\]
176
- // escaped base: bg-\\[rgb\\(255\\2c 0\\2c 0\\)\\]
177
- //
178
- selector.walkClasses((node) => {
179
- if (node.raws && node.value.includes(base)) {
180
- node.raws.value = escapeClassName(unescape(node.raws.value))
181
- }
182
- })
183
-
184
- // Remove extraneous selectors that do not include the base candidate
185
- selector.each((sel) => eliminateIrrelevantSelectors(sel, base))
186
-
187
- // If there are no formats that means there were no variants added to the candidate
188
- // so we can just return the selector as-is
189
- let formatAst = Array.isArray(formats)
190
- ? formatVariantSelector(formats, { context, candidate })
191
- : formats
192
-
193
- if (formatAst === null) {
194
- return selector.toString()
195
- }
196
-
197
- let simpleStart = selectorParser.comment({ value: '/*__simple__*/' })
198
- let simpleEnd = selectorParser.comment({ value: '/*__simple__*/' })
199
-
200
- // We can safely replace the escaped base now, since the `base` section is
201
- // now in a normalized escaped value.
202
- selector.walkClasses((node) => {
203
- if (node.value !== base) {
204
- return
205
- }
206
-
207
- let parent = node.parent
208
- let formatNodes = formatAst.nodes[0].nodes
209
-
210
- // Perf optimization: if the parent is a single class we can just replace it and be done
211
- if (parent.nodes.length === 1) {
212
- node.replaceWith(...formatNodes)
213
- return
214
- }
215
-
216
- let simpleSelector = simpleSelectorForNode(node)
217
- parent.insertBefore(simpleSelector[0], simpleStart)
218
- parent.insertAfter(simpleSelector[simpleSelector.length - 1], simpleEnd)
219
-
220
- for (let child of formatNodes) {
221
- parent.insertBefore(simpleSelector[0], child)
222
- }
223
-
224
- node.remove()
225
-
226
- // Re-sort the simple selector to ensure it's in the correct order
227
- simpleSelector = simpleSelectorForNode(simpleStart)
228
- let firstNode = parent.index(simpleStart)
229
-
230
- parent.nodes.splice(
231
- firstNode,
232
- simpleSelector.length,
233
- ...resortSelector(selectorParser.selector({ nodes: simpleSelector })).nodes
234
- )
235
-
236
- simpleStart.remove()
237
- simpleEnd.remove()
238
- })
239
-
240
- // Remove unnecessary pseudo selectors that we used as placeholders
241
- selector.walkPseudos((p) => {
242
- if (p.value === MERGE) {
243
- p.replaceWith(p.nodes)
244
- }
245
- })
246
-
247
- // Move pseudo elements to the end of the selector (if necessary)
248
- selector.each((sel) => {
249
- let pseudoElements = collectPseudoElements(sel)
250
- if (pseudoElements.length > 0) {
251
- sel.nodes.push(pseudoElements.sort(sortSelector))
252
- }
253
- })
254
-
255
- return selector.toString()
256
- }
257
-
258
- /**
259
- *
260
- * @param {Selector} selector
261
- * @param {Selector} format
262
- */
263
- export function handleMergePseudo(selector, format) {
264
- /** @type {{pseudo: Pseudo, value: string}[]} */
265
- let merges = []
266
-
267
- // Find all :merge() pseudo-classes in `selector`
268
- selector.walkPseudos((pseudo) => {
269
- if (pseudo.value === MERGE) {
270
- merges.push({
271
- pseudo,
272
- value: pseudo.nodes[0].toString(),
273
- })
274
- }
275
- })
276
-
277
- // Find all :merge() "attachments" in `format` and attach them to the matching selector in `selector`
278
- format.walkPseudos((pseudo) => {
279
- if (pseudo.value !== MERGE) {
280
- return
281
- }
282
-
283
- let value = pseudo.nodes[0].toString()
284
-
285
- // Does `selector` contain a :merge() pseudo-class with the same value?
286
- let existing = merges.find((merge) => merge.value === value)
287
-
288
- // Nope so there's nothing to do
289
- if (!existing) {
290
- return
291
- }
292
-
293
- // Everything after `:merge()` up to the next combinator is what is attached to the merged selector
294
- let attachments = []
295
- let next = pseudo.next()
296
- while (next && next.type !== 'combinator') {
297
- attachments.push(next)
298
- next = next.next()
299
- }
300
-
301
- let combinator = next
302
-
303
- existing.pseudo.parent.insertAfter(
304
- existing.pseudo,
305
- selectorParser.selector({ nodes: attachments.map((node) => node.clone()) })
306
- )
307
-
308
- pseudo.remove()
309
- attachments.forEach((node) => node.remove())
310
-
311
- // What about this case:
312
- // :merge(.group):focus > &
313
- // :merge(.group):hover &
314
- if (combinator && combinator.type === 'combinator') {
315
- combinator.remove()
316
- }
317
- })
318
-
319
- return [selector, format]
320
- }
321
-
322
- // Note: As a rule, double colons (::) should be used instead of a single colon
323
- // (:). This distinguishes pseudo-classes from pseudo-elements. However, since
324
- // this distinction was not present in older versions of the W3C spec, most
325
- // browsers support both syntaxes for the original pseudo-elements.
326
- let pseudoElementsBC = [':before', ':after', ':first-line', ':first-letter']
327
-
328
- // These pseudo-elements _can_ be combined with other pseudo selectors AND the order does matter.
329
- let pseudoElementExceptions = [
330
- '::file-selector-button',
331
-
332
- // Webkit scroll bar pseudo elements can be combined with user-action pseudo classes
333
- '::-webkit-scrollbar',
334
- '::-webkit-scrollbar-button',
335
- '::-webkit-scrollbar-thumb',
336
- '::-webkit-scrollbar-track',
337
- '::-webkit-scrollbar-track-piece',
338
- '::-webkit-scrollbar-corner',
339
- '::-webkit-resizer',
340
- ]
341
-
342
- /**
343
- * This will make sure to move pseudo's to the correct spot (the end for
344
- * pseudo elements) because otherwise the selector will never work
345
- * anyway.
346
- *
347
- * E.g.:
348
- * - `before:hover:text-center` would result in `.before\:hover\:text-center:hover::before`
349
- * - `hover:before:text-center` would result in `.hover\:before\:text-center:hover::before`
350
- *
351
- * `::before:hover` doesn't work, which means that we can make it work for you by flipping the order.
352
- *
353
- * @param {Selector} selector
354
- **/
355
- function collectPseudoElements(selector) {
356
- /** @type {Node[]} */
357
- let nodes = []
358
-
359
- for (let node of selector.nodes) {
360
- if (isPseudoElement(node)) {
361
- nodes.push(node)
362
- selector.removeChild(node)
363
- }
364
-
365
- if (node?.nodes) {
366
- nodes.push(...collectPseudoElements(node))
367
- }
368
- }
369
-
370
- return nodes
371
- }
372
-
373
- // This will make sure to move pseudo's to the correct spot (the end for
374
- // pseudo elements) because otherwise the selector will never work
375
- // anyway.
376
- //
377
- // E.g.:
378
- // - `before:hover:text-center` would result in `.before\:hover\:text-center:hover::before`
379
- // - `hover:before:text-center` would result in `.hover\:before\:text-center:hover::before`
380
- //
381
- // `::before:hover` doesn't work, which means that we can make it work
382
- // for you by flipping the order.
383
- function sortSelector(a, z) {
384
- // Both nodes are non-pseudo's so we can safely ignore them and keep
385
- // them in the same order.
386
- if (a.type !== 'pseudo' && z.type !== 'pseudo') {
387
- return 0
388
- }
389
-
390
- // If one of them is a combinator, we need to keep it in the same order
391
- // because that means it will start a new "section" in the selector.
392
- if ((a.type === 'combinator') ^ (z.type === 'combinator')) {
393
- return 0
394
- }
395
-
396
- // One of the items is a pseudo and the other one isn't. Let's move
397
- // the pseudo to the right.
398
- if ((a.type === 'pseudo') ^ (z.type === 'pseudo')) {
399
- return (a.type === 'pseudo') - (z.type === 'pseudo')
400
- }
401
-
402
- // Both are pseudo's, move the pseudo elements (except for
403
- // ::file-selector-button) to the right.
404
- return isPseudoElement(a) - isPseudoElement(z)
405
- }
406
-
407
- function isPseudoElement(node) {
408
- if (node.type !== 'pseudo') return false
409
- if (pseudoElementExceptions.includes(node.value)) return false
410
-
411
- return node.value.startsWith('::') || pseudoElementsBC.includes(node.value)
412
- }
@@ -1,38 +0,0 @@
1
- import defaultConfig from '../../stubs/defaultConfig.stub.js'
2
- import { flagEnabled } from '../featureFlags'
3
-
4
- export default function getAllConfigs(config) {
5
- const configs = (config?.presets ?? [defaultConfig])
6
- .slice()
7
- .reverse()
8
- .flatMap((preset) => getAllConfigs(preset instanceof Function ? preset() : preset))
9
-
10
- const features = {
11
- // Add experimental configs here...
12
- respectDefaultRingColorOpacity: {
13
- theme: {
14
- ringColor: ({ theme }) => ({
15
- DEFAULT: '#3b82f67f',
16
- ...theme('colors'),
17
- }),
18
- },
19
- },
20
-
21
- disableColorOpacityUtilitiesByDefault: {
22
- corePlugins: {
23
- backgroundOpacity: false,
24
- borderOpacity: false,
25
- divideOpacity: false,
26
- placeholderOpacity: false,
27
- ringOpacity: false,
28
- textOpacity: false,
29
- },
30
- },
31
- }
32
-
33
- const experimentals = Object.keys(features)
34
- .filter((feature) => flagEnabled(config, feature))
35
- .map((feature) => features[feature])
36
-
37
- return [config, ...experimentals, ...configs]
38
- }
@@ -1,5 +0,0 @@
1
- import hash from 'object-hash'
2
-
3
- export default function hashConfig(config) {
4
- return hash(config, { ignoreUnknown: true })
5
- }
@@ -1,3 +0,0 @@
1
- export default function isKeyframeRule(rule) {
2
- return rule.parent && rule.parent.type === 'atrule' && /keyframes$/.test(rule.parent.name)
3
- }
@@ -1,8 +0,0 @@
1
- export default function isPlainObject(value) {
2
- if (Object.prototype.toString.call(value) !== '[object Object]') {
3
- return false
4
- }
5
-
6
- const prototype = Object.getPrototypeOf(value)
7
- return prototype === null || prototype === Object.prototype
8
- }
@@ -1,61 +0,0 @@
1
- let matchingBrackets = new Map([
2
- ['{', '}'],
3
- ['[', ']'],
4
- ['(', ')'],
5
- ])
6
- let inverseMatchingBrackets = new Map(
7
- Array.from(matchingBrackets.entries()).map(([k, v]) => [v, k])
8
- )
9
-
10
- let quotes = new Set(['"', "'", '`'])
11
-
12
- // Arbitrary values must contain balanced brackets (), [] and {}. Escaped
13
- // values don't count, and brackets inside quotes also don't count.
14
- //
15
- // E.g.: w-[this-is]w-[weird-and-invalid]
16
- // E.g.: w-[this-is\\]w-\\[weird-but-valid]
17
- // E.g.: content-['this-is-also-valid]-weirdly-enough']
18
- export default function isSyntacticallyValidPropertyValue(value) {
19
- let stack = []
20
- let inQuotes = false
21
-
22
- for (let i = 0; i < value.length; i++) {
23
- let char = value[i]
24
-
25
- if (char === ':' && !inQuotes && stack.length === 0) {
26
- return false
27
- }
28
-
29
- // Non-escaped quotes allow us to "allow" anything in between
30
- if (quotes.has(char) && value[i - 1] !== '\\') {
31
- inQuotes = !inQuotes
32
- }
33
-
34
- if (inQuotes) continue
35
- if (value[i - 1] === '\\') continue // Escaped
36
-
37
- if (matchingBrackets.has(char)) {
38
- stack.push(char)
39
- } else if (inverseMatchingBrackets.has(char)) {
40
- let inverse = inverseMatchingBrackets.get(char)
41
-
42
- // Nothing to pop from, therefore it is unbalanced
43
- if (stack.length <= 0) {
44
- return false
45
- }
46
-
47
- // Popped value must match the inverse value, otherwise it is unbalanced
48
- if (stack.pop() !== inverse) {
49
- return false
50
- }
51
- }
52
- }
53
-
54
- // If there is still something on the stack, it is also unbalanced
55
- if (stack.length > 0) {
56
- return false
57
- }
58
-
59
- // All good, totally balanced!
60
- return true
61
- }
package/src/util/log.js DELETED
@@ -1,29 +0,0 @@
1
- import colors from 'picocolors'
2
-
3
- let alreadyShown = new Set()
4
-
5
- function log(type, messages, key) {
6
- if (typeof process !== 'undefined' && process.env.JEST_WORKER_ID) return
7
-
8
- if (key && alreadyShown.has(key)) return
9
- if (key) alreadyShown.add(key)
10
-
11
- console.warn('')
12
- messages.forEach((message) => console.warn(type, '-', message))
13
- }
14
-
15
- export function dim(input) {
16
- return colors.dim(input)
17
- }
18
-
19
- export default {
20
- info(key, messages) {
21
- log(colors.bold(colors.cyan('info')), ...(Array.isArray(key) ? [key] : [messages, key]))
22
- },
23
- warn(key, messages) {
24
- log(colors.bold(colors.yellow('warn')), ...(Array.isArray(key) ? [key] : [messages, key]))
25
- },
26
- risk(key, messages) {
27
- log(colors.bold(colors.magenta('risk')), ...(Array.isArray(key) ? [key] : [messages, key]))
28
- },
29
- }
@@ -1,30 +0,0 @@
1
- import escapeClassName from './escapeClassName'
2
- import escapeCommas from './escapeCommas'
3
-
4
- export function asClass(name) {
5
- return escapeCommas(`.${escapeClassName(name)}`)
6
- }
7
-
8
- export default function nameClass(classPrefix, key) {
9
- return asClass(formatClass(classPrefix, key))
10
- }
11
-
12
- export function formatClass(classPrefix, key) {
13
- if (key === 'DEFAULT') {
14
- return classPrefix
15
- }
16
-
17
- if (key === '-' || key === '-DEFAULT') {
18
- return `-${classPrefix}`
19
- }
20
-
21
- if (key.startsWith('-')) {
22
- return `-${classPrefix}${key}`
23
- }
24
-
25
- if (key.startsWith('/')) {
26
- return `${classPrefix}${key}`
27
- }
28
-
29
- return `${classPrefix}-${key}`
30
- }
@@ -1,24 +0,0 @@
1
- export default function negateValue(value) {
2
- value = `${value}`
3
-
4
- if (value === '0') {
5
- return '0'
6
- }
7
-
8
- // Flip sign of numbers
9
- if (/^[+-]?(\d+|\d*\.\d+)(e[+-]?\d+)?(%|\w+)?$/.test(value)) {
10
- return value.replace(/^[+-]?/, (sign) => (sign === '-' ? '' : '-'))
11
- }
12
-
13
- // What functions we support negating numeric values for
14
- // var() isn't inherently a numeric function but we support it anyway
15
- // The trigonometric functions are omitted because you'll need to use calc(…) with them _anyway_
16
- // to produce generally useful results and that will be covered already
17
- let numericFunctions = ['var', 'calc', 'min', 'max', 'clamp']
18
-
19
- for (const fn of numericFunctions) {
20
- if (value.includes(`${fn}(`)) {
21
- return `calc(${value} * -1)`
22
- }
23
- }
24
- }