From 6b4e66a0d7eb3e5f88eb1e24cfc8ec05c5791cf1 Mon Sep 17 00:00:00 2001 From: Dan Green Date: Sun, 21 Aug 2016 14:55:25 +0700 Subject: [PATCH 1/7] partial offline svg support --- helpers-es5.js | 18 +++++++++++++++--- index.js | 2 +- package.json | 1 + 3 files changed, 17 insertions(+), 4 deletions(-) diff --git a/helpers-es5.js b/helpers-es5.js index c51c91da..f58d713e 100644 --- a/helpers-es5.js +++ b/helpers-es5.js @@ -15,6 +15,7 @@ var path = require('path'), async = require('async'), mkdirp = require('mkdirp'), Jimp = require('jimp'), + svg2png = require('svg2png'), File = require('vinyl'), Reflect = require('harmony-reflect'), NRC = require('node-rest-client').Client; @@ -212,9 +213,20 @@ var path = require('path'), return callback(error, canvas, jimp); }); }, - read: function read(file, callback) { - print('Image:read', 'Reading file: ' + file.buffer); - Jimp.read(file, callback); + read: function read(file, type, callback) { + print('Image:read', 'Reading file: ' + file.buffer + ' with type ' + type); + + function readFile(file) { + Jimp.read(file, callback); + } + + if (type == 'svg') { + svg2png(file, { width: 512, height: 512 }) + .then(readFile) + .catch(callback); + } else { + readFile(file); + } }, resize: function resize(image, properties, offset, callback) { print('Images:resize', 'Resizing image to contain in ' + properties.width + 'x' + properties.height + ' with offset ' + offset); diff --git a/index.js b/index.js index 2da780aa..bb12d930 100644 --- a/index.js +++ b/index.js @@ -55,7 +55,7 @@ const _ = require('underscore'), async.waterfall([ (cb) => - µ.Images.read(icon.file, cb), + µ.Images.read(icon.file, icon.size.type, cb), (buffer, cb) => µ.Images.resize(buffer, properties, offset, cb), (resizedBuffer, cb) => diff --git a/package.json b/package.json index 426fcb2b..c7b88dd4 100644 --- a/package.json +++ b/package.json @@ -37,6 +37,7 @@ "mkdirp": "^0.5.1", "node-rest-client": "^1.5.1", "require-directory": "^2.1.1", + "svg2png": "^3.0.1", "through2": "^2.0.0", "tinycolor2": "^1.1.2", "to-ico": "^1.0.1", From ba2cde6d70cbf9991f58b289f70d233189e1228e Mon Sep 17 00:00:00 2001 From: Dan Green Date: Sun, 21 Aug 2016 17:17:17 +0700 Subject: [PATCH 2/7] source parameter as array fix, better svg support --- es5.js | 30 ++++++++++++---------- helpers-es5.js | 69 +++++++++++++++++++++++++++++++++++--------------- helpers.js | 56 +++++++++++++++++++++++++++++++++------- index.js | 8 +++--- readme.md | 2 +- 5 files changed, 117 insertions(+), 48 deletions(-) diff --git a/es5.js b/es5.js index 349478c3..fce33553 100644 --- a/es5.js +++ b/es5.js @@ -25,7 +25,7 @@ var _ = require('underscore'), µ = helpers(options), background = µ.General.background(options.background); - function createFavicon(sourceset, properties, name, callback) { + function createFavicon(sourceset, properties, name, platformOptions, callback) { if (path.extname(name) === '.ico') { async.map(properties.sizes, function (sizeProperties, cb) { var newProperties = clone(properties); @@ -35,7 +35,7 @@ var _ = require('underscore'), var tempName = 'favicon-temp-' + newProperties.width + 'x' + newProperties.height + '.png'; - createFavicon(sourceset, newProperties, tempName, cb); + createFavicon(sourceset, newProperties, tempName, platformOptions, cb); }, function (error, results) { var files = []; @@ -49,21 +49,21 @@ var _ = require('underscore'), }); } else { (function () { - var minimum = Math.min(properties.width, properties.height), - icon = _.min(sourceset, function (ico) { - return ico.size >= minimum; - }); + var maximum = Math.max(properties.width, properties.height), + offset = Math.round(maximum / 100 * platformOptions.offset) || 0; async.waterfall([function (cb) { - return µ.Images.read(icon.file, cb); + return µ.Images.nearest(sourceset, properties); + }, function (nearest, cb) { + return µ.Images.read(nearest.file, cb); }, function (buffer, cb) { - return µ.Images.resize(buffer, minimum, cb); + return µ.Images.resize(buffer, properties, offset, cb); }, function (resizedBuffer, cb) { return µ.Images.create(properties, background, function (error, canvas) { return cb(error, resizedBuffer, canvas); }); }, function (resizedBuffer, canvas, cb) { - return µ.Images.composite(canvas, resizedBuffer, properties, minimum, cb); + return µ.Images.composite(canvas, resizedBuffer, properties, maximum - offset, cb); }, function (composite, cb) { µ.Images.getBuffer(composite, cb); }], function (error, buffer) { @@ -97,11 +97,11 @@ var _ = require('underscore'), }); } - function createFavicons(sourceset, platform, callback) { + function createFavicons(sourceset, platform, platformOptions, callback) { var images = []; async.forEachOf(config.icons[platform], function (properties, name, cb) { - return createFavicon(sourceset, properties, name, function (error, image) { + return createFavicon(sourceset, properties, name, platformOptions, function (error, image) { return cb(images.push(image) && error); }); }, function (error) { @@ -109,9 +109,9 @@ var _ = require('underscore'), }); } - function createPlatform(sourceset, platform, callback) { + function createPlatform(sourceset, platform, platformOptions, callback) { async.parallel([function (cb) { - return createFavicons(sourceset, platform, cb); + return createFavicons(sourceset, platform, platformOptions, cb); }, function (cb) { return createFiles(platform, cb); }, function (cb) { @@ -125,8 +125,10 @@ var _ = require('underscore'), var response = { images: [], files: [], html: [] }; async.forEachOf(options.icons, function (enabled, platform, cb) { + var platformOptions = (typeof enabled === 'undefined' ? 'undefined' : _typeof(enabled)) == "object" ? enabled : {}; + if (enabled) { - createPlatform(sourceset, platform, function (error, images, files, html) { + createPlatform(sourceset, platform, platformOptions, function (error, images, files, html) { response.images = response.images.concat(images); response.files = response.files.concat(files); response.html = response.html.concat(html); diff --git a/helpers-es5.js b/helpers-es5.js index f58d713e..abcd1e8c 100644 --- a/helpers-es5.js +++ b/helpers-es5.js @@ -95,23 +95,31 @@ var path = require('path'), return callback('No source provided'); } else if (Buffer.isBuffer(_source)) { sourceset = [{ size: sizeOf(_source), file: _source }]; - return callback(sourceset.length ? null : 'Favicons source is invalid', sourceset); - } else if ((typeof _source === 'undefined' ? 'undefined' : _typeof(_source)) === 'object') { - async.each(_source, function (file, size, cb) { + callback(null, sourceset); + } else if (Array.isArray(_source)) { + async.each(_source, function (file, cb) { return readFile(file, function (error, buffer) { + if (error) { + return cb(error); + } + sourceset.push({ - size: { width: size, height: size, type: 'png' }, + size: sizeOf(buffer), file: buffer }); - return cb(error); + cb(null); }); }, function (error) { - return callback(error || sourceset.length ? null : 'Favicons source is invalid'); - }, sourceset); + return callback(error || sourceset.length ? null : 'Favicons source is invalid', sourceset); + }); } else if (typeof _source === 'string') { readFile(_source, function (error, buffer) { + if (error) { + return callback(error); + } + sourceset = [{ size: sizeOf(buffer), file: buffer }]; - return callback(error || (sourceset.length ? null : 'Favicons source is invalid'), sourceset); + callback(null, sourceset); }); } else { return callback('Invalid source type provided'); @@ -213,19 +221,40 @@ var path = require('path'), return callback(error, canvas, jimp); }); }, - read: function read(file, type, callback) { - print('Image:read', 'Reading file: ' + file.buffer + ' with type ' + type); - - function readFile(file) { - Jimp.read(file, callback); - } + read: function read(file, callback) { + print('Image:read', 'Reading file: ' + file.buffer); + return Jimp.read(file, callback); + }, + nearest: function nearest(sourceset, properties, callback) { + print('Image:nearest', 'Find nearest icon to ' + properties.width + 'x' + properties.height); + var sideSize = Math.max(properties.width, properties.height), + nearestIcon = sourceset[0], + nearestSideSize = Math.max(nearestIcon.size.width, nearestIcon.size.height), + svgSource = _.find(sourceset, function (source) { + return source.size.type == 'svg'; + }); - if (type == 'svg') { - svg2png(file, { width: 512, height: 512 }) - .then(readFile) - .catch(callback); + if (svgSource) { + print('Image:nearest', 'SVG source will be saved as ' + properties.width + 'x' + properties.height); + svg2png(svgSource.file, { height: properties.height, width: properties.width }).then(function (resizedBuffer) { + return callback(null, { + size: sizeOf(resizedBuffer), + file: resizedBuffer + }); + }).catch(function (err) { + console.error(err);callback(err); + }); } else { - readFile(file); + _.each(sourceset, function (icon) { + var max = Math.max(icon.size.width, icon.size.height); + + if ((nearestSideSize > max || nearestSideSize < sideSzie) && max >= sideSzie) { + nearestIcon = icon; + nearestSideSize = max; + } + }); + + callback(null, nearestIcon); } }, resize: function resize(image, properties, offset, callback) { @@ -235,7 +264,7 @@ var path = require('path'), if (offset) { image.resize(properties.width - offset, properties.height - offset); } - + return callback(null, image); }, composite: function composite(canvas, image, properties, maximum, callback) { diff --git a/helpers.js b/helpers.js index 64b44ec8..5c577447 100644 --- a/helpers.js +++ b/helpers.js @@ -11,6 +11,7 @@ const path = require('path'), async = require('async'), mkdirp = require('mkdirp'), Jimp = require('jimp'), + svg2png = require('svg2png'), File = require('vinyl'), Reflect = require('harmony-reflect'), NRC = require('node-rest-client').Client; @@ -90,22 +91,31 @@ const path = require('path'), return callback('No source provided'); } else if (Buffer.isBuffer(source)) { sourceset = [{ size: sizeOf(source), file: source }]; - return callback(sourceset.length ? null : 'Favicons source is invalid', sourceset); - } else if (typeof source === 'object') { - async.each(source, (file, size, cb) => + callback(null, sourceset); + } else if (Array.isArray(source)) { + async.each(source, (file, cb) => readFile(file, (error, buffer) => { + if (error) { + return cb(error); + } + sourceset.push({ - size: { width: size, height: size, type: 'png' }, + size: sizeOf(buffer), file: buffer }); - return cb(error); + cb(null); }), - (error) => - callback(error || sourceset.length ? null : 'Favicons source is invalid'), sourceset); + (error) => + callback(error || sourceset.length ? null : 'Favicons source is invalid', sourceset) + ); } else if (typeof source === 'string') { readFile(source, (error, buffer) => { + if (error) { + return callback(error); + } + sourceset = [{ size: sizeOf(buffer), file: buffer }]; - return callback(error || (sourceset.length ? null : 'Favicons source is invalid'), sourceset); + callback(null, sourceset); }); } else { return callback('Invalid source type provided'); @@ -202,7 +212,35 @@ const path = require('path'), }, read: (file, callback) => { print('Image:read', `Reading file: ${ file.buffer }`); - Jimp.read(file, callback); + return Jimp.read(file, callback); + }, + nearest: (sourceset, properties, callback) => { + print('Image:nearest', `Find nearest icon to ${ properties.width }x${ properties.height }`); + let sideSize = Math.max(properties.width, properties.height), + nearestIcon = sourceset[0], + nearestSideSize = Math.max(nearestIcon.size.width, nearestIcon.size.height), + svgSource = _.find(sourceset, (source) => source.size.type == 'svg'); + + if (svgSource) { + print('Image:nearest', `SVG source will be saved as ${ properties.width }x${ properties.height }`); + svg2png(svgSource.file, { height: properties.height, width: properties.width }) + .then((resizedBuffer) => callback(null, { + size: sizeOf(resizedBuffer), + file: resizedBuffer + })) + .catch(callback); + } else { + _.each(sourceset, (icon) => { + let max = Math.max(icon.size.width, icon.size.height); + + if ((nearestSideSize > max || nearestSideSize < sideSzie) && max >= sideSzie) { + nearestIcon = icon; + nearestSideSize = max; + } + }); + + callback(null, nearestIcon); + } }, resize: (image, properties, offset, callback) => { print('Images:resize', `Resizing image to contain in ${ properties.width }x${ properties.height } with offset ${ offset }`); diff --git a/index.js b/index.js index bb12d930..441caa8f 100644 --- a/index.js +++ b/index.js @@ -48,14 +48,14 @@ const _ = require('underscore'), } ); } else { - const minimum = Math.min(properties.width, properties.height), - maximum = Math.max(properties.width, properties.height), - icon = _.min(sourceset, (ico) => ico.size >= minimum), + const maximum = Math.max(properties.width, properties.height), offset = Math.round(maximum / 100 * platformOptions.offset) || 0; async.waterfall([ (cb) => - µ.Images.read(icon.file, icon.size.type, cb), + µ.Images.nearest(sourceset, properties, cb), + (nearest, cb) => + µ.Images.read(nearest.file, cb), (buffer, cb) => µ.Images.resize(buffer, properties, offset, cb), (resizedBuffer, cb) => diff --git a/readme.md b/readme.md index 01a8ef3d..ca94b5a8 100644 --- a/readme.md +++ b/readme.md @@ -20,7 +20,7 @@ Please note: Favicons is written in ES6, meaning you need Node 4.x or above. ```js var favicons = require('favicons'), - source = 'test/logo.png', // Source image(s). `string`, `buffer` or array of `{ size: filepath }` + source = 'test/logo.png', // Source image(s). `string`, `buffer` or array of `string` configuration = { appName: null, // Your application's name. `string` appDescription: null, // Your application's description. `string` From 14c4cc5e152b1d822aa867381236b85b7c1c41c7 Mon Sep 17 00:00:00 2001 From: Dan Green Date: Mon, 22 Aug 2016 00:48:50 +0700 Subject: [PATCH 3/7] platform options checking, firefox icon fix, apply offset to rfg --- config/platform-options.json | 6 +++ config/rfg.json | 9 ++-- es5.js | 6 +-- helpers-es5.js | 98 +++++++++++++++++++++++++----------- helpers.js | 82 +++++++++++++++++++++--------- index.js | 6 +-- readme.md | 10 ++-- 7 files changed, 151 insertions(+), 66 deletions(-) create mode 100644 config/platform-options.json diff --git a/config/platform-options.json b/config/platform-options.json new file mode 100644 index 00000000..b867be49 --- /dev/null +++ b/config/platform-options.json @@ -0,0 +1,6 @@ +{ + "offset": { + "platforms": ["appleIcon", "firefox", "coast"], + "defaultTo": 0 + } +} \ No newline at end of file diff --git a/config/rfg.json b/config/rfg.json index 0e2e250b..eb033dce 100644 --- a/config/rfg.json +++ b/config/rfg.json @@ -12,7 +12,7 @@ "desktop_browser": {}, "ios": { "picture_aspect": "background_and_margin", - "margin": "4", + "margin": "0", "background_color": "#FFFFFF", "startup_image": { "background_color": "#FFFFFF" @@ -25,7 +25,8 @@ "firefox_app": { "picture_aspect": "circle", "keep_picture_in_circle": "true", - "circle_inner_margin": "5", + "circle_inner_margin": "0", + "margin": "0", "background_color": "#FFFFFF", "manifest": { "app_name": "Favicons", @@ -35,7 +36,7 @@ } }, "android_chrome": { - "picture_aspect": "shadow", + "picture_aspect": "no_change", "manifest": { "name": "Favicons", "display": "standalone", @@ -46,7 +47,7 @@ "coast": { "picture_aspect": "background_and_margin", "background_color": "#FFFFFF", - "margin": "12%" + "margin": "0" }, "yandex_browser": { "background_color": "#FFFFFF", diff --git a/es5.js b/es5.js index fce33553..bf69589c 100644 --- a/es5.js +++ b/es5.js @@ -53,7 +53,7 @@ var _ = require('underscore'), offset = Math.round(maximum / 100 * platformOptions.offset) || 0; async.waterfall([function (cb) { - return µ.Images.nearest(sourceset, properties); + return µ.Images.nearest(sourceset, properties, offset, cb); }, function (nearest, cb) { return µ.Images.read(nearest.file, cb); }, function (buffer, cb) { @@ -63,7 +63,7 @@ var _ = require('underscore'), return cb(error, resizedBuffer, canvas); }); }, function (resizedBuffer, canvas, cb) { - return µ.Images.composite(canvas, resizedBuffer, properties, maximum - offset, cb); + return µ.Images.composite(canvas, resizedBuffer, properties, offset, maximum, cb); }, function (composite, cb) { µ.Images.getBuffer(composite, cb); }], function (error, buffer) { @@ -125,7 +125,7 @@ var _ = require('underscore'), var response = { images: [], files: [], html: [] }; async.forEachOf(options.icons, function (enabled, platform, cb) { - var platformOptions = (typeof enabled === 'undefined' ? 'undefined' : _typeof(enabled)) == "object" ? enabled : {}; + var platformOptions = µ.General.preparePlatformOptions(platform, enabled); if (enabled) { createPlatform(sourceset, platform, platformOptions, function (error, images, files, html) { diff --git a/helpers-es5.js b/helpers-es5.js index abcd1e8c..987c8702 100644 --- a/helpers-es5.js +++ b/helpers-es5.js @@ -18,7 +18,8 @@ var path = require('path'), svg2png = require('svg2png'), File = require('vinyl'), Reflect = require('harmony-reflect'), - NRC = require('node-rest-client').Client; + NRC = require('node-rest-client').Client, + PLATFORM_OPTIONS = require('./config/platform-options.json'); (function () { @@ -125,6 +126,30 @@ var path = require('path'), return callback('Invalid source type provided'); } }, + preparePlatformOptions: function preparePlatformOptions(platform, options) { + if ((typeof options === 'undefined' ? 'undefined' : _typeof(options)) != 'object') { + options = {}; + } + + _.each(options, function (value, key) { + var platformOptionsRef = PLATFORM_OPTIONS[key]; + + if (typeof platformOptionsRef == 'undefined' || platformOptionsRef.platforms.indexOf(platform) == -1) { + return Reflect.deleteProperty(options, key); + } + }); + + _.each(PLATFORM_OPTIONS, function (_ref, key) { + var platforms = _ref.platforms; + var defaultTo = _ref.defaultTo; + + if (typeof options[key] == 'undefined' && platforms.indexOf(platform) != -1) { + options[key] = defaultTo; + } + }); + + return options; + }, vinyl: function vinyl(object) { return new File({ path: object.name, @@ -225,30 +250,33 @@ var path = require('path'), print('Image:read', 'Reading file: ' + file.buffer); return Jimp.read(file, callback); }, - nearest: function nearest(sourceset, properties, callback) { - print('Image:nearest', 'Find nearest icon to ' + properties.width + 'x' + properties.height); - var sideSize = Math.max(properties.width, properties.height), - nearestIcon = sourceset[0], - nearestSideSize = Math.max(nearestIcon.size.width, nearestIcon.size.height), + nearest: function nearest(sourceset, properties, offset, callback) { + print('Image:nearest', 'Find nearest icon to ' + properties.width + 'x' + properties.height + ' with offset ' + offset + '%'); + + var offsetSize = offset * 2, + width = properties.width - offsetSize, + height = properties.height - offsetSize, + sideSize = Math.max(width, height), svgSource = _.find(sourceset, function (source) { return source.size.type == 'svg'; }); + var nearestIcon = sourceset[0], + nearestSideSize = Math.max(nearestIcon.size.width, nearestIcon.size.height); + if (svgSource) { - print('Image:nearest', 'SVG source will be saved as ' + properties.width + 'x' + properties.height); - svg2png(svgSource.file, { height: properties.height, width: properties.width }).then(function (resizedBuffer) { + print('Image:nearest', 'SVG source will be saved as ' + width + 'x' + height); + svg2png(svgSource.file, { height: height, width: width }).then(function (resizedBuffer) { return callback(null, { size: sizeOf(resizedBuffer), file: resizedBuffer }); - }).catch(function (err) { - console.error(err);callback(err); - }); + }).catch(callback); } else { _.each(sourceset, function (icon) { var max = Math.max(icon.size.width, icon.size.height); - if ((nearestSideSize > max || nearestSideSize < sideSzie) && max >= sideSzie) { + if ((nearestSideSize > max || nearestSideSize < sideSize) && max >= sideSize) { nearestIcon = icon; nearestSideSize = max; } @@ -258,18 +286,16 @@ var path = require('path'), } }, resize: function resize(image, properties, offset, callback) { - print('Images:resize', 'Resizing image to contain in ' + properties.width + 'x' + properties.height + ' with offset ' + offset); - image.contain(properties.width, properties.height, Jimp.HORIZONTAL_ALIGN_CENTER | Jimp.VERTICAL_ALIGN_MIDDLE); - - if (offset) { - image.resize(properties.width - offset, properties.height - offset); - } - + print('Images:resize', 'Resizing image to contain in ' + properties.width + 'x' + properties.height + ' with offset ' + offset + '%'); + var offsetSize = offset * 2; + image.contain(properties.width - offsetSize, properties.height - offsetSize, Jimp.HORIZONTAL_ALIGN_CENTER | Jimp.VERTICAL_ALIGN_MIDDLE); return callback(null, image); }, - composite: function composite(canvas, image, properties, maximum, callback) { - var offsetHeight = properties.height - maximum > 0 ? (properties.height - maximum) / 2 : 0, - offsetWidth = properties.width - maximum > 0 ? (properties.width - maximum) / 2 : 0, + composite: function composite(canvas, image, properties, offset, maximum, callback) { + var offsetSize = offset * 2, + maximumWithOffset = maximum - offsetSize, + offsetHeight = properties.height - maximumWithOffset > 0 ? (properties.height - maximumWithOffset) / 2 : 0, + offsetWidth = properties.width - maximumWithOffset > 0 ? (properties.width - maximumWithOffset) / 2 : 0, circle = path.join(__dirname, 'mask.png'), overlay = path.join(__dirname, 'overlay.png'); @@ -278,8 +304,10 @@ var path = require('path'), image.rotate(ROTATE_DEGREES); } - print('Images:composite', 'Compositing ' + maximum + 'x' + maximum + ' favicon on ' + properties.width + 'x' + properties.height + ' canvas'); - canvas.composite(image, offsetWidth, offsetHeight); + var compositeIcon = function compositeIcon() { + print('Images:composite', 'Compositing ' + maximum + 'x' + maximum + ' favicon on ' + properties.width + 'x' + properties.height + ' canvas with offset ' + offset + '%'); + canvas.composite(image, offsetWidth, offsetHeight); + }; if (properties.mask) { print('Images:composite', 'Masking composite image on circle'); @@ -292,9 +320,11 @@ var path = require('path'), images[1].resize(maximum, Jimp.AUTO); canvas.mask(images[0], 0, 0); canvas.composite(images[1], 0, 0); + compositeIcon(); return callback(error, canvas); }); } else { + compositeIcon(); return callback(null, canvas); } }, @@ -307,22 +337,30 @@ var path = require('path'), RFG: { configure: function configure(sourceset, request, callback) { print('RFG:configure', 'Configuring RFG API request'); - request.master_picture.content = _.max(sourceset, function (image) { - return image.size.width; - }).file.toString('base64'); + var svgSource = _.find(sourceset, function (source) { + return source.size.type == 'svg'; + }); + request.master_picture.content = (svgSource || _.max(sourceset, function (_ref2) { + var _ref2$size = _ref2.size; + var width = _ref2$size.width; + var height = _ref2$size.height; + return Math.max(width, height); + })).file.toString('base64'); request.files_location.path = options.path; if (options.icons.android) { + request.favicon_design.android_chrome.theme_color = options.background; request.favicon_design.android_chrome.manifest.name = options.appName; request.favicon_design.android_chrome.manifest.display = options.display; request.favicon_design.android_chrome.manifest.orientation = options.orientation; - request.favicon_design.android_chrome.theme_color = options.background; } else { Reflect.deleteProperty(request.favicon_design, 'android_chrome'); } if (options.icons.appleIcon) { + var offset = _.property('offset')(options.icons.appleIcon) || 0; request.favicon_design.ios.background_color = options.background; + request.favicon_design.ios.margin = Math.round(57 / 100 * offset); } else { Reflect.deleteProperty(request.favicon_design, 'ios'); } @@ -334,7 +372,9 @@ var path = require('path'), } if (options.icons.coast) { + var _offset = _.property('offset')(options.icons.coast) || 0; request.favicon_design.coast.background_color = options.background; + request.favicon_design.coast.margin = Math.round(228 / 100 * _offset); } else { Reflect.deleteProperty(request.favicon_design, 'coast'); } @@ -344,7 +384,9 @@ var path = require('path'), } if (options.icons.firefox) { + var _offset2 = _.property('offset')(options.icons.firefox) || 0; request.favicon_design.firefox_app.background_color = options.background; + request.favicon_design.firefox_app.margin = Math.round(60 / 100 * _offset2); request.favicon_design.firefox_app.manifest.app_name = options.appName; request.favicon_design.firefox_app.manifest.app_description = options.appDescription; request.favicon_design.firefox_app.manifest.developer_name = options.developerName; diff --git a/helpers.js b/helpers.js index 5c577447..c87e0744 100644 --- a/helpers.js +++ b/helpers.js @@ -14,7 +14,8 @@ const path = require('path'), svg2png = require('svg2png'), File = require('vinyl'), Reflect = require('harmony-reflect'), - NRC = require('node-rest-client').Client; + NRC = require('node-rest-client').Client, + PLATFORM_OPTIONS = require('./config/platform-options.json'); (() => { @@ -121,6 +122,27 @@ const path = require('path'), return callback('Invalid source type provided'); } }, + preparePlatformOptions: (platform, options) => { + if (typeof options != 'object') { + options = {}; + } + + _.each(options, (value, key) => { + let platformOptionsRef = PLATFORM_OPTIONS[key]; + + if (typeof platformOptionsRef == 'undefined' || platformOptionsRef.platforms.indexOf(platform) == -1) { + return Reflect.deleteProperty(options, key); + } + }); + + _.each(PLATFORM_OPTIONS, ({ platforms, defaultTo }, key) => { + if (typeof options[key] == 'undefined' && platforms.indexOf(platform) != -1) { + options[key] = defaultTo; + } + }); + + return options; + }, vinyl: (object) => new File({ path: object.name, @@ -214,16 +236,21 @@ const path = require('path'), print('Image:read', `Reading file: ${ file.buffer }`); return Jimp.read(file, callback); }, - nearest: (sourceset, properties, callback) => { - print('Image:nearest', `Find nearest icon to ${ properties.width }x${ properties.height }`); - let sideSize = Math.max(properties.width, properties.height), - nearestIcon = sourceset[0], - nearestSideSize = Math.max(nearestIcon.size.width, nearestIcon.size.height), + nearest: (sourceset, properties, offset, callback) => { + print('Image:nearest', `Find nearest icon to ${ properties.width }x${ properties.height } with offset ${ offset }%`); + + const offsetSize = offset * 2, + width = properties.width - offsetSize, + height = properties.height - offsetSize, + sideSize = Math.max(width, height), svgSource = _.find(sourceset, (source) => source.size.type == 'svg'); + let nearestIcon = sourceset[0], + nearestSideSize = Math.max(nearestIcon.size.width, nearestIcon.size.height); + if (svgSource) { - print('Image:nearest', `SVG source will be saved as ${ properties.width }x${ properties.height }`); - svg2png(svgSource.file, { height: properties.height, width: properties.width }) + print('Image:nearest', `SVG source will be saved as ${ width }x${ height }`); + svg2png(svgSource.file, { height, width }) .then((resizedBuffer) => callback(null, { size: sizeOf(resizedBuffer), file: resizedBuffer @@ -233,7 +260,7 @@ const path = require('path'), _.each(sourceset, (icon) => { let max = Math.max(icon.size.width, icon.size.height); - if ((nearestSideSize > max || nearestSideSize < sideSzie) && max >= sideSzie) { + if ((nearestSideSize > max || nearestSideSize < sideSize) && max >= sideSize) { nearestIcon = icon; nearestSideSize = max; } @@ -243,18 +270,16 @@ const path = require('path'), } }, resize: (image, properties, offset, callback) => { - print('Images:resize', `Resizing image to contain in ${ properties.width }x${ properties.height } with offset ${ offset }`); - image.contain(properties.width, properties.height, Jimp.HORIZONTAL_ALIGN_CENTER | Jimp.VERTICAL_ALIGN_MIDDLE); - - if (offset) { - image.resize(properties.width - offset, properties.height - offset); - } - + print('Images:resize', `Resizing image to contain in ${ properties.width }x${ properties.height } with offset ${ offset }%`); + let offsetSize = offset * 2; + image.contain(properties.width - offsetSize, properties.height - offsetSize, Jimp.HORIZONTAL_ALIGN_CENTER | Jimp.VERTICAL_ALIGN_MIDDLE); return callback(null, image); }, - composite: (canvas, image, properties, maximum, callback) => { - const offsetHeight = properties.height - maximum > 0 ? (properties.height - maximum) / 2 : 0, - offsetWidth = properties.width - maximum > 0 ? (properties.width - maximum) / 2 : 0, + composite: (canvas, image, properties, offset, maximum, callback) => { + const offsetSize = offset * 2, + maximumWithOffset = maximum - offsetSize, + offsetHeight = properties.height - maximumWithOffset > 0 ? (properties.height - maximumWithOffset) / 2 : 0, + offsetWidth = properties.width - maximumWithOffset > 0 ? (properties.width - maximumWithOffset) / 2 : 0, circle = path.join(__dirname, 'mask.png'), overlay = path.join(__dirname, 'overlay.png'); @@ -263,8 +288,10 @@ const path = require('path'), image.rotate(ROTATE_DEGREES); } - print('Images:composite', `Compositing ${ maximum }x${ maximum } favicon on ${ properties.width }x${ properties.height } canvas`); - canvas.composite(image, offsetWidth, offsetHeight); + const compositeIcon = () => { + print('Images:composite', `Compositing ${ maximum }x${ maximum } favicon on ${ properties.width }x${ properties.height } canvas with offset ${ offset }%`); + canvas.composite(image, offsetWidth, offsetHeight); + }; if (properties.mask) { print('Images:composite', 'Masking composite image on circle'); @@ -276,9 +303,11 @@ const path = require('path'), images[1].resize(maximum, Jimp.AUTO); canvas.mask(images[0], 0, 0); canvas.composite(images[1], 0, 0); + compositeIcon(); return callback(error, canvas); }); } else { + compositeIcon(); return callback(null, canvas); } }, @@ -291,20 +320,23 @@ const path = require('path'), RFG: { configure: (sourceset, request, callback) => { print('RFG:configure', 'Configuring RFG API request'); - request.master_picture.content = _.max(sourceset, (image) => image.size.width).file.toString('base64'); + const svgSource = _.find(sourceset, (source) => source.size.type == 'svg'); + request.master_picture.content = (svgSource || _.max(sourceset, ({ size: { width, height }}) => Math.max(width, height))).file.toString('base64'); request.files_location.path = options.path; if (options.icons.android) { + request.favicon_design.android_chrome.theme_color = options.background; request.favicon_design.android_chrome.manifest.name = options.appName; request.favicon_design.android_chrome.manifest.display = options.display; request.favicon_design.android_chrome.manifest.orientation = options.orientation; - request.favicon_design.android_chrome.theme_color = options.background; } else { Reflect.deleteProperty(request.favicon_design, 'android_chrome'); } if (options.icons.appleIcon) { + let offset = _.property('offset')(options.icons.appleIcon) || 0; request.favicon_design.ios.background_color = options.background; + request.favicon_design.ios.margin = Math.round(57 / 100 * offset); } else { Reflect.deleteProperty(request.favicon_design, 'ios'); } @@ -316,7 +348,9 @@ const path = require('path'), } if (options.icons.coast) { + let offset = _.property('offset')(options.icons.coast) || 0; request.favicon_design.coast.background_color = options.background; + request.favicon_design.coast.margin = Math.round(228 / 100 * offset); } else { Reflect.deleteProperty(request.favicon_design, 'coast'); } @@ -326,7 +360,9 @@ const path = require('path'), } if (options.icons.firefox) { + let offset = _.property('offset')(options.icons.firefox) || 0; request.favicon_design.firefox_app.background_color = options.background; + request.favicon_design.firefox_app.margin = Math.round(60 / 100 * offset); request.favicon_design.firefox_app.manifest.app_name = options.appName; request.favicon_design.firefox_app.manifest.app_description = options.appDescription; request.favicon_design.firefox_app.manifest.developer_name = options.developerName; diff --git a/index.js b/index.js index 441caa8f..1609cf69 100644 --- a/index.js +++ b/index.js @@ -53,7 +53,7 @@ const _ = require('underscore'), async.waterfall([ (cb) => - µ.Images.nearest(sourceset, properties, cb), + µ.Images.nearest(sourceset, properties, offset, cb), (nearest, cb) => µ.Images.read(nearest.file, cb), (buffer, cb) => @@ -62,7 +62,7 @@ const _ = require('underscore'), µ.Images.create(properties, background, (error, canvas) => cb(error, resizedBuffer, canvas)), (resizedBuffer, canvas, cb) => - µ.Images.composite(canvas, resizedBuffer, properties, maximum - offset, cb), + µ.Images.composite(canvas, resizedBuffer, properties, offset, maximum, cb), (composite, cb) => { µ.Images.getBuffer(composite, cb); } @@ -118,7 +118,7 @@ const _ = require('underscore'), const response = { images: [], files: [], html: [] }; async.forEachOf(options.icons, (enabled, platform, cb) => { - const platformOptions = typeof enabled == "object" ? enabled : {}; + const platformOptions = µ.General.preparePlatformOptions(platform, enabled); if (enabled) { createPlatform(sourceset, platform, platformOptions, (error, images, files, html) => { diff --git a/readme.md b/readme.md index ca94b5a8..278326c5 100644 --- a/readme.md +++ b/readme.md @@ -35,14 +35,14 @@ var favicons = require('favicons'), logging: false, // Print logs to console? `boolean` online: false, // Use RealFaviconGenerator to create favicons? `boolean` icons: { - android: true, // Create Android homescreen icon. `boolean` or `{ offset: offsetInPercentage }` + android: true, // Create Android homescreen icon. `boolean` appleIcon: true, // Create Apple touch icons. `boolean` or `{ offset: offsetInPercentage }` - appleStartup: true, // Create Apple startup images. `boolean` or `{ offset: offsetInPercentage }` + appleStartup: true, // Create Apple startup images. `boolean` coast: { offset: 25 }, // Create Opera Coast icon with offset 25%. `boolean` or `{ offset: offsetInPercentage }` - favicons: true, // Create regular favicons. `boolean` or `{ offset: offsetInPercentage }` + favicons: true, // Create regular favicons. `boolean` firefox: true, // Create Firefox OS icons. `boolean` or `{ offset: offsetInPercentage }` - windows: true, // Create Windows 8 tile icons. `boolean` or `{ offset: offsetInPercentage }` - yandex: true // Create Yandex browser icon. `boolean` or `{ offset: offsetInPercentage }` + windows: true, // Create Windows 8 tile icons. `boolean` + yandex: true // Create Yandex browser icon. `boolean` } }, callback = function (error, response) { From 4c2b14bfc0ef7dbf345c14612084c92c98b5aeba Mon Sep 17 00:00:00 2001 From: Dan Green Date: Mon, 22 Aug 2016 01:25:20 +0700 Subject: [PATCH 4/7] rfg platformOptions fix, html from rfg fix --- config/defaults.json | 1 + es5.js | 10 ++++--- helpers-es5.js | 62 +++++++++++++++++++++++--------------------- helpers.js | 56 ++++++++++++++++++++------------------- index.js | 13 +++++++--- readme.md | 1 + 6 files changed, 79 insertions(+), 64 deletions(-) diff --git a/config/defaults.json b/config/defaults.json index d76f224e..83cde0fc 100644 --- a/config/defaults.json +++ b/config/defaults.json @@ -12,6 +12,7 @@ "version": "1.0", "logging": false, "online": false, + "preferOnline": false, "pipeHTML": false, "icons": { "android": true, diff --git a/es5.js b/es5.js index bf69589c..643ec8f8 100644 --- a/es5.js +++ b/es5.js @@ -143,7 +143,7 @@ var _ = require('underscore'), } function unpack(pack, callback) { - var response = { images: [], files: [], html: pack.html.split(',') }; + var response = { images: [], files: [], html: pack.html.split('\n') }; async.each(pack.files, function (url, cb) { return µ.RFG.fetch(url, function (error, box) { @@ -162,12 +162,16 @@ var _ = require('underscore'), }, function (pack, cb) { return unpack(pack, cb); }], function (error, results) { - return callback(error, results); + if (error && options.preferOnline) { + createOffline(sourceset, callback); + } else { + callback(error, results); + } }); } function create(sourceset, callback) { - options.online ? createOnline(sourceset, callback) : createOffline(sourceset, callback); + options.online || options.preferOnline ? createOnline(sourceset, callback) : createOffline(sourceset, callback); } async.waterfall([function (callback) { diff --git a/helpers-es5.js b/helpers-es5.js index 987c8702..7c9cd008 100644 --- a/helpers-es5.js +++ b/helpers-es5.js @@ -79,9 +79,35 @@ var path = require('path'), }); } + function preparePlatformOptions(platform, options) { + if ((typeof options === 'undefined' ? 'undefined' : _typeof(options)) != 'object') { + options = {}; + } + + _.each(options, function (value, key) { + var platformOptionsRef = PLATFORM_OPTIONS[key]; + + if (typeof platformOptionsRef == 'undefined' || platformOptionsRef.platforms.indexOf(platform) == -1) { + return Reflect.deleteProperty(options, key); + } + }); + + _.each(PLATFORM_OPTIONS, function (_ref, key) { + var platforms = _ref.platforms; + var defaultTo = _ref.defaultTo; + + if (typeof options[key] == 'undefined' && platforms.indexOf(platform) != -1) { + options[key] = defaultTo; + } + }); + + return options; + } + return { General: { + preparePlatformOptions: preparePlatformOptions, background: function background(hex) { print('General:background', 'Parsing colour ' + hex); var rgba = color(hex).toRgb(); @@ -126,30 +152,6 @@ var path = require('path'), return callback('Invalid source type provided'); } }, - preparePlatformOptions: function preparePlatformOptions(platform, options) { - if ((typeof options === 'undefined' ? 'undefined' : _typeof(options)) != 'object') { - options = {}; - } - - _.each(options, function (value, key) { - var platformOptionsRef = PLATFORM_OPTIONS[key]; - - if (typeof platformOptionsRef == 'undefined' || platformOptionsRef.platforms.indexOf(platform) == -1) { - return Reflect.deleteProperty(options, key); - } - }); - - _.each(PLATFORM_OPTIONS, function (_ref, key) { - var platforms = _ref.platforms; - var defaultTo = _ref.defaultTo; - - if (typeof options[key] == 'undefined' && platforms.indexOf(platform) != -1) { - options[key] = defaultTo; - } - }); - - return options; - }, vinyl: function vinyl(object) { return new File({ path: object.name, @@ -358,9 +360,9 @@ var path = require('path'), } if (options.icons.appleIcon) { - var offset = _.property('offset')(options.icons.appleIcon) || 0; + var appleIconOptions = preparePlatformOptions('appleIcon', options.icons.appleIcon); request.favicon_design.ios.background_color = options.background; - request.favicon_design.ios.margin = Math.round(57 / 100 * offset); + request.favicon_design.ios.margin = Math.round(57 / 100 * appleIconOptions.offset); } else { Reflect.deleteProperty(request.favicon_design, 'ios'); } @@ -372,9 +374,9 @@ var path = require('path'), } if (options.icons.coast) { - var _offset = _.property('offset')(options.icons.coast) || 0; + var coastOptions = preparePlatformOptions('coast', options.icons.coast); request.favicon_design.coast.background_color = options.background; - request.favicon_design.coast.margin = Math.round(228 / 100 * _offset); + request.favicon_design.coast.margin = Math.round(228 / 100 * coastOptions.offset); } else { Reflect.deleteProperty(request.favicon_design, 'coast'); } @@ -384,9 +386,9 @@ var path = require('path'), } if (options.icons.firefox) { - var _offset2 = _.property('offset')(options.icons.firefox) || 0; + var firefoxOptions = preparePlatformOptions('firefox', options.icons.firefox); request.favicon_design.firefox_app.background_color = options.background; - request.favicon_design.firefox_app.margin = Math.round(60 / 100 * _offset2); + request.favicon_design.firefox_app.margin = Math.round(60 / 100 * firefoxOptions.offset); request.favicon_design.firefox_app.manifest.app_name = options.appName; request.favicon_design.firefox_app.manifest.app_description = options.appDescription; request.favicon_design.firefox_app.manifest.developer_name = options.developerName; diff --git a/helpers.js b/helpers.js index c87e0744..c85b12d9 100644 --- a/helpers.js +++ b/helpers.js @@ -75,9 +75,32 @@ const path = require('path'), }); } + function preparePlatformOptions(platform, options) { + if (typeof options != 'object') { + options = {}; + } + + _.each(options, (value, key) => { + let platformOptionsRef = PLATFORM_OPTIONS[key]; + + if (typeof platformOptionsRef == 'undefined' || platformOptionsRef.platforms.indexOf(platform) == -1) { + return Reflect.deleteProperty(options, key); + } + }); + + _.each(PLATFORM_OPTIONS, ({ platforms, defaultTo }, key) => { + if (typeof options[key] == 'undefined' && platforms.indexOf(platform) != -1) { + options[key] = defaultTo; + } + }); + + return options; + } + return { General: { + preparePlatformOptions: preparePlatformOptions, background: (hex) => { print('General:background', `Parsing colour ${ hex }`); const rgba = color(hex).toRgb(); @@ -122,27 +145,6 @@ const path = require('path'), return callback('Invalid source type provided'); } }, - preparePlatformOptions: (platform, options) => { - if (typeof options != 'object') { - options = {}; - } - - _.each(options, (value, key) => { - let platformOptionsRef = PLATFORM_OPTIONS[key]; - - if (typeof platformOptionsRef == 'undefined' || platformOptionsRef.platforms.indexOf(platform) == -1) { - return Reflect.deleteProperty(options, key); - } - }); - - _.each(PLATFORM_OPTIONS, ({ platforms, defaultTo }, key) => { - if (typeof options[key] == 'undefined' && platforms.indexOf(platform) != -1) { - options[key] = defaultTo; - } - }); - - return options; - }, vinyl: (object) => new File({ path: object.name, @@ -334,9 +336,9 @@ const path = require('path'), } if (options.icons.appleIcon) { - let offset = _.property('offset')(options.icons.appleIcon) || 0; + let appleIconOptions = preparePlatformOptions('appleIcon', options.icons.appleIcon); request.favicon_design.ios.background_color = options.background; - request.favicon_design.ios.margin = Math.round(57 / 100 * offset); + request.favicon_design.ios.margin = Math.round(57 / 100 * appleIconOptions.offset); } else { Reflect.deleteProperty(request.favicon_design, 'ios'); } @@ -348,9 +350,9 @@ const path = require('path'), } if (options.icons.coast) { - let offset = _.property('offset')(options.icons.coast) || 0; + let coastOptions = preparePlatformOptions('coast', options.icons.coast); request.favicon_design.coast.background_color = options.background; - request.favicon_design.coast.margin = Math.round(228 / 100 * offset); + request.favicon_design.coast.margin = Math.round(228 / 100 * coastOptions.offset); } else { Reflect.deleteProperty(request.favicon_design, 'coast'); } @@ -360,9 +362,9 @@ const path = require('path'), } if (options.icons.firefox) { - let offset = _.property('offset')(options.icons.firefox) || 0; + let firefoxOptions = preparePlatformOptions('firefox', options.icons.firefox); request.favicon_design.firefox_app.background_color = options.background; - request.favicon_design.firefox_app.margin = Math.round(60 / 100 * offset); + request.favicon_design.firefox_app.margin = Math.round(60 / 100 * firefoxOptions.offset); request.favicon_design.firefox_app.manifest.app_name = options.appName; request.favicon_design.firefox_app.manifest.app_description = options.appDescription; request.favicon_design.firefox_app.manifest.developer_name = options.developerName; diff --git a/index.js b/index.js index 1609cf69..e8c27e5d 100644 --- a/index.js +++ b/index.js @@ -135,7 +135,7 @@ const _ = require('underscore'), } function unpack (pack, callback) { - const response = { images: [], files: [], html: pack.html.split(',') }; + const response = { images: [], files: [], html: pack.html.split('\n') }; async.each(pack.files, (url, cb) => µ.RFG.fetch(url, (error, box) => @@ -152,12 +152,17 @@ const _ = require('underscore'), µ.RFG.request(request, cb), (pack, cb) => unpack(pack, cb) - ], (error, results) => - callback(error, results)); + ], (error, results) => { + if (error && options.preferOnline) { + createOffline(sourceset, callback) + } else { + callback(error, results); + } + }); } function create (sourceset, callback) { - options.online ? createOnline(sourceset, callback) : createOffline(sourceset, callback); + options.online || options.preferOnline ? createOnline(sourceset, callback) : createOffline(sourceset, callback); } async.waterfall([ diff --git a/readme.md b/readme.md index 278326c5..e3c8b6fa 100644 --- a/readme.md +++ b/readme.md @@ -34,6 +34,7 @@ var favicons = require('favicons'), version: "1.0", // Your application's version number. `number` logging: false, // Print logs to console? `boolean` online: false, // Use RealFaviconGenerator to create favicons? `boolean` + preferOnline: false, // Use offline generation, if online generation has failed. `boolean` icons: { android: true, // Create Android homescreen icon. `boolean` appleIcon: true, // Create Apple touch icons. `boolean` or `{ offset: offsetInPercentage }` From f904304e926a143a402b7c8bc63c3d18f47da47f Mon Sep 17 00:00:00 2001 From: Dan Green Date: Mon, 22 Aug 2016 11:35:24 +0700 Subject: [PATCH 5/7] ico little fix --- es5.js | 10 +++++++--- index.js | 14 ++++++++------ 2 files changed, 15 insertions(+), 9 deletions(-) diff --git a/es5.js b/es5.js index 643ec8f8..925c0654 100644 --- a/es5.js +++ b/es5.js @@ -37,15 +37,19 @@ var _ = require('underscore'), createFavicon(sourceset, newProperties, tempName, platformOptions, cb); }, function (error, results) { + if (error) { + return callback(error); + } + var files = []; results.forEach(function (icoImage) { - files.push(icoImage.contents); + return files.push(icoImage.contents); }); toIco(files).then(function (buffer) { - callback(error, { name: name, contents: buffer }); - }); + return callback(null, { name: name, contents: buffer }); + }).catch(callback); }); } else { (function () { diff --git a/index.js b/index.js index e8c27e5d..fe764034 100644 --- a/index.js +++ b/index.js @@ -36,15 +36,17 @@ const _ = require('underscore'), createFavicon(sourceset, newProperties, tempName, platformOptions, cb); }, (error, results) => { + if (error) { + return callback(error); + } + const files = []; - results.forEach((icoImage) => { - files.push(icoImage.contents); - }); + results.forEach((icoImage) => files.push(icoImage.contents)); - toIco(files).then((buffer) => { - callback(error, { name, contents: buffer }); - }); + toIco(files) + .then((buffer) => callback(null, { name, contents: buffer })) + .catch(callback); } ); } else { From 152f41ca19948333dece889da29c104ef3cf7003 Mon Sep 17 00:00:00 2001 From: Dan Green Date: Mon, 22 Aug 2016 11:42:10 +0700 Subject: [PATCH 6/7] little fix --- es5.js | 6 ++---- helpers-es5.js | 6 +++--- helpers.js | 6 +++--- index.js | 4 +--- 4 files changed, 9 insertions(+), 13 deletions(-) diff --git a/es5.js b/es5.js index 925c0654..b1cedc11 100644 --- a/es5.js +++ b/es5.js @@ -41,10 +41,8 @@ var _ = require('underscore'), return callback(error); } - var files = []; - - results.forEach(function (icoImage) { - return files.push(icoImage.contents); + var files = results.map(function (icoImage) { + return icoImage.contents; }); toIco(files).then(function (buffer) { diff --git a/helpers-es5.js b/helpers-es5.js index 7c9cd008..6afedc76 100644 --- a/helpers-es5.js +++ b/helpers-es5.js @@ -253,7 +253,7 @@ var path = require('path'), return Jimp.read(file, callback); }, nearest: function nearest(sourceset, properties, offset, callback) { - print('Image:nearest', 'Find nearest icon to ' + properties.width + 'x' + properties.height + ' with offset ' + offset + '%'); + print('Image:nearest', 'Find nearest icon to ' + properties.width + 'x' + properties.height + ' with offset ' + offset); var offsetSize = offset * 2, width = properties.width - offsetSize, @@ -288,7 +288,7 @@ var path = require('path'), } }, resize: function resize(image, properties, offset, callback) { - print('Images:resize', 'Resizing image to contain in ' + properties.width + 'x' + properties.height + ' with offset ' + offset + '%'); + print('Images:resize', 'Resizing image to contain in ' + properties.width + 'x' + properties.height + ' with offset ' + offset); var offsetSize = offset * 2; image.contain(properties.width - offsetSize, properties.height - offsetSize, Jimp.HORIZONTAL_ALIGN_CENTER | Jimp.VERTICAL_ALIGN_MIDDLE); return callback(null, image); @@ -307,7 +307,7 @@ var path = require('path'), } var compositeIcon = function compositeIcon() { - print('Images:composite', 'Compositing ' + maximum + 'x' + maximum + ' favicon on ' + properties.width + 'x' + properties.height + ' canvas with offset ' + offset + '%'); + print('Images:composite', 'Compositing ' + maximum + 'x' + maximum + ' favicon on ' + properties.width + 'x' + properties.height + ' canvas with offset ' + offset); canvas.composite(image, offsetWidth, offsetHeight); }; diff --git a/helpers.js b/helpers.js index c85b12d9..8d263b89 100644 --- a/helpers.js +++ b/helpers.js @@ -239,7 +239,7 @@ const path = require('path'), return Jimp.read(file, callback); }, nearest: (sourceset, properties, offset, callback) => { - print('Image:nearest', `Find nearest icon to ${ properties.width }x${ properties.height } with offset ${ offset }%`); + print('Image:nearest', `Find nearest icon to ${ properties.width }x${ properties.height } with offset ${ offset }`); const offsetSize = offset * 2, width = properties.width - offsetSize, @@ -272,7 +272,7 @@ const path = require('path'), } }, resize: (image, properties, offset, callback) => { - print('Images:resize', `Resizing image to contain in ${ properties.width }x${ properties.height } with offset ${ offset }%`); + print('Images:resize', `Resizing image to contain in ${ properties.width }x${ properties.height } with offset ${ offset }`); let offsetSize = offset * 2; image.contain(properties.width - offsetSize, properties.height - offsetSize, Jimp.HORIZONTAL_ALIGN_CENTER | Jimp.VERTICAL_ALIGN_MIDDLE); return callback(null, image); @@ -291,7 +291,7 @@ const path = require('path'), } const compositeIcon = () => { - print('Images:composite', `Compositing ${ maximum }x${ maximum } favicon on ${ properties.width }x${ properties.height } canvas with offset ${ offset }%`); + print('Images:composite', `Compositing ${ maximum }x${ maximum } favicon on ${ properties.width }x${ properties.height } canvas with offset ${ offset }`); canvas.composite(image, offsetWidth, offsetHeight); }; diff --git a/index.js b/index.js index fe764034..b5abcab5 100644 --- a/index.js +++ b/index.js @@ -40,9 +40,7 @@ const _ = require('underscore'), return callback(error); } - const files = []; - - results.forEach((icoImage) => files.push(icoImage.contents)); + const files = results.map((icoImage) => icoImage.contents); toIco(files) .then((buffer) => callback(null, { name, contents: buffer })) From 324d337c3c71028d7550baa3d702b2658d87cdef Mon Sep 17 00:00:00 2001 From: Dan Green Date: Mon, 22 Aug 2016 20:54:33 +0700 Subject: [PATCH 7/7] convert color to HEX for RFG --- helpers-es5.js | 1 + helpers.js | 1 + 2 files changed, 2 insertions(+) diff --git a/helpers-es5.js b/helpers-es5.js index 6afedc76..10959bbc 100644 --- a/helpers-es5.js +++ b/helpers-es5.js @@ -342,6 +342,7 @@ var path = require('path'), var svgSource = _.find(sourceset, function (source) { return source.size.type == 'svg'; }); + options.background = '#' + color(options.background).toHex(); request.master_picture.content = (svgSource || _.max(sourceset, function (_ref2) { var _ref2$size = _ref2.size; var width = _ref2$size.width; diff --git a/helpers.js b/helpers.js index 8d263b89..b5f8618f 100644 --- a/helpers.js +++ b/helpers.js @@ -323,6 +323,7 @@ const path = require('path'), configure: (sourceset, request, callback) => { print('RFG:configure', 'Configuring RFG API request'); const svgSource = _.find(sourceset, (source) => source.size.type == 'svg'); + options.background = `#${ color(options.background).toHex() }`; request.master_picture.content = (svgSource || _.max(sourceset, ({ size: { width, height }}) => Math.max(width, height))).file.toString('base64'); request.files_location.path = options.path;