tailwindcss 3.4.1 → 4.0.0-alpha.2

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