Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mhanberg/jekyll-purgecss

A Jekyll plugin for Purgecss.
https://github.com/mhanberg/jekyll-purgecss

Last synced: 3 months ago
JSON representation

A Jekyll plugin for Purgecss.

Awesome Lists containing this project

README

        

# Jekyll Purgecss

[![Build Status](https://travis-ci.com/mhanberg/jekyll-purgecss.svg?branch=master)](https://travis-ci.com/mhanberg/jekyll-purgecss)
[![Gem Version](https://badge.fury.io/rb/jekyll-purgecss.svg)](https://badge.fury.io/rb/jekyll-purgecss)

A Jekyll plugin for Purgecss.

## Installation

Add this line to your application's Gemfile:

```ruby
gem 'jekyll-purgecss'
```

And then add this line to your application's `_config.yml`:

```yml
# _config.yml

plugins:
- jekyll-purgecss

css_dir: "" # defaults to "css"
```

jekyll-purgecss only runs in production, so make sure that `JEKYLL_ENV=production` on the server where you build your site.

## Usage

Make sure you have [purgecss](https://www.purgecss.com/#cli) installed and has its binary located at `./node_modules/.bin/purgecss`.

Add your Purgecss configuration to a `purgecss.config.js` file in the root of your repository.

```javascript
// purgecss.config.js

module.exports = {
// These are the files that Purgecss will search through
content: ["./_site/**/*.html"],

// These are the stylesheets that will be subjected to the purge
css: ["./_site/css/site.css"]
};
```

#### Tailwind CSS

If you are using [Tailwind CSS](https://tailwindcss.com), you'll need to add a custom `extractor`. More can be read on the Tailwind [documentation](https://tailwindcss.com/docs/controlling-file-size#removing-unused-css-with-purgecss).

```javascript
module.exports = {
content: ["./_site/**/*.html"],
css: ["./_site/css/site.css"],

// Tailwind CSS config
defaultExtractor: content => content.match(/[\w-/:]+(?