Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

gatsby-plugin-purgecss

Package Overview
Dependencies
Maintainers
1
Versions
24
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

gatsby-plugin-purgecss

Gatsby plugin for purgecss. Removes unused css/sass/less/stylus from files and modules.

  • 2.0.2
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
8.6K
decreased by-3.04%
Maintainers
1
Weekly downloads
 
Created
Source

Gatsby Plugin Purgecss npm version

For Gatsby 2 only

CircleCI Build Status Coverage Status Renovate badge Known Vulnerabilities tested with jest

dependencies dev dependencies peer dependencies

What is this plugin about?

This plugin allows Gatsby to remove unused css from css/sass/less/stylus files and modules using purgecss.

Supported files

Installation

npm i --save-dev gatsby-plugin-purgecss

Usage

Add the plugin AFTER other css plugins

// gatsy-config.js
module.exports = {
  plugins: [
    `gatsby-plugin-stylus`,
    `gatsby-plugin-sass`,
    `gatsby-plugin-less`,
    // Add after these plugins if used
    `gatsby-plugin-purgecss`
  ]
};

Important Notes

Running

This plugin only runs when building the project (gatsby build).
To make sure the plugin is working, set rejected: true option to print out the removed selectors.

Selector matching

This plugin loads css files (or transformed output from css plugins) and searches for matching selectors in js, jsx, ts, tsx files in src/. It does not know which css file belongs to which source file. Therefore, for eg., if there is a class .module in some css file, it will not be removed if it used in any script file under src/.

Whitelist ['html', 'body']

Since html and body tags do not appear in src/ files, it is whitelisted by default to not be removed.
If there is a need to modify the whitelist, it is recommended to keep these tags and append the required selectors using the option whitelist: ['html', 'body', '.my-selector']

Options

This plugins supports most purgecss options as is (except css).

Read about purgecss options in detail

{
  resolve: `gatsby-plugin-purgecss`,
  options: {
    /** 
     * Print the list of removed selectors.
     * default: false
     **/ 
    rejected?: boolean,


    /**
     * Stops from removing these selectors.
     * default: ['html', 'body']
     * If you want to whitelist more selectors, make sure to include 'html', 'body' in the array.
     **/
    whitelist?: Array<string>,


    /**
     * These options are available but not used by default.
     * Read more https://www.purgecss.com/configuration
     **/
    extractors?: Array<ExtractorsObj>,
    whitelistPatterns?: Array<RegExp>,
    whitelistPatternsChildren?: Array<RegExp>,
    keyframes?: boolean,
    fontFace?: boolean,


    /**
     * Files to search for selectors.
     **/
     // default: [path.join(process.cwd(), 'src/**/!(*.d).{ts,js,jsx,tsx}')]
    content: Array<string | RawContent>, 
  }
}

Versioning

Gatsy-plugin-purgecss use SemVer for versioning.
It will try to match official gatsby plugin's major version.

Acknowledgment

This project was made possible due to the incredible work done on the following projects:

License

This project is licensed under the MIT License - see the LICENSE file for details.

Keywords

FAQs

Package last updated on 02 Aug 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc