Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

postcss-nested

postcss67.2mMIT7.0.2TypeScript support: included

PostCSS plugin to unwrap nested rules like how Sass does it

postcss, css, postcss-plugin, sass, nested

readme

PostCSS Nested

PostCSS plugin to unwrap nested rules closer to Sass syntax.

.phone {
  &_title {
    width: 500px;
    @media (max-width: 500px) {
      width: auto;
    }
    body.is_dark & {
      color: white;
    }
  }
  img {
    display: block;
  }
}

.title {
  font-size: var(--font);

  @at-root html {
    --font: 16px;
  }
}

will be processed to:

.phone_title {
  width: 500px;
}
@media (max-width: 500px) {
  .phone_title {
    width: auto;
  }
}
body.is_dark .phone_title {
  color: white;
}
.phone img {
  display: block;
}

.title {
  font-size: var(--font);
}
html {
  --font: 16px;
}

Related plugins:

  • Use postcss-current-selector after this plugin if you want to use current selector in properties or variables values.
  • Use postcss-nested-ancestors before this plugin if you want to reference any ancestor element directly in your selectors with ^&.

Alternatives:

Sponsored by Evil Martians

Docs

Read full docs here.

changelog

Change Log

This project adheres to Semantic Versioning.

7.0.2

  • Fixed nested selector regression (by @Ulyanov-programmer).

7.0.1

  • Fixed RegExp issue with nested comments (by @Ulyanov-programmer).

7.0.0

  • More complex logic of when to move comments (by @Ulyanov-programmer).
  • Removed Node.js 16, 14, and 12 support.

6.2.0

  • Added @starting-style to bubbling at-rules.

6.1.0

  • Added @container to bubbling at-rules.

6.0

  • Added @layer to bubbling at-rules (by Már Örlygsson).
  • Added moving all preceding comments with rule (by Már Örlygsson).
  • Added with & without parameters on @at-root (by Már Örlygsson).
  • Added rootRuleName option (by Már Örlygsson).
  • Fixed handling sibling @at-root rule blocks (by Már Örlygsson).

5.0.6

  • Fixed custom at-rules nesting (by @bsak-shell).

5.0.5

  • Fixed , at the tail (by Jesse de Boer).

5.0.4

  • Fixed nested & at the tail (by Raphael Luba).
  • Fixed docs (by Samuel Charpentier).

5.0.3

  • Fixed compatibility with Autoprefixer by adding @-webkit-keyframes support.

5.0.2

  • Fixed compatibility with postcss-mixins by moving to visitor API.

5.0.1

  • Fixed PostCSS 8.1 compatibility.
  • Added funding links.

5.0

  • Moved to PostCSS 8.
  • Moved postcss to peerDependencies.

4.2.3

  • Fixed declarations after nested rule and before at-rule (by Rodion Demikhov).

4.2.2

  • Fixed wrong specificity order of declarations (by Rodion Demikhov).

4.2.1

  • Fix TypeScript definitions (by Avi Vahl).

4.2

  • Add @at-root support (by Jason Quense).

4.1.2

  • Improve error messsage on broken selector

4.1.1

  • Add &(:hover) support (by Ben Delarre).

4.1

  • Add unwrap option.

4.0

  • Use PostCSS 7 (by Aleks Hudochenkov).
  • Remove Node.js 4 support.

3.0

  • Add @font-face to bubbling at-rules (by Valeriy Komlev).
  • Add special logic for @font-face bubbling (by Phanindra Pydisetty).
  • Use PostCSS selector parser 3.0.

2.1.2

  • Fix replacing multiple &.

2.1.1

  • Fix :not(&) support.

2.1

  • Add preserveEmpty option (by Federico Zivolo).

2.0.4

  • Fix finding & in some selectors (by Stepan Mikhaylyuk).

2.0.3

  • Doesn’t replace & inside string (by Paul Kiddle).

2.0.2

  • Fix comments moving regression.

2.0.1

  • Fix rules order regression (by Dmitry Vibe).

2.0

  • Use PostCSS 6 API.

1.0.1

  • Clean up npm package.

1.0

  • Use PostCSS 5.0 API.
  • Do not add spaces to selector in compressed CSS.
  • Move nodes with its comment above.

0.3.2

  • Fix @supports at-rule support (by Ben Briggs).

0.3.1

  • Pass PostCSS Plugin Guidelines.

0.3

  • Do not unwrap custom at-rules.
  • Add bubble option to unwrap some custom at-rules.
  • Support PostCSS 4.1 API.
  • Fix last semicolon after unwrapping.

0.2.2

  • Module returns function to have common PostCSS API.

0.2.1

  • Add comma support to selectors unwrap.

0.2

  • Use PostCSS 4.0.
  • Fix indent, when move rules to other parent.

0.1

  • Initial release.