tailwindcss 0.0.0-insiders.f599430 → 0.0.0-insiders.f65023e

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 (235) hide show
  1. package/LICENSE +1 -2
  2. package/README.md +17 -10
  3. package/colors.d.ts +3 -0
  4. package/colors.js +2 -1
  5. package/defaultConfig.d.ts +3 -0
  6. package/defaultConfig.js +2 -1
  7. package/defaultTheme.d.ts +4 -0
  8. package/defaultTheme.js +2 -1
  9. package/lib/cli/build/deps.js +62 -0
  10. package/lib/cli/build/index.js +54 -0
  11. package/lib/cli/build/plugin.js +373 -0
  12. package/lib/cli/build/utils.js +88 -0
  13. package/lib/cli/build/watching.js +182 -0
  14. package/lib/cli/help/index.js +73 -0
  15. package/lib/cli/index.js +230 -0
  16. package/lib/cli/init/index.js +63 -0
  17. package/lib/cli-peer-dependencies.js +28 -7
  18. package/lib/cli.js +1 -704
  19. package/lib/corePluginList.js +25 -5
  20. package/lib/corePlugins.js +2643 -1894
  21. package/lib/css/preflight.css +42 -17
  22. package/lib/featureFlags.js +45 -26
  23. package/lib/index.js +1 -31
  24. package/lib/lib/cacheInvalidation.js +92 -0
  25. package/lib/lib/collapseAdjacentRules.js +30 -10
  26. package/lib/lib/collapseDuplicateDeclarations.js +85 -0
  27. package/lib/lib/content.js +236 -0
  28. package/lib/lib/defaultExtractor.js +273 -0
  29. package/lib/lib/evaluateTailwindFunctions.js +117 -46
  30. package/lib/lib/expandApplyAtRules.js +484 -159
  31. package/lib/lib/expandTailwindAtRules.js +166 -130
  32. package/lib/lib/findAtConfigPath.js +46 -0
  33. package/lib/lib/generateRules.js +643 -139
  34. package/lib/lib/getModuleDependencies.js +88 -37
  35. package/lib/lib/load-config.js +61 -0
  36. package/lib/lib/normalizeTailwindDirectives.js +46 -33
  37. package/lib/lib/offsets.js +355 -0
  38. package/lib/lib/partitionApplyAtRules.js +58 -0
  39. package/lib/lib/regex.js +74 -0
  40. package/lib/lib/remap-bitfield.js +89 -0
  41. package/lib/lib/resolveDefaultsAtRules.js +98 -56
  42. package/lib/lib/setupContextUtils.js +815 -326
  43. package/lib/lib/setupTrackingContext.js +71 -75
  44. package/lib/lib/sharedState.js +70 -10
  45. package/lib/lib/substituteScreenAtRules.js +16 -9
  46. package/lib/plugin.js +48 -0
  47. package/{nesting → lib/postcss-plugins/nesting}/README.md +2 -2
  48. package/lib/postcss-plugins/nesting/index.js +21 -0
  49. package/lib/postcss-plugins/nesting/plugin.js +89 -0
  50. package/lib/processTailwindFeatures.js +38 -25
  51. package/lib/public/colors.js +272 -246
  52. package/lib/public/create-plugin.js +9 -5
  53. package/lib/public/default-config.js +10 -6
  54. package/lib/public/default-theme.js +10 -6
  55. package/lib/public/load-config.js +12 -0
  56. package/lib/public/resolve-config.js +11 -6
  57. package/lib/util/applyImportantSelector.js +38 -0
  58. package/lib/util/bigSign.js +6 -1
  59. package/lib/util/buildMediaQuery.js +20 -24
  60. package/lib/util/cloneDeep.js +9 -6
  61. package/lib/util/cloneNodes.js +44 -4
  62. package/lib/util/color.js +70 -38
  63. package/lib/util/colorNames.js +752 -0
  64. package/lib/util/configurePlugins.js +7 -2
  65. package/lib/util/createPlugin.js +8 -6
  66. package/lib/util/createUtilityPlugin.js +14 -14
  67. package/lib/util/dataTypes.js +342 -101
  68. package/lib/util/defaults.js +14 -3
  69. package/lib/util/escapeClassName.js +13 -8
  70. package/lib/util/escapeCommas.js +7 -2
  71. package/lib/util/flattenColorPalette.js +11 -12
  72. package/lib/util/formatVariantSelector.js +270 -0
  73. package/lib/util/getAllConfigs.js +33 -12
  74. package/lib/util/hashConfig.js +9 -4
  75. package/lib/util/isKeyframeRule.js +7 -2
  76. package/lib/util/isPlainObject.js +8 -3
  77. package/lib/util/isSyntacticallyValidPropertyValue.js +74 -0
  78. package/lib/util/log.js +27 -13
  79. package/lib/util/nameClass.js +27 -9
  80. package/lib/util/negateValue.js +25 -8
  81. package/lib/util/normalizeConfig.js +147 -60
  82. package/lib/util/normalizeScreens.js +178 -0
  83. package/lib/util/parseAnimationValue.js +45 -41
  84. package/lib/util/parseBoxShadowValue.js +88 -0
  85. package/lib/util/parseDependency.js +39 -55
  86. package/lib/util/parseGlob.js +35 -0
  87. package/lib/util/parseObjectStyles.js +15 -10
  88. package/lib/util/pluginUtils.js +178 -199
  89. package/lib/util/prefixSelector.js +30 -14
  90. package/lib/util/pseudoElements.js +212 -0
  91. package/lib/util/removeAlphaVariables.js +31 -0
  92. package/lib/util/resolveConfig.js +96 -74
  93. package/lib/util/resolveConfigPath.js +32 -12
  94. package/lib/util/responsive.js +11 -6
  95. package/lib/util/splitAtTopLevelOnly.js +47 -0
  96. package/lib/util/tap.js +6 -1
  97. package/lib/util/toColorValue.js +7 -3
  98. package/lib/util/toPath.js +26 -3
  99. package/lib/util/transformThemeValue.js +52 -32
  100. package/lib/util/validateConfig.js +37 -0
  101. package/lib/util/validateFormalSyntax.js +26 -0
  102. package/lib/util/withAlphaVariable.js +27 -15
  103. package/lib/value-parser/LICENSE +22 -0
  104. package/lib/value-parser/README.md +3 -0
  105. package/lib/value-parser/index.d.js +2 -0
  106. package/lib/value-parser/index.js +22 -0
  107. package/lib/value-parser/parse.js +259 -0
  108. package/lib/value-parser/stringify.js +38 -0
  109. package/lib/value-parser/unit.js +86 -0
  110. package/lib/value-parser/walk.js +16 -0
  111. package/loadConfig.d.ts +4 -0
  112. package/loadConfig.js +2 -0
  113. package/nesting/index.d.ts +4 -0
  114. package/nesting/index.js +2 -12
  115. package/package.json +62 -57
  116. package/peers/index.js +70037 -49116
  117. package/plugin.d.ts +11 -0
  118. package/plugin.js +2 -1
  119. package/resolveConfig.d.ts +31 -0
  120. package/resolveConfig.js +2 -1
  121. package/scripts/generate-types.js +104 -0
  122. package/scripts/release-channel.js +18 -0
  123. package/scripts/release-notes.js +21 -0
  124. package/scripts/type-utils.js +27 -0
  125. package/src/cli/build/deps.js +56 -0
  126. package/src/cli/build/index.js +49 -0
  127. package/src/cli/build/plugin.js +441 -0
  128. package/src/cli/build/utils.js +76 -0
  129. package/src/cli/build/watching.js +229 -0
  130. package/src/cli/help/index.js +70 -0
  131. package/src/cli/index.js +216 -0
  132. package/src/cli/init/index.js +79 -0
  133. package/src/cli-peer-dependencies.js +7 -1
  134. package/src/cli.js +1 -766
  135. package/src/corePluginList.js +1 -1
  136. package/src/corePlugins.js +1133 -563
  137. package/src/css/preflight.css +42 -17
  138. package/src/featureFlags.js +13 -5
  139. package/src/index.js +1 -34
  140. package/src/lib/cacheInvalidation.js +52 -0
  141. package/src/lib/collapseAdjacentRules.js +21 -2
  142. package/src/lib/collapseDuplicateDeclarations.js +93 -0
  143. package/src/lib/content.js +281 -0
  144. package/src/lib/defaultExtractor.js +255 -0
  145. package/src/lib/evaluateTailwindFunctions.js +88 -11
  146. package/src/lib/expandApplyAtRules.js +538 -152
  147. package/src/lib/expandTailwindAtRules.js +115 -83
  148. package/src/lib/findAtConfigPath.js +48 -0
  149. package/src/lib/generateRules.js +672 -110
  150. package/src/lib/getModuleDependencies.js +70 -30
  151. package/src/lib/load-config.ts +55 -0
  152. package/src/lib/normalizeTailwindDirectives.js +7 -1
  153. package/src/lib/offsets.js +432 -0
  154. package/src/lib/partitionApplyAtRules.js +52 -0
  155. package/src/lib/regex.js +74 -0
  156. package/src/lib/remap-bitfield.js +82 -0
  157. package/src/lib/resolveDefaultsAtRules.js +63 -17
  158. package/src/lib/setupContextUtils.js +756 -183
  159. package/src/lib/setupTrackingContext.js +52 -65
  160. package/src/lib/sharedState.js +54 -7
  161. package/src/lib/substituteScreenAtRules.js +6 -3
  162. package/src/plugin.js +47 -0
  163. package/src/postcss-plugins/nesting/README.md +42 -0
  164. package/src/postcss-plugins/nesting/index.js +13 -0
  165. package/src/postcss-plugins/nesting/plugin.js +80 -0
  166. package/src/processTailwindFeatures.js +15 -5
  167. package/src/public/colors.js +22 -0
  168. package/src/public/default-config.js +1 -1
  169. package/src/public/default-theme.js +2 -2
  170. package/src/public/load-config.js +2 -0
  171. package/src/util/applyImportantSelector.js +26 -0
  172. package/src/util/buildMediaQuery.js +14 -16
  173. package/src/util/cloneNodes.js +40 -2
  174. package/src/util/color.js +44 -12
  175. package/src/util/colorNames.js +150 -0
  176. package/src/util/dataTypes.js +247 -23
  177. package/src/util/defaults.js +6 -0
  178. package/src/util/formatVariantSelector.js +324 -0
  179. package/src/util/getAllConfigs.js +21 -2
  180. package/src/util/isPlainObject.js +1 -1
  181. package/src/util/isSyntacticallyValidPropertyValue.js +61 -0
  182. package/src/util/log.js +11 -7
  183. package/src/util/nameClass.js +5 -1
  184. package/src/util/negateValue.js +11 -3
  185. package/src/util/normalizeConfig.js +74 -8
  186. package/src/util/normalizeScreens.js +140 -0
  187. package/src/util/parseAnimationValue.js +1 -1
  188. package/src/util/parseBoxShadowValue.js +72 -0
  189. package/src/util/parseDependency.js +37 -42
  190. package/src/util/parseGlob.js +23 -0
  191. package/src/util/pluginUtils.js +151 -159
  192. package/src/util/prefixSelector.js +31 -13
  193. package/src/util/pseudoElements.js +171 -0
  194. package/src/util/removeAlphaVariables.js +24 -0
  195. package/src/util/resolveConfig.js +74 -26
  196. package/src/util/resolveConfigPath.js +14 -1
  197. package/src/util/splitAtTopLevelOnly.js +48 -0
  198. package/src/util/toPath.js +23 -1
  199. package/src/util/transformThemeValue.js +33 -8
  200. package/src/util/validateConfig.js +26 -0
  201. package/src/util/validateFormalSyntax.js +34 -0
  202. package/src/util/withAlphaVariable.js +1 -1
  203. package/src/value-parser/LICENSE +22 -0
  204. package/src/value-parser/README.md +3 -0
  205. package/src/value-parser/index.d.ts +177 -0
  206. package/src/value-parser/index.js +28 -0
  207. package/src/value-parser/parse.js +303 -0
  208. package/src/value-parser/stringify.js +41 -0
  209. package/src/value-parser/unit.js +118 -0
  210. package/src/value-parser/walk.js +18 -0
  211. package/stubs/.gitignore +1 -0
  212. package/stubs/.prettierrc.json +6 -0
  213. package/stubs/{defaultConfig.stub.js → config.full.js} +322 -184
  214. package/stubs/postcss.config.js +6 -0
  215. package/stubs/tailwind.config.cjs +2 -0
  216. package/stubs/tailwind.config.js +2 -0
  217. package/stubs/tailwind.config.ts +3 -0
  218. package/types/config.d.ts +376 -0
  219. package/types/generated/.gitkeep +0 -0
  220. package/types/generated/colors.d.ts +298 -0
  221. package/types/generated/corePluginList.d.ts +1 -0
  222. package/types/generated/default-theme.d.ts +397 -0
  223. package/types/index.d.ts +11 -0
  224. package/CHANGELOG.md +0 -1778
  225. package/lib/constants.js +0 -37
  226. package/lib/lib/detectNesting.js +0 -19
  227. package/lib/lib/setupWatchingContext.js +0 -288
  228. package/nesting/plugin.js +0 -41
  229. package/scripts/install-integrations.js +0 -27
  230. package/scripts/rebuildFixtures.js +0 -68
  231. package/src/constants.js +0 -17
  232. package/src/lib/detectNesting.js +0 -20
  233. package/src/lib/setupWatchingContext.js +0 -311
  234. /package/stubs/{simpleConfig.stub.js → config.simple.js} +0 -0
  235. /package/stubs/{defaultPostCssConfig.stub.js → postcss.config.cjs} +0 -0
