Skip to content

sputnik-maps/gulp-inline-svg

 
 

Repository files navigation

gulp-inline-svg

inline-svg plugin for gulp

This plugin takes a couple of SVG files and provides them inside a Sass mixin as inlined background-images. By doing so, you can use them without having to touch you Markup.

Compatibility

The inlined SVG gets URL encoded, so it is save to use starting with IE9.

Important notes

The generated mixin contains width and height values for each SVG. Those values are taken from the width and height attribute inside the SVG. If it does not provide them, they will be set to 0px. You can still overwrite them in your CSS.

Usage

First, install gulp-inline-svg as a development dependency:

npm install --save-dev gulp-inline-svg

Then, add it to your gulpfile.js. I'd recommend to use it in conjunction with gulp-svgmin to clean the SVG before inlining them.

var inlineSvg = require("gulp-inline-svg"),
	svgMin = require('gulp-svgmin');

gulp.src("css/**/*.css")
	.pipe(svgMin())
	.pipe(inlineSvg())
	.pipe(gulp.dest("sass"));

This will create a _svg.scss file inside your 'sass' folder.

Usage inside you Sass code

The _svg.scss file will provide you with the following mixins and functions:

inline-svg mixin

.my-icon {
	// will set the svg as background-image and width/height
	@include inline-svg($icon-name);
}

Paint background SVG

Since @function svg-paint($svg, $options) was added you can paint SVG backgrounds passing $options SASS-map:

.bg-paint-sample {
	@include inline-svg('share', ('fill':#00f, 'stroke': blue));
}

inline-svg-width function

.my-icon {
	margin-left: inline-svg-width($icon-name);
}

inline-svg-height function

.my-icon {
	margin-bottom: inline-svg-height($icon-name);
}

Configuration

If you want wo customize the default configuration, you can pass an options object to the task function:

gulp.src("css/**/*.css")
	.pipe(svgMin())
	.pipe(inlineSvg({
		filename: '_svg-file.scss',
		template: 'mytemplate.mustache'
	}))
	.pipe(gulp.dest("sass"));

filename

Specifies the name of the generated file.

template

The plugin will generate an .scss-file by default, but you can easily adopt this for other languages, by using your own template. With this option, you can specify the path to a mustache template.

You can use the default template as a blueprint to create your own. And please don't hesitate to share your template if you create one for an additional language.

License

MIT License

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 47.8%
  • JavaScript 44.6%
  • CSS 7.6%