1
0
mirror of https://github.com/simple-icons/simple-icons.git synced 2025-01-05 01:20:39 +02:00
simple-icons/build.js

150 lines
5.1 KiB
JavaScript
Raw Normal View History

2015-10-14 17:52:04 +02:00
// Get JSON from source file
var source = require('./simple-icons.json');
// Loop through icons
for (var i = 0; i < source.icons.length; i++) {
var hex = source.icons[i].hex;
// Add red, green and blue values to the JSON object
var red = parseInt(hex.substr(0,2), 16) / 255;
var green = parseInt(hex.substr(2,2), 16) / 255;
var blue = parseInt(hex.substr(4,2), 16) / 255;
// Add hue to the JSON object
var max = Math.max(red, green, blue);
var min = Math.min(red, green, blue);
var delta = max - min;
2015-10-16 15:35:52 +02:00
source.icons[i].luminance = 100 * (max + min) / 2;
2015-10-14 17:52:04 +02:00
if (delta === 0) {
var hue = 0;
2015-10-16 16:43:13 +02:00
source.icons[i].saturation = 0;
2015-10-14 17:52:04 +02:00
} else {
2015-10-16 16:43:13 +02:00
if (source.icons[i].luminance < 50) {
source.icons[i].saturation = 100 * (max - min) / (max + min);
} else {
source.icons[i].saturation = 100 * (max - min) / (2 - max - min);
}
2015-10-14 17:52:04 +02:00
if (max === red) {
var hue = ((green - blue) / delta) * 60;
if (hue < 0) {
hue += 360;
}
} else if (max === green) {
var hue = (((blue - red) / delta) + 2) * 60;
} else {
var hue = (((red - green) / delta) + 4) * 60;
}
}
source.icons[i].hue = hue;
}
// Sort icons by hue
2015-10-15 15:30:13 +02:00
// Ensures blue icons appear first in the last, purple ones last
for (var i = 0; i < source.icons.length; i++) {
2015-10-16 17:25:35 +02:00
source.icons[i].hue += 100;
2015-10-15 15:30:13 +02:00
source.icons[i].hue = source.icons[i].hue % 360;
}
2015-10-14 17:52:04 +02:00
source.icons.sort(function(a, b) {
return parseFloat(b.hue) - parseFloat(a.hue);
});
2015-10-15 15:30:13 +02:00
var tmp = [];
for (var i = 0; i < source.icons.length; i++) {
if (source.icons[i].luminance < 10) {
tmp.push(source.icons[i]);
source.icons.splice(i,1);
i--;
}
}
2015-10-16 15:35:52 +02:00
for (var i = 0; i < source.icons.length; i++) {
if (source.icons[i].saturation < 5) {
tmp.push(source.icons[i]);
source.icons.splice(i,1);
i--;
}
}
2015-10-15 15:30:13 +02:00
tmp.sort(function(a, b) {
return parseFloat(b.luminance) - parseFloat(a.luminance);
});
for (var i = 0; i < tmp.length; i++) {
source.icons.push(tmp[i]);
}
console.log(tmp);
2015-10-14 17:52:04 +02:00
// Read header and footer content into variables
var fs = require('fs');
function readFile(path, callback) {
try {
var filename = require.resolve(path);
fs.readFile(filename, 'utf8', callback);
} catch (e) {
callback(e);
}
}
var fs = require('fs');
var header = fs.readFileSync('./src/header.html', 'utf8');
var footer = fs.readFileSync('./src/footer.html', 'utf8');
2015-10-15 15:30:13 +02:00
// Build content
2015-10-19 10:02:03 +02:00
var main = "<p class=\"hero\">" + source.icons.length + " SVG icons for popular brands <a href=\"https://github.com/danleech/simple-icons\">Download them from GitHub</a></p>\n<ul class=\"tiles\">";
2015-10-15 15:30:13 +02:00
2015-10-14 17:52:04 +02:00
for (var i = 0; i < source.icons.length; i++) {
2015-10-17 12:38:33 +02:00
var fileName = source.icons[i].title.toLowerCase();
fileName = fileName.replace(' ', '');
2015-10-18 11:09:37 +02:00
fileName = fileName.replace('!', '');
2015-10-17 12:38:33 +02:00
fileName = fileName.replace('.', '');
fileName = fileName.replace('+', 'plus');
filePath = "./icons/" + fileName + ".svg";
2015-10-16 15:35:52 +02:00
console.log(source.icons[i].title + ", sat = " + source.icons[i].saturation);
2015-10-15 15:30:13 +02:00
var fs = require('fs');
var svg = fs.readFileSync(filePath, 'utf8');
2015-10-19 10:02:03 +02:00
main += "\t\t\t<li style=\"background-color:#" + source.icons[i].hex + "\"><a href=\"https://github.com/danleech/simple-icons/blob/gh-pages/icons/" + fileName + ".svg\">" + svg + source.icons[i].title + "<br><span class=\"hex\">#" + source.icons[i].hex + "</span></a></li>\n";
2015-10-14 17:52:04 +02:00
}
// Put all content together and export to index.html
var htmlOutput = header + main + footer;
fs.writeFile("./index.html", htmlOutput, function(err) {
if(err) {
return console.log(err);
}
console.log("The file was saved!");
2015-10-19 12:08:22 +02:00
});
// Build Sharing content
var sharingMain = "";
for (var i = 0; i < source.icons.length; i++) {
var fileName = source.icons[i].title.toLowerCase();
fileName = fileName.replace(' ', '');
fileName = fileName.replace('!', '');
fileName = fileName.replace('.', '');
fileName = fileName.replace('+', 'plus');
filePath = "./icons/" + fileName + ".svg";
console.log(source.icons[i].title + ", sat = " + source.icons[i].saturation);
var fs = require('fs');
var svg = fs.readFileSync(filePath, 'utf8');
sharingMain += "\t\t\t<li style=\"background-color:#" + source.icons[i].hex + "\" class=\"bars__item\"></li>\n";
}
// Read sharing header and footer content into variables
var fs = require('fs');
function readFile(path, callback) {
try {
var filename = require.resolve(path);
fs.readFile(filename, 'utf8', callback);
} catch (e) {
callback(e);
}
}
var fs = require('fs');
var sharingHeader = fs.readFileSync('./src/sharing-header.html', 'utf8');
var sharingFooter = fs.readFileSync('./src/sharing-footer.html', 'utf8');
// Put all sharing content together and export to sharing.html
var sharingHtmlOutput = sharingHeader + sharingMain + sharingFooter;
fs.writeFile("./sharing.html", sharingHtmlOutput, function(err) {
if(err) {
return console.log(err);
}
console.log("The sharing file was saved!");
2015-10-14 17:52:04 +02:00
});