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,169 +0,0 @@
1
- // @ts-check
2
-
3
- import fs from 'fs'
4
- import LRU from '@alloc/quick-lru'
5
-
6
- import hash from '../util/hashConfig'
7
- import resolveConfig from '../public/resolve-config'
8
- import resolveConfigPath from '../util/resolveConfigPath'
9
- import { getContext, getFileModifiedMap } from './setupContextUtils'
10
- import parseDependency from '../util/parseDependency'
11
- import { validateConfig } from '../util/validateConfig.js'
12
- import { parseCandidateFiles, resolvedChangedContent } from './content.js'
13
- import { loadConfig } from '../lib/load-config'
14
- import getModuleDependencies from './getModuleDependencies'
15
-
16
- let configPathCache = new LRU({ maxSize: 100 })
17
-
18
- let candidateFilesCache = new WeakMap()
19
-
20
- function getCandidateFiles(context, tailwindConfig) {
21
- if (candidateFilesCache.has(context)) {
22
- return candidateFilesCache.get(context)
23
- }
24
-
25
- let candidateFiles = parseCandidateFiles(context, tailwindConfig)
26
-
27
- return candidateFilesCache.set(context, candidateFiles).get(context)
28
- }
29
-
30
- // Get the config object based on a path
31
- function getTailwindConfig(configOrPath) {
32
- let userConfigPath = resolveConfigPath(configOrPath)
33
-
34
- if (userConfigPath !== null) {
35
- let [prevConfig, prevConfigHash, prevDeps, prevModified] =
36
- configPathCache.get(userConfigPath) || []
37
-
38
- let newDeps = getModuleDependencies(userConfigPath)
39
-
40
- let modified = false
41
- let newModified = new Map()
42
- for (let file of newDeps) {
43
- let time = fs.statSync(file).mtimeMs
44
- newModified.set(file, time)
45
- if (!prevModified || !prevModified.has(file) || time > prevModified.get(file)) {
46
- modified = true
47
- }
48
- }
49
-
50
- // It hasn't changed (based on timestamps)
51
- if (!modified) {
52
- return [prevConfig, userConfigPath, prevConfigHash, prevDeps]
53
- }
54
-
55
- // It has changed (based on timestamps), or first run
56
- for (let file of newDeps) {
57
- delete require.cache[file]
58
- }
59
- let newConfig = validateConfig(resolveConfig(loadConfig(userConfigPath)))
60
- let newHash = hash(newConfig)
61
- configPathCache.set(userConfigPath, [newConfig, newHash, newDeps, newModified])
62
- return [newConfig, userConfigPath, newHash, newDeps]
63
- }
64
-
65
- // It's a plain object, not a path
66
- let newConfig = resolveConfig(configOrPath?.config ?? configOrPath ?? {})
67
-
68
- newConfig = validateConfig(newConfig)
69
-
70
- return [newConfig, null, hash(newConfig), []]
71
- }
72
-
73
- // DISABLE_TOUCH = TRUE
74
-
75
- // Retrieve an existing context from cache if possible (since contexts are unique per
76
- // source path), or set up a new one (including setting up watchers and registering
77
- // plugins) then return it
78
- export default function setupTrackingContext(configOrPath) {
79
- return ({ tailwindDirectives, registerDependency }) => {
80
- return (root, result) => {
81
- let [tailwindConfig, userConfigPath, tailwindConfigHash, configDependencies] =
82
- getTailwindConfig(configOrPath)
83
-
84
- let contextDependencies = new Set(configDependencies)
85
-
86
- // If there are no @tailwind or @apply rules, we don't consider this CSS
87
- // file or its dependencies to be dependencies of the context. Can reuse
88
- // the context even if they change. We may want to think about `@layer`
89
- // being part of this trigger too, but it's tough because it's impossible
90
- // for a layer in one file to end up in the actual @tailwind rule in
91
- // another file since independent sources are effectively isolated.
92
- if (tailwindDirectives.size > 0) {
93
- // Add current css file as a context dependencies.
94
- contextDependencies.add(result.opts.from)
95
-
96
- // Add all css @import dependencies as context dependencies.
97
- for (let message of result.messages) {
98
- if (message.type === 'dependency') {
99
- contextDependencies.add(message.file)
100
- }
101
- }
102
- }
103
-
104
- let [context, , mTimesToCommit] = getContext(
105
- root,
106
- result,
107
- tailwindConfig,
108
- userConfigPath,
109
- tailwindConfigHash,
110
- contextDependencies
111
- )
112
-
113
- let fileModifiedMap = getFileModifiedMap(context)
114
-
115
- let candidateFiles = getCandidateFiles(context, tailwindConfig)
116
-
117
- // If there are no @tailwind or @apply rules, we don't consider this CSS file or it's
118
- // dependencies to be dependencies of the context. Can reuse the context even if they change.
119
- // We may want to think about `@layer` being part of this trigger too, but it's tough
120
- // because it's impossible for a layer in one file to end up in the actual @tailwind rule
121
- // in another file since independent sources are effectively isolated.
122
- if (tailwindDirectives.size > 0) {
123
- // Add template paths as postcss dependencies.
124
- for (let contentPath of candidateFiles) {
125
- for (let dependency of parseDependency(contentPath)) {
126
- registerDependency(dependency)
127
- }
128
- }
129
-
130
- let [changedContent, contentMTimesToCommit] = resolvedChangedContent(
131
- context,
132
- candidateFiles,
133
- fileModifiedMap
134
- )
135
-
136
- for (let content of changedContent) {
137
- context.changedContent.push(content)
138
- }
139
-
140
- // Add the mtimes of the content files to the commit list
141
- // We can overwrite the existing values because unconditionally
142
- // This is because:
143
- // 1. Most of the files here won't be in the map yet
144
- // 2. If they are that means it's a context dependency
145
- // and we're reading this after the context. This means
146
- // that the mtime we just read is strictly >= the context
147
- // mtime. Unless the user / os is doing something weird
148
- // in which the mtime would be going backwards. If that
149
- // happens there's already going to be problems.
150
- for (let [path, mtime] of contentMTimesToCommit.entries()) {
151
- mTimesToCommit.set(path, mtime)
152
- }
153
- }
154
-
155
- for (let file of configDependencies) {
156
- registerDependency({ type: 'dependency', file })
157
- }
158
-
159
- // "commit" the new modified time for all context deps
160
- // We do this here because we want content tracking to
161
- // read the "old" mtime even when it's a context dependency.
162
- for (let [path, mtime] of mTimesToCommit.entries()) {
163
- fileModifiedMap.set(path, mtime)
164
- }
165
-
166
- return context
167
- }
168
- }
169
- }
@@ -1,57 +0,0 @@
1
- export const env =
2
- typeof process !== 'undefined'
3
- ? {
4
- NODE_ENV: process.env.NODE_ENV,
5
- DEBUG: resolveDebug(process.env.DEBUG),
6
- }
7
- : {
8
- NODE_ENV: 'production',
9
- DEBUG: false,
10
- }
11
-
12
- export const contextMap = new Map()
13
- export const configContextMap = new Map()
14
- export const contextSourcesMap = new Map()
15
- export const sourceHashMap = new Map()
16
- export const NOT_ON_DEMAND = new String('*')
17
-
18
- export const NONE = Symbol('__NONE__')
19
-
20
- export function resolveDebug(debug) {
21
- if (debug === undefined) {
22
- return false
23
- }
24
-
25
- // Environment variables are strings, so convert to boolean
26
- if (debug === 'true' || debug === '1') {
27
- return true
28
- }
29
-
30
- if (debug === 'false' || debug === '0') {
31
- return false
32
- }
33
-
34
- // Keep the debug convention into account:
35
- // DEBUG=* -> This enables all debug modes
36
- // DEBUG=projectA,projectB,projectC -> This enables debug for projectA, projectB and projectC
37
- // DEBUG=projectA:* -> This enables all debug modes for projectA (if you have sub-types)
38
- // DEBUG=projectA,-projectB -> This enables debug for projectA and explicitly disables it for projectB
39
-
40
- if (debug === '*') {
41
- return true
42
- }
43
-
44
- let debuggers = debug.split(',').map((d) => d.split(':')[0])
45
-
46
- // Ignoring tailwindcss
47
- if (debuggers.includes('-tailwindcss')) {
48
- return false
49
- }
50
-
51
- // Including tailwindcss
52
- if (debuggers.includes('tailwindcss')) {
53
- return true
54
- }
55
-
56
- return false
57
- }
@@ -1,19 +0,0 @@
1
- import { normalizeScreens } from '../util/normalizeScreens'
2
- import buildMediaQuery from '../util/buildMediaQuery'
3
-
4
- export default function ({ tailwindConfig: { theme } }) {
5
- return function (css) {
6
- css.walkAtRules('screen', (atRule) => {
7
- let screen = atRule.params
8
- let screens = normalizeScreens(theme.screens)
9
- let screenDefinition = screens.find(({ name }) => name === screen)
10
-
11
- if (!screenDefinition) {
12
- throw atRule.error(`No \`${screen}\` screen found.`)
13
- }
14
-
15
- atRule.name = 'media'
16
- atRule.params = buildMediaQuery(screenDefinition)
17
- })
18
- }
19
- }
package/src/plugin.js DELETED
@@ -1,124 +0,0 @@
1
- import postcss from 'postcss'
2
- import lightningcss from 'lightningcss'
3
- import browserslist from 'browserslist'
4
- import setupTrackingContext from './lib/setupTrackingContext'
5
- import processTailwindFeatures from './processTailwindFeatures'
6
- import { env } from './lib/sharedState'
7
- import { findAtConfigPath } from './lib/findAtConfigPath'
8
- import { handleImportAtRules } from './lib/handleImportAtRules'
9
-
10
- module.exports = function tailwindcss(configOrPath) {
11
- return {
12
- postcssPlugin: 'tailwindcss',
13
- plugins: [
14
- env.DEBUG &&
15
- function (root) {
16
- console.log('\n')
17
- console.time('JIT TOTAL')
18
- return root
19
- },
20
- ...handleImportAtRules(),
21
- function (root, result) {
22
- // Use the path for the `@config` directive if it exists, otherwise use the
23
- // path for the file being processed
24
- configOrPath = findAtConfigPath(root, result) ?? configOrPath
25
-
26
- let context = setupTrackingContext(configOrPath)
27
-
28
- if (root.type === 'document') {
29
- let roots = root.nodes.filter((node) => node.type === 'root')
30
-
31
- for (const root of roots) {
32
- if (root.type === 'root') {
33
- processTailwindFeatures(context)(root, result)
34
- }
35
- }
36
-
37
- return
38
- }
39
-
40
- processTailwindFeatures(context)(root, result)
41
- },
42
- function lightningCssPlugin(_root, result) {
43
- let map = result.map ?? result.opts.map
44
-
45
- let intermediateResult = result.root.toResult({
46
- map: map ? { inline: true } : false,
47
- })
48
- let intermediateMap = intermediateResult.map?.toJSON?.() ?? map
49
-
50
- try {
51
- let transformed = lightningcss.transform({
52
- filename: result.opts.from,
53
- code: Buffer.from(intermediateResult.css),
54
- minify: false,
55
- sourceMap: !!intermediateMap,
56
- targets:
57
- typeof process !== 'undefined' && process.env.JEST_WORKER_ID
58
- ? { chrome: 111 << 16 }
59
- : lightningcss.browserslistToTargets(
60
- browserslist(require('../package.json').browserslist)
61
- ),
62
- drafts: {
63
- nesting: true,
64
- customMedia: true,
65
- },
66
- nonStandard: {
67
- deepSelectorCombinator: true,
68
- },
69
- })
70
-
71
- let code = transformed.code.toString()
72
-
73
- // https://postcss.org/api/#sourcemapoptions
74
- if (intermediateMap && transformed.map != null) {
75
- let prev = transformed.map.toString()
76
-
77
- if (typeof intermediateMap === 'object') {
78
- intermediateMap.prev = prev
79
- } else {
80
- code = `${code}\n/*# sourceMappingURL=data:application/json;base64,${Buffer.from(
81
- prev
82
- ).toString('base64')} */`
83
- }
84
- }
85
-
86
- result.root = postcss.parse(code, {
87
- ...result.opts,
88
- map: intermediateMap,
89
- })
90
- } catch (err) {
91
- if (err.source && typeof process !== 'undefined' && process.env.JEST_WORKER_ID) {
92
- let lines = err.source.split('\n')
93
- err = new Error(
94
- [
95
- 'Error formatting using Lightning CSS:',
96
- '',
97
- ...[
98
- '```css',
99
- ...lines.slice(Math.max(err.loc.line - 3, 0), err.loc.line),
100
- ' '.repeat(err.loc.column - 1) + '^-- ' + err.toString(),
101
- ...lines.slice(err.loc.line, err.loc.line + 2),
102
- '```',
103
- ],
104
- ].join('\n')
105
- )
106
- }
107
-
108
- if (Error.captureStackTrace) {
109
- Error.captureStackTrace(err, lightningCssPlugin)
110
- }
111
- throw err
112
- }
113
- },
114
- env.DEBUG &&
115
- function (root) {
116
- console.timeEnd('JIT TOTAL')
117
- console.log('\n')
118
- return root
119
- },
120
- ].filter(Boolean),
121
- }
122
- }
123
-
124
- module.exports.postcss = true
@@ -1,42 +0,0 @@
1
- # tailwindcss/nesting
2
-
3
- This is a PostCSS plugin that wraps [postcss-nested](https://github.com/postcss/postcss-nested) or [postcss-nesting](https://github.com/csstools/postcss-plugins/tree/main/plugins/postcss-nesting) and acts as a compatibility layer to make sure your nesting plugin of choice properly understands Tailwind's custom syntax like `@apply` and `@screen`.
4
-
5
- Add it to your PostCSS configuration, somewhere before Tailwind itself:
6
-
7
- ```js
8
- // postcss.config.js
9
- module.exports = {
10
- plugins: [
11
- require('postcss-import'),
12
- require('tailwindcss/nesting'),
13
- require('tailwindcss'),
14
- require('autoprefixer'),
15
- ]
16
- }
17
- ```
18
-
19
- By default, it uses the [postcss-nested](https://github.com/postcss/postcss-nested) plugin under the hood, which uses a Sass-like syntax and is the plugin that powers nesting support in the [Tailwind CSS plugin API](https://tailwindcss.com/docs/plugins#css-in-js-syntax).
20
-
21
- If you'd rather use [postcss-nesting](https://github.com/csstools/postcss-plugins/tree/main/plugins/postcss-nesting) (which is based on the work-in-progress [CSS Nesting](https://drafts.csswg.org/css-nesting-1/) specification), first install the plugin alongside:
22
-
23
- ```shell
24
- npm install postcss-nesting
25
- ```
26
-
27
- Then pass the plugin itself as an argument to `tailwindcss/nesting` in your PostCSS configuration:
28
-
29
- ```js
30
- // postcss.config.js
31
- module.exports = {
32
- plugins: [
33
- require('postcss-import'),
34
- require('tailwindcss/nesting')(require('postcss-nesting')),
35
- require('tailwindcss'),
36
- require('autoprefixer'),
37
- ]
38
- }
39
- ```
40
-
41
- This can also be helpful if for whatever reason you need to use a very specific version of `postcss-nested` and want to override the version we bundle with `tailwindcss/nesting` itself.
42
-
@@ -1,13 +0,0 @@
1
- import { nesting } from './plugin'
2
-
3
- export default Object.assign(
4
- function (opts) {
5
- return {
6
- postcssPlugin: 'tailwindcss/nesting',
7
- Once(root, { result }) {
8
- return nesting(opts)(root, result)
9
- },
10
- }
11
- },
12
- { postcss: true }
13
- )
@@ -1,80 +0,0 @@
1
- import postcss from 'postcss'
2
- import postcssNested from 'postcss-nested'
3
-
4
- export function nesting(opts = postcssNested) {
5
- return (root, result) => {
6
- root.walkAtRules('screen', (rule) => {
7
- rule.name = 'media'
8
- rule.params = `screen(${rule.params})`
9
- })
10
-
11
- root.walkAtRules('apply', (rule) => {
12
- rule.before(postcss.decl({ prop: '__apply', value: rule.params, source: rule.source }))
13
- rule.remove()
14
- })
15
-
16
- let plugin = (() => {
17
- if (
18
- typeof opts === 'function' ||
19
- (typeof opts === 'object' && opts?.hasOwnProperty?.('postcssPlugin'))
20
- ) {
21
- return opts
22
- }
23
-
24
- if (typeof opts === 'string') {
25
- return require(opts)
26
- }
27
-
28
- if (Object.keys(opts).length <= 0) {
29
- return postcssNested
30
- }
31
-
32
- throw new Error('tailwindcss/nesting should be loaded with a nesting plugin.')
33
- })()
34
-
35
- postcss([plugin]).process(root, result.opts).sync()
36
-
37
- root.walkDecls('__apply', (decl) => {
38
- decl.before(postcss.atRule({ name: 'apply', params: decl.value, source: decl.source }))
39
- decl.remove()
40
- })
41
-
42
- /**
43
- * Use a private PostCSS API to remove the "clean" flag from the entire AST.
44
- * This is done because running process() on the AST will set the "clean"
45
- * flag on all nodes, which we don't want.
46
- *
47
- * This causes downstream plugins using the visitor API to be skipped.
48
- *
49
- * This is guarded because the PostCSS API is not public
50
- * and may change in future versions of PostCSS.
51
- *
52
- * See https://github.com/postcss/postcss/issues/1712 for more details
53
- *
54
- * @param {import('postcss').Node} node
55
- */
56
- function markDirty(node) {
57
- if (!('markDirty' in node)) {
58
- return
59
- }
60
-
61
- // Traverse the tree down to the leaf nodes
62
- if (node.nodes) {
63
- node.nodes.forEach((n) => markDirty(n))
64
- }
65
-
66
- // If it's a leaf node mark it as dirty
67
- // We do this here because marking a node as dirty
68
- // will walk up the tree and mark all parents as dirty
69
- // resulting in a lot of unnecessary work if we did this
70
- // for every single node
71
- if (!node.nodes) {
72
- node.markDirty()
73
- }
74
- }
75
-
76
- markDirty(root)
77
-
78
- return root
79
- }
80
- }
@@ -1,58 +0,0 @@
1
- import normalizeTailwindDirectives from './lib/normalizeTailwindDirectives'
2
- import expandTailwindAtRules from './lib/expandTailwindAtRules'
3
- import expandApplyAtRules from './lib/expandApplyAtRules'
4
- import evaluateTailwindFunctions from './lib/evaluateTailwindFunctions'
5
- import substituteScreenAtRules from './lib/substituteScreenAtRules'
6
- import resolveDefaultsAtRules from './lib/resolveDefaultsAtRules'
7
- import collapseAdjacentRules from './lib/collapseAdjacentRules'
8
- import collapseDuplicateDeclarations from './lib/collapseDuplicateDeclarations'
9
- import partitionApplyAtRules from './lib/partitionApplyAtRules'
10
- import detectNesting from './lib/detectNesting'
11
- import { createContext } from './lib/setupContextUtils'
12
- import { issueFlagNotices } from './featureFlags'
13
-
14
- export default function processTailwindFeatures(setupContext) {
15
- return function (root, result) {
16
- let { tailwindDirectives, applyDirectives } = normalizeTailwindDirectives(root)
17
-
18
- detectNesting()(root, result)
19
-
20
- // Partition apply rules that are found in the css
21
- // itself.
22
- partitionApplyAtRules()(root, result)
23
-
24
- let context = setupContext({
25
- tailwindDirectives,
26
- applyDirectives,
27
- registerDependency(dependency) {
28
- result.messages.push({
29
- plugin: 'tailwindcss',
30
- parent: result.opts.from,
31
- ...dependency,
32
- })
33
- },
34
- createContext(tailwindConfig, changedContent) {
35
- return createContext(tailwindConfig, changedContent, root)
36
- },
37
- })(root, result)
38
-
39
- if (context.tailwindConfig.separator === '-') {
40
- throw new Error(
41
- "The '-' character cannot be used as a custom separator in JIT mode due to parsing ambiguity. Please use another character like '_' instead."
42
- )
43
- }
44
-
45
- issueFlagNotices(context.tailwindConfig)
46
-
47
- expandTailwindAtRules(context)(root, result)
48
- // Partition apply rules that are generated by
49
- // addComponents, addUtilities and so on.
50
- partitionApplyAtRules()(root, result)
51
- expandApplyAtRules(context)(root, result)
52
- evaluateTailwindFunctions(context)(root, result)
53
- substituteScreenAtRules(context)(root, result)
54
- resolveDefaultsAtRules(context)(root, result)
55
- collapseAdjacentRules(context)(root, result)
56
- collapseDuplicateDeclarations(context)(root, result)
57
- }
58
- }