Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sporeball/linn
organize your CSS properties according to 9elements' guide "How to organize CSS"
https://github.com/sporeball/linn
css enforce-conventions sass
Last synced: 3 months ago
JSON representation
organize your CSS properties according to 9elements' guide "How to organize CSS"
- Host: GitHub
- URL: https://github.com/sporeball/linn
- Owner: sporeball
- License: mit
- Created: 2021-09-15T01:07:19.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2021-11-10T01:35:54.000Z (about 3 years ago)
- Last Synced: 2024-04-24T11:29:06.742Z (9 months ago)
- Topics: css, enforce-conventions, sass
- Language: JavaScript
- Homepage:
- Size: 11.7 KB
- Stars: 6
- Watchers: 2
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hackclub - linn - [@sporeball](https://github.com/sporeball) - **(JavaScript)** _Organize CSS properties according to 9elements' style guide._ (CLI Tools)
README
# linn
**linn** is a little tool that reorders CSS properties to conform to [9elements](https://9elements.com)' guide [How to organize CSS](https://9elements.com/css-rule-order).
**disclaimer: this is meant to be used on well-structured, un-minified CSS files. i am not responsible for unexpected behavior or loss of data.**
### install
```
npm i -g linn
```### usage
```css
/* style.css */
a {
color:#0076d1;
text-decoration:none
}p {
font-size:1rem;
float:left;
margin-bottom:0.5rem
}
```
```
$ linn style.css
linn (https://github.com/sporeball/linn)
o reordered 2 rules:
- a
- p
$ cat style.css
a {
text-decoration:none;
color:#0076d1
}p {
float:left;
margin-bottom:0.5rem;
font-size:1rem
}
```### FAQ
#### why did you make this?
i like 9elements' guide, but it's hard to keep everything in order by hand. this can do that for me.#### how is the order decided?
properties are ordered as suggested in the guide, with related properties grouped together. in the case of properties like `background`, the shorthand property appears first, followed by the more specific properties in the order they appear in the shorthand. properties that do not specifically appear in the order will be placed after the ones which do.if you want to look at the order, see [lib/order.js](https://github.com/sporeball/linn/blob/master/lib/order.js).
#### i disagree with where something is in the order. can you change it?
no. like [standard/standard](https://github.com/standard/standard), linn is really supposed to help you avoid [bikeshedding](https://docs.freebsd.org/en/books/faq/#bikeshed-painting). unless i've forgotten a property or a new one is added to the CSS spec, the order is unlikely to change.### donate
you can support the development of this project and others via Patreon:[![Support me on Patreon](https://img.shields.io/endpoint.svg?url=https%3A%2F%2Fshieldsio-patreon.vercel.app%2Fapi%3Fusername%3Dsporeball%26type%3Dpledges%26suffix%3D%252Fmonth&style=for-the-badge)](https://patreon.com/sporeball)