tailwindcss 0.0.0-insiders.c6bac2d → 0.0.0-insiders.c834da4
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/CHANGELOG.md +134 -8
- package/README.md +6 -5
- package/lib/cli/build/deps.js +54 -0
- package/lib/cli/build/index.js +48 -0
- package/lib/cli/build/plugin.js +362 -0
- package/lib/cli/build/utils.js +78 -0
- package/lib/cli/build/watching.js +178 -0
- package/lib/cli/help/index.js +71 -0
- package/lib/cli/index.js +18 -0
- package/lib/cli/init/index.js +46 -0
- package/lib/cli/shared.js +12 -0
- package/lib/cli.js +32 -601
- package/lib/corePlugins.js +345 -114
- package/lib/css/preflight.css +23 -0
- package/lib/featureFlags.js +15 -12
- package/lib/index.js +6 -1
- package/lib/lib/collapseAdjacentRules.js +2 -2
- package/lib/lib/collapseDuplicateDeclarations.js +2 -2
- package/lib/lib/content.js +177 -0
- package/lib/lib/defaultExtractor.js +19 -14
- package/lib/lib/detectNesting.js +2 -2
- package/lib/lib/evaluateTailwindFunctions.js +19 -3
- package/lib/lib/expandApplyAtRules.js +92 -39
- package/lib/lib/expandTailwindAtRules.js +15 -47
- package/lib/lib/findAtConfigPath.js +44 -0
- package/lib/lib/generateRules.js +218 -114
- package/lib/lib/normalizeTailwindDirectives.js +1 -1
- package/lib/lib/offsets.js +285 -0
- package/lib/lib/regex.js +1 -1
- package/lib/lib/remap-bitfield.js +87 -0
- package/lib/lib/resolveDefaultsAtRules.js +4 -4
- package/lib/lib/setupContextUtils.js +373 -127
- package/lib/lib/setupTrackingContext.js +5 -39
- package/lib/lib/sharedState.js +2 -0
- package/lib/postcss-plugins/nesting/plugin.js +2 -2
- package/lib/public/colors.js +1 -1
- package/lib/util/buildMediaQuery.js +6 -3
- package/lib/util/cloneNodes.js +2 -2
- package/lib/util/color.js +4 -4
- package/lib/util/configurePlugins.js +1 -1
- package/lib/util/createUtilityPlugin.js +2 -2
- package/lib/util/dataTypes.js +25 -20
- package/lib/util/defaults.js +4 -4
- package/lib/util/escapeClassName.js +3 -3
- package/lib/util/formatVariantSelector.js +106 -14
- package/lib/util/getAllConfigs.js +16 -5
- package/lib/util/{isValidArbitraryValue.js → isSyntacticallyValidPropertyValue.js} +3 -3
- package/lib/util/nameClass.js +3 -0
- package/lib/util/negateValue.js +15 -2
- package/lib/util/normalizeConfig.js +50 -22
- package/lib/util/normalizeScreens.js +100 -3
- package/lib/util/parseAnimationValue.js +1 -1
- package/lib/util/parseBoxShadowValue.js +1 -1
- package/lib/util/parseDependency.js +33 -54
- package/lib/util/parseGlob.js +34 -0
- package/lib/util/parseObjectStyles.js +1 -1
- package/lib/util/pluginUtils.js +111 -23
- package/lib/util/resolveConfig.js +14 -19
- package/lib/util/splitAtTopLevelOnly.js +31 -81
- package/lib/util/transformThemeValue.js +9 -2
- package/lib/util/validateConfig.js +1 -1
- package/lib/util/validateFormalSyntax.js +24 -0
- package/package.json +21 -20
- package/peers/index.js +3707 -2146
- package/plugin.d.ts +3 -3
- package/resolveConfig.d.ts +11 -2
- package/scripts/release-channel.js +18 -0
- package/scripts/release-notes.js +21 -0
- package/src/cli/build/deps.js +56 -0
- package/src/cli/build/index.js +49 -0
- package/src/cli/build/plugin.js +434 -0
- package/src/cli/build/utils.js +76 -0
- package/src/cli/build/watching.js +227 -0
- package/src/cli/help/index.js +70 -0
- package/src/cli/index.js +3 -0
- package/src/cli/init/index.js +50 -0
- package/src/cli/shared.js +5 -0
- package/src/cli.js +28 -709
- package/src/corePlugins.js +272 -40
- package/src/css/preflight.css +23 -0
- package/src/featureFlags.js +12 -2
- package/src/index.js +5 -0
- package/src/lib/content.js +213 -0
- package/src/lib/defaultExtractor.js +5 -2
- package/src/lib/evaluateTailwindFunctions.js +22 -1
- package/src/lib/expandApplyAtRules.js +98 -31
- package/src/lib/expandTailwindAtRules.js +8 -46
- package/src/lib/findAtConfigPath.js +48 -0
- package/src/lib/generateRules.js +259 -115
- package/src/lib/offsets.js +351 -0
- package/src/lib/remap-bitfield.js +82 -0
- package/src/lib/setupContextUtils.js +397 -105
- package/src/lib/setupTrackingContext.js +4 -45
- package/src/lib/sharedState.js +2 -0
- package/src/util/buildMediaQuery.js +5 -3
- package/src/util/dataTypes.js +30 -21
- package/src/util/formatVariantSelector.js +125 -10
- package/src/util/getAllConfigs.js +14 -2
- package/src/util/{isValidArbitraryValue.js → isSyntacticallyValidPropertyValue.js} +1 -1
- package/src/util/nameClass.js +4 -0
- package/src/util/negateValue.js +10 -2
- package/src/util/normalizeConfig.js +40 -2
- package/src/util/normalizeScreens.js +99 -4
- package/src/util/parseBoxShadowValue.js +1 -1
- package/src/util/parseDependency.js +37 -42
- package/src/util/parseGlob.js +24 -0
- package/src/util/pluginUtils.js +119 -9
- package/src/util/resolveConfig.js +5 -11
- package/src/util/splitAtTopLevelOnly.js +23 -49
- package/src/util/transformThemeValue.js +9 -1
- package/src/util/validateFormalSyntax.js +34 -0
- package/stubs/defaultConfig.stub.js +165 -165
- package/types/config.d.ts +51 -15
- package/types/generated/default-theme.d.ts +87 -76
package/CHANGELOG.md
CHANGED
|
@@ -7,7 +7,131 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
|
7
7
|
|
|
8
8
|
## [Unreleased]
|
|
9
9
|
|
|
10
|
-
|
|
10
|
+
### Added
|
|
11
|
+
|
|
12
|
+
- Add `line-height` modifier support to `font-size` utilities ([#9875](https://github.com/tailwindlabs/tailwindcss/pull/9875))
|
|
13
|
+
- Support using variables as arbitrary values without `var(...)` ([#9880](https://github.com/tailwindlabs/tailwindcss/pull/9880), [#9962](https://github.com/tailwindlabs/tailwindcss/pull/9962))
|
|
14
|
+
- Add `--watch=always` option to prevent exit when stdin closes ([#9966](https://github.com/tailwindlabs/tailwindcss/pull/9966))
|
|
15
|
+
- Add standalone CLI build for 64-bit Windows on ARM (`node16-win-arm64`) ([#10001](https://github.com/tailwindlabs/tailwindcss/pull/10001))
|
|
16
|
+
|
|
17
|
+
### Fixed
|
|
18
|
+
|
|
19
|
+
- Cleanup unused `variantOrder` ([#9829](https://github.com/tailwindlabs/tailwindcss/pull/9829))
|
|
20
|
+
- Fix `foo-[abc]/[def]` not being handled correctly ([#9866](https://github.com/tailwindlabs/tailwindcss/pull/9866))
|
|
21
|
+
- Add container queries plugin to standalone CLI ([#9865](https://github.com/tailwindlabs/tailwindcss/pull/9865))
|
|
22
|
+
- Support renaming of output files by `PostCSS` plugin. ([#9944](https://github.com/tailwindlabs/tailwindcss/pull/9944))
|
|
23
|
+
- Improve return value of `resolveConfig`, unwrap `ResolvableTo` ([#9972](https://github.com/tailwindlabs/tailwindcss/pull/9972))
|
|
24
|
+
- Clip unbalanced brackets in arbitrary values ([#9973](https://github.com/tailwindlabs/tailwindcss/pull/9973))
|
|
25
|
+
- Don’t reorder webkit scrollbar pseudo elements ([#9991](https://github.com/tailwindlabs/tailwindcss/pull/9991))
|
|
26
|
+
- Deterministic sorting of arbitrary variants ([#10016](https://github.com/tailwindlabs/tailwindcss/pull/10016))
|
|
27
|
+
- Add `data` key to theme types ([#10023](https://github.com/tailwindlabs/tailwindcss/pull/10023))
|
|
28
|
+
- Prevent invalid arbitrary variant selectors from failing the build ([#10059](https://github.com/tailwindlabs/tailwindcss/pull/10059))
|
|
29
|
+
- Properly handle subtraction followed by a variable ([#10074](https://github.com/tailwindlabs/tailwindcss/pull/10074))
|
|
30
|
+
- Fix missing `string[]` in the `theme.dropShadow` types ([#10072](https://github.com/tailwindlabs/tailwindcss/pull/10072))
|
|
31
|
+
|
|
32
|
+
### Changed
|
|
33
|
+
|
|
34
|
+
- Alphabetize `theme` keys in default config ([#9953](https://github.com/tailwindlabs/tailwindcss/pull/9953))
|
|
35
|
+
|
|
36
|
+
## [3.2.4] - 2022-11-11
|
|
37
|
+
|
|
38
|
+
### Added
|
|
39
|
+
|
|
40
|
+
- Add `blocklist` option to prevent generating unwanted CSS ([#9812](https://github.com/tailwindlabs/tailwindcss/pull/9812))
|
|
41
|
+
|
|
42
|
+
### Fixed
|
|
43
|
+
|
|
44
|
+
- Fix watching of files on Linux when renames are involved ([#9796](https://github.com/tailwindlabs/tailwindcss/pull/9796))
|
|
45
|
+
- Make sure errors are always displayed when watching for changes ([#9810](https://github.com/tailwindlabs/tailwindcss/pull/9810))
|
|
46
|
+
|
|
47
|
+
## [3.2.3] - 2022-11-09
|
|
48
|
+
|
|
49
|
+
### Fixed
|
|
50
|
+
|
|
51
|
+
- Fixed use of `raw` content in the CLI ([#9773](https://github.com/tailwindlabs/tailwindcss/pull/9773))
|
|
52
|
+
- Pick up changes from files that are both context and content deps ([#9787](https://github.com/tailwindlabs/tailwindcss/pull/9787))
|
|
53
|
+
- Sort pseudo-elements ONLY after classes when using variants and `@apply` ([#9765](https://github.com/tailwindlabs/tailwindcss/pull/9765))
|
|
54
|
+
- Support important utilities in the safelist (pattern must include a `!`) ([#9791](https://github.com/tailwindlabs/tailwindcss/pull/9791))
|
|
55
|
+
|
|
56
|
+
## [3.2.2] - 2022-11-04
|
|
57
|
+
|
|
58
|
+
### Fixed
|
|
59
|
+
|
|
60
|
+
- Escape special characters in resolved content base paths ([#9650](https://github.com/tailwindlabs/tailwindcss/pull/9650))
|
|
61
|
+
- Don't reuse container for array returning variant functions ([#9644](https://github.com/tailwindlabs/tailwindcss/pull/9644))
|
|
62
|
+
- Exclude non-relevant selectors when generating rules with the important modifier ([#9677](https://github.com/tailwindlabs/tailwindcss/issues/9677))
|
|
63
|
+
- Fix merging of arrays during config resolution ([#9706](https://github.com/tailwindlabs/tailwindcss/issues/9706))
|
|
64
|
+
- Ensure configured `font-feature-settings` are included in Preflight ([#9707](https://github.com/tailwindlabs/tailwindcss/pull/9707))
|
|
65
|
+
- Fix fractional values not being parsed properly inside arbitrary properties ([#9705](https://github.com/tailwindlabs/tailwindcss/pull/9705))
|
|
66
|
+
- Fix incorrect selectors when using `@apply` in selectors with combinators and pseudos ([#9722](https://github.com/tailwindlabs/tailwindcss/pull/9722))
|
|
67
|
+
- Fix cannot read properties of undefined (reading 'modifier') ([#9656](https://github.com/tailwindlabs/tailwindcss/pull/9656), [aa979d6](https://github.com/tailwindlabs/tailwindcss/commit/aa979d645f8bf4108c5fc938d7c0ba085b654c31))
|
|
68
|
+
|
|
69
|
+
## [3.2.1] - 2022-10-21
|
|
70
|
+
|
|
71
|
+
### Fixed
|
|
72
|
+
|
|
73
|
+
- Fix missing `supports` in types ([#9616](https://github.com/tailwindlabs/tailwindcss/pull/9616))
|
|
74
|
+
- Fix missing PostCSS dependencies in the CLI ([#9617](https://github.com/tailwindlabs/tailwindcss/pull/9617))
|
|
75
|
+
- Ensure `micromatch` is a proper CLI dependency ([#9620](https://github.com/tailwindlabs/tailwindcss/pull/9620))
|
|
76
|
+
- Ensure modifier values exist when using a `modifiers` object for `matchVariant` ([ba6551db0f2726461371b4f3c6cd4c7090888504](https://github.com/tailwindlabs/tailwindcss/commit/ba6551db0f2726461371b4f3c6cd4c7090888504))
|
|
77
|
+
|
|
78
|
+
## [3.2.0] - 2022-10-19
|
|
79
|
+
|
|
80
|
+
### Added
|
|
81
|
+
|
|
82
|
+
- Add new `@config` directive ([#9405](https://github.com/tailwindlabs/tailwindcss/pull/9405))
|
|
83
|
+
- Add new `relative: true` option to resolve content paths relative to the config file ([#9396](https://github.com/tailwindlabs/tailwindcss/pull/9396))
|
|
84
|
+
- Add new `supports-*` variant ([#9453](https://github.com/tailwindlabs/tailwindcss/pull/9453))
|
|
85
|
+
- Add new `min-*` and `max-*` variants ([#9558](https://github.com/tailwindlabs/tailwindcss/pull/9558))
|
|
86
|
+
- Add new `aria-*` variants ([#9557](https://github.com/tailwindlabs/tailwindcss/pull/9557), [#9588](https://github.com/tailwindlabs/tailwindcss/pull/9588))
|
|
87
|
+
- Add new `data-*` variants ([#9559](https://github.com/tailwindlabs/tailwindcss/pull/9559), [#9588](https://github.com/tailwindlabs/tailwindcss/pull/9588))
|
|
88
|
+
- Add new `break-keep` utility for `word-break: keep-all` ([#9393](https://github.com/tailwindlabs/tailwindcss/pull/9393))
|
|
89
|
+
- Add new `collapse` utility for `visibility: collapse` ([#9181](https://github.com/tailwindlabs/tailwindcss/pull/9181))
|
|
90
|
+
- Add new `fill-none` utility for `fill: none` ([#9403](https://github.com/tailwindlabs/tailwindcss/pull/9403))
|
|
91
|
+
- Add new `stroke-none` utility for `stroke: none` ([#9403](https://github.com/tailwindlabs/tailwindcss/pull/9403))
|
|
92
|
+
- Add new `place-content-baseline` utility for `place-content: baseline` ([#9498](https://github.com/tailwindlabs/tailwindcss/pull/9498))
|
|
93
|
+
- Add new `place-items-baseline` utility for `place-items: baseline` ([#9507](https://github.com/tailwindlabs/tailwindcss/pull/9507))
|
|
94
|
+
- Add new `content-baseline` utility for `align-content: baseline` ([#9507](https://github.com/tailwindlabs/tailwindcss/pull/9507))
|
|
95
|
+
- Add support for configuring default `font-feature-settings` for a font family ([#9039](https://github.com/tailwindlabs/tailwindcss/pull/9039))
|
|
96
|
+
- Add standalone CLI build for 32-bit Linux on ARM (`node16-linux-armv7`) ([#9084](https://github.com/tailwindlabs/tailwindcss/pull/9084))
|
|
97
|
+
- Add future flag to disable color opacity utility plugins ([#9088](https://github.com/tailwindlabs/tailwindcss/pull/9088))
|
|
98
|
+
- Add negative value support for `outline-offset` ([#9136](https://github.com/tailwindlabs/tailwindcss/pull/9136))
|
|
99
|
+
- Add support for modifiers to `matchUtilities` ([#9541](https://github.com/tailwindlabs/tailwindcss/pull/9541))
|
|
100
|
+
- Allow negating utilities using `min`/`max`/`clamp` ([#9237](https://github.com/tailwindlabs/tailwindcss/pull/9237))
|
|
101
|
+
- Implement fallback plugins when there is ambiguity between plugins when using arbitrary values ([#9376](https://github.com/tailwindlabs/tailwindcss/pull/9376))
|
|
102
|
+
- Support `sort` function in `matchVariant` ([#9423](https://github.com/tailwindlabs/tailwindcss/pull/9423))
|
|
103
|
+
- Upgrade to `postcss-nested` v6.0 ([#9546](https://github.com/tailwindlabs/tailwindcss/pull/9546))
|
|
104
|
+
|
|
105
|
+
### Fixed
|
|
106
|
+
|
|
107
|
+
- Use absolute paths when resolving changed files for resilience against working directory changes ([#9032](https://github.com/tailwindlabs/tailwindcss/pull/9032))
|
|
108
|
+
- Fix ring color utility generation when using `respectDefaultRingColorOpacity` ([#9070](https://github.com/tailwindlabs/tailwindcss/pull/9070))
|
|
109
|
+
- Sort tags before classes when `@apply`-ing a selector with joined classes ([#9107](https://github.com/tailwindlabs/tailwindcss/pull/9107))
|
|
110
|
+
- Remove invalid `outline-hidden` utility ([#9147](https://github.com/tailwindlabs/tailwindcss/pull/9147))
|
|
111
|
+
- Honor the `hidden` attribute on elements in preflight ([#9174](https://github.com/tailwindlabs/tailwindcss/pull/9174))
|
|
112
|
+
- Don't stop watching atomically renamed files ([#9173](https://github.com/tailwindlabs/tailwindcss/pull/9173), [#9215](https://github.com/tailwindlabs/tailwindcss/pull/9215))
|
|
113
|
+
- Fix duplicate utilities issue causing memory leaks ([#9208](https://github.com/tailwindlabs/tailwindcss/pull/9208))
|
|
114
|
+
- Fix `fontFamily` config TypeScript types ([#9214](https://github.com/tailwindlabs/tailwindcss/pull/9214))
|
|
115
|
+
- Handle variants on complex selector utilities ([#9262](https://github.com/tailwindlabs/tailwindcss/pull/9262))
|
|
116
|
+
- Fix shared config mutation issue ([#9294](https://github.com/tailwindlabs/tailwindcss/pull/9294))
|
|
117
|
+
- Fix ordering of parallel variants ([#9282](https://github.com/tailwindlabs/tailwindcss/pull/9282))
|
|
118
|
+
- Handle variants in utility selectors using `:where()` and `:has()` ([#9309](https://github.com/tailwindlabs/tailwindcss/pull/9309))
|
|
119
|
+
- Improve data type analysis for arbitrary values ([#9320](https://github.com/tailwindlabs/tailwindcss/pull/9320))
|
|
120
|
+
- Don't emit generated utilities with invalid uses of theme functions ([#9319](https://github.com/tailwindlabs/tailwindcss/pull/9319))
|
|
121
|
+
- Revert change that only listened for stdin close on TTYs ([#9331](https://github.com/tailwindlabs/tailwindcss/pull/9331))
|
|
122
|
+
- Ignore unset values (like `null` or `undefined`) when resolving the classList for intellisense ([#9385](https://github.com/tailwindlabs/tailwindcss/pull/9385))
|
|
123
|
+
- Improve type checking for formal syntax ([#9349](https://github.com/tailwindlabs/tailwindcss/pull/9349), [#9448](https://github.com/tailwindlabs/tailwindcss/pull/9448))
|
|
124
|
+
- Fix incorrect required `content` key in custom plugin configs ([#9502](https://github.com/tailwindlabs/tailwindcss/pull/9502), [#9545](https://github.com/tailwindlabs/tailwindcss/pull/9545))
|
|
125
|
+
- Fix content path detection on Windows ([#9569](https://github.com/tailwindlabs/tailwindcss/pull/9569))
|
|
126
|
+
- Ensure `--content` is used in the CLI when passed ([#9587](https://github.com/tailwindlabs/tailwindcss/pull/9587))
|
|
127
|
+
|
|
128
|
+
## [3.1.8] - 2022-08-05
|
|
129
|
+
|
|
130
|
+
### Fixed
|
|
131
|
+
|
|
132
|
+
- Don’t prefix classes within reused arbitrary variants ([#8992](https://github.com/tailwindlabs/tailwindcss/pull/8992))
|
|
133
|
+
- Fix usage of alpha values inside single-named colors that are functions ([#9008](https://github.com/tailwindlabs/tailwindcss/pull/9008))
|
|
134
|
+
- Fix `@apply` of user utilities when negative and non-negative versions both exist ([#9027](https://github.com/tailwindlabs/tailwindcss/pull/9027))
|
|
11
135
|
|
|
12
136
|
## [3.1.7] - 2022-07-29
|
|
13
137
|
|
|
@@ -19,10 +143,6 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
|
19
143
|
|
|
20
144
|
- Added types for `resolveConfig` ([#8924](https://github.com/tailwindlabs/tailwindcss/pull/8924))
|
|
21
145
|
|
|
22
|
-
### Changed
|
|
23
|
-
|
|
24
|
-
- Don't use `cursor: pointer` for buttons by default ([#8962](https://github.com/tailwindlabs/tailwindcss/pull/8962))
|
|
25
|
-
|
|
26
146
|
## [3.1.6] - 2022-07-11
|
|
27
147
|
|
|
28
148
|
### Fixed
|
|
@@ -100,7 +220,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
|
100
220
|
- Move `important` selector to the front when `@apply`-ing selector-modifying variants in custom utilities ([#8313](https://github.com/tailwindlabs/tailwindcss/pull/8313))
|
|
101
221
|
- Error when registering an invalid custom variant ([#8345](https://github.com/tailwindlabs/tailwindcss/pull/8345))
|
|
102
222
|
- Create tailwind.config.cjs file in ESM package when running init ([#8363](https://github.com/tailwindlabs/tailwindcss/pull/8363))
|
|
103
|
-
- Fix `
|
|
223
|
+
- Fix `matchVariant` that use at-rules and placeholders ([#8392](https://github.com/tailwindlabs/tailwindcss/pull/8392))
|
|
104
224
|
- Improve types of the `tailwindcss/plugin` ([#8400](https://github.com/tailwindlabs/tailwindcss/pull/8400))
|
|
105
225
|
- Allow returning parallel variants from `addVariant` or `matchVariant` callback functions ([#8455](https://github.com/tailwindlabs/tailwindcss/pull/8455))
|
|
106
226
|
- Try using local `postcss` installation first in the CLI ([#8270](https://github.com/tailwindlabs/tailwindcss/pull/8270))
|
|
@@ -453,7 +573,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
|
453
573
|
|
|
454
574
|
### Fixed
|
|
455
575
|
|
|
456
|
-
- Ensure `corePlugins` order is
|
|
576
|
+
- Ensure `corePlugins` order is consistent in AOT mode ([#5928](https://github.com/tailwindlabs/tailwindcss/pull/5928))
|
|
457
577
|
|
|
458
578
|
## [2.2.18] - 2021-10-29
|
|
459
579
|
|
|
@@ -2025,7 +2145,13 @@ No release notes
|
|
|
2025
2145
|
|
|
2026
2146
|
- Everything!
|
|
2027
2147
|
|
|
2028
|
-
[unreleased]: https://github.com/tailwindlabs/tailwindcss/compare/v3.
|
|
2148
|
+
[unreleased]: https://github.com/tailwindlabs/tailwindcss/compare/v3.2.4...HEAD
|
|
2149
|
+
[3.2.4]: https://github.com/tailwindlabs/tailwindcss/compare/v3.2.3...v3.2.4
|
|
2150
|
+
[3.2.3]: https://github.com/tailwindlabs/tailwindcss/compare/v3.2.2...v3.2.3
|
|
2151
|
+
[3.2.2]: https://github.com/tailwindlabs/tailwindcss/compare/v3.2.1...v3.2.2
|
|
2152
|
+
[3.2.1]: https://github.com/tailwindlabs/tailwindcss/compare/v3.2.0...v3.2.1
|
|
2153
|
+
[3.2.0]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.8...v3.2.0
|
|
2154
|
+
[3.1.8]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.7...v3.1.8
|
|
2029
2155
|
[3.1.7]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.6...v3.1.7
|
|
2030
2156
|
[3.1.6]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.5...v3.1.6
|
|
2031
2157
|
[3.1.5]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.4...v3.1.5
|
package/README.md
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
<p align="center">
|
|
2
|
-
<a href="https://tailwindcss.com
|
|
3
|
-
<
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
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>
|
|
7
8
|
</a>
|
|
8
9
|
</p>
|
|
9
10
|
|
|
@@ -0,0 +1,54 @@
|
|
|
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: ()=>loadPostcss,
|
|
14
|
+
loadPostcssImport: ()=>loadPostcssImport,
|
|
15
|
+
loadCssNano: ()=>loadCssNano,
|
|
16
|
+
loadAutoprefixer: ()=>loadAutoprefixer
|
|
17
|
+
});
|
|
18
|
+
const _indexJs = require("../../../peers/index.js");
|
|
19
|
+
function loadPostcss() {
|
|
20
|
+
// Try to load a local `postcss` version first
|
|
21
|
+
try {
|
|
22
|
+
return require("postcss");
|
|
23
|
+
} catch {}
|
|
24
|
+
return (0, _indexJs.lazyPostcss)();
|
|
25
|
+
}
|
|
26
|
+
function loadPostcssImport() {
|
|
27
|
+
// Try to load a local `postcss-import` version first
|
|
28
|
+
try {
|
|
29
|
+
return require("postcss-import");
|
|
30
|
+
} catch {}
|
|
31
|
+
return (0, _indexJs.lazyPostcssImport)();
|
|
32
|
+
}
|
|
33
|
+
function loadCssNano() {
|
|
34
|
+
let options = {
|
|
35
|
+
preset: [
|
|
36
|
+
"default",
|
|
37
|
+
{
|
|
38
|
+
cssDeclarationSorter: false
|
|
39
|
+
}
|
|
40
|
+
]
|
|
41
|
+
};
|
|
42
|
+
// Try to load a local `cssnano` version first
|
|
43
|
+
try {
|
|
44
|
+
return require("cssnano");
|
|
45
|
+
} catch {}
|
|
46
|
+
return (0, _indexJs.lazyCssnano)()(options);
|
|
47
|
+
}
|
|
48
|
+
function loadAutoprefixer() {
|
|
49
|
+
// Try to load a local `autoprefixer` version first
|
|
50
|
+
try {
|
|
51
|
+
return require("autoprefixer");
|
|
52
|
+
} catch {}
|
|
53
|
+
return (0, _indexJs.lazyAutoprefixer)();
|
|
54
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
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: ()=>build
|
|
9
|
+
});
|
|
10
|
+
const _fs = /*#__PURE__*/ _interopRequireDefault(require("fs"));
|
|
11
|
+
const _path = /*#__PURE__*/ _interopRequireDefault(require("path"));
|
|
12
|
+
const _pluginJs = require("./plugin.js");
|
|
13
|
+
function _interopRequireDefault(obj) {
|
|
14
|
+
return obj && obj.__esModule ? obj : {
|
|
15
|
+
default: obj
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
async function build(args, configs) {
|
|
19
|
+
let input = args["--input"];
|
|
20
|
+
let shouldWatch = args["--watch"];
|
|
21
|
+
// TODO: Deprecate this in future versions
|
|
22
|
+
if (!input && args["_"][1]) {
|
|
23
|
+
console.error("[deprecation] Running tailwindcss without -i, please provide an input file.");
|
|
24
|
+
input = args["--input"] = args["_"][1];
|
|
25
|
+
}
|
|
26
|
+
if (input && input !== "-" && !_fs.default.existsSync(input = _path.default.resolve(input))) {
|
|
27
|
+
console.error(`Specified input file ${args["--input"]} does not exist.`);
|
|
28
|
+
process.exit(9);
|
|
29
|
+
}
|
|
30
|
+
if (args["--config"] && !_fs.default.existsSync(args["--config"] = _path.default.resolve(args["--config"]))) {
|
|
31
|
+
console.error(`Specified config file ${args["--config"]} does not exist.`);
|
|
32
|
+
process.exit(9);
|
|
33
|
+
}
|
|
34
|
+
// TODO: Reference the @config path here if exists
|
|
35
|
+
let configPath = args["--config"] ? args["--config"] : ((defaultPath)=>_fs.default.existsSync(defaultPath) ? defaultPath : null)(_path.default.resolve(`./${configs.tailwind}`));
|
|
36
|
+
let processor = await (0, _pluginJs.createProcessor)(args, configPath);
|
|
37
|
+
if (shouldWatch) {
|
|
38
|
+
// Abort the watcher if stdin is closed to avoid zombie processes
|
|
39
|
+
// You can disable this behavior with --watch=always
|
|
40
|
+
if (args["--watch"] !== "always") {
|
|
41
|
+
process.stdin.on("end", ()=>process.exit(0));
|
|
42
|
+
}
|
|
43
|
+
process.stdin.resume();
|
|
44
|
+
await processor.watch();
|
|
45
|
+
} else {
|
|
46
|
+
await processor.build();
|
|
47
|
+
}
|
|
48
|
+
}
|
|
@@ -0,0 +1,362 @@
|
|
|
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: ()=>createProcessor
|
|
9
|
+
});
|
|
10
|
+
const _path = /*#__PURE__*/ _interopRequireDefault(require("path"));
|
|
11
|
+
const _fs = /*#__PURE__*/ _interopRequireDefault(require("fs"));
|
|
12
|
+
const _postcssLoadConfig = /*#__PURE__*/ _interopRequireDefault(require("postcss-load-config"));
|
|
13
|
+
const _lilconfig = require("lilconfig");
|
|
14
|
+
const _plugins = /*#__PURE__*/ _interopRequireDefault(require("postcss-load-config/src/plugins" // Little bit scary, looking at private/internal API
|
|
15
|
+
));
|
|
16
|
+
const _options = /*#__PURE__*/ _interopRequireDefault(require("postcss-load-config/src/options" // Little bit scary, looking at private/internal API
|
|
17
|
+
));
|
|
18
|
+
const _processTailwindFeatures = /*#__PURE__*/ _interopRequireDefault(require("../../processTailwindFeatures"));
|
|
19
|
+
const _deps = require("./deps");
|
|
20
|
+
const _utils = require("./utils");
|
|
21
|
+
const _shared = require("../shared");
|
|
22
|
+
const _resolveConfigJs = /*#__PURE__*/ _interopRequireDefault(require("../../../resolveConfig.js"));
|
|
23
|
+
const _getModuleDependenciesJs = /*#__PURE__*/ _interopRequireDefault(require("../../lib/getModuleDependencies.js"));
|
|
24
|
+
const _contentJs = require("../../lib/content.js");
|
|
25
|
+
const _watchingJs = require("./watching.js");
|
|
26
|
+
const _fastGlob = /*#__PURE__*/ _interopRequireDefault(require("fast-glob"));
|
|
27
|
+
const _findAtConfigPathJs = require("../../lib/findAtConfigPath.js");
|
|
28
|
+
const _log = /*#__PURE__*/ _interopRequireDefault(require("../../util/log"));
|
|
29
|
+
function _interopRequireDefault(obj) {
|
|
30
|
+
return obj && obj.__esModule ? obj : {
|
|
31
|
+
default: obj
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
*
|
|
36
|
+
* @param {string} [customPostCssPath ]
|
|
37
|
+
* @returns
|
|
38
|
+
*/ async function loadPostCssPlugins(customPostCssPath) {
|
|
39
|
+
let config = customPostCssPath ? await (async ()=>{
|
|
40
|
+
let file = _path.default.resolve(customPostCssPath);
|
|
41
|
+
// Implementation, see: https://unpkg.com/browse/postcss-load-config@3.1.0/src/index.js
|
|
42
|
+
// @ts-ignore
|
|
43
|
+
let { config ={} } = await (0, _lilconfig.lilconfig)("postcss").load(file);
|
|
44
|
+
if (typeof config === "function") {
|
|
45
|
+
config = config();
|
|
46
|
+
} else {
|
|
47
|
+
config = Object.assign({}, config);
|
|
48
|
+
}
|
|
49
|
+
if (!config.plugins) {
|
|
50
|
+
config.plugins = [];
|
|
51
|
+
}
|
|
52
|
+
return {
|
|
53
|
+
file,
|
|
54
|
+
plugins: (0, _plugins.default)(config, file),
|
|
55
|
+
options: (0, _options.default)(config, file)
|
|
56
|
+
};
|
|
57
|
+
})() : await (0, _postcssLoadConfig.default)();
|
|
58
|
+
let configPlugins = config.plugins;
|
|
59
|
+
let configPluginTailwindIdx = configPlugins.findIndex((plugin)=>{
|
|
60
|
+
if (typeof plugin === "function" && plugin.name === "tailwindcss") {
|
|
61
|
+
return true;
|
|
62
|
+
}
|
|
63
|
+
if (typeof plugin === "object" && plugin !== null && plugin.postcssPlugin === "tailwindcss") {
|
|
64
|
+
return true;
|
|
65
|
+
}
|
|
66
|
+
return false;
|
|
67
|
+
});
|
|
68
|
+
let beforePlugins = configPluginTailwindIdx === -1 ? [] : configPlugins.slice(0, configPluginTailwindIdx);
|
|
69
|
+
let afterPlugins = configPluginTailwindIdx === -1 ? configPlugins : configPlugins.slice(configPluginTailwindIdx + 1);
|
|
70
|
+
return [
|
|
71
|
+
beforePlugins,
|
|
72
|
+
afterPlugins,
|
|
73
|
+
config.options
|
|
74
|
+
];
|
|
75
|
+
}
|
|
76
|
+
function loadBuiltinPostcssPlugins() {
|
|
77
|
+
let postcss = (0, _deps.loadPostcss)();
|
|
78
|
+
let IMPORT_COMMENT = "__TAILWIND_RESTORE_IMPORT__: ";
|
|
79
|
+
return [
|
|
80
|
+
[
|
|
81
|
+
(root)=>{
|
|
82
|
+
root.walkAtRules("import", (rule)=>{
|
|
83
|
+
if (rule.params.slice(1).startsWith("tailwindcss/")) {
|
|
84
|
+
rule.after(postcss.comment({
|
|
85
|
+
text: IMPORT_COMMENT + rule.params
|
|
86
|
+
}));
|
|
87
|
+
rule.remove();
|
|
88
|
+
}
|
|
89
|
+
});
|
|
90
|
+
},
|
|
91
|
+
(0, _deps.loadPostcssImport)(),
|
|
92
|
+
(root)=>{
|
|
93
|
+
root.walkComments((rule)=>{
|
|
94
|
+
if (rule.text.startsWith(IMPORT_COMMENT)) {
|
|
95
|
+
rule.after(postcss.atRule({
|
|
96
|
+
name: "import",
|
|
97
|
+
params: rule.text.replace(IMPORT_COMMENT, "")
|
|
98
|
+
}));
|
|
99
|
+
rule.remove();
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
],
|
|
104
|
+
[],
|
|
105
|
+
{}
|
|
106
|
+
];
|
|
107
|
+
}
|
|
108
|
+
let state = {
|
|
109
|
+
/** @type {any} */ context: null,
|
|
110
|
+
/** @type {ReturnType<typeof createWatcher> | null} */ watcher: null,
|
|
111
|
+
/** @type {{content: string, extension: string}[]} */ changedContent: [],
|
|
112
|
+
configDependencies: new Set(),
|
|
113
|
+
contextDependencies: new Set(),
|
|
114
|
+
/** @type {import('../../lib/content.js').ContentPath[]} */ contentPaths: [],
|
|
115
|
+
refreshContentPaths () {
|
|
116
|
+
var _this_context;
|
|
117
|
+
this.contentPaths = (0, _contentJs.parseCandidateFiles)(this.context, (_this_context = this.context) === null || _this_context === void 0 ? void 0 : _this_context.tailwindConfig);
|
|
118
|
+
},
|
|
119
|
+
get config () {
|
|
120
|
+
return this.context.tailwindConfig;
|
|
121
|
+
},
|
|
122
|
+
get contentPatterns () {
|
|
123
|
+
return {
|
|
124
|
+
all: this.contentPaths.map((contentPath)=>contentPath.pattern),
|
|
125
|
+
dynamic: this.contentPaths.filter((contentPath)=>contentPath.glob !== undefined).map((contentPath)=>contentPath.pattern)
|
|
126
|
+
};
|
|
127
|
+
},
|
|
128
|
+
loadConfig (configPath, content) {
|
|
129
|
+
if (this.watcher && configPath) {
|
|
130
|
+
this.refreshConfigDependencies(configPath);
|
|
131
|
+
}
|
|
132
|
+
let config = configPath ? require(configPath) : {};
|
|
133
|
+
// @ts-ignore
|
|
134
|
+
config = (0, _resolveConfigJs.default)(config, {
|
|
135
|
+
content: {
|
|
136
|
+
files: []
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
// Override content files if `--content` has been passed explicitly
|
|
140
|
+
if ((content === null || content === void 0 ? void 0 : content.length) > 0) {
|
|
141
|
+
config.content.files = content;
|
|
142
|
+
}
|
|
143
|
+
return config;
|
|
144
|
+
},
|
|
145
|
+
refreshConfigDependencies (configPath) {
|
|
146
|
+
_shared.env.DEBUG && console.time("Module dependencies");
|
|
147
|
+
for (let file of this.configDependencies){
|
|
148
|
+
delete require.cache[require.resolve(file)];
|
|
149
|
+
}
|
|
150
|
+
if (configPath) {
|
|
151
|
+
let deps = (0, _getModuleDependenciesJs.default)(configPath).map(({ file })=>file);
|
|
152
|
+
for (let dependency of deps){
|
|
153
|
+
this.configDependencies.add(dependency);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
_shared.env.DEBUG && console.timeEnd("Module dependencies");
|
|
157
|
+
},
|
|
158
|
+
readContentPaths () {
|
|
159
|
+
let content = [];
|
|
160
|
+
// Resolve globs from the content config
|
|
161
|
+
// TODO: When we make the postcss plugin async-capable this can become async
|
|
162
|
+
let files = _fastGlob.default.sync(this.contentPatterns.all);
|
|
163
|
+
for (let file of files){
|
|
164
|
+
content.push({
|
|
165
|
+
content: _fs.default.readFileSync(_path.default.resolve(file), "utf8"),
|
|
166
|
+
extension: _path.default.extname(file).slice(1)
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
// Resolve raw content in the tailwind config
|
|
170
|
+
let rawContent = this.config.content.files.filter((file)=>{
|
|
171
|
+
return file !== null && typeof file === "object";
|
|
172
|
+
});
|
|
173
|
+
for (let { raw: htmlContent , extension ="html" } of rawContent){
|
|
174
|
+
content.push({
|
|
175
|
+
content: htmlContent,
|
|
176
|
+
extension
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
return content;
|
|
180
|
+
},
|
|
181
|
+
getContext ({ createContext , cliConfigPath , root , result , content }) {
|
|
182
|
+
if (this.context) {
|
|
183
|
+
this.context.changedContent = this.changedContent.splice(0);
|
|
184
|
+
return this.context;
|
|
185
|
+
}
|
|
186
|
+
_shared.env.DEBUG && console.time("Searching for config");
|
|
187
|
+
var _findAtConfigPath;
|
|
188
|
+
let configPath = (_findAtConfigPath = (0, _findAtConfigPathJs.findAtConfigPath)(root, result)) !== null && _findAtConfigPath !== void 0 ? _findAtConfigPath : cliConfigPath;
|
|
189
|
+
_shared.env.DEBUG && console.timeEnd("Searching for config");
|
|
190
|
+
_shared.env.DEBUG && console.time("Loading config");
|
|
191
|
+
let config = this.loadConfig(configPath, content);
|
|
192
|
+
_shared.env.DEBUG && console.timeEnd("Loading config");
|
|
193
|
+
_shared.env.DEBUG && console.time("Creating context");
|
|
194
|
+
this.context = createContext(config, []);
|
|
195
|
+
Object.assign(this.context, {
|
|
196
|
+
userConfigPath: configPath
|
|
197
|
+
});
|
|
198
|
+
_shared.env.DEBUG && console.timeEnd("Creating context");
|
|
199
|
+
_shared.env.DEBUG && console.time("Resolving content paths");
|
|
200
|
+
this.refreshContentPaths();
|
|
201
|
+
_shared.env.DEBUG && console.timeEnd("Resolving content paths");
|
|
202
|
+
if (this.watcher) {
|
|
203
|
+
_shared.env.DEBUG && console.time("Watch new files");
|
|
204
|
+
this.watcher.refreshWatchedFiles();
|
|
205
|
+
_shared.env.DEBUG && console.timeEnd("Watch new files");
|
|
206
|
+
}
|
|
207
|
+
_shared.env.DEBUG && console.time("Reading content files");
|
|
208
|
+
for (let file of this.readContentPaths()){
|
|
209
|
+
this.context.changedContent.push(file);
|
|
210
|
+
}
|
|
211
|
+
_shared.env.DEBUG && console.timeEnd("Reading content files");
|
|
212
|
+
return this.context;
|
|
213
|
+
}
|
|
214
|
+
};
|
|
215
|
+
async function createProcessor(args, cliConfigPath) {
|
|
216
|
+
var _args_content;
|
|
217
|
+
let postcss = (0, _deps.loadPostcss)();
|
|
218
|
+
let input = args["--input"];
|
|
219
|
+
let output = args["--output"];
|
|
220
|
+
let includePostCss = args["--postcss"];
|
|
221
|
+
let customPostCssPath = typeof args["--postcss"] === "string" ? args["--postcss"] : undefined;
|
|
222
|
+
let [beforePlugins, afterPlugins, postcssOptions] = includePostCss ? await loadPostCssPlugins(customPostCssPath) : loadBuiltinPostcssPlugins();
|
|
223
|
+
if (args["--purge"]) {
|
|
224
|
+
_log.default.warn("purge-flag-deprecated", [
|
|
225
|
+
"The `--purge` flag has been deprecated.",
|
|
226
|
+
"Please use `--content` instead."
|
|
227
|
+
]);
|
|
228
|
+
if (!args["--content"]) {
|
|
229
|
+
args["--content"] = args["--purge"];
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
var _args_content_split;
|
|
233
|
+
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 : [];
|
|
234
|
+
let tailwindPlugin = ()=>{
|
|
235
|
+
return {
|
|
236
|
+
postcssPlugin: "tailwindcss",
|
|
237
|
+
Once (root, { result }) {
|
|
238
|
+
_shared.env.DEBUG && console.time("Compiling CSS");
|
|
239
|
+
(0, _processTailwindFeatures.default)(({ createContext })=>{
|
|
240
|
+
console.error();
|
|
241
|
+
console.error("Rebuilding...");
|
|
242
|
+
return ()=>{
|
|
243
|
+
return state.getContext({
|
|
244
|
+
createContext,
|
|
245
|
+
cliConfigPath,
|
|
246
|
+
root,
|
|
247
|
+
result,
|
|
248
|
+
content
|
|
249
|
+
});
|
|
250
|
+
};
|
|
251
|
+
})(root, result);
|
|
252
|
+
_shared.env.DEBUG && console.timeEnd("Compiling CSS");
|
|
253
|
+
}
|
|
254
|
+
};
|
|
255
|
+
};
|
|
256
|
+
tailwindPlugin.postcss = true;
|
|
257
|
+
let plugins = [
|
|
258
|
+
...beforePlugins,
|
|
259
|
+
tailwindPlugin,
|
|
260
|
+
!args["--minify"] && _utils.formatNodes,
|
|
261
|
+
...afterPlugins,
|
|
262
|
+
!args["--no-autoprefixer"] && (0, _deps.loadAutoprefixer)(),
|
|
263
|
+
args["--minify"] && (0, _deps.loadCssNano)()
|
|
264
|
+
].filter(Boolean);
|
|
265
|
+
/** @type {import('postcss').Processor} */ // @ts-ignore
|
|
266
|
+
let processor = postcss(plugins);
|
|
267
|
+
async function readInput() {
|
|
268
|
+
// Piping in data, let's drain the stdin
|
|
269
|
+
if (input === "-") {
|
|
270
|
+
return (0, _utils.drainStdin)();
|
|
271
|
+
}
|
|
272
|
+
// Input file has been provided
|
|
273
|
+
if (input) {
|
|
274
|
+
return _fs.default.promises.readFile(_path.default.resolve(input), "utf8");
|
|
275
|
+
}
|
|
276
|
+
// No input file provided, fallback to default atrules
|
|
277
|
+
return "@tailwind base; @tailwind components; @tailwind utilities";
|
|
278
|
+
}
|
|
279
|
+
async function build() {
|
|
280
|
+
let start = process.hrtime.bigint();
|
|
281
|
+
return readInput().then((css)=>processor.process(css, {
|
|
282
|
+
...postcssOptions,
|
|
283
|
+
from: input,
|
|
284
|
+
to: output
|
|
285
|
+
})).then((result)=>{
|
|
286
|
+
if (!state.watcher) {
|
|
287
|
+
return result;
|
|
288
|
+
}
|
|
289
|
+
_shared.env.DEBUG && console.time("Recording PostCSS dependencies");
|
|
290
|
+
for (let message of result.messages){
|
|
291
|
+
if (message.type === "dependency") {
|
|
292
|
+
state.contextDependencies.add(message.file);
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
_shared.env.DEBUG && console.timeEnd("Recording PostCSS dependencies");
|
|
296
|
+
// TODO: This needs to be in a different spot
|
|
297
|
+
_shared.env.DEBUG && console.time("Watch new files");
|
|
298
|
+
state.watcher.refreshWatchedFiles();
|
|
299
|
+
_shared.env.DEBUG && console.timeEnd("Watch new files");
|
|
300
|
+
return result;
|
|
301
|
+
}).then((result)=>{
|
|
302
|
+
if (!output) {
|
|
303
|
+
process.stdout.write(result.css);
|
|
304
|
+
return;
|
|
305
|
+
}
|
|
306
|
+
return Promise.all([
|
|
307
|
+
(0, _utils.outputFile)(result.opts.to, result.css),
|
|
308
|
+
result.map && (0, _utils.outputFile)(result.opts.to + ".map", result.map.toString())
|
|
309
|
+
]);
|
|
310
|
+
}).then(()=>{
|
|
311
|
+
let end = process.hrtime.bigint();
|
|
312
|
+
console.error();
|
|
313
|
+
console.error("Done in", (end - start) / BigInt(1e6) + "ms.");
|
|
314
|
+
}).then(()=>{}, (err)=>{
|
|
315
|
+
// TODO: If an initial build fails we can't easily pick up any PostCSS dependencies
|
|
316
|
+
// that were collected before the error occurred
|
|
317
|
+
// The result is not stored on the error so we have to store it externally
|
|
318
|
+
// and pull the messages off of it here somehow
|
|
319
|
+
// This results in a less than ideal DX because the watcher will not pick up
|
|
320
|
+
// changes to imported CSS if one of them caused an error during the initial build
|
|
321
|
+
// If you fix it and then save the main CSS file so there's no error
|
|
322
|
+
// The watcher will start watching the imported CSS files and will be
|
|
323
|
+
// resilient to future errors.
|
|
324
|
+
console.error(err);
|
|
325
|
+
});
|
|
326
|
+
}
|
|
327
|
+
/**
|
|
328
|
+
* @param {{file: string, content(): Promise<string>, extension: string}[]} changes
|
|
329
|
+
*/ async function parseChanges(changes) {
|
|
330
|
+
return Promise.all(changes.map(async (change)=>({
|
|
331
|
+
content: await change.content(),
|
|
332
|
+
extension: change.extension
|
|
333
|
+
})));
|
|
334
|
+
}
|
|
335
|
+
if (input !== undefined && input !== "-") {
|
|
336
|
+
state.contextDependencies.add(_path.default.resolve(input));
|
|
337
|
+
}
|
|
338
|
+
return {
|
|
339
|
+
build,
|
|
340
|
+
watch: async ()=>{
|
|
341
|
+
state.watcher = (0, _watchingJs.createWatcher)(args, {
|
|
342
|
+
state,
|
|
343
|
+
/**
|
|
344
|
+
* @param {{file: string, content(): Promise<string>, extension: string}[]} changes
|
|
345
|
+
*/ async rebuild (changes) {
|
|
346
|
+
let needsNewContext = changes.some((change)=>{
|
|
347
|
+
return state.configDependencies.has(change.file) || state.contextDependencies.has(change.file);
|
|
348
|
+
});
|
|
349
|
+
if (needsNewContext) {
|
|
350
|
+
state.context = null;
|
|
351
|
+
} else {
|
|
352
|
+
for (let change of (await parseChanges(changes))){
|
|
353
|
+
state.changedContent.push(change);
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
return build();
|
|
357
|
+
}
|
|
358
|
+
});
|
|
359
|
+
await build();
|
|
360
|
+
}
|
|
361
|
+
};
|
|
362
|
+
}
|