tailwindcss 0.0.0-insiders.eebf529 → 0.0.0-insiders.ef2ebb2
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.
- package/LICENSE +1 -2
- package/README.md +15 -7
- package/colors.d.ts +3 -0
- package/defaultConfig.d.ts +3 -0
- package/defaultTheme.d.ts +4 -0
- package/index.css +5 -0
- package/lib/cli/build/index.js +57 -0
- package/lib/cli/build/plugin.js +433 -0
- package/lib/cli/build/utils.js +88 -0
- package/lib/cli/build/watching.js +182 -0
- package/lib/cli/help/index.js +73 -0
- package/lib/cli/index.js +231 -0
- package/lib/cli/init/index.js +63 -0
- package/lib/cli.js +1 -704
- package/lib/corePluginList.js +13 -3
- package/lib/corePlugins.js +2399 -1867
- package/lib/css/preflight.css +17 -9
- package/lib/featureFlags.js +50 -26
- package/lib/index.js +1 -31
- package/lib/lib/cacheInvalidation.js +92 -0
- package/lib/lib/collapseAdjacentRules.js +30 -10
- package/lib/lib/collapseDuplicateDeclarations.js +60 -4
- package/lib/lib/content.js +207 -0
- package/lib/lib/defaultExtractor.js +243 -0
- package/lib/lib/detectNesting.js +21 -10
- package/lib/lib/evaluateTailwindFunctions.js +117 -50
- package/lib/lib/expandApplyAtRules.js +467 -161
- package/lib/lib/expandTailwindAtRules.js +200 -133
- package/lib/lib/findAtConfigPath.js +46 -0
- package/lib/lib/generateRules.js +550 -200
- package/lib/lib/getModuleDependencies.js +88 -37
- package/lib/lib/handleImportAtRules.js +50 -0
- package/lib/lib/load-config.js +42 -0
- package/lib/lib/normalizeTailwindDirectives.js +36 -38
- package/lib/lib/offsets.js +306 -0
- package/lib/lib/partitionApplyAtRules.js +58 -0
- package/lib/lib/regex.js +74 -0
- package/lib/lib/remap-bitfield.js +89 -0
- package/lib/lib/resolveDefaultsAtRules.js +98 -58
- package/lib/lib/setupContextUtils.js +767 -325
- package/lib/lib/setupTrackingContext.js +71 -75
- package/lib/lib/sharedState.js +70 -10
- package/lib/lib/substituteScreenAtRules.js +14 -10
- package/lib/plugin.js +166 -0
- package/{nesting → lib/postcss-plugins/nesting}/README.md +2 -2
- package/lib/postcss-plugins/nesting/index.js +21 -0
- package/lib/postcss-plugins/nesting/plugin.js +89 -0
- package/lib/processTailwindFeatures.js +39 -26
- package/lib/public/colors.js +272 -246
- package/lib/public/create-plugin.js +9 -5
- package/lib/public/default-config.js +10 -6
- package/lib/public/default-theme.js +10 -6
- package/lib/public/load-config.js +12 -0
- package/lib/public/resolve-config.js +11 -6
- package/lib/util/applyImportantSelector.js +36 -0
- package/lib/util/bigSign.js +6 -1
- package/lib/util/buildMediaQuery.js +13 -6
- package/lib/util/cloneDeep.js +9 -6
- package/lib/util/cloneNodes.js +23 -3
- package/lib/util/color.js +70 -38
- package/lib/util/colorNames.js +752 -0
- package/lib/util/configurePlugins.js +7 -2
- package/lib/util/createPlugin.js +8 -6
- package/lib/util/createUtilityPlugin.js +16 -16
- package/lib/util/dataTypes.js +182 -111
- package/lib/util/defaults.js +14 -3
- package/lib/util/escapeClassName.js +13 -8
- package/lib/util/escapeCommas.js +7 -2
- package/lib/util/flattenColorPalette.js +11 -12
- package/lib/util/formatVariantSelector.js +228 -151
- package/lib/util/getAllConfigs.js +33 -12
- package/lib/util/hashConfig.js +9 -4
- package/lib/util/isKeyframeRule.js +7 -2
- package/lib/util/isPlainObject.js +7 -2
- package/lib/util/{isValidArbitraryValue.js → isSyntacticallyValidPropertyValue.js} +25 -15
- package/lib/util/log.js +44 -13
- package/lib/util/nameClass.js +27 -10
- package/lib/util/negateValue.js +25 -8
- package/lib/util/normalizeConfig.js +167 -67
- package/lib/util/normalizeScreens.js +128 -11
- package/lib/util/parseAnimationValue.js +44 -40
- package/lib/util/parseBoxShadowValue.js +34 -23
- package/lib/util/parseDependency.js +39 -55
- package/lib/util/parseGlob.js +36 -0
- package/lib/util/parseObjectStyles.js +15 -10
- package/lib/util/pluginUtils.js +157 -69
- package/lib/util/prefixSelector.js +30 -12
- package/lib/util/pseudoElements.js +209 -0
- package/lib/util/removeAlphaVariables.js +31 -0
- package/lib/util/resolveConfig.js +101 -79
- package/lib/util/resolveConfigPath.js +30 -12
- package/lib/util/responsive.js +11 -6
- package/lib/util/splitAtTopLevelOnly.js +51 -0
- package/lib/util/tap.js +6 -1
- package/lib/util/toColorValue.js +7 -3
- package/lib/util/toPath.js +26 -3
- package/lib/util/transformThemeValue.js +40 -30
- package/lib/util/validateConfig.js +48 -0
- package/lib/util/validateFormalSyntax.js +26 -0
- package/lib/util/withAlphaVariable.js +27 -15
- package/lib/value-parser/LICENSE +22 -0
- package/lib/value-parser/README.md +3 -0
- package/lib/value-parser/index.d.js +2 -0
- package/lib/value-parser/index.js +22 -0
- package/lib/value-parser/parse.js +259 -0
- package/lib/value-parser/stringify.js +38 -0
- package/lib/value-parser/unit.js +86 -0
- package/lib/value-parser/walk.js +16 -0
- package/loadConfig.d.ts +4 -0
- package/loadConfig.js +2 -0
- package/nesting/index.js +2 -12
- package/package.json +63 -62
- package/plugin.d.ts +11 -0
- package/resolveConfig.d.ts +12 -0
- package/scripts/generate-types.js +105 -0
- package/scripts/release-channel.js +18 -0
- package/scripts/release-notes.js +21 -0
- package/scripts/type-utils.js +27 -0
- package/src/cli/build/index.js +53 -0
- package/src/cli/build/plugin.js +476 -0
- package/src/cli/build/utils.js +76 -0
- package/src/cli/build/watching.js +229 -0
- package/src/cli/help/index.js +70 -0
- package/src/cli/index.js +217 -0
- package/src/cli/init/index.js +79 -0
- package/src/cli.js +1 -766
- package/src/corePluginList.js +1 -1
- package/src/corePlugins.js +800 -296
- package/src/css/preflight.css +17 -9
- package/src/featureFlags.js +20 -6
- package/src/index.js +1 -34
- package/src/lib/cacheInvalidation.js +52 -0
- package/src/lib/collapseAdjacentRules.js +21 -2
- package/src/lib/collapseDuplicateDeclarations.js +66 -1
- package/src/lib/content.js +240 -0
- package/src/lib/defaultExtractor.js +217 -0
- package/src/lib/detectNesting.js +9 -1
- package/src/lib/evaluateTailwindFunctions.js +83 -9
- package/src/lib/expandApplyAtRules.js +515 -153
- package/src/lib/expandTailwindAtRules.js +147 -86
- package/src/lib/findAtConfigPath.js +48 -0
- package/src/lib/generateRules.js +541 -147
- package/src/lib/getModuleDependencies.js +70 -30
- package/src/lib/handleImportAtRules.js +34 -0
- package/src/lib/load-config.ts +31 -0
- package/src/lib/normalizeTailwindDirectives.js +5 -26
- package/src/lib/offsets.js +373 -0
- package/src/lib/partitionApplyAtRules.js +52 -0
- package/src/lib/regex.js +74 -0
- package/src/lib/remap-bitfield.js +82 -0
- package/src/lib/resolveDefaultsAtRules.js +59 -17
- package/src/lib/setupContextUtils.js +693 -176
- package/src/lib/setupTrackingContext.js +52 -65
- package/src/lib/sharedState.js +54 -7
- package/src/plugin.js +141 -0
- package/src/postcss-plugins/nesting/README.md +42 -0
- package/src/postcss-plugins/nesting/index.js +13 -0
- package/src/postcss-plugins/nesting/plugin.js +80 -0
- package/src/processTailwindFeatures.js +12 -2
- package/src/public/colors.js +22 -0
- package/src/public/default-config.js +1 -1
- package/src/public/default-theme.js +2 -2
- package/src/public/load-config.js +2 -0
- package/src/util/applyImportantSelector.js +27 -0
- package/src/util/buildMediaQuery.js +5 -3
- package/src/util/cloneNodes.js +19 -2
- package/src/util/color.js +44 -12
- package/src/util/colorNames.js +150 -0
- package/src/util/dataTypes.js +67 -23
- package/src/util/defaults.js +6 -0
- package/src/util/formatVariantSelector.js +264 -144
- package/src/util/getAllConfigs.js +21 -2
- package/src/util/{isValidArbitraryValue.js → isSyntacticallyValidPropertyValue.js} +1 -1
- package/src/util/log.js +35 -7
- package/src/util/nameClass.js +4 -0
- package/src/util/negateValue.js +11 -3
- package/src/util/normalizeConfig.js +86 -7
- package/src/util/normalizeScreens.js +99 -4
- package/src/util/parseBoxShadowValue.js +4 -3
- package/src/util/parseDependency.js +37 -42
- package/src/util/parseGlob.js +24 -0
- package/src/util/pluginUtils.js +118 -23
- package/src/util/prefixSelector.js +30 -10
- package/src/util/pseudoElements.js +167 -0
- package/src/util/removeAlphaVariables.js +24 -0
- package/src/util/resolveConfig.js +74 -26
- package/src/util/resolveConfigPath.js +12 -1
- package/src/util/splitAtTopLevelOnly.js +52 -0
- package/src/util/toPath.js +23 -1
- package/src/util/transformThemeValue.js +13 -3
- package/src/util/validateConfig.js +36 -0
- package/src/util/validateFormalSyntax.js +34 -0
- package/src/util/withAlphaVariable.js +1 -1
- package/src/value-parser/LICENSE +22 -0
- package/src/value-parser/README.md +3 -0
- package/src/value-parser/index.d.ts +177 -0
- package/src/value-parser/index.js +28 -0
- package/src/value-parser/parse.js +303 -0
- package/src/value-parser/stringify.js +41 -0
- package/src/value-parser/unit.js +118 -0
- package/src/value-parser/walk.js +18 -0
- package/stubs/.gitignore +1 -0
- package/stubs/.prettierrc.json +6 -0
- package/stubs/{defaultConfig.stub.js → config.full.js} +220 -167
- package/stubs/{simpleConfig.stub.js → config.simple.js} +1 -1
- package/stubs/{defaultPostCssConfig.stub.js → postcss.config.cjs} +0 -1
- package/stubs/postcss.config.js +5 -0
- package/stubs/tailwind.config.cjs +2 -0
- package/stubs/tailwind.config.js +2 -0
- package/stubs/tailwind.config.ts +3 -0
- package/types/config.d.ts +369 -0
- package/types/generated/.gitkeep +0 -0
- package/types/generated/colors.d.ts +298 -0
- package/types/generated/corePluginList.d.ts +1 -0
- package/types/generated/default-theme.d.ts +372 -0
- package/types/index.d.ts +7 -0
- package/CHANGELOG.md +0 -1853
- package/lib/cli-peer-dependencies.js +0 -15
- package/lib/constants.js +0 -37
- package/lib/lib/setupWatchingContext.js +0 -288
- package/nesting/plugin.js +0 -41
- package/peers/index.js +0 -76107
- package/scripts/install-integrations.js +0 -27
- package/scripts/rebuildFixtures.js +0 -68
- package/src/cli-peer-dependencies.js +0 -9
- package/src/constants.js +0 -17
- package/src/lib/setupWatchingContext.js +0 -311
package/LICENSE
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
MIT License
|
|
2
2
|
|
|
3
|
-
Copyright (c)
|
|
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,12 +1,20 @@
|
|
|
1
|
-
<p>
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
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
|
-
|
|
11
|
+
<p align="center">
|
|
12
|
+
A utility-first CSS framework for rapidly building custom user interfaces.
|
|
13
|
+
</p>
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
<p align="center">
|
|
17
|
+
<a href="https://github.com/tailwindlabs/tailwindcss/actions"><img src="https://img.shields.io/github/actions/workflow/status/tailwindlabs/tailwindcss/ci.yml?branch=master" alt="Build Status"></a>
|
|
10
18
|
<a href="https://www.npmjs.com/package/tailwindcss"><img src="https://img.shields.io/npm/dt/tailwindcss.svg" alt="Total Downloads"></a>
|
|
11
19
|
<a href="https://github.com/tailwindcss/tailwindcss/releases"><img src="https://img.shields.io/npm/v/tailwindcss.svg" alt="Latest Release"></a>
|
|
12
20
|
<a href="https://github.com/tailwindcss/tailwindcss/blob/master/LICENSE"><img src="https://img.shields.io/npm/l/tailwindcss.svg" alt="License"></a>
|
package/colors.d.ts
ADDED
package/index.css
ADDED
|
@@ -0,0 +1,57 @@
|
|
|
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
|
+
if (args["--no-autoprefixer"]) {
|
|
38
|
+
console.error("[deprecation] The --no-autoprefixer flag is deprecated and has no effect.");
|
|
39
|
+
}
|
|
40
|
+
// TODO: Reference the @config path here if exists
|
|
41
|
+
let configPath = args["--config"] ? args["--config"] : (0, _resolveConfigPath.resolveDefaultConfigPath)();
|
|
42
|
+
let processor = await (0, _plugin.createProcessor)(args, configPath);
|
|
43
|
+
if (shouldWatch) {
|
|
44
|
+
// Abort the watcher if stdin is closed to avoid zombie processes
|
|
45
|
+
// You can disable this behavior with --watch=always
|
|
46
|
+
if (args["--watch"] !== "always") {
|
|
47
|
+
process.stdin.on("end", ()=>process.exit(0));
|
|
48
|
+
}
|
|
49
|
+
process.stdin.resume();
|
|
50
|
+
await processor.watch();
|
|
51
|
+
} else {
|
|
52
|
+
await processor.build().catch((e)=>{
|
|
53
|
+
console.error(e);
|
|
54
|
+
process.exit(1);
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
@@ -0,0 +1,433 @@
|
|
|
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 _packagejson = /*#__PURE__*/ _interop_require_default(require("../../../package.json"));
|
|
13
|
+
const _path = /*#__PURE__*/ _interop_require_default(require("path"));
|
|
14
|
+
const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
|
|
15
|
+
const _postcss = /*#__PURE__*/ _interop_require_default(require("postcss"));
|
|
16
|
+
const _postcssloadconfig = /*#__PURE__*/ _interop_require_default(require("postcss-load-config"));
|
|
17
|
+
const _browserslist = /*#__PURE__*/ _interop_require_default(require("browserslist"));
|
|
18
|
+
const _lightningcss = /*#__PURE__*/ _interop_require_wildcard(require("lightningcss"));
|
|
19
|
+
const _lilconfig = require("lilconfig");
|
|
20
|
+
const _plugins = /*#__PURE__*/ _interop_require_default(require("postcss-load-config/src/plugins" // Little bit scary, looking at private/internal API
|
|
21
|
+
));
|
|
22
|
+
const _options = /*#__PURE__*/ _interop_require_default(require("postcss-load-config/src/options" // Little bit scary, looking at private/internal API
|
|
23
|
+
));
|
|
24
|
+
const _processTailwindFeatures = /*#__PURE__*/ _interop_require_default(require("../../processTailwindFeatures"));
|
|
25
|
+
const _utils = require("./utils");
|
|
26
|
+
const _sharedState = require("../../lib/sharedState");
|
|
27
|
+
const _resolveConfig = /*#__PURE__*/ _interop_require_default(require("../../../resolveConfig.js"));
|
|
28
|
+
const _content = require("../../lib/content.js");
|
|
29
|
+
const _watching = require("./watching.js");
|
|
30
|
+
const _fastglob = /*#__PURE__*/ _interop_require_default(require("fast-glob"));
|
|
31
|
+
const _findAtConfigPath = require("../../lib/findAtConfigPath.js");
|
|
32
|
+
const _log = /*#__PURE__*/ _interop_require_default(require("../../util/log"));
|
|
33
|
+
const _loadconfig = require("../../lib/load-config");
|
|
34
|
+
const _getModuleDependencies = /*#__PURE__*/ _interop_require_default(require("../../lib/getModuleDependencies"));
|
|
35
|
+
const _validateConfig = require("../../util/validateConfig");
|
|
36
|
+
const _handleImportAtRules = require("../../lib/handleImportAtRules");
|
|
37
|
+
const _featureFlags = require("../../featureFlags");
|
|
38
|
+
function _interop_require_default(obj) {
|
|
39
|
+
return obj && obj.__esModule ? obj : {
|
|
40
|
+
default: obj
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
function _getRequireWildcardCache(nodeInterop) {
|
|
44
|
+
if (typeof WeakMap !== "function") return null;
|
|
45
|
+
var cacheBabelInterop = new WeakMap();
|
|
46
|
+
var cacheNodeInterop = new WeakMap();
|
|
47
|
+
return (_getRequireWildcardCache = function(nodeInterop) {
|
|
48
|
+
return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
|
|
49
|
+
})(nodeInterop);
|
|
50
|
+
}
|
|
51
|
+
function _interop_require_wildcard(obj, nodeInterop) {
|
|
52
|
+
if (!nodeInterop && obj && obj.__esModule) {
|
|
53
|
+
return obj;
|
|
54
|
+
}
|
|
55
|
+
if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
|
|
56
|
+
return {
|
|
57
|
+
default: obj
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
var cache = _getRequireWildcardCache(nodeInterop);
|
|
61
|
+
if (cache && cache.has(obj)) {
|
|
62
|
+
return cache.get(obj);
|
|
63
|
+
}
|
|
64
|
+
var newObj = {};
|
|
65
|
+
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
|
|
66
|
+
for(var key in obj){
|
|
67
|
+
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
68
|
+
var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
|
|
69
|
+
if (desc && (desc.get || desc.set)) {
|
|
70
|
+
Object.defineProperty(newObj, key, desc);
|
|
71
|
+
} else {
|
|
72
|
+
newObj[key] = obj[key];
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
newObj.default = obj;
|
|
77
|
+
if (cache) {
|
|
78
|
+
cache.set(obj, newObj);
|
|
79
|
+
}
|
|
80
|
+
return newObj;
|
|
81
|
+
}
|
|
82
|
+
async function lightningcss(result, { map =true , minify =true } = {}) {
|
|
83
|
+
try {
|
|
84
|
+
var _browserslist_findConfig;
|
|
85
|
+
let includeFeatures = _lightningcss.Features.Nesting;
|
|
86
|
+
let excludeFeatures = 0;
|
|
87
|
+
var _result_opts_from;
|
|
88
|
+
let resolvedBrowsersListConfig = (_browserslist_findConfig = _browserslist.default.findConfig((_result_opts_from = result.opts.from) !== null && _result_opts_from !== void 0 ? _result_opts_from : process.cwd())) === null || _browserslist_findConfig === void 0 ? void 0 : _browserslist_findConfig.defaults;
|
|
89
|
+
let defaultBrowsersListConfig = _packagejson.default.browserslist;
|
|
90
|
+
let browsersListConfig = resolvedBrowsersListConfig !== null && resolvedBrowsersListConfig !== void 0 ? resolvedBrowsersListConfig : defaultBrowsersListConfig;
|
|
91
|
+
if (browsersListConfig.join(",") === defaultBrowsersListConfig.join(",")) {
|
|
92
|
+
includeFeatures |= _lightningcss.Features.ColorFunction | _lightningcss.Features.OklabColors | _lightningcss.Features.LabColors | _lightningcss.Features.P3Colors;
|
|
93
|
+
excludeFeatures |= _lightningcss.Features.HexAlphaColors | _lightningcss.Features.LogicalProperties | _lightningcss.Features.SpaceSeparatedColorNotation;
|
|
94
|
+
}
|
|
95
|
+
let transformed = _lightningcss.default.transform({
|
|
96
|
+
filename: result.opts.from || "input.css",
|
|
97
|
+
code: Buffer.from(result.css, "utf-8"),
|
|
98
|
+
minify,
|
|
99
|
+
sourceMap: result.map === undefined ? map : !!result.map,
|
|
100
|
+
inputSourceMap: result.map ? result.map.toString() : undefined,
|
|
101
|
+
targets: _lightningcss.default.browserslistToTargets((0, _browserslist.default)(browsersListConfig)),
|
|
102
|
+
drafts: {
|
|
103
|
+
nesting: true
|
|
104
|
+
},
|
|
105
|
+
include: includeFeatures,
|
|
106
|
+
exclude: excludeFeatures
|
|
107
|
+
});
|
|
108
|
+
return Object.assign(result, {
|
|
109
|
+
css: transformed.code.toString("utf8"),
|
|
110
|
+
map: result.map ? Object.assign(result.map, {
|
|
111
|
+
toString () {
|
|
112
|
+
var _transformed_map;
|
|
113
|
+
return (_transformed_map = transformed.map) === null || _transformed_map === void 0 ? void 0 : _transformed_map.toString();
|
|
114
|
+
}
|
|
115
|
+
}) : result.map
|
|
116
|
+
});
|
|
117
|
+
} catch (err) {
|
|
118
|
+
console.error("Unable to use Lightning CSS. Using raw version instead.");
|
|
119
|
+
console.error(err);
|
|
120
|
+
return result;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
*
|
|
125
|
+
* @param {string} [customPostCssPath ]
|
|
126
|
+
* @returns
|
|
127
|
+
*/ async function loadPostCssPlugins(customPostCssPath) {
|
|
128
|
+
let config = customPostCssPath ? await (async ()=>{
|
|
129
|
+
let file = _path.default.resolve(customPostCssPath);
|
|
130
|
+
// Implementation, see: https://unpkg.com/browse/postcss-load-config@3.1.0/src/index.js
|
|
131
|
+
// @ts-ignore
|
|
132
|
+
let { config ={} } = await (0, _lilconfig.lilconfig)("postcss").load(file);
|
|
133
|
+
if (typeof config === "function") {
|
|
134
|
+
config = config();
|
|
135
|
+
} else {
|
|
136
|
+
config = Object.assign({}, config);
|
|
137
|
+
}
|
|
138
|
+
if (!config.plugins) {
|
|
139
|
+
config.plugins = [];
|
|
140
|
+
}
|
|
141
|
+
return {
|
|
142
|
+
file,
|
|
143
|
+
plugins: (0, _plugins.default)(config, file),
|
|
144
|
+
options: (0, _options.default)(config, file)
|
|
145
|
+
};
|
|
146
|
+
})() : await (0, _postcssloadconfig.default)();
|
|
147
|
+
let configPlugins = config.plugins;
|
|
148
|
+
let configPluginTailwindIdx = configPlugins.findIndex((plugin)=>{
|
|
149
|
+
if (typeof plugin === "function" && plugin.name === "tailwindcss") {
|
|
150
|
+
return true;
|
|
151
|
+
}
|
|
152
|
+
if (typeof plugin === "object" && plugin !== null && plugin.postcssPlugin === "tailwindcss") {
|
|
153
|
+
return true;
|
|
154
|
+
}
|
|
155
|
+
return false;
|
|
156
|
+
});
|
|
157
|
+
let beforePlugins = configPluginTailwindIdx === -1 ? [] : configPlugins.slice(0, configPluginTailwindIdx);
|
|
158
|
+
let afterPlugins = configPluginTailwindIdx === -1 ? configPlugins : configPlugins.slice(configPluginTailwindIdx + 1);
|
|
159
|
+
return [
|
|
160
|
+
beforePlugins,
|
|
161
|
+
afterPlugins,
|
|
162
|
+
config.options
|
|
163
|
+
];
|
|
164
|
+
}
|
|
165
|
+
let state = {
|
|
166
|
+
/** @type {any} */ context: null,
|
|
167
|
+
/** @type {ReturnType<typeof createWatcher> | null} */ watcher: null,
|
|
168
|
+
/** @type {{content: string, extension: string}[]} */ changedContent: [],
|
|
169
|
+
/** @type {{config: import('../../../types').Config, dependencies: Set<string>, dispose: Function } | null} */ configBag: null,
|
|
170
|
+
contextDependencies: new Set(),
|
|
171
|
+
/** @type {import('../../lib/content.js').ContentPath[]} */ contentPaths: [],
|
|
172
|
+
refreshContentPaths () {
|
|
173
|
+
var _this_context;
|
|
174
|
+
this.contentPaths = (0, _content.parseCandidateFiles)(this.context, (_this_context = this.context) === null || _this_context === void 0 ? void 0 : _this_context.tailwindConfig);
|
|
175
|
+
},
|
|
176
|
+
get config () {
|
|
177
|
+
return this.context.tailwindConfig;
|
|
178
|
+
},
|
|
179
|
+
get contentPatterns () {
|
|
180
|
+
return {
|
|
181
|
+
all: this.contentPaths.map((contentPath)=>contentPath.pattern),
|
|
182
|
+
dynamic: this.contentPaths.filter((contentPath)=>contentPath.glob !== undefined).map((contentPath)=>contentPath.pattern)
|
|
183
|
+
};
|
|
184
|
+
},
|
|
185
|
+
loadConfig (configPath, content) {
|
|
186
|
+
if (this.watcher && configPath) {
|
|
187
|
+
this.refreshConfigDependencies();
|
|
188
|
+
}
|
|
189
|
+
let config = (0, _loadconfig.loadConfig)(configPath);
|
|
190
|
+
let dependencies = (0, _getModuleDependencies.default)(configPath);
|
|
191
|
+
this.configBag = {
|
|
192
|
+
config,
|
|
193
|
+
dependencies,
|
|
194
|
+
dispose () {
|
|
195
|
+
for (let file of dependencies){
|
|
196
|
+
delete require.cache[require.resolve(file)];
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
};
|
|
200
|
+
this.configBag.config = (0, _validateConfig.validateConfig)((0, _resolveConfig.default)(this.configBag.config));
|
|
201
|
+
// Override content files if `--content` has been passed explicitly
|
|
202
|
+
if ((content === null || content === void 0 ? void 0 : content.length) > 0) {
|
|
203
|
+
this.configBag.config.content.files = content;
|
|
204
|
+
}
|
|
205
|
+
return this.configBag.config;
|
|
206
|
+
},
|
|
207
|
+
refreshConfigDependencies () {
|
|
208
|
+
var _this_configBag;
|
|
209
|
+
_sharedState.env.DEBUG && console.time("Module dependencies");
|
|
210
|
+
(_this_configBag = this.configBag) === null || _this_configBag === void 0 ? void 0 : _this_configBag.dispose();
|
|
211
|
+
_sharedState.env.DEBUG && console.timeEnd("Module dependencies");
|
|
212
|
+
},
|
|
213
|
+
readContentPaths () {
|
|
214
|
+
let content = [];
|
|
215
|
+
// Resolve globs from the content config
|
|
216
|
+
// TODO: When we make the postcss plugin async-capable this can become async
|
|
217
|
+
let files = _fastglob.default.sync(this.contentPatterns.all);
|
|
218
|
+
for (let file of files){
|
|
219
|
+
if ((0, _featureFlags.flagEnabled)(this.config, "oxideParser")) {
|
|
220
|
+
content.push({
|
|
221
|
+
file,
|
|
222
|
+
extension: _path.default.extname(file).slice(1)
|
|
223
|
+
});
|
|
224
|
+
} else {
|
|
225
|
+
content.push({
|
|
226
|
+
content: _fs.default.readFileSync(_path.default.resolve(file), "utf8"),
|
|
227
|
+
extension: _path.default.extname(file).slice(1)
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
// Resolve raw content in the tailwind config
|
|
232
|
+
let rawContent = this.config.content.files.filter((file)=>{
|
|
233
|
+
return file !== null && typeof file === "object";
|
|
234
|
+
});
|
|
235
|
+
for (let { raw: htmlContent , extension ="html" } of rawContent){
|
|
236
|
+
content.push({
|
|
237
|
+
content: htmlContent,
|
|
238
|
+
extension
|
|
239
|
+
});
|
|
240
|
+
}
|
|
241
|
+
return content;
|
|
242
|
+
},
|
|
243
|
+
getContext ({ createContext , cliConfigPath , root , result , content }) {
|
|
244
|
+
if (this.context) {
|
|
245
|
+
this.context.changedContent = this.changedContent.splice(0);
|
|
246
|
+
return this.context;
|
|
247
|
+
}
|
|
248
|
+
_sharedState.env.DEBUG && console.time("Searching for config");
|
|
249
|
+
var _findAtConfigPath1;
|
|
250
|
+
let configPath = (_findAtConfigPath1 = (0, _findAtConfigPath.findAtConfigPath)(root, result)) !== null && _findAtConfigPath1 !== void 0 ? _findAtConfigPath1 : cliConfigPath;
|
|
251
|
+
_sharedState.env.DEBUG && console.timeEnd("Searching for config");
|
|
252
|
+
_sharedState.env.DEBUG && console.time("Loading config");
|
|
253
|
+
let config = this.loadConfig(configPath, content);
|
|
254
|
+
_sharedState.env.DEBUG && console.timeEnd("Loading config");
|
|
255
|
+
_sharedState.env.DEBUG && console.time("Creating context");
|
|
256
|
+
this.context = createContext(config, []);
|
|
257
|
+
Object.assign(this.context, {
|
|
258
|
+
userConfigPath: configPath
|
|
259
|
+
});
|
|
260
|
+
_sharedState.env.DEBUG && console.timeEnd("Creating context");
|
|
261
|
+
_sharedState.env.DEBUG && console.time("Resolving content paths");
|
|
262
|
+
this.refreshContentPaths();
|
|
263
|
+
_sharedState.env.DEBUG && console.timeEnd("Resolving content paths");
|
|
264
|
+
if (this.watcher) {
|
|
265
|
+
_sharedState.env.DEBUG && console.time("Watch new files");
|
|
266
|
+
this.watcher.refreshWatchedFiles();
|
|
267
|
+
_sharedState.env.DEBUG && console.timeEnd("Watch new files");
|
|
268
|
+
}
|
|
269
|
+
for (let file of this.readContentPaths()){
|
|
270
|
+
this.context.changedContent.push(file);
|
|
271
|
+
}
|
|
272
|
+
return this.context;
|
|
273
|
+
}
|
|
274
|
+
};
|
|
275
|
+
async function createProcessor(args, cliConfigPath) {
|
|
276
|
+
var _args_content;
|
|
277
|
+
let input = args["--input"];
|
|
278
|
+
let output = args["--output"];
|
|
279
|
+
let includePostCss = args["--postcss"];
|
|
280
|
+
let customPostCssPath = typeof args["--postcss"] === "string" ? args["--postcss"] : undefined;
|
|
281
|
+
let [beforePlugins, afterPlugins, postcssOptions] = includePostCss ? await loadPostCssPlugins(customPostCssPath) : [
|
|
282
|
+
[],
|
|
283
|
+
[],
|
|
284
|
+
{}
|
|
285
|
+
];
|
|
286
|
+
beforePlugins.unshift(...(0, _handleImportAtRules.handleImportAtRules)());
|
|
287
|
+
if (args["--purge"]) {
|
|
288
|
+
_log.default.warn("purge-flag-deprecated", [
|
|
289
|
+
"The `--purge` flag has been deprecated.",
|
|
290
|
+
"Please use `--content` instead."
|
|
291
|
+
]);
|
|
292
|
+
if (!args["--content"]) {
|
|
293
|
+
args["--content"] = args["--purge"];
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
var _args_content_split;
|
|
297
|
+
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 : [];
|
|
298
|
+
let tailwindPlugin = ()=>{
|
|
299
|
+
return {
|
|
300
|
+
postcssPlugin: "tailwindcss",
|
|
301
|
+
Once (root, { result }) {
|
|
302
|
+
_sharedState.env.DEBUG && console.time("Compiling CSS");
|
|
303
|
+
(0, _processTailwindFeatures.default)(({ createContext })=>{
|
|
304
|
+
console.error();
|
|
305
|
+
console.error("Rebuilding...");
|
|
306
|
+
return ()=>{
|
|
307
|
+
return state.getContext({
|
|
308
|
+
createContext,
|
|
309
|
+
cliConfigPath,
|
|
310
|
+
root,
|
|
311
|
+
result,
|
|
312
|
+
content
|
|
313
|
+
});
|
|
314
|
+
};
|
|
315
|
+
})(root, result);
|
|
316
|
+
_sharedState.env.DEBUG && console.timeEnd("Compiling CSS");
|
|
317
|
+
}
|
|
318
|
+
};
|
|
319
|
+
};
|
|
320
|
+
tailwindPlugin.postcss = true;
|
|
321
|
+
let plugins = [
|
|
322
|
+
...beforePlugins,
|
|
323
|
+
tailwindPlugin,
|
|
324
|
+
!args["--minify"] && _utils.formatNodes,
|
|
325
|
+
...afterPlugins
|
|
326
|
+
].filter(Boolean);
|
|
327
|
+
/** @type {import('postcss').Processor} */ // @ts-ignore
|
|
328
|
+
let processor = (0, _postcss.default)(plugins);
|
|
329
|
+
async function readInput() {
|
|
330
|
+
// Piping in data, let's drain the stdin
|
|
331
|
+
if (input === "-") {
|
|
332
|
+
return (0, _utils.drainStdin)();
|
|
333
|
+
}
|
|
334
|
+
// Input file has been provided
|
|
335
|
+
if (input) {
|
|
336
|
+
return _fs.default.promises.readFile(_path.default.resolve(input), "utf8");
|
|
337
|
+
}
|
|
338
|
+
// No input file provided, fallback to default atrules
|
|
339
|
+
return "@tailwind base; @tailwind components; @tailwind utilities";
|
|
340
|
+
}
|
|
341
|
+
async function build() {
|
|
342
|
+
let start = process.hrtime.bigint();
|
|
343
|
+
let options = {
|
|
344
|
+
...postcssOptions,
|
|
345
|
+
from: input,
|
|
346
|
+
to: output
|
|
347
|
+
};
|
|
348
|
+
return readInput().then((css)=>processor.process(css, options)).then((result)=>lightningcss(result, {
|
|
349
|
+
...options,
|
|
350
|
+
minify: !!args["--minify"]
|
|
351
|
+
})).then((result)=>{
|
|
352
|
+
if (!state.watcher) {
|
|
353
|
+
return result;
|
|
354
|
+
}
|
|
355
|
+
_sharedState.env.DEBUG && console.time("Recording PostCSS dependencies");
|
|
356
|
+
for (let message of result.messages){
|
|
357
|
+
if (message.type === "dependency") {
|
|
358
|
+
state.contextDependencies.add(message.file);
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
_sharedState.env.DEBUG && console.timeEnd("Recording PostCSS dependencies");
|
|
362
|
+
// TODO: This needs to be in a different spot
|
|
363
|
+
_sharedState.env.DEBUG && console.time("Watch new files");
|
|
364
|
+
state.watcher.refreshWatchedFiles();
|
|
365
|
+
_sharedState.env.DEBUG && console.timeEnd("Watch new files");
|
|
366
|
+
return result;
|
|
367
|
+
}).then((result)=>{
|
|
368
|
+
if (!output) {
|
|
369
|
+
process.stdout.write(result.css);
|
|
370
|
+
return;
|
|
371
|
+
}
|
|
372
|
+
return Promise.all([
|
|
373
|
+
(0, _utils.outputFile)(result.opts.to, result.css),
|
|
374
|
+
result.map && (0, _utils.outputFile)(result.opts.to + ".map", result.map.toString())
|
|
375
|
+
]);
|
|
376
|
+
}).then(()=>{
|
|
377
|
+
let end = process.hrtime.bigint();
|
|
378
|
+
console.error();
|
|
379
|
+
console.error("Done in", (end - start) / BigInt(1e6) + "ms.");
|
|
380
|
+
}).then(()=>{}, (err)=>{
|
|
381
|
+
// TODO: If an initial build fails we can't easily pick up any PostCSS dependencies
|
|
382
|
+
// that were collected before the error occurred
|
|
383
|
+
// The result is not stored on the error so we have to store it externally
|
|
384
|
+
// and pull the messages off of it here somehow
|
|
385
|
+
// This results in a less than ideal DX because the watcher will not pick up
|
|
386
|
+
// changes to imported CSS if one of them caused an error during the initial build
|
|
387
|
+
// If you fix it and then save the main CSS file so there's no error
|
|
388
|
+
// The watcher will start watching the imported CSS files and will be
|
|
389
|
+
// resilient to future errors.
|
|
390
|
+
if (state.watcher) {
|
|
391
|
+
console.error(err);
|
|
392
|
+
} else {
|
|
393
|
+
return Promise.reject(err);
|
|
394
|
+
}
|
|
395
|
+
});
|
|
396
|
+
}
|
|
397
|
+
/**
|
|
398
|
+
* @param {{file: string, content(): Promise<string>, extension: string}[]} changes
|
|
399
|
+
*/ async function parseChanges(changes) {
|
|
400
|
+
return Promise.all(changes.map(async (change)=>({
|
|
401
|
+
content: await change.content(),
|
|
402
|
+
extension: change.extension
|
|
403
|
+
})));
|
|
404
|
+
}
|
|
405
|
+
if (input !== undefined && input !== "-") {
|
|
406
|
+
state.contextDependencies.add(_path.default.resolve(input));
|
|
407
|
+
}
|
|
408
|
+
return {
|
|
409
|
+
build,
|
|
410
|
+
watch: async ()=>{
|
|
411
|
+
state.watcher = (0, _watching.createWatcher)(args, {
|
|
412
|
+
state,
|
|
413
|
+
/**
|
|
414
|
+
* @param {{file: string, content(): Promise<string>, extension: string}[]} changes
|
|
415
|
+
*/ async rebuild (changes) {
|
|
416
|
+
let needsNewContext = changes.some((change)=>{
|
|
417
|
+
var _state_configBag;
|
|
418
|
+
return ((_state_configBag = state.configBag) === null || _state_configBag === void 0 ? void 0 : _state_configBag.dependencies.has(change.file)) || state.contextDependencies.has(change.file);
|
|
419
|
+
});
|
|
420
|
+
if (needsNewContext) {
|
|
421
|
+
state.context = null;
|
|
422
|
+
} else {
|
|
423
|
+
for (let change of (await parseChanges(changes))){
|
|
424
|
+
state.changedContent.push(change);
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
return build();
|
|
428
|
+
}
|
|
429
|
+
});
|
|
430
|
+
await build();
|
|
431
|
+
}
|
|
432
|
+
};
|
|
433
|
+
}
|
|
@@ -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
|
+
}
|