Easy custom icon fonts 

Sam Brook

Standard Icon Fonts

  • Font-awesome
  • fontello.com

Popular standard Icon Font's

Does the job

Custom icon font generators

Get custom icons

http://iconmonstr.com/

https://thenounproject.com/

Online Generators

  • icomoon.io
  • weloveiconfonts.com
  • fontastic.me

Does the job...but

Lives outside the project

=
Difficult to maintain

Solution?

Offline Generator

grunt-webfont

https://github.com/sapegin/grunt-webfont

Gruntfile.js

module.exports = function(grunt) {

  // Project configuration.
  grunt.initConfig({
    pkg: grunt.file.readJSON('package.json'),

	webfont: {
		icons: {
			src: 'src/icons/*.svg',
                        destCss: 'build/assets/css/',
			options: {
				engine: 'node',
			}
		}
	},
  });

  // Load the plugins
  grunt.loadNpmTasks('grunt-webfont');

  // Default task(s).
  grunt.registerTask('default', ['webfont']);

};

Icon Directory

All your .svgs

Generates Icon Font

And CSS

/* Generated by grunt-webfont */
@font-face {
	font-family:"icons";
	src:url("../fonts/icons.eot?a85957eab5f906c56cb7212f45127dae");
	src:url("../fonts/icons.eot?#iefix") format("embedded-opentype"),
		url("../fonts/icons.woff?a85957eab5f906c56cb7212f45127dae") format("woff"),
		url("../fonts/icons.ttf?a85957eab5f906c56cb7212f45127dae") format("truetype");
	font-weight:normal;
	font-style:normal;
}

.icon {
	font-family:"icons";
	display:inline-block;
	vertical-align:middle;
	line-height:1;
	font-weight:normal;
	font-style:normal;
	speak:none;
	text-decoration:inherit;
	text-transform:none;
	text-rendering:auto;
	-webkit-font-smoothing:antialiased;
	-moz-osx-font-smoothing:grayscale;
}

icons.css


/* Icons */


.icon_code-page:before {
	content:"\f101";
}


.icon_code-square:before {
	content:"\f102";
}


.icon_css-code:before {
	content:"\f103";
}


.icon_html-code:before {
	content:"\f104";
}


.icon_javascript-code:before {
	content:"\f105";
}


.icon_php-code:before {
	content:"\f106";
}


.icon_source:before {
	content:"\f107";
}

icons.css

Plus html preview

Optional

Change up to sass

    webfont: {
        icons: {
            destCss: 'src/scss/',
            options: {
                engine: 'node',
                stylesheet: 'scss',
                relativeFontPath: '../fonts',
               // template: 'src/templates/webfont.template.css',
               // templateOptions: {
               //     baseClass:   'iconcss',
               //     classPrefix: 'icon-',
               //     elPrefix:    'i-'
                }
            }
        }
    },

Making it easy

Customise sass output

/** Extends icon classes created by grunt-webfont
 *	@param (string) $icon - the icon to use (without icon- prefix)
 */
@mixin icon($icon, $size:false, $extendbase:true) {
	@extend .icon-#{$icon};
	@if($extendbase) {
		@extend .iconcss; 
	}
	@if($size) {
		font-size: $size;
		width: $size;
		height: $size;
	}
}

src/templates/webfont.template.css

Extending the default iconfont _icons.scss file

Allows for this 

/* main.scss */

@import 'icons';

.subnav-item {
    &:before { @include icon('php-code',30px); }
}

.php-icon {
    &:before { @include icon('php-code',30px); }
}

Summary

Easy to update

Consistant per project

Easier maintenance

The End

Easy custom icon fonts

By Sam Brook

Easy custom icon fonts

  • 1,183