mirror of
https://github.com/JuanCanham/HackMyResume.git
synced 2025-04-19 14:20:25 +01:00
209 lines
5.9 KiB
JavaScript
209 lines
5.9 KiB
JavaScript
/**
|
|
Output routines for HackMyResume.
|
|
@license MIT. See LICENSE.md for details.
|
|
@module out.js
|
|
*/
|
|
|
|
|
|
|
|
(function() {
|
|
|
|
|
|
|
|
var chalk = require('chalk')
|
|
, HME = require('../core/event-codes')
|
|
, _ = require('underscore')
|
|
, Class = require('../utils/class.js')
|
|
, M2C = require('../utils/md2chalk.js')
|
|
, PATH = require('path')
|
|
, LO = require('lodash')
|
|
, FS = require('fs')
|
|
, EXTEND = require('../utils/extend')
|
|
, HANDLEBARS = require('handlebars')
|
|
, YAML = require('yamljs')
|
|
, printf = require('printf')
|
|
, pad = require('string-padding');
|
|
|
|
|
|
|
|
/**
|
|
A stateful output module. All HMR console output handled here.
|
|
*/
|
|
var OutputHandler = module.exports = Class.extend({
|
|
|
|
|
|
|
|
init: function( opts ) {
|
|
this.opts = EXTEND( true, this.opts || { }, opts );
|
|
this.msgs = YAML.load(PATH.join( __dirname, 'msg.yml' )).events;
|
|
},
|
|
|
|
|
|
|
|
log: function( msg ) {
|
|
msg = msg || '';
|
|
var printf = require('printf');
|
|
var finished = printf.apply( printf, arguments );
|
|
this.opts.silent || console.log( finished );
|
|
},
|
|
|
|
|
|
|
|
do: function( evt ) {
|
|
|
|
var that = this;
|
|
function L() {
|
|
that.log.apply( that, arguments );
|
|
}
|
|
|
|
switch( evt.sub ) {
|
|
|
|
case HME.error:
|
|
//L('ERROR occured');
|
|
break;
|
|
|
|
case HME.beforeCreate:
|
|
L( M2C( this.msgs.beforeCreate.msg, 'green' ), evt.fmt, evt.file );
|
|
break;
|
|
|
|
case HME.beforeRead:
|
|
L(
|
|
M2C( this.msgs.beforeRead.msg, 'cyan' ), evt.file
|
|
);
|
|
break;
|
|
|
|
case HME.afterRead:
|
|
break;
|
|
|
|
case HME.beforeTheme:
|
|
this.opts.debug &&
|
|
L( M2C( this.msgs.beforeTheme.msg, 'cyan'), evt.theme.toUpperCase() );
|
|
break;
|
|
|
|
case HME.afterTheme:
|
|
this.theme = evt.theme;
|
|
this.opts.debug && L( M2C(this.msgs.beforeTheme.msg, 'cyan'), evt.theme );
|
|
break;
|
|
|
|
case HME.beforeMerge:
|
|
var msg = '';
|
|
evt.f.reverse().forEach( function( a, idx ) {
|
|
msg += printf(
|
|
((idx === 0) ?
|
|
this.msgs.beforeMerge.msg[0] :
|
|
this.msgs.beforeMerge.msg[1] ), a.i().file
|
|
);
|
|
}, this);
|
|
L( M2C(msg, 'cyan') );
|
|
break;
|
|
|
|
case HME.afterMerge:
|
|
var numFormats = Object.keys( this.theme.formats ).length;
|
|
L( M2C(this.msgs.afterMerge.msg, 'yellow'),
|
|
this.theme.name.toUpperCase(),
|
|
numFormats, ( numFormats === 1 ? '' : 's') );
|
|
break;
|
|
|
|
case HME.end:
|
|
if( evt.cmd === 'build' ) {
|
|
var themeName = this.theme.name.toUpperCase();
|
|
if( this.opts.tips && (this.theme.message || this.theme.render) ) {
|
|
var WRAP = require('word-wrap');
|
|
if( this.theme.message ) {
|
|
L( M2C( this.msgs.afterBuild.msg[0], 'cyan' ), themeName );
|
|
L( M2C( this.theme.message, 'white' ));
|
|
}
|
|
else if ( this.theme.render ) {
|
|
L( M2C( this.msgs.afterBuild.msg[0], 'cyan'), themeName);
|
|
L( M2C( this.msgs.afterBuild.msg[1], 'white'));
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
|
|
case HME.beforeGenerate:
|
|
var suffix = '';
|
|
if( evt.fmt === 'pdf' ) {
|
|
if( this.opts.pdf ) {
|
|
if( this.opts.pdf !== 'none' ) {
|
|
suffix = printf( M2C( this.msgs.beforeGenerate.msg[0], 'green' ), this.opts.pdf );
|
|
}
|
|
else {
|
|
L( M2C( this.msgs.beforeGenerate.msg[1], 'gray' ),
|
|
evt.fmt.toUpperCase(), evt.file );
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
L( M2C( this.msgs.beforeGenerate.msg[2] + suffix, 'green' ),
|
|
pad(evt.fmt.toUpperCase(),4,null,pad.RIGHT),
|
|
PATH.relative(process.cwd(), evt.file ));
|
|
break;
|
|
|
|
case HME.beforeAnalyze:
|
|
L( M2C( this.msgs.beforeAnalyze.msg, 'cyan' ), evt.fmt, evt.file);
|
|
break;
|
|
|
|
case HME.afterAnalyze:
|
|
var info = evt.info;
|
|
var rawTpl = FS.readFileSync( PATH.join( __dirname, 'analyze.hbs' ), 'utf8');
|
|
HANDLEBARS.registerHelper( require('../helpers/console-helpers') );
|
|
var template = HANDLEBARS.compile(rawTpl, { strict: false, assumeObjects: false });
|
|
var tot = 0;
|
|
info.keywords.forEach(function(g) { tot += g.count; });
|
|
info.keywords.totalKeywords = tot;
|
|
var output = template( info );
|
|
this.log( chalk.cyan(output) );
|
|
break;
|
|
|
|
case HME.beforeConvert:
|
|
L( M2C( this.msgs.beforeConvert.msg, 'green' ),
|
|
evt.srcFile, evt.srcFmt, evt.dstFile, evt.dstFmt
|
|
);
|
|
break;
|
|
|
|
case HME.afterValidate:
|
|
var style = evt.isValid ? 'green' : 'yellow';
|
|
L(
|
|
M2C( this.msgs.afterValidate.msg[0], 'white' ) +
|
|
chalk[style].bold( evt.isValid ?
|
|
this.msgs.afterValidate.msg[1] :
|
|
this.msgs.afterValidate.msg[2] ),
|
|
evt.file, evt.fmt
|
|
);
|
|
|
|
if( evt.errors ) {
|
|
_.each(evt.errors, function(err,idx) {
|
|
L( chalk.yellow.bold('--> ') +
|
|
chalk.yellow(err.field.replace('data.','resume.').toUpperCase() + ' ' +
|
|
err.message) );
|
|
}, this);
|
|
}
|
|
|
|
break;
|
|
|
|
case HME.beforePeek:
|
|
if( evt.target )
|
|
L(M2C(this.msgs.beforePeek.msg[0], 'cyan'), evt.target, evt.file);
|
|
else
|
|
L(M2C(this.msgs.beforePeek.msg[1], 'cyan'), evt.file);
|
|
break;
|
|
|
|
case HME.afterPeek:
|
|
if( evt.target )
|
|
console.dir( evt.target, { depth: null, colors: true } );
|
|
else
|
|
L(M2C( this.msgs.afterPeek.msg, 'yellow'), evt.requested, evt.file);
|
|
break;
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
}());
|