Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/christianmurphy/postcss-combine-duplicated-selectors
automatically keep css selectors unique.
https://github.com/christianmurphy/postcss-combine-duplicated-selectors
css javascript plugin postcss
Last synced: 5 days ago
JSON representation
automatically keep css selectors unique.
- Host: GitHub
- URL: https://github.com/christianmurphy/postcss-combine-duplicated-selectors
- Owner: ChristianMurphy
- License: mit
- Created: 2016-05-10T19:50:26.000Z (over 8 years ago)
- Default Branch: main
- Last Pushed: 2025-01-08T23:30:25.000Z (15 days ago)
- Last Synced: 2025-01-12T03:41:44.749Z (12 days ago)
- Topics: css, javascript, plugin, postcss
- Language: JavaScript
- Homepage:
- Size: 5.02 MB
- Stars: 97
- Watchers: 4
- Forks: 11
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Postcss combine duplicated selectors
[![npm](https://img.shields.io/npm/v/postcss-combine-duplicated-selectors.svg)](https://www.npmjs.com/package/postcss-combine-duplicated-selectors)
[![build status](https://github.com/ChristianMurphy/postcss-combine-duplicated-selectors/workflows/CI/badge.svg)](https://github.com/ChristianMurphy/postcss-combine-duplicated-selectors/actions)
[![dependency status](https://david-dm.org/ChristianMurphy/postcss-combine-duplicated-selectors.svg)](https://david-dm.org/ChristianMurphy/postcss-combine-duplicated-selectors)
[![devDependency status](https://david-dm.org/ChristianMurphy/postcss-combine-duplicated-selectors/dev-status.svg)](https://david-dm.org/ChristianMurphy/postcss-combine-duplicated-selectors?type=dev)Automatically detects and combines duplicated css selectors so you don't have to
:smile:## Usage
### Requirements
In order to use this you will need to have [postcss](https://github.com/postcss/postcss) installed. Depending on whether or not you want to use the CLI you need to install [postcss-cli](https://github.com/postcss/postcss-cli).
```bash
npm install --save-dev postcss postcss-combine-duplicated-selectors
# or
yarn add --dev postcss postcss-combine-duplicated-selectors
```### Using PostCSS JS API
```js
'use strict';const fs = require('fs');
const postcss = require('postcss');
const css = fs.readFileSync('src/app.css');postcss([require('postcss-combine-duplicated-selectors')])
.process(css, {from: 'src/app.css', to: 'app.css'})
.then((result) => {
fs.writeFileSync('app.css', result.css);
if (result.map) fs.writeFileSync('app.css.map', result.map);
});
```### Using PostCSS CLI
```sh
postcss style.css --use postcss-combine-duplicated-selectors --output newcss.css
```### Using Vite
In a `postcss.config.js` file :
```js
module.exports = {
plugins: [require('postcss-combine-duplicated-selectors')],
};
```## Example
Input
```css
.module {
color: green;
}
.another-module {
color: blue;
}
.module {
background: red;
}
.another-module {
background: yellow;
}
```Output
```css
.module {
color: green;
background: red;
}
.another-module {
color: blue;
background: yellow;
}
```### Duplicated Properties
Duplicated properties can optionally be combined.
Set the `removeDuplicatedProperties` option to `true` to enable.
```js
const postcss = require('postcss');
const combineSelectors = require('postcss-combine-duplicated-selectors');postcss([combineSelectors({removeDuplicatedProperties: true})]);
```When enabled the following css
```css
.a {
height: 10px;
background: orange;
background: rgba(255, 165, 0, 0.5);
}
```will combine into
```css
.a {
height: 10px;
background: rgba(255, 165, 0, 0.5);
}
```In order to limit this to only combining properties when the values are equal, set the `removeDuplicatedValues` option to `true` instead. This could clean up duplicated properties, but allow for conscious duplicates such as fallbacks for custom properties.
```js
const postcss = require('postcss');
const combineSelectors = require('postcss-combine-duplicated-selectors');postcss([combineSelectors({removeDuplicatedValues: true})]);
```This will transform the following css
```css
.a {
height: 10px;
}.a {
width: 20px;
background: var(--custom-color);
background: rgba(255, 165, 0, 0.5);
}
```into
```css
.a {
height: 10px;
width: 20px;
background: var(--custom-color);
background: rgba(255, 165, 0, 0.5);
}
```### Media Queries
If you have code with media queries, pass code through [_postcss-combine-media-query_](https://github.com/SassNinja/postcss-combine-media-query) or [_css-mquery-packer_](https://github.com/n19htz/css-mquery-packer) before _postcss-combine-duplicated-selectors_ to ensure optimal results.