gallery.accords-library.com/client/build.js

120 lines
3.5 KiB
JavaScript
Raw Normal View History

'use strict';
const fs = require('fs');
2016-03-27 19:10:41 +00:00
const glob = require('glob');
const path = require('path');
const util = require('util');
2016-03-31 21:18:08 +00:00
const execSync = require('child_process').execSync;
function getVersion() {
return execSync('git describe --always --dirty --long --tags').toString();
}
function getConfig() {
const ini = require('ini');
const merge = require('merge');
const camelcaseKeys = require('camelcase-keys');
function parseIniFile(path) {
let result = ini.parse(fs.readFileSync(path, 'utf-8')
.replace(/#.+$/gm, '')
.replace(/\s+$/gm, ''));
Object.keys(result).map((key, _) => {
result[key] = camelcaseKeys(result[key]);
});
return result;
}
2016-04-01 16:45:25 +00:00
let config = parseIniFile('../config.ini.dist');
try {
2016-04-01 16:45:25 +00:00
const localConfig = parseIniFile('../config.ini');
config = merge.recursive(config, localConfig);
} catch (e) {
console.warn('Local config does not exist, ignoring');
}
delete config.basic.secret;
delete config.smtp;
delete config.database;
config.service.userRanks = config.service.userRanks.split(/,\s*/);
config.service.tagCategories = config.service.tagCategories.split(/,\s*/);
2016-03-31 21:18:08 +00:00
config.meta = {
version: getVersion(),
buildDate: new Date().toUTCString(),
};
return config;
}
2016-03-27 19:10:41 +00:00
function bundleHtml(config) {
const minify = require('html-minifier').minify;
2016-04-01 16:45:25 +00:00
const baseHtml = fs.readFileSync('./html/index.htm', 'utf-8');
glob('./html/**/*.hbs', {}, (er, files) => {
2016-03-27 19:10:41 +00:00
let templatesHtml = '';
for (const file of files) {
templatesHtml += util.format(
'<template id=\'%s-template\'>%s</template>',
2016-04-01 08:24:04 +00:00
path.basename(file, '.hbs').replace('_', '-'),
2016-03-27 19:10:41 +00:00
fs.readFileSync(file));
}
const finalHtml = baseHtml
.replace(/(<\/head>)/, templatesHtml + '$1')
.replace(
/(<title>)(.*)(<\/title>)/,
util.format('$1%s$3', config.basic.name));
fs.writeFileSync(
'./public/index.htm',
minify(
finalHtml, {
removeComments: true,
collapseWhitespace: true,
conservativeCollapse: true}));
2016-03-27 19:10:41 +00:00
console.info('Bundled HTML');
});
}
function bundleCss() {
const minify = require('csso').minify;
2016-04-01 16:45:25 +00:00
glob('./css/**/*.css', {}, (er, files) => {
let css = '';
for (const file of files) {
css += fs.readFileSync(file);
}
fs.writeFileSync('./public/bundle.min.css', minify(css));
console.info('Bundled CSS');
});
}
function bundleJs() {
const browserify = require('browserify');
const uglifyjs = require('uglify-js');
2016-04-01 16:45:25 +00:00
glob('./js/**/*.js', {}, function(er, files) {
const outputFile = fs.createWriteStream('./public/bundle.min.js');
browserify().add(files).bundle().pipe(outputFile);
outputFile.on('finish', function() {
const result = uglifyjs.minify('./public/bundle.min.js');
fs.writeFileSync('./public/bundle.min.js', result.code);
console.info('Bundled JS');
});
});
}
function bundleConfig(config) {
fs.writeFileSync(
2016-04-01 16:45:25 +00:00
'./js/.config.autogen.json', JSON.stringify(config));
}
2016-03-30 14:06:51 +00:00
function copyFile(source, target) {
fs.createReadStream(source).pipe(fs.createWriteStream(target));
}
const config = getConfig();
bundleConfig(config);
2016-03-27 19:10:41 +00:00
bundleHtml(config);
bundleCss();
bundleJs();
2016-04-01 16:45:25 +00:00
copyFile('./img/favicon.png', './public/favicon.png');