Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lazarljubenovic/grassy
Build layout through ASCII art in Sass (and more). No pre-built CSS. No additional markup.
https://github.com/lazarljubenovic/grassy
ascii-art grid grid-layout grid-system sass
Last synced: 4 months ago
JSON representation
Build layout through ASCII art in Sass (and more). No pre-built CSS. No additional markup.
- Host: GitHub
- URL: https://github.com/lazarljubenovic/grassy
- Owner: lazarljubenovic
- License: mit
- Created: 2017-03-11T16:14:56.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2017-03-22T15:22:58.000Z (almost 8 years ago)
- Last Synced: 2024-08-09T09:30:42.737Z (7 months ago)
- Topics: ascii-art, grid, grid-layout, grid-system, sass
- Language: CSS
- Homepage:
- Size: 253 KB
- Stars: 333
- Watchers: 13
- Forks: 8
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
Awesome Lists containing this project
README
# Grassy | [Docs](https://lazarljubenovic.github.io/grassy/) | [Playground](http://codepen.io/dbox/pen/aJLGxE)
> What you ASCII is what you get.
Build layout through ASCII art in Sass (and more).
## Installation and Usage
```
yarn add grassy -D
``````scss
@import "node_modules/grassy/grassy";
```## Quick overview
### ASCII art
HTML:
```htmlHello
Grassy
World!```
Sass:
```scss
section {
@include grid((
'x-x',
'x x',
));
}
```Result:
data:image/s3,"s3://crabby-images/efdc5/efdc5da476af77e8f39b82432411f30c47de1292" alt="A grid with two columns. The first column has one cell; the second column has two cells."
### As complex as you like!
HTML _never_ requires any additional classes, wrappers, etc.
```scss
@include grid(
'x-x-x x x'
'x x-x-x-x'
' x-x x'
' x x-x '
);
```data:image/s3,"s3://crabby-images/a2e4d/a2e4d8dbd37c752e15d9302e6f7a8c43064b5c7f" alt=""
### `distribute` syntax
Don't lose count of your `x`s! Freely combine `distribute` with your ASCII art.
```scss
section {
@include grid((
'x-x x x',
distribute 7,
));
}
```data:image/s3,"s3://crabby-images/42e16/42e166867fc3e8edcafada0230b82e3d7cc0954f" alt=""
### Quick `n`-column layouts
As basic as it gets.
```scss
section {
@include fixed-grid(3);
}
```data:image/s3,"s3://crabby-images/18c73/18c7352ac4a859f345f522e1ae613187ff47e6d6" alt=""
### Don't like dangling elements?
Just tell Grassy to distribute dangling elements.
```scss
section {
@include fixed-grid(
3,
$distribute-dangling: true
);
}
```data:image/s3,"s3://crabby-images/2501f/2501f8a4a367a8fb3856a848487dba318af6636e" alt=""
Or distribute them at the top if you prefer it that way.
```scss
section {
@include fixed-grid(
3,
$distribute-dangling: true,
$dangling-at-beginning: true,
);
}
```data:image/s3,"s3://crabby-images/344e3/344e31b920602c7e16891372a3a76125a065b1b9" alt=""
Also take a look at [full documentation](https://lazarljubenovic.github.io/grassy/). (Includes both the public API and explanation of some internal functions to help you if you want to contribute but have no idea where to start from.)
## Playground
Try it out now in the [Codepen playground](http://codepen.io/dbox/pen/aJLGxE).
## Why Grassy?
- No additional markup.
- CSS is generated based on your needs: you won't have styles you don't use.
- The syntax makes it almost like you're drawing boxes instead of doing CSS.
- Great for generated content.
- Zero runtime dependencies.More coming [soon™©®](https://github.com/lazarljubenovic/grassy/issues?q=is%3Aissue+is%3Aopen+label%3A%22future+plans%22).
---
**NOTE** This is still in rapid development phase. There might be breaking changes along the way. For this reason, I advise you not to use this in serious projects. However, to find (and fix) bugs, people have to use it _somewhere_. So if you have a suitable non-critical project, it would be awesome if you could try out Grassy.
Please report bugs and suggest ideas by [opening an issue](https://github.com/lazarljubenovic/grassy/issues).
---
Grassy is heavily inspired by [Effortless Style](https://vimeo.com/101718785), a talk by [Heydon Pickering](https://twitter.com/heydonworks).