1.0.10 • Published 5 days ago

@csstools/postcss-gradient-stop-increments-experimental v1.0.10

Weekly downloads
-
License
CC0-1.0
Repository
github
Last release
5 days ago

PostCSS Gradient Stop Increments

npm install @csstools/postcss-gradient-stop-increments-experimental --save-dev

PostCSS Gradient Stop Increments lets you increment gradient stops following the CSSWG 8616 proposal.

.example-1 {
	background: linear-gradient(red 50%, blue ++1px);
}

.example-2 {
	background: conic-gradient(red ++60deg, blue ++10deg ++50deg, green ++60deg, yellow ++60deg);
}

.example-3 {
	background: conic-gradient(pink ++60deg, cyan 0 ++20deg, gold 0 ++10deg);
}

.example-4 {
	background: linear-gradient(orange 20px, magenta 2vi, aqua ++2vw);
}

/* becomes */

.example-1 {
	background: linear-gradient(red 50%, blue calc(50% + +1px));
}

.example-2 {
	background: conic-gradient(red +60deg, blue 70deg 120deg, green 180deg, yellow 240deg);
}

.example-3 {
	background: conic-gradient(pink +60deg, cyan 0 80deg, gold 0 90deg);
}

.example-4 {
	background: linear-gradient(orange 20px, magenta 2vi, aqua calc(max(20px, 2vi) + +2vw));
}

Usage

Add PostCSS Gradient Stop Increments to your project:

npm install postcss @csstools/postcss-gradient-stop-increments-experimental --save-dev

Use it as a PostCSS plugin:

const postcss = require('postcss');
const postcssGradientStopIncrementsExperimental = require('@csstools/postcss-gradient-stop-increments-experimental');

postcss([
	postcssGradientStopIncrementsExperimental(/* pluginOptions */)
]).process(YOUR_CSS /*, processOptions */);

PostCSS Gradient Stop Increments runs in all Node environments, with special instructions for:

Options

preserve

The preserve option determines whether the original notation is preserved. By default, it is not preserved.

postcssGradientStopIncrementsExperimental({ preserve: true })
.example-1 {
	background: linear-gradient(red 50%, blue ++1px);
}

.example-2 {
	background: conic-gradient(red ++60deg, blue ++10deg ++50deg, green ++60deg, yellow ++60deg);
}

.example-3 {
	background: conic-gradient(pink ++60deg, cyan 0 ++20deg, gold 0 ++10deg);
}

.example-4 {
	background: linear-gradient(orange 20px, magenta 2vi, aqua ++2vw);
}

/* becomes */

.example-1 {
	background: linear-gradient(red 50%, blue calc(50% + +1px));
	background: linear-gradient(red 50%, blue ++1px);
}

.example-2 {
	background: conic-gradient(red +60deg, blue 70deg 120deg, green 180deg, yellow 240deg);
	background: conic-gradient(red ++60deg, blue ++10deg ++50deg, green ++60deg, yellow ++60deg);
}

.example-3 {
	background: conic-gradient(pink +60deg, cyan 0 80deg, gold 0 90deg);
	background: conic-gradient(pink ++60deg, cyan 0 ++20deg, gold 0 ++10deg);
}

.example-4 {
	background: linear-gradient(orange 20px, magenta 2vi, aqua calc(max(20px, 2vi) + +2vw));
	background: linear-gradient(orange 20px, magenta 2vi, aqua ++2vw);
}
1.0.10

5 days ago

1.0.9

5 days ago

1.0.8

2 months ago

1.0.7

3 months ago

1.0.6

4 months ago

1.0.5

5 months ago

1.0.2

10 months ago

1.0.4

8 months ago

1.0.3

10 months ago

1.0.1

1 year ago

1.0.0

1 year ago