tailwindcss 0.0.0-oxide-insiders.f49b054 → 0.0.0-oxide.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 (286) hide show
  1. package/dist/chunk-J6HTTNZH.mjs +5017 -0
  2. package/dist/cli.d.mts +2 -0
  3. package/dist/cli.d.ts +2 -0
  4. package/dist/cli.js +5446 -0
  5. package/dist/cli.mjs +438 -0
  6. package/dist/lib.d.mts +244 -0
  7. package/dist/lib.d.ts +244 -0
  8. package/dist/lib.js +4947 -0
  9. package/dist/lib.mjs +1 -0
  10. package/index.css +4 -4
  11. package/package.json +36 -106
  12. package/preflight.css +404 -0
  13. package/theme.css +468 -0
  14. package/LICENSE +0 -21
  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 -383
  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 -67
  32. package/lib/cli-peer-dependencies.js +0 -36
  33. package/lib/cli.js +0 -7
  34. package/lib/corePluginList.js +0 -187
  35. package/lib/corePlugins.js +0 -4173
  36. package/lib/css/LICENSE +0 -25
  37. package/lib/css/preflight.css +0 -375
  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 -202
  44. package/lib/lib/defaultExtractor.js +0 -243
  45. package/lib/lib/detectNesting.js +0 -45
  46. package/lib/lib/evaluateTailwindFunctions.js +0 -238
  47. package/lib/lib/expandApplyAtRules.js +0 -534
  48. package/lib/lib/expandTailwindAtRules.js +0 -274
  49. package/lib/lib/findAtConfigPath.js +0 -46
  50. package/lib/lib/generateRules.js +0 -882
  51. package/lib/lib/getModuleDependencies.js +0 -99
  52. package/lib/lib/handleImportAtRules.js +0 -49
  53. package/lib/lib/load-config.js +0 -42
  54. package/lib/lib/normalizeTailwindDirectives.js +0 -91
  55. package/lib/lib/offsets.js +0 -306
  56. package/lib/lib/partitionApplyAtRules.js +0 -58
  57. package/lib/lib/regex.js +0 -74
  58. package/lib/lib/remap-bitfield.js +0 -89
  59. package/lib/lib/resolveDefaultsAtRules.js +0 -165
  60. package/lib/lib/setupContextUtils.js +0 -1255
  61. package/lib/lib/setupTrackingContext.js +0 -165
  62. package/lib/lib/sharedState.js +0 -87
  63. package/lib/lib/substituteScreenAtRules.js +0 -31
  64. package/lib/oxide/cli/build/deps.js +0 -89
  65. package/lib/oxide/cli/build/index.js +0 -53
  66. package/lib/oxide/cli/build/plugin.js +0 -354
  67. package/lib/oxide/cli/build/utils.js +0 -87
  68. package/lib/oxide/cli/build/watching.js +0 -179
  69. package/lib/oxide/cli/help/index.js +0 -72
  70. package/lib/oxide/cli/index.js +0 -214
  71. package/lib/oxide/cli/init/index.js +0 -56
  72. package/lib/oxide/cli.js +0 -5
  73. package/lib/oxide/postcss-plugin.js +0 -2
  74. package/lib/plugin.js +0 -100
  75. package/lib/postcss-plugins/nesting/README.md +0 -42
  76. package/lib/postcss-plugins/nesting/index.js +0 -21
  77. package/lib/postcss-plugins/nesting/plugin.js +0 -89
  78. package/lib/processTailwindFeatures.js +0 -64
  79. package/lib/public/colors.js +0 -355
  80. package/lib/public/create-plugin.js +0 -17
  81. package/lib/public/default-config.js +0 -18
  82. package/lib/public/default-theme.js +0 -18
  83. package/lib/public/load-config.js +0 -12
  84. package/lib/public/resolve-config.js +0 -24
  85. package/lib/util/applyImportantSelector.js +0 -36
  86. package/lib/util/bigSign.js +0 -13
  87. package/lib/util/buildMediaQuery.js +0 -27
  88. package/lib/util/cloneDeep.js +0 -22
  89. package/lib/util/cloneNodes.js +0 -34
  90. package/lib/util/color.js +0 -116
  91. package/lib/util/colorNames.js +0 -752
  92. package/lib/util/configurePlugins.js +0 -23
  93. package/lib/util/createPlugin.js +0 -32
  94. package/lib/util/createUtilityPlugin.js +0 -53
  95. package/lib/util/dataTypes.js +0 -304
  96. package/lib/util/defaults.js +0 -27
  97. package/lib/util/escapeClassName.js +0 -24
  98. package/lib/util/escapeCommas.js +0 -13
  99. package/lib/util/flattenColorPalette.js +0 -18
  100. package/lib/util/formatVariantSelector.js +0 -263
  101. package/lib/util/getAllConfigs.js +0 -52
  102. package/lib/util/hashConfig.js +0 -21
  103. package/lib/util/isKeyframeRule.js +0 -13
  104. package/lib/util/isPlainObject.js +0 -17
  105. package/lib/util/isSyntacticallyValidPropertyValue.js +0 -74
  106. package/lib/util/log.js +0 -61
  107. package/lib/util/nameClass.js +0 -49
  108. package/lib/util/negateValue.js +0 -36
  109. package/lib/util/normalizeConfig.js +0 -304
  110. package/lib/util/normalizeScreens.js +0 -178
  111. package/lib/util/parseAnimationValue.js +0 -93
  112. package/lib/util/parseBoxShadowValue.js +0 -88
  113. package/lib/util/parseDependency.js +0 -47
  114. package/lib/util/parseGlob.js +0 -36
  115. package/lib/util/parseObjectStyles.js +0 -36
  116. package/lib/util/pluginUtils.js +0 -276
  117. package/lib/util/prefixSelector.js +0 -39
  118. package/lib/util/pseudoElements.js +0 -229
  119. package/lib/util/removeAlphaVariables.js +0 -31
  120. package/lib/util/resolveConfig.js +0 -256
  121. package/lib/util/resolveConfigPath.js +0 -70
  122. package/lib/util/responsive.js +0 -24
  123. package/lib/util/splitAtTopLevelOnly.js +0 -51
  124. package/lib/util/tap.js +0 -14
  125. package/lib/util/toColorValue.js +0 -13
  126. package/lib/util/toPath.js +0 -32
  127. package/lib/util/transformThemeValue.js +0 -73
  128. package/lib/util/validateConfig.js +0 -43
  129. package/lib/util/validateFormalSyntax.js +0 -26
  130. package/lib/util/withAlphaVariable.js +0 -79
  131. package/lib/value-parser/LICENSE +0 -22
  132. package/lib/value-parser/README.md +0 -3
  133. package/lib/value-parser/index.d.js +0 -2
  134. package/lib/value-parser/index.js +0 -22
  135. package/lib/value-parser/parse.js +0 -259
  136. package/lib/value-parser/stringify.js +0 -38
  137. package/lib/value-parser/unit.js +0 -86
  138. package/lib/value-parser/walk.js +0 -16
  139. package/loadConfig.d.ts +0 -4
  140. package/loadConfig.js +0 -2
  141. package/nesting/index.js +0 -2
  142. package/peers/index.js +0 -96294
  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 -12
  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 -105
  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 -451
  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 -84
  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 -2849
  167. package/src/css/LICENSE +0 -25
  168. package/src/css/preflight.css +0 -375
  169. package/src/featureFlags.js +0 -70
  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 -235
  175. package/src/lib/defaultExtractor.js +0 -217
  176. package/src/lib/detectNesting.js +0 -47
  177. package/src/lib/evaluateTailwindFunctions.js +0 -272
  178. package/src/lib/expandApplyAtRules.js +0 -613
  179. package/src/lib/expandTailwindAtRules.js +0 -283
  180. package/src/lib/findAtConfigPath.js +0 -48
  181. package/src/lib/generateRules.js +0 -927
  182. package/src/lib/getModuleDependencies.js +0 -79
  183. package/src/lib/handleImportAtRules.js +0 -33
  184. package/src/lib/load-config.ts +0 -31
  185. package/src/lib/normalizeTailwindDirectives.js +0 -86
  186. package/src/lib/offsets.js +0 -373
  187. package/src/lib/partitionApplyAtRules.js +0 -52
  188. package/src/lib/regex.js +0 -74
  189. package/src/lib/remap-bitfield.js +0 -82
  190. package/src/lib/resolveDefaultsAtRules.js +0 -163
  191. package/src/lib/setupContextUtils.js +0 -1327
  192. package/src/lib/setupTrackingContext.js +0 -171
  193. package/src/lib/sharedState.js +0 -61
  194. package/src/lib/substituteScreenAtRules.js +0 -19
  195. package/src/oxide/cli/build/deps.ts +0 -91
  196. package/src/oxide/cli/build/index.ts +0 -47
  197. package/src/oxide/cli/build/plugin.ts +0 -419
  198. package/src/oxide/cli/build/utils.ts +0 -74
  199. package/src/oxide/cli/build/watching.ts +0 -225
  200. package/src/oxide/cli/help/index.ts +0 -69
  201. package/src/oxide/cli/index.ts +0 -204
  202. package/src/oxide/cli/init/index.ts +0 -64
  203. package/src/oxide/cli.ts +0 -1
  204. package/src/oxide/postcss-plugin.ts +0 -1
  205. package/src/plugin.js +0 -109
  206. package/src/postcss-plugins/nesting/README.md +0 -42
  207. package/src/postcss-plugins/nesting/index.js +0 -13
  208. package/src/postcss-plugins/nesting/plugin.js +0 -80
  209. package/src/processTailwindFeatures.js +0 -58
  210. package/src/public/colors.js +0 -322
  211. package/src/public/create-plugin.js +0 -2
  212. package/src/public/default-config.js +0 -4
  213. package/src/public/default-theme.js +0 -4
  214. package/src/public/load-config.js +0 -2
  215. package/src/public/resolve-config.js +0 -7
  216. package/src/util/applyImportantSelector.js +0 -27
  217. package/src/util/bigSign.js +0 -3
  218. package/src/util/buildMediaQuery.js +0 -22
  219. package/src/util/cloneDeep.js +0 -11
  220. package/src/util/cloneNodes.js +0 -28
  221. package/src/util/color.js +0 -88
  222. package/src/util/colorNames.js +0 -150
  223. package/src/util/configurePlugins.js +0 -23
  224. package/src/util/createPlugin.js +0 -27
  225. package/src/util/createUtilityPlugin.js +0 -37
  226. package/src/util/dataTypes.js +0 -292
  227. package/src/util/defaults.js +0 -17
  228. package/src/util/escapeClassName.js +0 -8
  229. package/src/util/escapeCommas.js +0 -3
  230. package/src/util/flattenColorPalette.js +0 -13
  231. package/src/util/formatVariantSelector.js +0 -316
  232. package/src/util/getAllConfigs.js +0 -45
  233. package/src/util/hashConfig.js +0 -5
  234. package/src/util/isKeyframeRule.js +0 -3
  235. package/src/util/isPlainObject.js +0 -8
  236. package/src/util/isSyntacticallyValidPropertyValue.js +0 -61
  237. package/src/util/log.js +0 -29
  238. package/src/util/nameClass.js +0 -30
  239. package/src/util/negateValue.js +0 -24
  240. package/src/util/normalizeConfig.js +0 -335
  241. package/src/util/normalizeScreens.js +0 -140
  242. package/src/util/parseAnimationValue.js +0 -68
  243. package/src/util/parseBoxShadowValue.js +0 -72
  244. package/src/util/parseDependency.js +0 -44
  245. package/src/util/parseGlob.js +0 -24
  246. package/src/util/parseObjectStyles.js +0 -19
  247. package/src/util/pluginUtils.js +0 -291
  248. package/src/util/prefixSelector.js +0 -32
  249. package/src/util/pseudoElements.js +0 -170
  250. package/src/util/removeAlphaVariables.js +0 -24
  251. package/src/util/resolveConfig.js +0 -277
  252. package/src/util/resolveConfigPath.js +0 -66
  253. package/src/util/responsive.js +0 -10
  254. package/src/util/splitAtTopLevelOnly.js +0 -52
  255. package/src/util/tap.js +0 -4
  256. package/src/util/toColorValue.js +0 -3
  257. package/src/util/toPath.js +0 -26
  258. package/src/util/transformThemeValue.js +0 -62
  259. package/src/util/validateConfig.js +0 -33
  260. package/src/util/validateFormalSyntax.js +0 -34
  261. package/src/util/withAlphaVariable.js +0 -49
  262. package/src/value-parser/LICENSE +0 -22
  263. package/src/value-parser/README.md +0 -3
  264. package/src/value-parser/index.d.ts +0 -177
  265. package/src/value-parser/index.js +0 -28
  266. package/src/value-parser/parse.js +0 -303
  267. package/src/value-parser/stringify.js +0 -41
  268. package/src/value-parser/unit.js +0 -118
  269. package/src/value-parser/walk.js +0 -18
  270. package/stubs/.gitignore +0 -1
  271. package/stubs/.prettierrc.json +0 -6
  272. package/stubs/config.full.js +0 -991
  273. package/stubs/config.simple.js +0 -7
  274. package/stubs/postcss.config.cjs +0 -6
  275. package/stubs/postcss.config.js +0 -6
  276. package/stubs/tailwind.config.cjs +0 -2
  277. package/stubs/tailwind.config.js +0 -2
  278. package/stubs/tailwind.config.ts +0 -3
  279. package/tailwind.css +0 -5
  280. package/types/config.d.ts +0 -368
  281. package/types/generated/.gitkeep +0 -0
  282. package/types/generated/colors.d.ts +0 -298
  283. package/types/generated/corePluginList.d.ts +0 -1
  284. package/types/generated/default-theme.d.ts +0 -372
  285. package/types/index.d.ts +0 -7
  286. package/variants.css +0 -1
