tailwindcss 3.4.1 → 4.0.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (285) hide show
  1. package/dist/chunk-GNCUPSHB.mjs +5886 -0
  2. package/dist/cli.d.mts +1 -0
  3. package/dist/cli.d.ts +1 -0
  4. package/dist/cli.js +6309 -0
  5. package/dist/cli.mjs +432 -0
  6. package/dist/lib.d.mts +324 -0
  7. package/dist/lib.d.ts +324 -0
  8. package/dist/lib.js +5884 -0
  9. package/dist/lib.mjs +1 -0
  10. package/index.css +5 -0
  11. package/package.json +35 -104
  12. package/preflight.css +355 -0
  13. package/theme.css +465 -0
  14. package/CHANGELOG.md +0 -2571
  15. package/README.md +0 -41
  16. package/base.css +0 -1
  17. package/colors.d.ts +0 -3
  18. package/colors.js +0 -2
  19. package/components.css +0 -1
  20. package/defaultConfig.d.ts +0 -3
  21. package/defaultConfig.js +0 -2
  22. package/defaultTheme.d.ts +0 -4
  23. package/defaultTheme.js +0 -2
  24. package/lib/cli/build/deps.js +0 -62
  25. package/lib/cli/build/index.js +0 -54
  26. package/lib/cli/build/plugin.js +0 -378
  27. package/lib/cli/build/utils.js +0 -88
  28. package/lib/cli/build/watching.js +0 -182
  29. package/lib/cli/help/index.js +0 -73
  30. package/lib/cli/index.js +0 -230
  31. package/lib/cli/init/index.js +0 -63
  32. package/lib/cli-peer-dependencies.js +0 -36
  33. package/lib/cli.js +0 -7
  34. package/lib/corePluginList.js +0 -190
  35. package/lib/corePlugins.js +0 -4282
  36. package/lib/css/LICENSE +0 -25
  37. package/lib/css/preflight.css +0 -385
  38. package/lib/featureFlags.js +0 -83
  39. package/lib/index.js +0 -2
  40. package/lib/lib/cacheInvalidation.js +0 -92
  41. package/lib/lib/collapseAdjacentRules.js +0 -61
  42. package/lib/lib/collapseDuplicateDeclarations.js +0 -85
  43. package/lib/lib/content.js +0 -181
  44. package/lib/lib/defaultExtractor.js +0 -251
  45. package/lib/lib/detectNesting.js +0 -45
  46. package/lib/lib/evaluateTailwindFunctions.js +0 -238
  47. package/lib/lib/expandApplyAtRules.js +0 -540
  48. package/lib/lib/expandTailwindAtRules.js +0 -291
  49. package/lib/lib/findAtConfigPath.js +0 -46
  50. package/lib/lib/generateRules.js +0 -904
  51. package/lib/lib/getModuleDependencies.js +0 -99
  52. package/lib/lib/load-config.js +0 -53
  53. package/lib/lib/normalizeTailwindDirectives.js +0 -89
  54. package/lib/lib/offsets.js +0 -306
  55. package/lib/lib/partitionApplyAtRules.js +0 -58
  56. package/lib/lib/regex.js +0 -74
  57. package/lib/lib/remap-bitfield.js +0 -89
  58. package/lib/lib/resolveDefaultsAtRules.js +0 -165
  59. package/lib/lib/setupContextUtils.js +0 -1294
  60. package/lib/lib/setupTrackingContext.js +0 -166
  61. package/lib/lib/sharedState.js +0 -87
  62. package/lib/lib/substituteScreenAtRules.js +0 -31
  63. package/lib/oxide/cli/build/deps.js +0 -89
  64. package/lib/oxide/cli/build/index.js +0 -53
  65. package/lib/oxide/cli/build/plugin.js +0 -375
  66. package/lib/oxide/cli/build/utils.js +0 -87
  67. package/lib/oxide/cli/build/watching.js +0 -179
  68. package/lib/oxide/cli/help/index.js +0 -72
  69. package/lib/oxide/cli/index.js +0 -214
  70. package/lib/oxide/cli/init/index.js +0 -52
  71. package/lib/oxide/cli.js +0 -5
  72. package/lib/oxide/postcss-plugin.js +0 -2
  73. package/lib/plugin.js +0 -98
  74. package/lib/postcss-plugins/nesting/README.md +0 -42
  75. package/lib/postcss-plugins/nesting/index.js +0 -21
  76. package/lib/postcss-plugins/nesting/plugin.js +0 -89
  77. package/lib/processTailwindFeatures.js +0 -64
  78. package/lib/public/colors.js +0 -355
  79. package/lib/public/create-plugin.js +0 -17
  80. package/lib/public/default-config.js +0 -18
  81. package/lib/public/default-theme.js +0 -18
  82. package/lib/public/load-config.js +0 -12
  83. package/lib/public/resolve-config.js +0 -24
  84. package/lib/util/applyImportantSelector.js +0 -36
  85. package/lib/util/bigSign.js +0 -13
  86. package/lib/util/buildMediaQuery.js +0 -27
  87. package/lib/util/cloneDeep.js +0 -22
  88. package/lib/util/cloneNodes.js +0 -54
  89. package/lib/util/color.js +0 -116
  90. package/lib/util/colorNames.js +0 -752
  91. package/lib/util/configurePlugins.js +0 -23
  92. package/lib/util/createPlugin.js +0 -32
  93. package/lib/util/createUtilityPlugin.js +0 -53
  94. package/lib/util/dataTypes.js +0 -415
  95. package/lib/util/defaults.js +0 -27
  96. package/lib/util/escapeClassName.js +0 -24
  97. package/lib/util/escapeCommas.js +0 -13
  98. package/lib/util/flattenColorPalette.js +0 -18
  99. package/lib/util/formatVariantSelector.js +0 -270
  100. package/lib/util/getAllConfigs.js +0 -50
  101. package/lib/util/hashConfig.js +0 -21
  102. package/lib/util/isKeyframeRule.js +0 -13
  103. package/lib/util/isPlainObject.js +0 -17
  104. package/lib/util/isSyntacticallyValidPropertyValue.js +0 -74
  105. package/lib/util/log.js +0 -61
  106. package/lib/util/nameClass.js +0 -49
  107. package/lib/util/negateValue.js +0 -36
  108. package/lib/util/normalizeConfig.js +0 -282
  109. package/lib/util/normalizeScreens.js +0 -178
  110. package/lib/util/parseAnimationValue.js +0 -93
  111. package/lib/util/parseBoxShadowValue.js +0 -88
  112. package/lib/util/parseDependency.js +0 -47
  113. package/lib/util/parseGlob.js +0 -36
  114. package/lib/util/parseObjectStyles.js +0 -36
  115. package/lib/util/pluginUtils.js +0 -289
  116. package/lib/util/prefixSelector.js +0 -39
  117. package/lib/util/pseudoElements.js +0 -212
  118. package/lib/util/removeAlphaVariables.js +0 -31
  119. package/lib/util/resolveConfig.js +0 -256
  120. package/lib/util/resolveConfigPath.js +0 -70
  121. package/lib/util/responsive.js +0 -24
  122. package/lib/util/splitAtTopLevelOnly.js +0 -51
  123. package/lib/util/tap.js +0 -14
  124. package/lib/util/toColorValue.js +0 -13
  125. package/lib/util/toPath.js +0 -32
  126. package/lib/util/transformThemeValue.js +0 -73
  127. package/lib/util/validateConfig.js +0 -37
  128. package/lib/util/validateFormalSyntax.js +0 -26
  129. package/lib/util/withAlphaVariable.js +0 -79
  130. package/lib/value-parser/LICENSE +0 -22
  131. package/lib/value-parser/README.md +0 -3
  132. package/lib/value-parser/index.d.js +0 -2
  133. package/lib/value-parser/index.js +0 -22
  134. package/lib/value-parser/parse.js +0 -259
  135. package/lib/value-parser/stringify.js +0 -38
  136. package/lib/value-parser/unit.js +0 -86
  137. package/lib/value-parser/walk.js +0 -16
  138. package/loadConfig.d.ts +0 -4
  139. package/loadConfig.js +0 -2
  140. package/nesting/index.d.ts +0 -4
  141. package/nesting/index.js +0 -2
  142. package/peers/index.js +0 -96624
  143. package/plugin.d.ts +0 -11
  144. package/plugin.js +0 -2
  145. package/prettier.config.js +0 -19
  146. package/resolveConfig.d.ts +0 -31
  147. package/resolveConfig.js +0 -2
  148. package/screens.css +0 -1
  149. package/scripts/create-plugin-list.js +0 -10
  150. package/scripts/generate-types.js +0 -104
  151. package/scripts/release-channel.js +0 -18
  152. package/scripts/release-notes.js +0 -21
  153. package/scripts/swap-engines.js +0 -40
  154. package/scripts/type-utils.js +0 -27
  155. package/src/cli/build/deps.js +0 -56
  156. package/src/cli/build/index.js +0 -49
  157. package/src/cli/build/plugin.js +0 -444
  158. package/src/cli/build/utils.js +0 -76
  159. package/src/cli/build/watching.js +0 -229
  160. package/src/cli/help/index.js +0 -70
  161. package/src/cli/index.js +0 -216
  162. package/src/cli/init/index.js +0 -79
  163. package/src/cli-peer-dependencies.js +0 -15
  164. package/src/cli.js +0 -7
  165. package/src/corePluginList.js +0 -1
  166. package/src/corePlugins.js +0 -2943
  167. package/src/css/LICENSE +0 -25
  168. package/src/css/preflight.css +0 -385
  169. package/src/featureFlags.js +0 -66
  170. package/src/index.js +0 -1
  171. package/src/lib/cacheInvalidation.js +0 -52
  172. package/src/lib/collapseAdjacentRules.js +0 -58
  173. package/src/lib/collapseDuplicateDeclarations.js +0 -93
  174. package/src/lib/content.js +0 -208
  175. package/src/lib/defaultExtractor.js +0 -230
  176. package/src/lib/detectNesting.js +0 -47
  177. package/src/lib/evaluateTailwindFunctions.js +0 -272
  178. package/src/lib/expandApplyAtRules.js +0 -620
  179. package/src/lib/expandTailwindAtRules.js +0 -300
  180. package/src/lib/findAtConfigPath.js +0 -48
  181. package/src/lib/generateRules.js +0 -951
  182. package/src/lib/getModuleDependencies.js +0 -79
  183. package/src/lib/load-config.ts +0 -39
  184. package/src/lib/normalizeTailwindDirectives.js +0 -84
  185. package/src/lib/offsets.js +0 -373
  186. package/src/lib/partitionApplyAtRules.js +0 -52
  187. package/src/lib/regex.js +0 -74
  188. package/src/lib/remap-bitfield.js +0 -82
  189. package/src/lib/resolveDefaultsAtRules.js +0 -163
  190. package/src/lib/setupContextUtils.js +0 -1366
  191. package/src/lib/setupTrackingContext.js +0 -169
  192. package/src/lib/sharedState.js +0 -61
  193. package/src/lib/substituteScreenAtRules.js +0 -19
  194. package/src/oxide/cli/build/deps.ts +0 -91
  195. package/src/oxide/cli/build/index.ts +0 -47
  196. package/src/oxide/cli/build/plugin.ts +0 -442
  197. package/src/oxide/cli/build/utils.ts +0 -74
  198. package/src/oxide/cli/build/watching.ts +0 -225
  199. package/src/oxide/cli/help/index.ts +0 -69
  200. package/src/oxide/cli/index.ts +0 -204
  201. package/src/oxide/cli/init/index.ts +0 -59
  202. package/src/oxide/cli.ts +0 -1
  203. package/src/oxide/postcss-plugin.ts +0 -1
  204. package/src/plugin.js +0 -107
  205. package/src/postcss-plugins/nesting/README.md +0 -42
  206. package/src/postcss-plugins/nesting/index.js +0 -13
  207. package/src/postcss-plugins/nesting/plugin.js +0 -80
  208. package/src/processTailwindFeatures.js +0 -59
  209. package/src/public/colors.js +0 -322
  210. package/src/public/create-plugin.js +0 -2
  211. package/src/public/default-config.js +0 -4
  212. package/src/public/default-theme.js +0 -4
  213. package/src/public/load-config.js +0 -2
  214. package/src/public/resolve-config.js +0 -7
  215. package/src/util/applyImportantSelector.js +0 -27
  216. package/src/util/bigSign.js +0 -3
  217. package/src/util/buildMediaQuery.js +0 -22
  218. package/src/util/cloneDeep.js +0 -11
  219. package/src/util/cloneNodes.js +0 -49
  220. package/src/util/color.js +0 -88
  221. package/src/util/colorNames.js +0 -150
  222. package/src/util/configurePlugins.js +0 -23
  223. package/src/util/createPlugin.js +0 -27
  224. package/src/util/createUtilityPlugin.js +0 -37
  225. package/src/util/dataTypes.js +0 -406
  226. package/src/util/defaults.js +0 -17
  227. package/src/util/escapeClassName.js +0 -8
  228. package/src/util/escapeCommas.js +0 -3
  229. package/src/util/flattenColorPalette.js +0 -13
  230. package/src/util/formatVariantSelector.js +0 -324
  231. package/src/util/getAllConfigs.js +0 -38
  232. package/src/util/hashConfig.js +0 -5
  233. package/src/util/isKeyframeRule.js +0 -3
  234. package/src/util/isPlainObject.js +0 -8
  235. package/src/util/isSyntacticallyValidPropertyValue.js +0 -61
  236. package/src/util/log.js +0 -29
  237. package/src/util/nameClass.js +0 -30
  238. package/src/util/negateValue.js +0 -24
  239. package/src/util/normalizeConfig.js +0 -301
  240. package/src/util/normalizeScreens.js +0 -140
  241. package/src/util/parseAnimationValue.js +0 -68
  242. package/src/util/parseBoxShadowValue.js +0 -72
  243. package/src/util/parseDependency.js +0 -44
  244. package/src/util/parseGlob.js +0 -24
  245. package/src/util/parseObjectStyles.js +0 -19
  246. package/src/util/pluginUtils.js +0 -307
  247. package/src/util/prefixSelector.js +0 -33
  248. package/src/util/pseudoElements.js +0 -171
  249. package/src/util/removeAlphaVariables.js +0 -24
  250. package/src/util/resolveConfig.js +0 -277
  251. package/src/util/resolveConfigPath.js +0 -66
  252. package/src/util/responsive.js +0 -10
  253. package/src/util/splitAtTopLevelOnly.js +0 -52
  254. package/src/util/tap.js +0 -4
  255. package/src/util/toColorValue.js +0 -3
  256. package/src/util/toPath.js +0 -26
  257. package/src/util/transformThemeValue.js +0 -62
  258. package/src/util/validateConfig.js +0 -26
  259. package/src/util/validateFormalSyntax.js +0 -34
  260. package/src/util/withAlphaVariable.js +0 -49
  261. package/src/value-parser/LICENSE +0 -22
  262. package/src/value-parser/README.md +0 -3
  263. package/src/value-parser/index.d.ts +0 -177
  264. package/src/value-parser/index.js +0 -28
  265. package/src/value-parser/parse.js +0 -303
  266. package/src/value-parser/stringify.js +0 -41
  267. package/src/value-parser/unit.js +0 -118
  268. package/src/value-parser/walk.js +0 -18
  269. package/stubs/.gitignore +0 -1
  270. package/stubs/.prettierrc.json +0 -6
  271. package/stubs/config.full.js +0 -1062
  272. package/stubs/config.simple.js +0 -7
  273. package/stubs/postcss.config.cjs +0 -6
  274. package/stubs/postcss.config.js +0 -6
  275. package/stubs/tailwind.config.cjs +0 -2
  276. package/stubs/tailwind.config.js +0 -2
  277. package/stubs/tailwind.config.ts +0 -3
  278. package/tailwind.css +0 -5
  279. package/types/config.d.ts +0 -376
  280. package/types/generated/.gitkeep +0 -0
  281. package/types/generated/colors.d.ts +0 -298
  282. package/types/generated/corePluginList.d.ts +0 -1
  283. package/types/generated/default-theme.d.ts +0 -397
  284. package/types/index.d.ts +0 -11
  285. package/variants.css +0 -1