package/LICENSE CHANGED
@@ -1,7 +1,6 @@
1
1
  MIT License
2
2
 
3
- Copyright (c) Adam Wathan <adam.wathan@gmail.com>
4
- Copyright (c) Jonathan Reinink <jonathan@reinink.ca>
3
+ Copyright (c) Tailwind Labs, Inc.
5
4
 
6
5
  Permission is hereby granted, free of charge, to any person obtaining a copy
7
6
  of this software and associated documentation files (the "Software"), to deal
package/README.md CHANGED
@@ -1,18 +1,25 @@
1
- <p>
2
- <a href="https://tailwindcss.com/" target="_blank">
3
- <img alt="Tailwind CSS" width="350" src="https://refactoringui.nyc3.cdn.digitaloceanspaces.com/tailwind-logo-sticker.svg">
4
- </a><br>
5
- A utility-first CSS framework for rapidly building custom user interfaces.
1
+ <p align="center">
2
+ <a href="https://tailwindcss.com" target="_blank">
3
+ <picture>
4
+ <source media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/tailwindlabs/tailwindcss/HEAD/.github/logo-dark.svg">
5
+ <source media="(prefers-color-scheme: light)" srcset="https://raw.githubusercontent.com/tailwindlabs/tailwindcss/HEAD/.github/logo-light.svg">
6
+ <img alt="Tailwind CSS" src="https://raw.githubusercontent.com/tailwindlabs/tailwindcss/HEAD/.github/logo-light.svg" width="350" height="70" style="max-width: 100%;">
7
+ </picture>
8
+ </a>
6
9
  </p>
