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,240 +0,0 @@
1
- // @ts-check
2
-
3
- import fs from 'fs'
4
- import path from 'path'
5
- import isGlob from 'is-glob'
6
- import fastGlob from 'fast-glob'
7
- import normalizePath from 'normalize-path'
8
- import { parseGlob } from '../util/parseGlob'
9
- import { env } from './sharedState'
10
- import { resolveContentPaths } from '@tailwindcss/oxide'
11
-
12
- /** @typedef {import('../../types/config.js').RawFile} RawFile */
13
- /** @typedef {import('../../types/config.js').FilePath} FilePath */
14
-
15
- /*
16
- * @param {import('tailwindcss').Config} tailwindConfig
17
- * @param {{skip:string[]}} options
18
- * @returns {ContentPath[]}
19
- */
20
- function resolveContentFiles(tailwindConfig, { skip = [] } = {}) {
21
- if (
22
- Array.isArray(tailwindConfig.content.files) &&
23
- tailwindConfig.content.files.includes('auto')
24
- ) {
25
- let idx = tailwindConfig.content.files.indexOf('auto')
26
- if (idx !== -1) {
27
- env.DEBUG && console.time('Calculating resolve content paths')
28
- let resolved = resolveContentPaths({ base: process.cwd() })
29
- env.DEBUG && console.timeEnd('Calculating resolve content paths')
30
-
31
- tailwindConfig.content.files.splice(idx, 1, ...resolved)
32
- }
33
- }
34
-
35
- if (skip.length > 0) {
36
- tailwindConfig.content.files = tailwindConfig.content.files.filter(
37
- (filePath) => !skip.includes(filePath)
38
- )
39
- }
40
-
41
- return tailwindConfig.content.files
42
- }
43
-
44
- /**
45
- * @typedef {object} ContentPath
46
- * @property {string} original
47
- * @property {string} base
48
- * @property {string | null} glob
49
- * @property {boolean} ignore
50
- * @property {string} pattern
51
- */
52
-
53
- /**
54
- * Turn a list of content paths (absolute or not; glob or not) into a list of
55
- * absolute file paths that exist on the filesystem
56
- *
57
- * If there are symlinks in the path then multiple paths will be returned
58
- * one for the symlink and one for the actual file
59
- *
60
- * @param {*} context
61
- * @param {import('tailwindcss').Config} tailwindConfig
62
- * @returns {ContentPath[]}
63
- */
64
- export function parseCandidateFiles(context, tailwindConfig) {
65
- let files = resolveContentFiles(tailwindConfig, {
66
- skip: [context.userConfigPath],
67
- })
68
-
69
- // Normalize the file globs
70
- files = files.filter((filePath) => typeof filePath === 'string')
71
- files = files.map(normalizePath)
72
-
73
- // Split into included and excluded globs
74
- let tasks = fastGlob.generateTasks(files)
75
-
76
- /** @type {ContentPath[]} */
77
- let included = []
78
-
79
- /** @type {ContentPath[]} */
80
- let excluded = []
81
-
82
- for (const task of tasks) {
83
- included.push(...task.positive.map((filePath) => parseFilePath(filePath, false)))
84
- excluded.push(...task.negative.map((filePath) => parseFilePath(filePath, true)))
85
- }
86
-
87
- let paths = [...included, ...excluded]
88
-
89
- // Resolve paths relative to the config file or cwd
90
- paths = resolveRelativePaths(context, paths)
91
-
92
- // Resolve symlinks if possible
93
- paths = paths.flatMap(resolvePathSymlinks)
94
-
95
- // Update cached patterns
96
- paths = paths.map(resolveGlobPattern)
97
-
98
- return paths
99
- }
100
-
101
- /**
102
- *
103
- * @param {string} filePath
104
- * @param {boolean} ignore
105
- * @returns {ContentPath}
106
- */
107
- function parseFilePath(filePath, ignore) {
108
- let contentPath = {
109
- original: filePath,
110
- base: filePath,
111
- ignore,
112
- pattern: filePath,
113
- glob: null,
114
- }
115
-
116
- if (isGlob(filePath)) {
117
- Object.assign(contentPath, parseGlob(filePath))
118
- }
119
-
120
- return contentPath
121
- }
122
-
123
- /**
124
- *
125
- * @param {ContentPath} contentPath
126
- * @returns {ContentPath}
127
- */
128
- function resolveGlobPattern(contentPath) {
129
- // This is required for Windows support to properly pick up Glob paths.
130
- // Afaik, this technically shouldn't be needed but there's probably
131
- // some internal, direct path matching with a normalized path in
132
- // a package which can't handle mixed directory separators
133
- let base = normalizePath(contentPath.base)
134
-
135
- // If the user's file path contains any special characters (like parens) for instance fast-glob
136
- // is like "OOOH SHINY" and treats them as such. So we have to escape the base path to fix this
137
- base = fastGlob.escapePath(base)
138
-
139
- contentPath.pattern = contentPath.glob ? `${base}/${contentPath.glob}` : base
140
- contentPath.pattern = contentPath.ignore ? `!${contentPath.pattern}` : contentPath.pattern
141
-
142
- return contentPath
143
- }
144
-
145
- /**
146
- * Resolve each path relative to the config file (when possible) if the experimental flag is enabled
147
- * Otherwise, resolve relative to the current working directory
148
- *
149
- * @param {any} context
150
- * @param {ContentPath[]} contentPaths
151
- * @returns {ContentPath[]}
152
- */
153
- function resolveRelativePaths(context, contentPaths) {
154
- let resolveFrom = []
155
-
156
- // Resolve base paths relative to the config file (when possible) if the experimental flag is enabled
157
- if (context.userConfigPath && context.tailwindConfig.content.relative) {
158
- resolveFrom = [path.dirname(context.userConfigPath)]
159
- }
160
-
161
- return contentPaths.map((contentPath) => {
162
- contentPath.base = path.resolve(...resolveFrom, contentPath.base)
163
-
164
- return contentPath
165
- })
166
- }
167
-
168
- /**
169
- * Resolve the symlink for the base directory / file in each path
170
- * These are added as additional dependencies to watch for changes because
171
- * some tools (like webpack) will only watch the actual file or directory
172
- * but not the symlink itself even in projects that use monorepos.
173
- *
174
- * @param {ContentPath} contentPath
175
- * @returns {ContentPath[]}
176
- */
177
- function resolvePathSymlinks(contentPath) {
178
- let paths = [contentPath]
179
-
180
- try {
181
- let resolvedPath = fs.realpathSync(contentPath.base)
182
- if (resolvedPath !== contentPath.base) {
183
- paths.push({
184
- ...contentPath,
185
- base: resolvedPath,
186
- })
187
- }
188
- } catch {
189
- // TODO: log this?
190
- }
191
-
192
- return paths
193
- }
194
-
195
- /**
196
- * @param {any} context
197
- * @param {ContentPath[]} candidateFiles
198
- * @param {Map<string, number>} fileModifiedMap
199
- * @returns {[{ content: string, extension: string }[], Map<string, number>]}
200
- */
201
- export function resolvedChangedContent(context, candidateFiles, fileModifiedMap) {
202
- let changedContent = context.tailwindConfig.content.files
203
- .filter((item) => typeof item.raw === 'string')
204
- .map(({ raw, extension = 'html' }) => ({ content: raw, extension }))
205
-
206
- let [changedFiles, mTimesToCommit] = resolveChangedFiles(candidateFiles, fileModifiedMap)
207
-
208
- for (let changedFile of changedFiles) {
209
- let extension = path.extname(changedFile).slice(1)
210
- changedContent.push({ file: changedFile, extension })
211
- }
212
-
213
- return [changedContent, mTimesToCommit]
214
- }
215
-
216
- /**
217
- *
218
- * @param {ContentPath[]} candidateFiles
219
- * @param {Map<string, number>} fileModifiedMap
220
- * @returns {[Set<string>, Map<string, number>]}
221
- */
222
- function resolveChangedFiles(candidateFiles, fileModifiedMap) {
223
- let paths = candidateFiles.map((contentPath) => contentPath.pattern)
224
- let mTimesToCommit = new Map()
225
-
226
- let changedFiles = new Set()
227
- env.DEBUG && console.time('Finding changed files')
228
- let files = fastGlob.sync(paths, { absolute: true })
229
- for (let file of files) {
230
- let prevModified = fileModifiedMap.get(file) || -Infinity
231
- let modified = fs.statSync(file).mtimeMs
232
-
233
- if (modified > prevModified) {
234
- changedFiles.add(file)
235
- mTimesToCommit.set(file, modified)
236
- }
237
- }
238
- env.DEBUG && console.timeEnd('Finding changed files')
239
- return [changedFiles, mTimesToCommit]
240
- }
@@ -1,217 +0,0 @@
1
- import { flagEnabled } from '../featureFlags'
2
- import * as regex from './regex'
3
-
4
- export function defaultExtractor(context) {
5
- let patterns = Array.from(buildRegExps(context))
6
-
7
- /**
8
- * @param {string} content
9
- */
10
- return (content) => {
11
- /** @type {(string|string)[]} */
12
- let results = []
13
-
14
- for (let pattern of patterns) {
15
- results = [...results, ...(content.match(pattern) ?? [])]
16
- }
17
-
18
- return results.filter((v) => v !== undefined).map(clipAtBalancedParens)
19
- }
20
- }
21
-
22
- function* buildRegExps(context) {
23
- let separator = context.tailwindConfig.separator
24
- let variantGroupingEnabled = flagEnabled(context.tailwindConfig, 'variantGrouping')
25
- let prefix =
26
- context.tailwindConfig.prefix !== ''
27
- ? regex.optional(regex.pattern([/-?/, regex.escape(context.tailwindConfig.prefix)]))
28
- : ''
29
-
30
- let utility = regex.any([
31
- // Arbitrary properties (without square brackets)
32
- /\[[^\s:'"`]+:[^\s\[\]]+\]/,
33
-
34
- // Arbitrary properties with balanced square brackets
35
- // This is a targeted fix to continue to allow theme()
36
- // with square brackets to work in arbitrary properties
37
- // while fixing a problem with the regex matching too much
38
- /\[[^\s:'"`]+:[^\s]+?\[[^\s]+\][^\s]+?\]/,
39
-
40
- // Utilities
41
- regex.pattern([
42
- // Utility Name / Group Name
43
- /-?(?:\w+)/,
44
-
45
- // Normal/Arbitrary values
46
- regex.optional(
47
- regex.any([
48
- regex.pattern([
49
- // Arbitrary values
50
- /-(?:\w+-)*\[[^\s:]+\]/,
51
-
52
- // Not immediately followed by an `{[(`
53
- /(?![{([]])/,
54
-
55
- // optionally followed by an opacity modifier
56
- /(?:\/[^\s'"`\\><$]*)?/,
57
- ]),
58
-
59
- regex.pattern([
60
- // Arbitrary values
61
- /-(?:\w+-)*\[[^\s]+\]/,
62
-
63
- // Not immediately followed by an `{[(`
64
- /(?![{([]])/,
65
-
66
- // optionally followed by an opacity modifier
67
- /(?:\/[^\s'"`\\$]*)?/,
68
- ]),
69
-
70
- // Normal values w/o quotes — may include an opacity modifier
71
- /[-\/][^\s'"`\\$={><]*/,
72
- ])
73
- ),
74
- ]),
75
- ])
76
-
77
- let variantPatterns = [
78
- // Without quotes
79
- regex.any([
80
- // This is here to provide special support for the `@` variant
81
- regex.pattern([/@\[[^\s"'`]+\](\/[^\s"'`]+)?/, separator]),
82
-
83
- regex.pattern([/([^\s"'`\[\\]+-)?\[[^\s"'`]+\]/, separator]),
84
- regex.pattern([/[^\s"'`\[\\]+/, separator]),
85
- ]),
86
-
87
- // With quotes allowed
88
- regex.any([
89
- regex.pattern([/([^\s"'`\[\\]+-)?\[[^\s`]+\]/, separator]),
90
- regex.pattern([/[^\s`\[\\]+/, separator]),
91
- ]),
92
- ]
93
-
94
- for (const variantPattern of variantPatterns) {
95
- yield regex.pattern([
96
- // Variants
97
- '((?=((',
98
- variantPattern,
99
- ')+))\\2)?',
100
-
101
- // Important (optional)
102
- /!?/,
103
-
104
- prefix,
105
-
106
- variantGroupingEnabled
107
- ? regex.any([
108
- // Or any of those things but grouped separated by commas
109
- regex.pattern([/\(/, utility, regex.zeroOrMore([/,/, utility]), /\)/]),
110
-
111
- // Arbitrary properties, constrained utilities, arbitrary values, etc…
112
- utility,
113
- ])
114
- : utility,
115
- ])
116
- }
117
-
118
- // 5. Inner matches
119
- yield /[^<>"'`\s.(){}[\]#=%$]*[^<>"'`\s.(){}[\]#=%:$]/g
120
- }
121
-
122
- // We want to capture any "special" characters
123
- // AND the characters immediately following them (if there is one)
124
- let SPECIALS = /([\[\]'"`])([^\[\]'"`])?/g
125
- let ALLOWED_CLASS_CHARACTERS = /[^"'`\s<>\]]+/
126
-
127
- /**
128
- * Clips a string ensuring that parentheses, quotes, etc… are balanced
129
- * Used for arbitrary values only
130
- *
131
- * We will go past the end of the balanced parens until we find a non-class character
132
- *
133
- * Depth matching behavior:
134
- * w-[calc(100%-theme('spacing[some_key][1.5]'))]']
135
- * ┬ ┬ ┬┬ ┬ ┬┬ ┬┬┬┬┬┬┬
136
- * 1 2 3 4 34 3 210 END
137
- * ╰────┴──────────┴────────┴────────┴┴───┴─┴┴┴
138
- *
139
- * @param {string} input
140
- */
141
- function clipAtBalancedParens(input) {
142
- // We are care about this for arbitrary values
143
- if (!input.includes('-[')) {
144
- return input
145
- }
146
-
147
- let depth = 0
148
- let openStringTypes = []
149
-
150
- // Find all parens, brackets, quotes, etc
151
- // Stop when we end at a balanced pair
152
- // This is naive and will treat mismatched parens as balanced
153
- // This shouldn't be a problem in practice though
154
- let matches = input.matchAll(SPECIALS)
155
-
156
- // We can't use lookbehind assertions because we have to support Safari
157
- // So, instead, we've emulated it using capture groups and we'll re-work the matches to accommodate
158
- matches = Array.from(matches).flatMap((match) => {
159
- const [, ...groups] = match
160
-
161
- return groups.map((group, idx) =>
162
- Object.assign([], match, {
163
- index: match.index + idx,
164
- 0: group,
165
- })
166
- )
167
- })
168
-
169
- for (let match of matches) {
170
- let char = match[0]
171
- let inStringType = openStringTypes[openStringTypes.length - 1]
172
-
173
- if (char === inStringType) {
174
- openStringTypes.pop()
175
- } else if (char === "'" || char === '"' || char === '`') {
176
- openStringTypes.push(char)
177
- }
178
-
179
- if (inStringType) {
180
- continue
181
- } else if (char === '[') {
182
- depth++
183
- continue
184
- } else if (char === ']') {
185
- depth--
186
- continue
187
- }
188
-
189
- // We've gone one character past the point where we should stop
190
- // This means that there was an extra closing `]`
191
- // We'll clip to just before it
192
- if (depth < 0) {
193
- return input.substring(0, match.index - 1)
194
- }
195
-
196
- // We've finished balancing the brackets but there still may be characters that can be included
197
- // For example in the class `text-[#336699]/[.35]`
198
- // The depth goes to `0` at the closing `]` but goes up again at the `[`
199
-
200
- // If we're at zero and encounter a non-class character then we clip the class there
201
- if (depth === 0 && !ALLOWED_CLASS_CHARACTERS.test(char)) {
202
- return input.substring(0, match.index)
203
- }
204
- }
205
-
206
- return input
207
- }
208
-
209
- // Regular utilities
210
- // {{modifier}:}*{namespace}{-{suffix}}*{/{opacityModifier}}?
211
-
212
- // Arbitrary values
213
- // {{modifier}:}*{namespace}-[{arbitraryValue}]{/{opacityModifier}}?
214
- // arbitraryValue: no whitespace, balanced quotes unless within quotes, balanced brackets unless within quotes
215
-
216
- // Arbitrary properties
217
- // {{modifier}:}*[{validCssPropertyName}:{arbitraryValue}]
@@ -1,47 +0,0 @@
1
- function isRoot(node) {
2
- return node.type === 'root'
3
- }
4
-
5
- function isAtLayer(node) {
6
- return node.type === 'atrule' && node.name === 'layer'
7
- }
8
-
9
- export default function (_context) {
10
- return (root, result) => {
11
- let found = false
12
-
13
- root.walkAtRules('tailwind', (node) => {
14
- if (found) return false
15
-
16
- if (node.parent && !(isRoot(node.parent) || isAtLayer(node.parent))) {
17
- found = true
18
- node.warn(
19
- result,
20
- [
21
- 'Nested @tailwind rules were detected, but are not supported.',
22
- "Consider using a prefix to scope Tailwind's classes: https://tailwindcss.com/docs/configuration#prefix",
23
- 'Alternatively, use the important selector strategy: https://tailwindcss.com/docs/configuration#selector-strategy',
24
- ].join('\n')
25
- )
26
- return false
27
- }
28
- })
29
-
30
- root.walkRules((rule) => {
31
- if (found) return false
32
-
33
- rule.walkRules((nestedRule) => {
34
- found = true
35
- nestedRule.warn(
36
- result,
37
- [
38
- 'Nested CSS was detected, but CSS nesting has not been configured correctly.',
39
- 'Please enable a CSS nesting plugin *before* Tailwind in your configuration.',
40
- 'See how here: https://tailwindcss.com/docs/using-with-preprocessors#nesting',
41
- ].join('\n')
42
- )
43
- return false
44
- })
45
- })
46
- }
47
- }