Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/apsislabs/jekyll-tidy
A gem for tidying Jekyll HTML output
https://github.com/apsislabs/jekyll-tidy
gem jekyll ruby
Last synced: 3 months ago
JSON representation
A gem for tidying Jekyll HTML output
- Host: GitHub
- URL: https://github.com/apsislabs/jekyll-tidy
- Owner: apsislabs
- License: mit
- Created: 2016-02-25T21:36:23.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2020-07-14T13:56:53.000Z (over 4 years ago)
- Last Synced: 2024-04-26T19:03:55.314Z (9 months ago)
- Topics: gem, jekyll, ruby
- Language: Ruby
- Size: 40 KB
- Stars: 42
- Watchers: 5
- Forks: 5
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Jekyll::Tidy
[![Build Status](https://travis-ci.org/apsislabs/jekyll-tidy.svg?branch=master)](https://travis-ci.org/apsislabs/jekyll-tidy) [![Gem Version](https://badge.fury.io/rb/jekyll-tidy.svg)](https://badge.fury.io/rb/jekyll-tidy)
`jekyll-tidy` is a plugin for tidying the HTML output of your Jekyll website, using either [`HtmlBeautifier`](https://github.com/threedaymonk/htmlbeautifier) or [`HtmlCompressor`](https://github.com/paolochiodi/htmlcompressor).
## Usage
Usage is straightforward.
### via Bundler
If you have the gem Bundler installed, simply include the gem in your `Gemfile` under the `:jekyll_plugins` group:
```ruby
group :jekyll_plugins do
gem "jekyll-tidy"
end
```
Run `bundle install` to install the plugin and its dependencies.
The plugin will be automatically loaded the next time you run `bundle exec jekyll build` or `bundle exec jekyll serve`### via config file
The plugin-gem can also be loaded via the `_config.yml`
Simply add this gem to the `gems:` list (or `plugins:` list, if you're on Jekyll v3.5 and above.)```yaml
gems:
- jekyll-tidy
```## Configuration
`jekyll-tidy` takes three configuration settings:
* `exclude` — an array of files to exclude from tidying.
* `ignore_env` — a `JEKYLL_ENV` string on which to skip tidying entirely.
* `compress_html` — a flag for whether or not to compress the HTML output```yaml
jekyll_tidy:
exclude: ["index.html"]
ignore_env: development
compress_html: true # or false
```### exclude (default: [])
`exclude` is an array of relative file paths that will be ignored by `jekyll-tidy`. Exclude must be set as an array, or it will cause errors.
```yaml
jekyll_tidy:
exclude: ["index.html"] # excludes only index.html
````exclude` can also take a glob of file paths.
**Note:** File globs need to be wrapped with `""` when defining the array with square brackets.```yaml
jekyll_tidy:
exclude: ["_posts/*.md"] # excludes all markdown files directly within the _posts directory.
``````yaml
jekyll_tidy:
exclude:
- _posts/*.md # excludes all markdown files directly within the _posts directory.
- _posts/**/*.md # excludes all markdown files anywhere within the _posts directory
```### compress_html (default: false)
If `compress_html` is set to `true` then `HtmlCompressor` will be used to tidy the markup.
When set to `false`, `HtmlBeautifier` will be used to tidy the markup.**Note**: if you set the `compress_html` option to `true` and your templates have inline CSS or javascript, it will not be minified.
### ignore_env (default: nil)
If `ignore_env` is set to a string, we will check the `JEKYLL_ENV` environment variable and skip tidying if it matches.
Setting `_config.yml` with:
```yaml
ignore_env: development
```and then running jekyll server with:
```sh
$ JEKYLL_ENV=development jekyll serve
```will skip all tidying.
## Development
After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake test` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run `bundle exec rake install`.
## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/apsislabs/jekyll-tidy.
## License
The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
---
# Built by Apsis
[![apsis](https://s3-us-west-2.amazonaws.com/apsiscdn/apsis.png)](https://www.apsis.io)
`jekyll-tidy` was built by Apsis Labs. We love sharing what we build! Check out our [other libraries on Github](https://github.com/apsislabs), and if you like our work you can [hire us](https://www.apsis.io/work-with-us/) to build your vision.