Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/polemius/postcss-clamp
PostCSS plugin to transform clamp() to combination of min/max
https://github.com/polemius/postcss-clamp
clamp css max min postcss
Last synced: about 2 hours ago
JSON representation
PostCSS plugin to transform clamp() to combination of min/max
- Host: GitHub
- URL: https://github.com/polemius/postcss-clamp
- Owner: polemius
- License: mit
- Created: 2020-05-03T05:33:37.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-01-06T04:51:59.000Z (about 2 years ago)
- Last Synced: 2025-01-16T20:17:37.215Z (7 days ago)
- Topics: clamp, css, max, min, postcss
- Language: JavaScript
- Homepage:
- Size: 331 KB
- Stars: 29
- Watchers: 2
- Forks: 1
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-list - postcss-clamp
README
# PostCSS Clamp
[![Build Status][ci-img]][ci] [![codecov.io][cov-img]][cov][PostCSS] plugin to transform `clamp()` to combination of `min/max`.
[PostCSS]: https://github.com/postcss/postcss
[ci-img]: https://travis-ci.com/polemius/postcss-clamp.svg?branch=master
[ci]: https://travis-ci.com/polemius/postcss-clamp
[cov-img]: https://codecov.io/github/polemius/postcss-clamp/coverage.svg?branch=master
[cov]: https://codecov.io/github/polemius/postcss-clamp?branch=masterThis plugin transform this css:
```css
.foo {
width: clamp(10px, 4em, 80px);
}
```into this:
```css
.foo {
width: max(10px, min(4em, 80px));
}
```Or with enabled options `precalculate`:
```css
.foo {
width: clamp(10em, 4px, 10px);
}/* becomes */
.foo {
width: max(10em, 14px);
}
```[!['Can I use' table](https://caniuse.bitsofco.de/image/css-math-functions.png)](https://caniuse.com/#feat=css-math-functions)
## Instalation
```bash
$ npm install postcss postcss-clamp --save-dev
or
$ yarn add --dev postcss postcss-clamp
```## Usage
Use [PostCSS Clamp] as a [PostCSS] plugin:
```js
const postcss = require('postcss');
const postcssClamp = require('postcss-clamp');postcss([
postcssClamp(/* pluginOptions */)
]).process(YOUR_CSS /*, processOptions */);
```[PostCSS Clamp] runs in all Node environments, with special instructions for:
| [Node](INSTALL.md#node) | [PostCSS CLI](INSTALL.md#postcss-cli) | [Webpack](INSTALL.md#webpack) | [Create React App](INSTALL.md#create-react-app) | [Gulp](INSTALL.md#gulp) | [Grunt](INSTALL.md#grunt) |
| --- | --- | --- | --- | --- | --- |See [PostCSS] docs for examples for your environment.
## Options
### precalculate
The `precalculate` option determines whether values with the same unit
should be precalculated. By default, these are not precalculation.```js
postcssColorHexAlpha({
precalculate: true
});
```The second and third value has the same unit (`px`):
```css
.foo {
width: clamp(10em, 4px, 10px);
}/* becomes */
.foo {
width: max(10em, 14px);
}
```Here all values have the same unit:
```css
.foo {
width: clamp(10px, 4px, 10px);
}/* becomes */
.foo {
width: 24px;
}
```## LICENSE
See [LICENSE](LICENSE)
[PostCSS]: https://github.com/postcss/postcss
[PostCSS Clamp]: https://github.com/polemius/postcss-clamp