Skip to content

Instantly share code, notes, and snippets.

What would you like to do?
Font editing with Fontello and Gulp
'use strict';
import gulp from 'gulp';
import gulpPlugins from 'gulp-load-plugins';
import pkg from './package.json';
const files = pkg.config.files;
// Rather than manually defined each gulp plugin we need, gulpPlugins defines them for us.
var plugins = gulpPlugins(),
// for executing commands in the command line
exec = require('child_process').exec,
platform = process.platform,
* Opens the font-server defined in package.json
* @return {void} logs to terminal.
fontEdit = () => {
let openFont = {
linux: `/opt/google/chrome/google-chrome --enable-plugins ${pkg.config.fontServer}/$(cat .fontello)`,
darwin: `open -a "Google Chrome" ${pkg.config.fontServer}/$(cat .fontello)`,
win32: `start chrome "${pkg.config.fontServer}/$(cat .fontello)"`
if (!openFont[platform]) {
return false;
// Connects to font server to get a fresh token for our editing session.
// sends current config in the process.
let getFontToken = `curl --silent --show-error --fail --output .fontello --form "config=@${files.fonts}/config.json" ${pkg.config.fontServer} \n`;
return exec(getFontToken + openFont[platform], function(err, stdout, stderr) {
if (stderr) {
console.error(err, stderr);
* Downloads and unpacks our updated font from the fontServer
* @return {void} logs operations to terminal.
fontSave = () => {
var script = [
'if test ! $(which unzip); then echo "Unzip is installed"; exit 128; fi',
'rm -rf .fontello.src',
`curl --silent --show-error --fail --output ${pkg.config.fontServer}/$(cat .fontello)/get`,
'unzip -d .fontello.src',
`rm -rf ${files.fonts}`,
`mv $(find ./.fontello.src -maxdepth 1 -name 'fontello-*') ${files.fonts}`,
'rm -rf .fontello.src'
exec(script.join(' \n '), function(err, stdout, stderr) {
return gulp.src([`${files.fonts}/css/fontello.css`])
if (stderr) {
console.error(err, stderr);
// Font editing tasks
gulp.task('font-edit', fontEdit);
gulp.task('font-save', fontSave);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.