Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/csstools/postcss-dir-pseudo-class
Use the :dir() pseudo-class to style by directionality in CSS
https://github.com/csstools/postcss-dir-pseudo-class
Last synced: 8 days ago
JSON representation
Use the :dir() pseudo-class to style by directionality in CSS
- Host: GitHub
- URL: https://github.com/csstools/postcss-dir-pseudo-class
- Owner: csstools
- License: cc0-1.0
- Archived: true
- Created: 2017-05-30T20:53:48.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2021-12-16T12:30:30.000Z (almost 3 years ago)
- Last Synced: 2024-04-14T04:01:07.239Z (7 months ago)
- Language: JavaScript
- Homepage: https://github.com/csstools/postcss-plugins/tree/main/plugins/postcss-dir-pseudo-class
- Size: 218 KB
- Stars: 16
- Watchers: 6
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
README
# PostCSS Dir Pseudo Class [][postcss]
[![NPM Version][npm-img]][npm-url]
[![CSS Standard Status][css-img]][css-url]
[![Build Status][cli-img]][cli-url]
[![Support Chat][git-img]][git-url][PostCSS Dir Pseudo Class] lets you style by directionality using the `:dir()`
pseudo-class in CSS, following the [Selectors] specification.[!['Can I use' table](https://caniuse.bitsofco.de/image/css-dir-pseudo.png)](https://caniuse.com/#feat=css-dir-pseudo)
```pcss
article h3:dir(rtl) {
margin-right: 10px;
}article h3:dir(ltr) {
margin-left: 10px;
}/* becomes */
[dir="rtl"] article h3 {
margin-right: 10px;
}[dir="ltr"] article h3 {
margin-left: 10px;
}
```### Maintaining Specificity
Using [PostCSS Dir Pseudo Class] will not impact selector weight, but it will
require having at least one `[dir]` attribute in your HTML. If you don’t have
_any_ `[dir]` attributes, consider using the following JavaScript:```js
// force at least one dir attribute (this can run at any time)
document.documentElement.dir=document.documentElement.dir||'ltr';
```If you absolutely cannot add a `[dir]` attribute in your HTML or even force one
via JavaScript, you can still work around this by presuming a direction in your
CSS using the [`dir` option](#dir-option), but understand that this will
sometimes increase selector weight by one element (`html`).## Usage
Add [PostCSS Dir Pseudo Class] to your project:
```bash
npm install postcss-dir-pseudo-class --save-dev
```Use [PostCSS Dir Pseudo Class] to process your CSS:
```js
const postcssDirPseudoClass = require('postcss-dir-pseudo-class');postcssDirPseudoClass.process(YOUR_CSS /*, processOptions, pluginOptions */);
```Or use it as a [PostCSS] plugin:
```js
const postcss = require('postcss');
const postcssDirPseudoClass = require('postcss-dir-pseudo-class');postcss([
postcssDirPseudoClass(/* pluginOptions */)
]).process(YOUR_CSS /*, processOptions */);
```[PostCSS Dir Pseudo Class] 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) |
| --- | --- | --- | --- | --- | --- |## Options
### dir
The `dir` option allows you presume a direction in your CSS. By default, this
is not specified and you are required to include a direction `[dir]` attribute
somewhere in your HTML, preferably on the `html` element.Here’s an example of using the `dir` option to presume a left-to-right
direction:```js
postcssDirPseudoClass({ dir: 'ltr' });
``````pcss
.example:dir(ltr) {
margin-left: 10px;
}.example:dir(rtl) {
margin-right: 10px;
}/* becomes */
html:not([dir="rtl"]) .example {
margin-left: 10px;
}[dir="rtl"] .example {
margin-right: 10px;
}
```### preserve
The `preserve` option determines whether the original `:dir()` rule should
remain in the CSS. By default, the original rule is not preserved.```js
postcssDirPseudoClass({ preserve: true });
``````pcss
article h3:dir(rtl) {
margin-right: 10px;
}article h3:dir(ltr) {
margin-left: 10px;
}/* becomes */
[dir="rtl"] article h3 {
margin-right: 10px;
}article h3:dir(rtl) {
margin-right: 10px;
}[dir="ltr"] article h3 {
margin-left: 10px;
}article h3:dir(ltr) {
margin-left: 10px;
}
```[cli-img]: https://github.com/csstools/postcss-dir-pseudo-class/workflows/test/badge.svg
[cli-url]: https://github.com/csstools/postcss-dir-pseudo-class/actions/workflows/test.yml?query=workflow/test
[css-img]: https://cssdb.org/badge/dir-pseudo-class.svg
[css-url]: https://cssdb.org/#dir-pseudo-class
[git-img]: https://img.shields.io/badge/support-chat-blue.svg
[git-url]: https://gitter.im/postcss/postcss
[npm-img]: https://img.shields.io/npm/v/postcss-dir-pseudo-class.svg
[npm-url]: https://www.npmjs.com/package/postcss-dir-pseudo-class
[win-img]: https://img.shields.io/appveyor/ci/jonathantneal/postcss-dir-pseudo-class.svg
[win-url]: https://ci.appveyor.com/project/jonathantneal/postcss-dir-pseudo-class[Gulp PostCSS]: https://github.com/postcss/gulp-postcss
[Grunt PostCSS]: https://github.com/nDmitry/grunt-postcss
[PostCSS]: https://github.com/postcss/postcss
[PostCSS Loader]: https://github.com/postcss/postcss-loader
[PostCSS Dir Pseudo Class]: https://github.com/jonathantneal/postcss-dir-pseudo-class
[Selectors]: https://www.w3.org/TR/selectors-4/#the-dir-pseudo