124 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| [![Build Status][ci-img]][ci] [![codecov][codecov-img]][codecov] [![npm][npm-img]][npm]
 | |
| 
 | |
| # CSS Modules: Local by Default
 | |
| 
 | |
| Transformation examples:
 | |
| 
 | |
| Selectors (mode `local`, by default)::
 | |
| 
 | |
| <!-- prettier-ignore-start -->
 | |
| ```css
 | |
| .foo { ... } /* => */ :local(.foo) { ... }
 | |
| 
 | |
| .foo .bar { ... } /* => */ :local(.foo) :local(.bar) { ... }
 | |
| 
 | |
| /* Shorthand global selector */
 | |
| 
 | |
| :global .foo .bar { ... } /* => */ .foo .bar { ... }
 | |
| 
 | |
| .foo :global .bar { ... } /* => */ :local(.foo) .bar { ... }
 | |
| 
 | |
| /* Targeted global selector */
 | |
| 
 | |
| :global(.foo) .bar { ... } /* => */ .foo :local(.bar) { ... }
 | |
| 
 | |
| .foo:global(.bar) { ... } /* => */ :local(.foo).bar { ... }
 | |
| 
 | |
| .foo :global(.bar) .baz { ... } /* => */ :local(.foo) .bar :local(.baz) { ... }
 | |
| 
 | |
| .foo:global(.bar) .baz { ... } /* => */ :local(.foo).bar :local(.baz) { ... }
 | |
| ```
 | |
| <!-- prettier-ignore-end -->
 | |
| 
 | |
| Declarations (mode `local`, by default):
 | |
| 
 | |
| <!-- prettier-ignore-start -->
 | |
| ```css
 | |
| .foo {
 | |
|   animation-name: fadeInOut, global(moveLeft300px), local(bounce);
 | |
| }
 | |
| 
 | |
| .bar {
 | |
|   animation: rotate 1s, global(spin) 3s, local(fly) 6s;
 | |
| }
 | |
| 
 | |
| /* => */ 
 | |
| 
 | |
| :local(.foo) {
 | |
|   animation-name: :local(fadeInOut), moveLeft300px, :local(bounce);
 | |
| }
 | |
| 
 | |
| :local(.bar) {
 | |
|   animation: :local(rotate) 1s, spin 3s, :local(fly) 6s;
 | |
| }
 | |
| ```
 | |
| <!-- prettier-ignore-end -->
 | |
| 
 | |
| ## Pure Mode
 | |
| 
 | |
| In pure mode, all selectors must contain at least one local class or id
 | |
| selector
 | |
| 
 | |
| To ignore this rule for a specific selector, add the a `/* cssmodules-pure-ignore */` comment in front
 | |
| of the selector:
 | |
| 
 | |
| ```css
 | |
| /* cssmodules-pure-ignore */
 | |
| :global(#modal-backdrop) {
 | |
|   ...;
 | |
| }
 | |
| ```
 | |
| 
 | |
| or by adding a `/* cssmodules-pure-no-check */` comment at the top of a file to disable this check for the whole file:
 | |
| 
 | |
| ```css
 | |
| /* cssmodules-pure-no-check */
 | |
| 
 | |
| :global(#modal-backdrop) {
 | |
|   ...;
 | |
| }
 | |
| 
 | |
| :global(#my-id) {
 | |
|   ...;
 | |
| }
 | |
| ```
 | |
| 
 | |
| ## Building
 | |
| 
 | |
| ```bash
 | |
| $ npm install
 | |
| $ npm test
 | |
| ```
 | |
| 
 | |
| - Build: [![Build Status][ci-img]][ci]
 | |
| - Lines: [![coveralls][coveralls-img]][coveralls]
 | |
| - Statements: [![codecov][codecov-img]][codecov]
 | |
| 
 | |
| ## Development
 | |
| 
 | |
| ```bash
 | |
| $ yarn test:watch
 | |
| ```
 | |
| 
 | |
| ## License
 | |
| 
 | |
| MIT
 | |
| 
 | |
| ## With thanks
 | |
| 
 | |
| - [Tobias Koppers](https://github.com/sokra)
 | |
| - [Glen Maddern](https://github.com/geelen)
 | |
| 
 | |
| ---
 | |
| 
 | |
| Mark Dalgleish, 2015.
 | |
| 
 | |
| [ci-img]: https://github.com/css-modules/postcss-modules-local-by-default/actions/workflows/nodejs.yml/badge.svg
 | |
| [ci]: https://github.com/css-modules/postcss-modules-local-by-default/actions/workflows/nodejs.yml
 | |
| [npm-img]: https://img.shields.io/npm/v/postcss-modules-local-by-default.svg?style=flat-square
 | |
| [npm]: https://www.npmjs.com/package/postcss-modules-local-by-default
 | |
| [coveralls-img]: https://img.shields.io/coveralls/css-modules/postcss-modules-local-by-default/master.svg?style=flat-square
 | |
| [coveralls]: https://coveralls.io/r/css-modules/postcss-modules-local-by-default?branch=master
 | |
| [codecov-img]: https://img.shields.io/codecov/c/github/css-modules/postcss-modules-local-by-default/master.svg?style=flat-square
 | |
| [codecov]: https://codecov.io/github/css-modules/postcss-modules-local-by-default?branch=master
 |