@@ -1,383 +0,0 @@
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
- const _validateConfig = require("../../util/validateConfig");
33
- function _interop_require_default(obj) {
34
- return obj && obj.__esModule ? obj : {
35
- default: obj
36
- };
37
- }
38
- /**
39
- *
40
- * @param {string} [customPostCssPath ]
41
- * @returns
42
- */ async function loadPostCssPlugins(customPostCssPath) {
43
- let config = customPostCssPath ? await (async ()=>{
44
- let file = _path.default.resolve(customPostCssPath);
45
- // Implementation, see: https://unpkg.com/browse/postcss-load-config@3.1.0/src/index.js
46
- // @ts-ignore
47
- let { config ={} } = await (0, _lilconfig.lilconfig)("postcss").load(file);
48
- if (typeof config === "function") {
49
- config = config();
50
- } else {
51
- config = Object.assign({}, config);
52
- }
53
- if (!config.plugins) {
54
- config.plugins = [];
55
- }
56
- return {
57
- file,
58
- plugins: (0, _plugins.default)(config, file),
59
- options: (0, _options.default)(config, file)
60
- };
61
- })() : await (0, _postcssloadconfig.default)();
62
- let configPlugins = config.plugins;
63
- let configPluginTailwindIdx = configPlugins.findIndex((plugin)=>{
64
- if (typeof plugin === "function" && plugin.name === "tailwindcss") {
65
- return true;
66
- }
67
- if (typeof plugin === "object" && plugin !== null && plugin.postcssPlugin === "tailwindcss") {
68
- return true;
69
- }
70
- return false;
71
- });
72
- let beforePlugins = configPluginTailwindIdx === -1 ? [] : configPlugins.slice(0, configPluginTailwindIdx);
73
- let afterPlugins = configPluginTailwindIdx === -1 ? configPlugins : configPlugins.slice(configPluginTailwindIdx + 1);
74
- return [
75
- beforePlugins,
76
- afterPlugins,
77
- config.options
78
- ];
79
- }
80
- function loadBuiltinPostcssPlugins() {
81
- let postcss = (0, _deps.loadPostcss)();
82
- let IMPORT_COMMENT = "__TAILWIND_RESTORE_IMPORT__: ";
83
- return [
84
- [
85
- (root)=>{
86
- root.walkAtRules("import", (rule)=>{
87
- if (rule.params.slice(1).startsWith("tailwindcss/")) {
88
- rule.after(postcss.comment({
89
- text: IMPORT_COMMENT + rule.params
90
- }));
91
- rule.remove();
92
- }
93
- });
94
- },
95
- (0, _deps.loadPostcssImport)(),
96
- (root)=>{
97
- root.walkComments((rule)=>{
98
- if (rule.text.startsWith(IMPORT_COMMENT)) {
99
- rule.after(postcss.atRule({
100
- name: "import",
101
- params: rule.text.replace(IMPORT_COMMENT, "")
102
- }));
103
- rule.remove();
104
- }
105
- });
106
- }
107
- ],
108
- [],
109
- {}
110
- ];
111
- }
112
- let state = {
113
- /** @type {any} */ context: null,
114
- /** @type {ReturnType<typeof createWatcher> | null} */ watcher: null,
115
- /** @type {{content: string, extension: string}[]} */ changedContent: [],
116
- /** @type {ReturnType<typeof load> | null} */ configBag: null,
117
- contextDependencies: new Set(),
118
- /** @type {import('../../lib/content.js').ContentPath[]} */ contentPaths: [],
119
- refreshContentPaths () {
120
- var _this_context;
121
- this.contentPaths = (0, _content.parseCandidateFiles)(this.context, (_this_context = this.context) === null || _this_context === void 0 ? void 0 : _this_context.tailwindConfig);
122
- },
123
- get config () {
124
- return this.context.tailwindConfig;
125
- },
126
- get contentPatterns () {
127
- return {
128
- all: this.contentPaths.map((contentPath)=>contentPath.pattern),
129
- dynamic: this.contentPaths.filter((contentPath)=>contentPath.glob !== undefined).map((contentPath)=>contentPath.pattern)
130
- };
131
- },
132
- loadConfig (configPath, content) {
133
- if (this.watcher && configPath) {
134
- this.refreshConfigDependencies();
135
- }
136
- let config = (0, _loadconfig.loadConfig)(configPath);
137
- let dependencies = (0, _getModuleDependencies.default)(configPath);
138
- this.configBag = {
139
- config,
140
- dependencies,
141
- dispose () {
142
- for (let file of dependencies){
143
- delete require.cache[require.resolve(file)];
144
- }
145
- }
146
- };
147
- // @ts-ignore
148
- if (true) {
149
- this.configBag.config = (0, _validateConfig.validateConfig)((0, _resolveConfig.default)(this.configBag.config));
150
- } else {
151
- this.configBag.config = (0, _validateConfig.validateConfig)((0, _resolveConfig.default)(this.configBag.config, {
152
- content: {
153
- files: []
154
- }
155
- }));
156
- }
157
- // Override content files if `--content` has been passed explicitly
158
- if ((content === null || content === void 0 ? void 0 : content.length) > 0) {
159
- this.configBag.config.content.files = content;
160
- }
161
- return this.configBag.config;
162
- },
163
- refreshConfigDependencies () {
164
- var _this_configBag;
165
- _sharedState.env.DEBUG && console.time("Module dependencies");
166
- (_this_configBag = this.configBag) === null || _this_configBag === void 0 ? void 0 : _this_configBag.dispose();
167
- _sharedState.env.DEBUG && console.timeEnd("Module dependencies");
168
- },
169
- readContentPaths () {
170
- let content = [];
171
- // Resolve globs from the content config
172
- // TODO: When we make the postcss plugin async-capable this can become async
173
- let files = _fastglob.default.sync(this.contentPatterns.all);
174
- for (let file of files){
175
- if (true) {
176
- content.push({
177
- file,
178
- extension: _path.default.extname(file).slice(1)
179
- });
180
- } else {
181
- content.push({
182
- content: _fs.default.readFileSync(_path.default.resolve(file), "utf8"),
183
- extension: _path.default.extname(file).slice(1)
184
- });
185
- }
186
- }
187
- // Resolve raw content in the tailwind config
188
- let rawContent = this.config.content.files.filter((file)=>{
189
- return file !== null && typeof file === "object";
190
- });
191
- for (let { raw: htmlContent , extension ="html" } of rawContent){
192
- content.push({
193
- content: htmlContent,
194
- extension
195
- });
196
- }
197
- return content;
198
- },
199
- getContext ({ createContext , cliConfigPath , root , result , content }) {
200
- if (this.context) {
201
- this.context.changedContent = this.changedContent.splice(0);
202
- return this.context;
203
- }
204
- _sharedState.env.DEBUG && console.time("Searching for config");
205
- var _findAtConfigPath1;
206
- let configPath = (_findAtConfigPath1 = (0, _findAtConfigPath.findAtConfigPath)(root, result)) !== null && _findAtConfigPath1 !== void 0 ? _findAtConfigPath1 : cliConfigPath;
207
- _sharedState.env.DEBUG && console.timeEnd("Searching for config");
208
- _sharedState.env.DEBUG && console.time("Loading config");
209
- let config = this.loadConfig(configPath, content);
210
- _sharedState.env.DEBUG && console.timeEnd("Loading config");
211
- _sharedState.env.DEBUG && console.time("Creating context");
212
- this.context = createContext(config, []);
213
- Object.assign(this.context, {
214
- userConfigPath: configPath
215
- });
216
- _sharedState.env.DEBUG && console.timeEnd("Creating context");
217
- _sharedState.env.DEBUG && console.time("Resolving content paths");
218
- this.refreshContentPaths();
219
- _sharedState.env.DEBUG && console.timeEnd("Resolving content paths");
220
- if (this.watcher) {
221
- _sharedState.env.DEBUG && console.time("Watch new files");
222
- this.watcher.refreshWatchedFiles();
223
- _sharedState.env.DEBUG && console.timeEnd("Watch new files");
224
- }
225
- for (let file of this.readContentPaths()){
226
- this.context.changedContent.push(file);
227
- }
228
- return this.context;
229
- }
230
- };
231
- async function createProcessor(args, cliConfigPath) {
232
- var _args_content;
233
- let postcss = (0, _deps.loadPostcss)();
234
- let input = args["--input"];
235
- let output = args["--output"];
236
- let includePostCss = args["--postcss"];
237
- let customPostCssPath = typeof args["--postcss"] === "string" ? args["--postcss"] : undefined;
238
- let [beforePlugins, afterPlugins, postcssOptions] = includePostCss ? await loadPostCssPlugins(customPostCssPath) : loadBuiltinPostcssPlugins();
239
- if (args["--purge"]) {
240
- _log.default.warn("purge-flag-deprecated", [
241
- "The `--purge` flag has been deprecated.",
242
- "Please use `--content` instead."
243
- ]);
244
- if (!args["--content"]) {
245
- args["--content"] = args["--purge"];
246
- }
247
- }
248
- var _args_content_split;
249
- 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 : [];
250
- let tailwindPlugin = ()=>{
251
- return {
252
- postcssPlugin: "tailwindcss",
253
- Once (root, { result }) {
254
- _sharedState.env.DEBUG && console.time("Compiling CSS");
255
- (0, _processTailwindFeatures.default)(({ createContext })=>{
256
- console.error();
257
- console.error("Rebuilding...");
258
- return ()=>{
259
- return state.getContext({
260
- createContext,
261
- cliConfigPath,
262
- root,
263
- result,
264
- content
265
- });
266
- };
267
- })(root, result);
268
- _sharedState.env.DEBUG && console.timeEnd("Compiling CSS");
269
- }
270
- };
271
- };
272
- tailwindPlugin.postcss = true;
273
- let plugins = [
274
- ...beforePlugins,
275
- tailwindPlugin,
276
- !args["--minify"] && _utils.formatNodes,
277
- ...afterPlugins,
278
- !args["--no-autoprefixer"] && (0, _deps.loadAutoprefixer)(),
279
- args["--minify"] && (0, _deps.loadCssNano)()
280
- ].filter(Boolean);
281
- /** @type {import('postcss').Processor} */ // @ts-ignore
282
- let processor = postcss(plugins);
283
- async function readInput() {
284
- // Piping in data, let's drain the stdin
285
- if (input === "-") {
286
- return (0, _utils.drainStdin)();
287
- }
288
- // Input file has been provided
289
- if (input) {
290
- return _fs.default.promises.readFile(_path.default.resolve(input), "utf8");
291
- }
292
- // No input file provided, fallback to default atrules
293
- return "@tailwind base; @tailwind components; @tailwind utilities";
294
- }
295
- async function build() {
296
- let start = process.hrtime.bigint();
297
- return readInput().then((css)=>processor.process(css, {
298
- ...postcssOptions,
299
- from: input,
300
- to: output
301
- })).then((result)=>{
302
- if (!state.watcher) {
303
- return result;
304
- }
305
- _sharedState.env.DEBUG && console.time("Recording PostCSS dependencies");
306
- for (let message of result.messages){
307
- if (message.type === "dependency") {
308
- state.contextDependencies.add(message.file);
309
- }
310
- }
311
- _sharedState.env.DEBUG && console.timeEnd("Recording PostCSS dependencies");
312
- // TODO: This needs to be in a different spot
313
- _sharedState.env.DEBUG && console.time("Watch new files");
314
- state.watcher.refreshWatchedFiles();
315
- _sharedState.env.DEBUG && console.timeEnd("Watch new files");
316
- return result;
317
- }).then((result)=>{
318
- if (!output) {
319
- process.stdout.write(result.css);
320
- return;
321
- }
322
- return Promise.all([
323
- (0, _utils.outputFile)(result.opts.to, result.css),
324
- result.map && (0, _utils.outputFile)(result.opts.to + ".map", result.map.toString())
325
- ]);
326
- }).then(()=>{
327
- let end = process.hrtime.bigint();
328
- console.error();
329
- console.error("Done in", (end - start) / BigInt(1e6) + "ms.");
330
- }).then(()=>{}, (err)=>{
331
- // TODO: If an initial build fails we can't easily pick up any PostCSS dependencies
332
- // that were collected before the error occurred
333
- // The result is not stored on the error so we have to store it externally
334
- // and pull the messages off of it here somehow
335
- // This results in a less than ideal DX because the watcher will not pick up
336
- // changes to imported CSS if one of them caused an error during the initial build
337
- // If you fix it and then save the main CSS file so there's no error
338
- // The watcher will start watching the imported CSS files and will be
339
- // resilient to future errors.
340
- if (state.watcher) {
341
- console.error(err);
342
- } else {
343
- return Promise.reject(err);
344
- }
345
- });
346
- }
347
- /**
348
- * @param {{file: string, content(): Promise<string>, extension: string}[]} changes
349
- */ async function parseChanges(changes) {
350
- return Promise.all(changes.map(async (change)=>({
351
- content: await change.content(),
352
- extension: change.extension
353
- })));
354
- }
355
- if (input !== undefined && input !== "-") {
356
- state.contextDependencies.add(_path.default.resolve(input));
357
- }
358
- return {
359
- build,
360
- watch: async ()=>{
361
- state.watcher = (0, _watching.createWatcher)(args, {
362
- state,
363
- /**
364
- * @param {{file: string, content(): Promise<string>, extension: string}[]} changes
365
- */ async rebuild (changes) {
366
- let needsNewContext = changes.some((change)=>{
367
- var _state_configBag;
368
- return ((_state_configBag = state.configBag) === null || _state_configBag === void 0 ? void 0 : _state_configBag.dependencies.has(change.file)) || state.contextDependencies.has(change.file);
369
- });
370
- if (needsNewContext) {
371
- state.context = null;
372
- } else {
373
- for (let change of (await parseChanges(changes))){
374
- state.changedContent.push(change);
375
- }
376
- }
377
- return build();
378
- }
379
- });
380
- await build();
381
- }
382
- };
383
- }
@@ -1,88 +0,0 @@
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
- }
@@ -1,182 +0,0 @@
1
- // @ts-check
2
- "use strict";
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- Object.defineProperty(exports, "createWatcher", {
7
- enumerable: true,
8
- get: function() {
9
- return createWatcher;
10
- }
11
- });
12
- const _chokidar = /*#__PURE__*/ _interop_require_default(require("chokidar"));
13
- const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
14
- const _micromatch = /*#__PURE__*/ _interop_require_default(require("micromatch"));
15
- const _normalizepath = /*#__PURE__*/ _interop_require_default(require("normalize-path"));
16
- const _path = /*#__PURE__*/ _interop_require_default(require("path"));
17
- const _utils = require("./utils.js");
18
- function _interop_require_default(obj) {
19
- return obj && obj.__esModule ? obj : {
20
- default: obj
21
- };
22
- }
23
- function createWatcher(args, { state , rebuild }) {
24
- let shouldPoll = args["--poll"];
25
- let shouldCoalesceWriteEvents = shouldPoll || process.platform === "win32";
26
- // Polling interval in milliseconds
27
- // Used only when polling or coalescing add/change events on Windows
28
- let pollInterval = 10;
29
- let watcher = _chokidar.default.watch([], {
30
- // Force checking for atomic writes in all situations
31
- // This causes chokidar to wait up to 100ms for a file to re-added after it's been unlinked
32
- // This only works when watching directories though
33
- atomic: true,
34
- usePolling: shouldPoll,
35
- interval: shouldPoll ? pollInterval : undefined,
36
- ignoreInitial: true,
37
- awaitWriteFinish: shouldCoalesceWriteEvents ? {
38
- stabilityThreshold: 50,
39
- pollInterval: pollInterval
40
- } : false
41
- });
42
- // A queue of rebuilds, file reads, etc… to run
43
- let chain = Promise.resolve();
44
- /**
45
- * A list of files that have been changed since the last rebuild
46
- *
47
- * @type {{file: string, content: () => Promise<string>, extension: string}[]}
48
- */ let changedContent = [];
49
- /**
50
- * A list of files for which a rebuild has already been queued.
51
- * This is used to prevent duplicate rebuilds when multiple events are fired for the same file.
52
- * The rebuilt file is cleared from this list when it's associated rebuild has _started_
53
- * This is because if the file is changed during a rebuild it won't trigger a new rebuild which it should
54
- **/ let pendingRebuilds = new Set();
55
- let _timer;
56
- let _reject;
57
- /**
58
- * Rebuilds the changed files and resolves when the rebuild is
59
- * complete regardless of whether it was successful or not
60
- */ async function rebuildAndContinue() {
61
- let changes = changedContent.splice(0);
62
- // There are no changes to rebuild so we can just do nothing
63
- if (changes.length === 0) {
64
- return Promise.resolve();
65
- }
66
- // Clear all pending rebuilds for the about-to-be-built files
67
- changes.forEach((change)=>pendingRebuilds.delete(change.file));
68
- // Resolve the promise even when the rebuild fails
69
- return rebuild(changes).then(()=>{}, (e)=>{
70
- console.error(e.toString());
71
- });
72
- }
73
- /**
74
- *
75
- * @param {*} file
76
- * @param {(() => Promise<string>) | null} content
77
- * @param {boolean} skipPendingCheck
78
- * @returns {Promise<void>}
79
- */ function recordChangedFile(file, content = null, skipPendingCheck = false) {
80
- file = _path.default.resolve(file);
81
- // Applications like Vim/Neovim fire both rename and change events in succession for atomic writes
82
- // In that case rebuild has already been queued by rename, so can be skipped in change
83
- if (pendingRebuilds.has(file) && !skipPendingCheck) {
84
- return Promise.resolve();
85
- }
86
- // Mark that a rebuild of this file is going to happen
87
- // It MUST happen synchronously before the rebuild is queued for this to be effective
88
- pendingRebuilds.add(file);
89
- changedContent.push({
90
- file,
91
- content: content !== null && content !== void 0 ? content : ()=>_fs.default.promises.readFile(file, "utf8"),
92
- extension: _path.default.extname(file).slice(1)
93
- });
94
- if (_timer) {
95
- clearTimeout(_timer);
96
- _reject();
97
- }
98
- // If a rebuild is already in progress we don't want to start another one until the 10ms timer has expired
99
- chain = chain.then(()=>new Promise((resolve, reject)=>{
100
- _timer = setTimeout(resolve, 10);
101
- _reject = reject;
102
- }));
103
- // Resolves once this file has been rebuilt (or the rebuild for this file has failed)
104
- // This queues as many rebuilds as there are changed files
105
- // But those rebuilds happen after some delay
106
- // And will immediately resolve if there are no changes
107
- chain = chain.then(rebuildAndContinue, rebuildAndContinue);
108
- return chain;
109
- }
110
- watcher.on("change", (file)=>recordChangedFile(file));
111
- watcher.on("add", (file)=>recordChangedFile(file));
112
- // Restore watching any files that are "removed"
113
- // This can happen when a file is pseudo-atomically replaced (a copy is created, overwritten, the old one is unlinked, and the new one is renamed)
114
- // TODO: An an optimization we should allow removal when the config changes
115
- watcher.on("unlink", (file)=>{
116
- file = (0, _normalizepath.default)(file);
117
- // Only re-add the file if it's not covered by a dynamic pattern
118
- if (!_micromatch.default.some([
119
- file
120
- ], state.contentPatterns.dynamic)) {
121
- watcher.add(file);
122
- }
123
- });
124
- // Some applications such as Visual Studio (but not VS Code)
125
- // will only fire a rename event for atomic writes and not a change event
126
- // This is very likely a chokidar bug but it's one we need to work around
127
- // We treat this as a change event and rebuild the CSS
128
- watcher.on("raw", (evt, filePath, meta)=>{
129
- if (evt !== "rename") {
130
- return;
131
- }
132
- let watchedPath = meta.watchedPath;
133
- // Watched path might be the file itself
134
- // Or the directory it is in
135
- filePath = watchedPath.endsWith(filePath) ? watchedPath : _path.default.join(watchedPath, filePath);
136
- // Skip this event since the files it is for does not match any of the registered content globs
137
- if (!_micromatch.default.some([
138
- filePath
139
- ], state.contentPatterns.all)) {
140
- return;
141
- }
142
- // Skip since we've already queued a rebuild for this file that hasn't happened yet
143
- if (pendingRebuilds.has(filePath)) {
144
- return;
145
- }
146
- // We'll go ahead and add the file to the pending rebuilds list here
147
- // It'll be removed when the rebuild starts unless the read fails
148
- // which will be taken care of as well
149
- pendingRebuilds.add(filePath);
150
- async function enqueue() {
151
- try {
152
- // We need to read the file as early as possible outside of the chain
153
- // because it may be gone by the time we get to it. doing the read
154
- // immediately increases the chance that the file is still there
155
- let content = await (0, _utils.readFileWithRetries)(_path.default.resolve(filePath));
156
- if (content === undefined) {
157
- return;
158
- }
159
- // This will push the rebuild onto the chain
160
- // We MUST skip the rebuild check here otherwise the rebuild will never happen on Linux
161
- // This is because the order of events and timing is different on Linux
162
- // @ts-ignore: TypeScript isn't picking up that content is a string here
163
- await recordChangedFile(filePath, ()=>content, true);
164
- } catch {
165
- // If reading the file fails, it's was probably a deleted temporary file
166
- // So we can ignore it and no rebuild is needed
167
- }
168
- }
169
- enqueue().then(()=>{
170
- // If the file read fails we still need to make sure the file isn't stuck in the pending rebuilds list
171
- pendingRebuilds.delete(filePath);
172
- });
173
- });
174
- return {
175
- fswatcher: watcher,
176
- refreshWatchedFiles () {
177
- watcher.add(Array.from(state.contextDependencies));
178
- watcher.add(Array.from(state.configBag.dependencies));
179
- watcher.add(state.contentPatterns.all);
180
- }
181
- };
182
- }