Merge SVGs from a folder.
Because Chris Coyier asked.
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-svgstore --save-dev
Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
grunt.loadNpmTasks('grunt-svgstore');
In your project's Gruntfile, add a section named svgstore
to the data object passed into grunt.initConfig()
.
grunt.initConfig({
svgstore: {
options: {
prefix : 'icon-', // This will prefix each ID
svg: { // will be added as attributes to the resulting SVG
viewBox : '0 0 100 100'
}
},
your_target: {
// Target-specific file lists and/or options go here.
},
},
});
Type: String
Default value: ''
A string value that is used to prefix each filename to generate the id.
Type: Object
Default value: {}
An object that is used to generate attributes for the resulting svg
file.
{
viewBox: '0 0 100 100'
}
will result in:
<svg viewBox="0 0 100 100">
[...]
Type: Object
Default value: {}
Just like options.svg
but will add attributes to each generated <symbol>
.
Type: Object
or boolean
Default value: false
Formatting options for generated code.
To format the generated HTML, set formatting
with options like: {indent_size : 2}
, which in context looks like:
default: {
options: {
formatting : {
indent_size : 2
}
}
See js-beautify for more options.
Type: boolean
Default value: false
This will include a demo HTML (named like destName + -demo.html
) from where you can copy your <use>
blocks.
Type: boolean
or Array
Default value: false
Clean up all inline style definitions that may jeopardise later stylesheet-based colouring (fill
).
Apart from true / false, the value of this property can be an array of attributes.
All attributes in the array are removed from all elements in the SVG.
Type: boolean
Default value: false
When set to false, no cleanup is performed on the <defs>
element.
This example will merge all elements from the svgs
folder into the <defs>
-Block of the dest.svg
. You can use that SVG in HTML like:
<!-- Include dest.svg -->
[...]
<svg><use xlink:href="#filename" /></svg>
grunt.initConfig({
svgstore: {
options: {},
default : {
files: {
'dest/dest.svg': ['svgs/*.svg'],
},
},
},
});
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.
- Changed the way ID are collected; unreferenced IDs are removed now in order to save space. (#40)
- Changed the behavior of the 'cleanup'-option (introduced in 0.2.6). Apart from true / false, the value of this property can now be an array of attributes. All attributes in the array are removed from all elements in the SVG. (#41)
- Added an option 'cleanupdefs' (default: false). When set to false, no cleanup is performed on the
<defs>
element. (#41) - Empty
<g>
elements are removed since they have no effect in a document. (#42)
Thanks to Frank3K for the PRs
- Don't generate IDs that start with a number by prefixing them with
svgstore
. (Thanks to #38)
- Add
options.clean
to remove inline styles from source svgs. (Thanks to ain) - Reformat source to use 2 spaces for indentation (Fix #36)
- To generate the id from the filename is now used as a title. (Fix #33)
- Added
options.symbol
to add attributes to generated<symbol>
s (#30) - To generate the id from the filename the name is now cut right before the first dot.
name.min.svg
becomesname
. (Fixes #29)
- Fixed lower case
viewBox
in outputted svg (fix #26)
- Fixed a bug where self-closing elements where nested.
- Move
<symbol>
-tag out of<defs>
-tag (see the spec) - Only create
<defs>
-tag if needed (e.g.<linearGradient>
is used)
- Use a
<symbol>
-tag for representing icons (See TxHawks Comment.) - Write the
viewBox
attribute to the<symbol>
-tag, - Include
title
anddesc
elements in the generated svg for each<symbol>
- use 'filename' as a fallback for
title
- Fix issue #1
- Fixed issue with referencing ids with
url()
(fix #12)
- Added
options.formatting
to format svg via js-beautify
- Fixed npm dependencies
- Inital release