@@ -1,442 +0,0 @@
1
- import path from 'path'
2
- import fs from 'fs'
3
- import postcssrc from 'postcss-load-config'
4
- import { lilconfig } from 'lilconfig'
5
- import loadPlugins from 'postcss-load-config/src/plugins' // Little bit scary, looking at private/internal API
6
- import loadOptions from 'postcss-load-config/src/options' // Little bit scary, looking at private/internal API
7
-
8
- import tailwind from '../../../processTailwindFeatures'
9
- import { loadPostcss, loadPostcssImport, lightningcss } from './deps'
10
- import { formatNodes, drainStdin, outputFile } from './utils'
11
- import { env } from '../../../lib/sharedState'
12
- import resolveConfig from '../../../../resolveConfig'
13
- import { parseCandidateFiles } from '../../../lib/content'
14
- import { createWatcher } from './watching'
15
- import fastGlob from 'fast-glob'
16
- import { findAtConfigPath } from '../../../lib/findAtConfigPath'
17
- import log from '../../../util/log'
18
- import { loadConfig } from '../../../lib/load-config'
19
- import getModuleDependencies from '../../../lib/getModuleDependencies'
20
- import type { Config } from '../../../../types'
21
-
22
- /**
23
- *
24
- * @param {string} [customPostCssPath ]
25
- * @returns
26
- */
27
- async function loadPostCssPlugins(customPostCssPath) {
28
- let config = customPostCssPath
29
- ? await (async () => {
30
- let file = path.resolve(customPostCssPath)
31
-
32
- // Implementation, see: https://unpkg.com/browse/postcss-load-config@3.1.0/src/index.js
33
- // @ts-ignore
34
- let { config = {} } = await lilconfig('postcss').load(file)
35
- if (typeof config === 'function') {
36
- config = config()
37
- } else {
38
- config = Object.assign({}, config)
39
- }
40
-
41
- if (!config.plugins) {
42
- config.plugins = []
43
- }
44
-
45
- return {
46
- file,
47
- plugins: loadPlugins(config, file),
48
- options: loadOptions(config, file),
49
- }
50
- })()
51
- : await postcssrc()
52
-
53
- let configPlugins = config.plugins
54
-
55
- let configPluginTailwindIdx = configPlugins.findIndex((plugin) => {
56
- if (typeof plugin === 'function' && plugin.name === 'tailwindcss') {
57
- return true
58
- }
59
-
60
- if (typeof plugin === 'object' && plugin !== null && plugin.postcssPlugin === 'tailwindcss') {
61
- return true
62
- }
63
-
64
- return false
65
- })
66
-
67
- let beforePlugins =
68
- configPluginTailwindIdx === -1 ? [] : configPlugins.slice(0, configPluginTailwindIdx)
69
- let afterPlugins =
70
- configPluginTailwindIdx === -1
71
- ? configPlugins
72
- : configPlugins.slice(configPluginTailwindIdx + 1)
73
-
74
- return [beforePlugins, afterPlugins, config.options]
75
- }
76
-
77
- function loadBuiltinPostcssPlugins() {
78
- let postcss = loadPostcss()
79
- let IMPORT_COMMENT = '__TAILWIND_RESTORE_IMPORT__: '
80
- return [
81
- [
82
- (root) => {
83
- root.walkAtRules('import', (rule) => {
84
- if (rule.params.slice(1).startsWith('tailwindcss/')) {
85
- rule.after(postcss.comment({ text: IMPORT_COMMENT + rule.params }))
86
- rule.remove()
87
- }
88
- })
89
- },
90
- loadPostcssImport(),
91
- (root) => {
92
- root.walkComments((rule) => {
93
- if (rule.text.startsWith(IMPORT_COMMENT)) {
94
- rule.after(
95
- postcss.atRule({
96
- name: 'import',
97
- params: rule.text.replace(IMPORT_COMMENT, ''),
98
- })
99
- )
100
- rule.remove()
101
- }
102
- })
103
- },
104
- ],
105
- [],
106
- {},
107
- ]
108
- }
109
-
110
- let state = {
111
- /** @type {any} */
112
- context: null,
113
-
114
- /** @type {ReturnType<typeof createWatcher> | null} */
115
- watcher: null,
116
-
117
- /** @type {{content: string, extension: string}[]} */
118
- changedContent: [],
119
-
120
- /** @type {{config: Config, dependencies: Set<string>, dispose: Function } | null} */
121
- configBag: null,
122
-
123
- contextDependencies: new Set(),
124
-
125
- /** @type {import('../../lib/content.js').ContentPath[]} */
126
- contentPaths: [],
127
-
128
- refreshContentPaths() {
129
- this.contentPaths = parseCandidateFiles(this.context, this.context?.tailwindConfig)
130
- },
131
-
132
- get config() {
133
- return this.context.tailwindConfig
134
- },
135
-
136
- get contentPatterns() {
137
- return {
138
- all: this.contentPaths.map((contentPath) => contentPath.pattern),
139
- dynamic: this.contentPaths
140
- .filter((contentPath) => contentPath.glob !== undefined)
141
- .map((contentPath) => contentPath.pattern),
142
- }
143
- },
144
-
145
- loadConfig(configPath, content) {
146
- if (this.watcher && configPath) {
147
- this.refreshConfigDependencies()
148
- }
149
-
150
- let config = loadConfig(configPath)
151
- let dependencies = getModuleDependencies(configPath)
152
- this.configBag = {
153
- config,
154
- dependencies,
155
- dispose() {
156
- for (let file of dependencies) {
157
- delete require.cache[require.resolve(file)]
158
- }
159
- },
160
- }
161
-
162
- // @ts-ignore
163
- this.configBag.config = resolveConfig(this.configBag.config, { content: { files: [] } })
164
-
165
- // Override content files if `--content` has been passed explicitly
166
- if (content?.length > 0) {
167
- this.configBag.config.content.files = content
168
- }
169
-
170
- return this.configBag.config
171
- },
172
-
173
- refreshConfigDependencies(configPath) {
174
- env.DEBUG && console.time('Module dependencies')
175
- this.configBag?.dispose()
176
- env.DEBUG && console.timeEnd('Module dependencies')
177
- },
178
-
179
- readContentPaths() {
180
- let content = []
181
-
182
- // Resolve globs from the content config
183
- // TODO: When we make the postcss plugin async-capable this can become async
184
- let files = fastGlob.sync(this.contentPatterns.all)
185
-
186
- for (let file of files) {
187
- if (__OXIDE__) {
188
- content.push({
189
- file,
190
- extension: path.extname(file).slice(1),
191
- })
192
- } else {
193
- content.push({
194
- content: fs.readFileSync(path.resolve(file), 'utf8'),
195
- extension: path.extname(file).slice(1),
196
- })
197
- }
198
- }
199
-
200
- // Resolve raw content in the tailwind config
201
- let rawContent = this.config.content.files.filter((file) => {
202
- return file !== null && typeof file === 'object'
203
- })
204
-
205
- for (let { raw: htmlContent, extension = 'html' } of rawContent) {
206
- content.push({ content: htmlContent, extension })
207
- }
208
-
209
- return content
210
- },
211
-
212
- getContext({ createContext, cliConfigPath, root, result, content }) {
213
- env.DEBUG && console.time('Searching for config')
214
- let configPath = findAtConfigPath(root, result) ?? cliConfigPath
215
- env.DEBUG && console.timeEnd('Searching for config')
216
-
217
- if (this.context) {
218
- this.context.changedContent = this.changedContent.splice(0)
219
-
220
- return this.context
221
- }
222
-
223
- env.DEBUG && console.time('Loading config')
224
- let config = this.loadConfig(configPath, content)
225
- env.DEBUG && console.timeEnd('Loading config')
226
-
227
- env.DEBUG && console.time('Creating context')
228
- this.context = createContext(config, [])
229
- Object.assign(this.context, {
230
- userConfigPath: configPath,
231
- })
232
- env.DEBUG && console.timeEnd('Creating context')
233
-
234
- env.DEBUG && console.time('Resolving content paths')
235
- this.refreshContentPaths()
236
- env.DEBUG && console.timeEnd('Resolving content paths')
237
-
238
- if (this.watcher) {
239
- env.DEBUG && console.time('Watch new files')
240
- this.watcher.refreshWatchedFiles()
241
- env.DEBUG && console.timeEnd('Watch new files')
242
- }
243
-
244
- for (let file of this.readContentPaths()) {
245
- this.context.changedContent.push(file)
246
- }
247
-
248
- return this.context
249
- },
250
- }
251
-
252
- export async function createProcessor(args, cliConfigPath) {
253
- let postcss = loadPostcss()
254
-
255
- let input = args['--input']
256
- let output = args['--output']
257
- let includePostCss = args['--postcss']
258
- let customPostCssPath = typeof args['--postcss'] === 'string' ? args['--postcss'] : undefined
259
-
260
- let [beforePlugins, afterPlugins, postcssOptions] = includePostCss
261
- ? await loadPostCssPlugins(customPostCssPath)
262
- : loadBuiltinPostcssPlugins()
263
-
264
- if (args['--purge']) {
265
- log.warn('purge-flag-deprecated', [
266
- 'The `--purge` flag has been deprecated.',
267
- 'Please use `--content` instead.',
268
- ])
269
-
270
- if (!args['--content']) {
271
- args['--content'] = args['--purge']
272
- }
273
- }
274
-
275
- let content = args['--content']?.split(/(?<!{[^}]+),/) ?? []
276
-
277
- let tailwindPlugin = () => {
278
- return {
279
- postcssPlugin: 'tailwindcss',
280
- async Once(root, { result }) {
281
- env.DEBUG && console.time('Compiling CSS')
282
- await tailwind(({ createContext }) => {
283
- console.error()
284
- console.error('Rebuilding...')
285
-
286
- return () => {
287
- return state.getContext({
288
- createContext,
289
- cliConfigPath,
290
- root,
291
- result,
292
- content,
293
- })
294
- }
295
- })(root, result)
296
- env.DEBUG && console.timeEnd('Compiling CSS')
297
- },
298
- }
299
- }
300
-
301
- tailwindPlugin.postcss = true
302
-
303
- let plugins = [
304
- ...beforePlugins,
305
- tailwindPlugin,
306
- !args['--minify'] && formatNodes,
307
- ...afterPlugins,
308
- ].filter(Boolean)
309
-
310
- /** @type {import('postcss').Processor} */
311
- // @ts-ignore
312
- let processor = postcss(plugins)
313
-
314
- async function readInput() {
315
- // Piping in data, let's drain the stdin
316
- if (input === '-') {
317
- return drainStdin()
318
- }
319
-
320
- // Input file has been provided
321
- if (input) {
322
- return fs.promises.readFile(path.resolve(input), 'utf8')
323
- }
324
-
325
- // No input file provided, fallback to default atrules
326
- return '@tailwind base; @tailwind components; @tailwind utilities'
327
- }
328
-
329
- async function build() {
330
- let start = process.hrtime.bigint()
331
-
332
- return readInput()
333
- .then((css) => processor.process(css, { ...postcssOptions, from: input, to: output }))
334
- .then((result) => lightningcss(!!args['--minify'], result))
335
- .then((result) => {
336
- if (!state.watcher) {
337
- return result
338
- }
339
-
340
- env.DEBUG && console.time('Recording PostCSS dependencies')
341
- for (let message of result.messages) {
342
- if (message.type === 'dependency') {
343
- state.contextDependencies.add(message.file)
344
- }
345
- }
346
- env.DEBUG && console.timeEnd('Recording PostCSS dependencies')
347
-
348
- // TODO: This needs to be in a different spot
349
- env.DEBUG && console.time('Watch new files')
350
- state.watcher.refreshWatchedFiles()
351
- env.DEBUG && console.timeEnd('Watch new files')
352
-
353
- return result
354
- })
355
- .then((result) => {
356
- if (!output) {
357
- process.stdout.write(result.css)
358
- return
359
- }
360
-
361
- return Promise.all([
362
- outputFile(result.opts.to, result.css),
363
- result.map && outputFile(result.opts.to + '.map', result.map.toString()),
364
- ])
365
- })
366
- .then(() => {
367
- let end = process.hrtime.bigint()
368
- console.error()
369
- console.error('Done in', (end - start) / BigInt(1e6) + 'ms.')
370
- })
371
- .then(
372
- () => {},
373
- (err) => {
374
- // TODO: If an initial build fails we can't easily pick up any PostCSS dependencies
375
- // that were collected before the error occurred
376
- // The result is not stored on the error so we have to store it externally
377
- // and pull the messages off of it here somehow
378
-
379
- // This results in a less than ideal DX because the watcher will not pick up
380
- // changes to imported CSS if one of them caused an error during the initial build
381
- // If you fix it and then save the main CSS file so there's no error
382
- // The watcher will start watching the imported CSS files and will be
383
- // resilient to future errors.
384
-
385
- if (state.watcher) {
386
- console.error(err)
387
- } else {
388
- return Promise.reject(err)
389
- }
390
- }
391
- )
392
- }
393
-
394
- /**
395
- * @param {{file: string, content(): Promise<string>, extension: string}[]} changes
396
- */
397
- async function parseChanges(changes) {
398
- return Promise.all(
399
- changes.map(async (change) => ({
400
- content: await change.content(),
401
- extension: change.extension,
402
- }))
403
- )
404
- }
405
-
406
- if (input !== undefined && input !== '-') {
407
- state.contextDependencies.add(path.resolve(input))
408
- }
409
-
410
- return {
411
- build,
412
- watch: async () => {
413
- state.watcher = createWatcher(args, {
414
- state,
415
-
416
- /**
417
- * @param {{file: string, content(): Promise<string>, extension: string}[]} changes
418
- */
419
- async rebuild(changes) {
420
- let needsNewContext = changes.some((change) => {
421
- return (
422
- state.configBag?.dependencies.has(change.file) ||
423
- state.contextDependencies.has(change.file)
424
- )
425
- })
426
-
427
- if (needsNewContext) {
428
- state.context = null
429
- } else {
430
- for (let change of await parseChanges(changes)) {
431
- state.changedContent.push(change)
432
- }
433
- }
434
-
435
- return build()
436
- },
437
- })
438
-
439
- await build()
440
- },
441
- }
442
- }
@@ -1,74 +0,0 @@
1
- import fs from 'fs'
2
- import path from 'path'
3
-
4
- export function indentRecursive(node, indent = 0) {
5
- node.each &&
6
- node.each((child, i) => {
7
- if (!child.raws.before || !child.raws.before.trim() || child.raws.before.includes('\n')) {
8
- child.raws.before = `\n${node.type !== 'rule' && i > 0 ? '\n' : ''}${' '.repeat(indent)}`
9
- }
10
- child.raws.after = `\n${' '.repeat(indent)}`
11
- indentRecursive(child, indent + 1)
12
- })
13
- }
14
-
15
- export function formatNodes(root) {
16
- indentRecursive(root)
17
- if (root.first) {
18
- root.first.raws.before = ''
19
- }
20
- }
21
-
22
- /**
23
- * When rapidly saving files atomically a couple of situations can happen:
24
- * - The file is missing since the external program has deleted it by the time we've gotten around to reading it from the earlier save.
25
- * - The file is being written to by the external program by the time we're going to read it and is thus treated as busy because a lock is held.
26
- *
27
- * To work around this we retry reading the file a handful of times with a delay between each attempt
28
- *
29
- * @param {string} path
30
- * @param {number} tries
31
- * @returns {Promise<string | undefined>}
32
- * @throws {Error} If the file is still missing or busy after the specified number of tries
33
- */
34
- export async function readFileWithRetries(path, tries = 5) {
35
- for (let n = 0; n <= tries; n++) {
36
- try {
37
- return await fs.promises.readFile(path, 'utf8')
38
- } catch (err) {
39
- if (n !== tries) {
40
- if (err.code === 'ENOENT' || err.code === 'EBUSY') {
41
- await new Promise((resolve) => setTimeout(resolve, 10))
42
-
43
- continue
44
- }
45
- }
46
-
47
- throw err
48
- }
49
- }
50
- }
51
-
52
- export function drainStdin() {
53
- return new Promise((resolve, reject) => {
54
- let result = ''
55
- process.stdin.on('data', (chunk) => {
56
- result += chunk
57
- })
58
- process.stdin.on('end', () => resolve(result))
59
- process.stdin.on('error', (err) => reject(err))
60
- })
61
- }
62
-
63
- export async function outputFile(file, newContents) {
64
- try {
65
- let currentContents = await fs.promises.readFile(file, 'utf8')
66
- if (currentContents === newContents) {
67
- return // Skip writing the file
68
- }
69
- } catch {}
70
-
71
- // Write the file
72
- await fs.promises.mkdir(path.dirname(file), { recursive: true })
73
- await fs.promises.writeFile(file, newContents, 'utf8')
74
- }