JSPM

  • Created
  • Published
  • Downloads 3890
  • Score
    100M100P100Q128321F

SVG sprites & stacks galore — Grunt plugin wrapping around svg-sprite that reads in a bunch of SVG files, optimizes them and creates SVG sprites and CSS resources in various flavours

Package Exports

  • grunt-svg-sprite

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (grunt-svg-sprite) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

grunt-svg-sprite NPM version Build Status Dependency Status

is a Grunt plugin wrapping around svg-sprite which reads in a bunch of SVG files, optimizes them and creates SVG sprites in various flavours:

  1. Traditional CSS sprites for use with background images (configuration)
  2. CSS sprites with pre-defined SVG views, suitable for foreground images as well (configuration)
  3. Inline sprites using the <defs> element (configuration)
  4. Inline sprites using the <symbol> element (configuration)
  5. SVG stacks (configuration)

Features & configuration? → svg-sprite

This manual covers only Grunt specific installation and configuration aspects. For a full list of features and options, please see the svg-sprite manual.

Getting Started

This plugin requires Grunt ~0.4.5

If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:

npm install grunt-svg-sprite --save-dev

Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:

grunt.loadNpmTasks('grunt-svg-sprite');

The «svg_sprite» task

Overview

In your project's Gruntfile, add a section named svg_sprite to the data object passed into grunt.initConfig().

grunt.initConfig({
    svg_sprite		: {
        options		: {
            // Task-specific options go here.
        },
        your_target	: {
            // Target-specific file lists and/or options go here.
        },
    },
});

The task-specific options are optional and affect all defined targets. You may define as many targets (your_target) as you want.

Targets

In the simplest case an «svg_sprite» target looks like this:

your_target: {
    src			: ['path/to/assets/**/*.svg'],
    dest		: 'path/to/css/dir',
    options		: {
        // Target-specific options
    }
},

However, as the path/to/assets would become part of the shape IDs, you will most likely want to add a working directory in most cases:

your_target: {
    expand		: true,
    cwd			: 'path/to/assets',
    src			: ['**/*.svg'],
    dest		: 'path/to/css/dir',
    options		: {
        // Target-specific options
    }
},

Options

As target-specific options you may provide a main configuration object as described in the svg-sprite manual. Configuration-wise, svg-sprite and grunt-svg-sprite differ only in one respect:

options.dest → dest

Type: String Default value: '.'

Instead of being nested inside the options object, svg-sprite's dest property gets promoted one level up and becomes part of the Grunt target configuration itself (see examples above).

Usage Examples

Basic example

In this very basic example, mostly default settings will be applied to create a traditional CSS sprite (bundle of SVG sprite and CSS stylesheet).

grunt.initConfig({
    svg_sprite					: {
        basic					: {
        
            // Target basics
            expand				: true,
            cwd					: 'assets',
            src					: ['**/*.svg'],
            dest				: 'out',
            
            // Target options
            options				: {
                mode			: {
                    css			: {		// Activate the «css» mode
                        render	: {
                            css	: true	// Activate CSS output (with default options)
                        }
                    }
                }
            }
        }
    }
});

The following files and directories are created:

out
`-- css
    |-- sprite.css
    `-- svg
        `-- sprite.css-495d2010.svg

The cryptical looking part in the SVG's file name is the result of svg-sprite's cache busting feature which is enabled by default for CSS sprites. We'll turn this off in the next example.

More complex example

The following example is a little more complex:

  • We'll create a «view» CSS sprite and a «symbol» sprite in one go.
  • Instead of CSS, we'll render a Sass stylesheet resource for the «view» sprite.
  • We'll turn off cache busting for the «view» sprite and create extra CSS rules specifying each shape's dimensions.
  • We'll downscale the SVG shapes to 32×32 pixels if necessary and add 10 pixels padding to all sides.
  • We'll keep the intermediate SVG source files.
grunt.initConfig({
    svg_sprite					: {
        complex: {
        
            // Target basics
            expand					: true,
            cwd						: 'assets',
            src						: ['**/*.svg'],
            dest					: 'out',
            
            // Target options
            options					: {
                shape				: {
                    dimension		: {			// Set maximum dimensions
                        maxWidth	: 32,
                        maxHeight	: 32
                    },
                    spacing			: {			// Add padding
                        padding		: 10
                    },
                    dest			: 'out/intermediate-svg'	// Keep the intermediate files
                },
                mode				: {
                    view			: {			// Activate the «view» mode
                        bust		: false,
                        render		: {
                            scss	: true		// Activate Sass output (with default options)
                        }
                    },
                    symbol			: true		// Activate the «symbol» mode
                }
            }
        }
    }
});

The following files and directories are created:

out
|-- intermediate-svg
|   |-- weather-clear.svg
|   |-- weather-snow.svg
|   `-- weather-storm.svg
|-- symbol
|   `-- svg
|       `-- sprite.symbol.svg
`-- view
    |-- sprite.scss
    `-- svg
        `-- sprite.view.svg

Advanced features

For more advanced features like

please refer to the svg-sprite manual.

Contributing

In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using Grunt.

Release history

v1.0.10 Feature release

v1.0.9 Maintenance release

  • Compatible with svg-sprite 1.0.9
  • Updated dependencies
  • Introduced svg getter in templating shape variables
  • Fixed logging error in SVGO optimization
  • Fixed missing XML namespaces in SVG stack
  • Fixed cache busting errors with example HTML document

v1.0.8 Bugfix release

v1.0.7 Feature & bugfix release

  • Compatible with svg-sprite 1.0.7
  • Improved error handling
  • Improved XML & DOCTYPE declaration handling and fixed (#28)

v1.0.6 Feature release

v1.0.5 Bufix release

v1.0.1

  • First release of the new plugin generation, compatible with svg-sprite 1.0.1
  • Rewritten from scratch (#18)
  • Dropped libxmljs dependency for improving Windows support (#14)
  • Added support for view, symbol and stack modes (#19, #24)
  • Switched to relative positioning in CSS sprites (#23)
  • Made the configuration of Mustache templates and destinations more intuitive
  • Enabled customization of shape IDs
  • Enabled custom SVG transformations
  • Enhanced padding options (#20)
  • Added cache busting for css and view mode (enabled by default; #9)
  • Added support for meta data injection

For older release notes please see here.

Copyright © 2015 Joschi Kuphal (joschi@kuphal.net / @jkphl)

grunt-svg-sprite is licensed under the terms of the MIT license.

The contained example SVG icons are part of the Tango Icon Library and belong to the Public Domain.