7
10
 
8
- <p>
9
- <a href="https://github.com/tailwindlabs/tailwindcss/actions"><img src="https://img.shields.io/github/workflow/status/tailwindlabs/tailwindcss/Node.js%20CI" alt="Build Status"></a>
11
+ <p align="center">
12
+ A utility-first CSS framework for rapidly building custom user interfaces.
13
+ </p>
14
+
15
+ <p align="center">
16
+ <a href="https://github.com/tailwindlabs/tailwindcss/actions"><img src="https://img.shields.io/github/actions/workflow/status/tailwindlabs/tailwindcss/ci.yml?branch=main" alt="Build Status"></a>
10
17
  <a href="https://www.npmjs.com/package/tailwindcss"><img src="https://img.shields.io/npm/dt/tailwindcss.svg" alt="Total Downloads"></a>
11
18
  <a href="https://github.com/tailwindcss/tailwindcss/releases"><img src="https://img.shields.io/npm/v/tailwindcss.svg" alt="Latest Release"></a>
12
- <a href="https://github.com/tailwindcss/tailwindcss/blob/master/LICENSE"><img src="https://img.shields.io/npm/l/tailwindcss.svg" alt="License"></a>
19
+ <a href="https://github.com/tailwindcss/tailwindcss/blob/main/LICENSE"><img src="https://img.shields.io/npm/l/tailwindcss.svg" alt="License"></a>
13
20
  </p>
14
21
 
15
- ------
22
+ ---
16
23
 
17
24
  ## Documentation
18
25
 
@@ -30,4 +37,4 @@ For casual chit-chat with others using the framework:
30
37
 
31
38
  ## Contributing
32
39
 
33
- If you're interested in contributing to Tailwind CSS, please read our [contributing docs](https://github.com/tailwindcss/tailwindcss/blob/master/.github/CONTRIBUTING.md) **before submitting a pull request**.
40
+ If you're interested in contributing to Tailwind CSS, please read our [contributing docs](https://github.com/tailwindcss/tailwindcss/blob/main/.github/CONTRIBUTING.md) **before submitting a pull request**.
package/colors.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ import type { DefaultColors } from './types/generated/colors'
2
+ declare const colors: DefaultColors
3
+ export = colors
package/colors.js CHANGED
@@ -1 +1,2 @@
1
- module.exports = require('./lib/public/colors').default
1
+ let colors = require('./lib/public/colors')
2
+ module.exports = (colors.__esModule ? colors : { default: colors }).default
@@ -0,0 +1,3 @@
1
+ import type { Config } from './types/config'
2
+ declare const config: Config
3
+ export = config
package/defaultConfig.js CHANGED
@@ -1 +1,2 @@
1
- module.exports = require('./lib/public/default-config').default
1
+ let defaultConfig = require('./lib/public/default-config')
2
+ module.exports = (defaultConfig.__esModule ? defaultConfig : { default: defaultConfig }).default
@@ -0,0 +1,4 @@
1
+ import type { Config } from './types/config'
2
+ import { DefaultTheme } from './types/generated/default-theme'
3
+ declare const theme: Config['theme'] & DefaultTheme
4
+ export = theme
package/defaultTheme.js CHANGED
@@ -1 +1,2 @@
1
- module.exports = require('./lib/public/default-theme').default
1
+ let defaultTheme = require('./lib/public/default-theme')
2
+ module.exports = (defaultTheme.__esModule ? defaultTheme : { default: defaultTheme }).default
@@ -0,0 +1,62 @@
1
+ // @ts-check
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ function _export(target, all) {
7
+ for(var name in all)Object.defineProperty(target, name, {
8
+ enumerable: true,
9
+ get: all[name]
10
+ });
11
+ }
12
+ _export(exports, {
13
+ loadPostcss: function() {
14
+ return loadPostcss;
15
+ },
16
+ loadPostcssImport: function() {
17
+ return loadPostcssImport;
18
+ },
19
+ loadCssNano: function() {
20
+ return loadCssNano;
21
+ },
22
+ loadAutoprefixer: function() {
23
+ return loadAutoprefixer;
24
+ }
25
+ });
26
+ const _index = require("../../../peers/index.js");
27
+ function loadPostcss() {
28
+ // Try to load a local `postcss` version first
29
+ try {
30
+ return require("postcss");
31
+ } catch {}
32
+ return (0, _index.lazyPostcss)();
33
+ }
34
+ function loadPostcssImport() {
35
+ // Try to load a local `postcss-import` version first
36
+ try {
37
+ return require("postcss-import");
38
+ } catch {}
39
+ return (0, _index.lazyPostcssImport)();
40
+ }
41
+ function loadCssNano() {
42
+ let options = {
43
+ preset: [
44
+ "default",
45
+ {
46
+ cssDeclarationSorter: false
47
+ }
48
+ ]
49
+ };
50
+ // Try to load a local `cssnano` version first
51
+ try {
52
+ return require("cssnano");
53
+ } catch {}
54
+ return (0, _index.lazyCssnano)()(options);
55
+ }
56
+ function loadAutoprefixer() {
57
+ // Try to load a local `autoprefixer` version first
58
+ try {
59
+ return require("autoprefixer");
60
+ } catch {}
61
+ return (0, _index.lazyAutoprefixer)();
62
+ }
@@ -0,0 +1,54 @@
1
+ // @ts-check
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "build", {
7
+ enumerable: true,
8
+ get: function() {
9
+ return build;
10
+ }
11
+ });
12
+ const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
13
+ const _path = /*#__PURE__*/ _interop_require_default(require("path"));
14
+ const _resolveConfigPath = require("../../util/resolveConfigPath.js");
15
+ const _plugin = require("./plugin.js");
16
+ function _interop_require_default(obj) {
17
+ return obj && obj.__esModule ? obj : {
18
+ default: obj
19
+ };
20
+ }
21
+ async function build(args) {
22
+ let input = args["--input"];
23
+ let shouldWatch = args["--watch"];
24
+ // TODO: Deprecate this in future versions
25
+ if (!input && args["_"][1]) {
26
+ console.error("[deprecation] Running tailwindcss without -i, please provide an input file.");
27
+ input = args["--input"] = args["_"][1];
28
+ }
29
+ if (input && input !== "-" && !_fs.default.existsSync(input = _path.default.resolve(input))) {
30
+ console.error(`Specified input file ${args["--input"]} does not exist.`);
31
+ process.exit(9);
32
+ }
33
+ if (args["--config"] && !_fs.default.existsSync(args["--config"] = _path.default.resolve(args["--config"]))) {
34
+ console.error(`Specified config file ${args["--config"]} does not exist.`);
35
+ process.exit(9);
36
+ }
37
+ // TODO: Reference the @config path here if exists
38
+ let configPath = args["--config"] ? args["--config"] : (0, _resolveConfigPath.resolveDefaultConfigPath)();
39
+ let processor = await (0, _plugin.createProcessor)(args, configPath);
40
+ if (shouldWatch) {
41
+ // Abort the watcher if stdin is closed to avoid zombie processes
42
+ // You can disable this behavior with --watch=always
43
+ if (args["--watch"] !== "always") {
44
+ process.stdin.on("end", ()=>process.exit(0));
45
+ }
46
+ process.stdin.resume();
47
+ await processor.watch();
48
+ } else {
49
+ await processor.build().catch((e)=>{
50
+ console.error(e);
51
+ process.exit(1);
52
+ });
53
+ }
54
+ }
@@ -0,0 +1,373 @@
1
+ // @ts-check
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "createProcessor", {
7
+ enumerable: true,
8
+ get: function() {
9
+ return createProcessor;
10
+ }
11
+ });
12
+ const _path = /*#__PURE__*/ _interop_require_default(require("path"));
13
+ const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
14
+ const _postcssloadconfig = /*#__PURE__*/ _interop_require_default(require("postcss-load-config"));
15
+ const _lilconfig = require("lilconfig");
16
+ const _plugins = /*#__PURE__*/ _interop_require_default(require("postcss-load-config/src/plugins" // Little bit scary, looking at private/internal API
17
+ ));
18
+ const _options = /*#__PURE__*/ _interop_require_default(require("postcss-load-config/src/options" // Little bit scary, looking at private/internal API
19
+ ));
20
+ const _processTailwindFeatures = /*#__PURE__*/ _interop_require_default(require("../../processTailwindFeatures"));
21
+ const _deps = require("./deps");
22
+ const _utils = require("./utils");
23
+ const _sharedState = require("../../lib/sharedState");
24
+ const _resolveConfig = /*#__PURE__*/ _interop_require_default(require("../../../resolveConfig.js"));
25
+ const _content = require("../../lib/content.js");
26
+ const _watching = require("./watching.js");
27
+ const _fastglob = /*#__PURE__*/ _interop_require_default(require("fast-glob"));
28
+ const _findAtConfigPath = require("../../lib/findAtConfigPath.js");
29
+ const _log = /*#__PURE__*/ _interop_require_default(require("../../util/log"));
30
+ const _loadconfig = require("../../lib/load-config");
31
+ const _getModuleDependencies = /*#__PURE__*/ _interop_require_default(require("../../lib/getModuleDependencies"));
32
+ function _interop_require_default(obj) {
33
+ return obj && obj.__esModule ? obj : {
34
+ default: obj
35
+ };
36
+ }
37
+ /**
38
+ *
39
+ * @param {string} [customPostCssPath ]
40
+ * @returns
41
+ */ async function loadPostCssPlugins(customPostCssPath) {
42
+ let config = customPostCssPath ? await (async ()=>{
43
+ let file = _path.default.resolve(customPostCssPath);
44
+ // Implementation, see: https://unpkg.com/browse/postcss-load-config@3.1.0/src/index.js
45
+ // @ts-ignore
46
+ let { config ={} } = await (0, _lilconfig.lilconfig)("postcss").load(file);
47
+ if (typeof config === "function") {
48
+ config = config();
49
+ } else {
50
+ config = Object.assign({}, config);
51
+ }
52
+ if (!config.plugins) {
53
+ config.plugins = [];
54
+ }
55
+ return {
56
+ file,
57
+ plugins: (0, _plugins.default)(config, file),
58
+ options: (0, _options.default)(config, file)
59
+ };
60
+ })() : await (0, _postcssloadconfig.default)();
61
+ let configPlugins = config.plugins;
62
+ let configPluginTailwindIdx = configPlugins.findIndex((plugin)=>{
63
+ if (typeof plugin === "function" && plugin.name === "tailwindcss") {
64
+ return true;
65
+ }
66
+ if (typeof plugin === "object" && plugin !== null && plugin.postcssPlugin === "tailwindcss") {
67
+ return true;
68
+ }
69
+ return false;
70
+ });
71
+ let beforePlugins = configPluginTailwindIdx === -1 ? [] : configPlugins.slice(0, configPluginTailwindIdx);
72
+ let afterPlugins = configPluginTailwindIdx === -1 ? configPlugins : configPlugins.slice(configPluginTailwindIdx + 1);
73
+ return [
74
+ beforePlugins,
75
+ afterPlugins,
76
+ config.options
77
+ ];
78
+ }
79
+ function loadBuiltinPostcssPlugins() {
80
+ let postcss = (0, _deps.loadPostcss)();
81
+ let IMPORT_COMMENT = "__TAILWIND_RESTORE_IMPORT__: ";
82
+ return [
83
+ [
84
+ (root)=>{
85
+ root.walkAtRules("import", (rule)=>{
86
+ if (rule.params.slice(1).startsWith("tailwindcss/")) {
87
+ rule.after(postcss.comment({
88
+ text: IMPORT_COMMENT + rule.params
89
+ }));
90
+ rule.remove();
91
+ }
92
+ });
93
+ },
94
+ (0, _deps.loadPostcssImport)(),
95
+ (root)=>{
96
+ root.walkComments((rule)=>{
97
+ if (rule.text.startsWith(IMPORT_COMMENT)) {
98
+ rule.after(postcss.atRule({
99
+ name: "import",
100
+ params: rule.text.replace(IMPORT_COMMENT, "")
101
+ }));
102
+ rule.remove();
103
+ }
104
+ });
105
+ }
106
+ ],
107
+ [],
108
+ {}
109
+ ];
110
+ }
111
+ let state = {
112
+ /** @type {any} */ context: null,
113
+ /** @type {ReturnType<typeof createWatcher> | null} */ watcher: null,
114
+ /** @type {{content: string, extension: string}[]} */ changedContent: [],
115
+ /** @type {ReturnType<typeof load> | null} */ configBag: null,
116
+ contextDependencies: new Set(),
117
+ /** @type {import('../../lib/content.js').ContentPath[]} */ contentPaths: [],
118
+ refreshContentPaths () {
119
+ var _this_context;
120
+ this.contentPaths = (0, _content.parseCandidateFiles)(this.context, (_this_context = this.context) === null || _this_context === void 0 ? void 0 : _this_context.tailwindConfig);
121
+ },
122
+ get config () {
123
+ return this.context.tailwindConfig;
124
+ },
125
+ get contentPatterns () {
126
+ return {
127
+ all: this.contentPaths.map((contentPath)=>contentPath.pattern),
128
+ dynamic: this.contentPaths.filter((contentPath)=>contentPath.glob !== undefined).map((contentPath)=>contentPath.pattern)
129
+ };
130
+ },
131
+ loadConfig (configPath, content) {
132
+ if (this.watcher && configPath) {
133
+ this.refreshConfigDependencies();
134
+ }
135
+ let config = (0, _loadconfig.loadConfig)(configPath);
136
+ let dependencies = (0, _getModuleDependencies.default)(configPath);
137
+ this.configBag = {
138
+ config,
139
+ dependencies,
140
+ dispose () {
141
+ for (let file of dependencies){
142
+ delete require.cache[require.resolve(file)];
143
+ }
144
+ }
145
+ };
146
+ // @ts-ignore
147
+ this.configBag.config = (0, _resolveConfig.default)(this.configBag.config, {
148
+ content: {
149
+ files: []
150
+ }
151
+ });
152
+ // Override content files if `--content` has been passed explicitly
153
+ if ((content === null || content === void 0 ? void 0 : content.length) > 0) {
154
+ this.configBag.config.content.files = content;
155
+ }
156
+ return this.configBag.config;
157
+ },
158
+ refreshConfigDependencies () {
159
+ var _this_configBag;
160
+ _sharedState.env.DEBUG && console.time("Module dependencies");
161
+ (_this_configBag = this.configBag) === null || _this_configBag === void 0 ? void 0 : _this_configBag.dispose();
162
+ _sharedState.env.DEBUG && console.timeEnd("Module dependencies");
163
+ },
164
+ readContentPaths () {
165
+ let content = [];
166
+ // Resolve globs from the content config
167
+ // TODO: When we make the postcss plugin async-capable this can become async
168
+ let files = _fastglob.default.sync(this.contentPatterns.all);
169
+ let checkBroadPattern = (0, _content.createBroadPatternCheck)(this.contentPatterns.all);
170
+ for (let file of files){
171
+ checkBroadPattern(file);
172
+ content.push({
173
+ content: _fs.default.readFileSync(_path.default.resolve(file), "utf8"),
174
+ extension: _path.default.extname(file).slice(1)
175
+ });
176
+ }
177
+ // Resolve raw content in the tailwind config
178
+ let rawContent = this.config.content.files.filter((file)=>{
179
+ return file !== null && typeof file === "object";
180
+ });
181
+ for (let { raw: htmlContent , extension ="html" } of rawContent){
182
+ content.push({
183
+ content: htmlContent,
184
+ extension
185
+ });
186
+ }
187
+ return content;
188
+ },
189
+ getContext ({ createContext , cliConfigPath , root , result , content }) {
190
+ _sharedState.env.DEBUG && console.time("Searching for config");
191
+ var _findAtConfigPath1;
192
+ let configPath = (_findAtConfigPath1 = (0, _findAtConfigPath.findAtConfigPath)(root, result)) !== null && _findAtConfigPath1 !== void 0 ? _findAtConfigPath1 : cliConfigPath;
193
+ _sharedState.env.DEBUG && console.timeEnd("Searching for config");
194
+ if (this.context) {
195
+ this.context.changedContent = this.changedContent.splice(0);
196
+ return this.context;
197
+ }
198
+ _sharedState.env.DEBUG && console.time("Loading config");
199
+ let config = this.loadConfig(configPath, content);
200
+ _sharedState.env.DEBUG && console.timeEnd("Loading config");
201
+ _sharedState.env.DEBUG && console.time("Creating context");
202
+ this.context = createContext(config, []);
203
+ Object.assign(this.context, {
204
+ userConfigPath: configPath
205
+ });
206
+ _sharedState.env.DEBUG && console.timeEnd("Creating context");
207
+ _sharedState.env.DEBUG && console.time("Resolving content paths");
208
+ this.refreshContentPaths();
209
+ _sharedState.env.DEBUG && console.timeEnd("Resolving content paths");
210
+ if (this.watcher) {
211
+ _sharedState.env.DEBUG && console.time("Watch new files");
212
+ this.watcher.refreshWatchedFiles();
213
+ _sharedState.env.DEBUG && console.timeEnd("Watch new files");
214
+ }
215
+ for (let file of this.readContentPaths()){
216
+ this.context.changedContent.push(file);
217
+ }
218
+ return this.context;
219
+ }
220
+ };
221
+ async function createProcessor(args, cliConfigPath) {
222
+ var _args_content;
223
+ let postcss = (0, _deps.loadPostcss)();
224
+ let input = args["--input"];
225
+ let output = args["--output"];
226
+ let includePostCss = args["--postcss"];
227
+ let customPostCssPath = typeof args["--postcss"] === "string" ? args["--postcss"] : undefined;
228
+ let [beforePlugins, afterPlugins, postcssOptions] = includePostCss ? await loadPostCssPlugins(customPostCssPath) : loadBuiltinPostcssPlugins();
229
+ if (args["--purge"]) {
230
+ _log.default.warn("purge-flag-deprecated", [
231
+ "The `--purge` flag has been deprecated.",
232
+ "Please use `--content` instead."
233
+ ]);
234
+ if (!args["--content"]) {
235
+ args["--content"] = args["--purge"];
236
+ }
237
+ }
238
+ var _args_content_split;
239
+ let content = (_args_content_split = (_args_content = args["--content"]) === null || _args_content === void 0 ? void 0 : _args_content.split(/(?<!{[^}]+),/)) !== null && _args_content_split !== void 0 ? _args_content_split : [];
240
+ let tailwindPlugin = ()=>{
241
+ return {
242
+ postcssPlugin: "tailwindcss",
243
+ async Once (root, { result }) {
244
+ _sharedState.env.DEBUG && console.time("Compiling CSS");
245
+ await (0, _processTailwindFeatures.default)(({ createContext })=>{
246
+ console.error();
247
+ console.error("Rebuilding...");
248
+ return ()=>{
249
+ return state.getContext({
250
+ createContext,
251
+ cliConfigPath,
252
+ root,
253
+ result,
254
+ content
255
+ });
256
+ };
257
+ })(root, result);
258
+ _sharedState.env.DEBUG && console.timeEnd("Compiling CSS");
259
+ }
260
+ };
261
+ };
262
+ tailwindPlugin.postcss = true;
263
+ let plugins = [
264
+ ...beforePlugins,
265
+ tailwindPlugin,
266
+ !args["--minify"] && _utils.formatNodes,
267
+ ...afterPlugins,
268
+ !args["--no-autoprefixer"] && (0, _deps.loadAutoprefixer)(),
269
+ args["--minify"] && (0, _deps.loadCssNano)()
270
+ ].filter(Boolean);
271
+ /** @type {import('postcss').Processor} */ // @ts-ignore
272
+ let processor = postcss(plugins);
273
+ async function readInput() {
274
+ // Piping in data, let's drain the stdin
275
+ if (input === "-") {
276
+ return (0, _utils.drainStdin)();
277
+ }
278
+ // Input file has been provided
279
+ if (input) {
280
+ return _fs.default.promises.readFile(_path.default.resolve(input), "utf8");
281
+ }
282
+ // No input file provided, fallback to default at-rules
283
+ return "@tailwind base; @tailwind components; @tailwind utilities";
284
+ }
285
+ async function build() {
286
+ let start = process.hrtime.bigint();
287
+ return readInput().then((css)=>processor.process(css, {
288
+ ...postcssOptions,
289
+ from: input,
290
+ to: output
291
+ })).then((result)=>{
292
+ if (!state.watcher) {
293
+ return result;
294
+ }
295
+ _sharedState.env.DEBUG && console.time("Recording PostCSS dependencies");
296
+ for (let message of result.messages){
297
+ if (message.type === "dependency") {
298
+ state.contextDependencies.add(message.file);
299
+ }
300
+ }
301
+ _sharedState.env.DEBUG && console.timeEnd("Recording PostCSS dependencies");
302
+ // TODO: This needs to be in a different spot
303
+ _sharedState.env.DEBUG && console.time("Watch new files");
304
+ state.watcher.refreshWatchedFiles();
305
+ _sharedState.env.DEBUG && console.timeEnd("Watch new files");
306
+ return result;
307
+ }).then((result)=>{
308
+ if (!output) {
309
+ process.stdout.write(result.css);
310
+ return;
311
+ }
312
+ return Promise.all([
313
+ (0, _utils.outputFile)(result.opts.to, result.css),
314
+ result.map && (0, _utils.outputFile)(result.opts.to + ".map", result.map.toString())
315
+ ]);
316
+ }).then(()=>{
317
+ let end = process.hrtime.bigint();
318
+ console.error();
319
+ console.error("Done in", (end - start) / BigInt(1e6) + "ms.");
320
+ }).then(()=>{}, (err)=>{
321
+ // TODO: If an initial build fails we can't easily pick up any PostCSS dependencies
322
+ // that were collected before the error occurred
323
+ // The result is not stored on the error so we have to store it externally
324
+ // and pull the messages off of it here somehow
325
+ // This results in a less than ideal DX because the watcher will not pick up
326
+ // changes to imported CSS if one of them caused an error during the initial build
327
+ // If you fix it and then save the main CSS file so there's no error
328
+ // The watcher will start watching the imported CSS files and will be
329
+ // resilient to future errors.
330
+ if (state.watcher) {
331
+ console.error(err);
332
+ } else {
333
+ return Promise.reject(err);
334
+ }
335
+ });
336
+ }
337
+ /**
338
+ * @param {{file: string, content(): Promise<string>, extension: string}[]} changes
339
+ */ async function parseChanges(changes) {
340
+ return Promise.all(changes.map(async (change)=>({
341
+ content: await change.content(),
342
+ extension: change.extension
343
+ })));
344
+ }
345
+ if (input !== undefined && input !== "-") {
346
+ state.contextDependencies.add(_path.default.resolve(input));
347
+ }
348
+ return {
349
+ build,
350
+ watch: async ()=>{
351
+ state.watcher = (0, _watching.createWatcher)(args, {
352
+ state,
353
+ /**
354
+ * @param {{file: string, content(): Promise<string>, extension: string}[]} changes
355
+ */ async rebuild (changes) {
356
+ let needsNewContext = changes.some((change)=>{
357
+ var _state_configBag;
358
+ return ((_state_configBag = state.configBag) === null || _state_configBag === void 0 ? void 0 : _state_configBag.dependencies.has(change.file)) || state.contextDependencies.has(change.file);
359
+ });
360
+ if (needsNewContext) {
361
+ state.context = null;
362
+ } else {
363
+ for (let change of (await parseChanges(changes))){
364
+ state.changedContent.push(change);
365
+ }
366
+ }
367
+ return build();
368
+ }
369
+ });
370
+ await build();
371
+ }
372
+ };
373
+ }
@@ -0,0 +1,88 @@
1
+ // @ts-check
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ function _export(target, all) {
7
+ for(var name in all)Object.defineProperty(target, name, {
8
+ enumerable: true,
9
+ get: all[name]
10
+ });
11
+ }
12
+ _export(exports, {
13
+ indentRecursive: function() {
14
+ return indentRecursive;
15
+ },
16
+ formatNodes: function() {
17
+ return formatNodes;
18
+ },
19
+ readFileWithRetries: function() {
20
+ return readFileWithRetries;
21
+ },
22
+ drainStdin: function() {
23
+ return drainStdin;
24
+ },
25
+ outputFile: function() {
26
+ return outputFile;
27
+ }
28
+ });
29
+ const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
30
+ const _path = /*#__PURE__*/ _interop_require_default(require("path"));
31
+ function _interop_require_default(obj) {
32
+ return obj && obj.__esModule ? obj : {
33
+ default: obj
34
+ };
35
+ }
36
+ function indentRecursive(node, indent = 0) {
37
+ node.each && node.each((child, i)=>{
38
+ if (!child.raws.before || !child.raws.before.trim() || child.raws.before.includes("\n")) {
39
+ child.raws.before = `\n${node.type !== "rule" && i > 0 ? "\n" : ""}${" ".repeat(indent)}`;
40
+ }
41
+ child.raws.after = `\n${" ".repeat(indent)}`;
42
+ indentRecursive(child, indent + 1);
43
+ });
44
+ }
45
+ function formatNodes(root) {
46
+ indentRecursive(root);
47
+ if (root.first) {
48
+ root.first.raws.before = "";
49
+ }
50
+ }
51
+ async function readFileWithRetries(path, tries = 5) {
52
+ for(let n = 0; n <= tries; n++){
53
+ try {
54
+ return await _fs.default.promises.readFile(path, "utf8");
55
+ } catch (err) {
56
+ if (n !== tries) {
57
+ if (err.code === "ENOENT" || err.code === "EBUSY") {
58
+ await new Promise((resolve)=>setTimeout(resolve, 10));
59
+ continue;
60
+ }
61
+ }
62
+ throw err;
63
+ }
64
+ }
65
+ }
66
+ function drainStdin() {
67
+ return new Promise((resolve, reject)=>{
68
+ let result = "";
69
+ process.stdin.on("data", (chunk)=>{
70
+ result += chunk;
71
+ });
72
+ process.stdin.on("end", ()=>resolve(result));
73
+ process.stdin.on("error", (err)=>reject(err));
74
+ });
75
+ }
76
+ async function outputFile(file, newContents) {
77
+ try {
78
+ let currentContents = await _fs.default.promises.readFile(file, "utf8");
79
+ if (currentContents === newContents) {
80
+ return; // Skip writing the file
81
+ }
82
+ } catch {}
83
+ // Write the file
84
+ await _fs.default.promises.mkdir(_path.default.dirname(file), {
85
+ recursive: true
86
+ });
87
+ await _fs.default.promises.writeFile(file, newContents, "utf8");
88
+ }