-
Notifications
You must be signed in to change notification settings - Fork 0
/
build.js
85 lines (73 loc) · 2.62 KB
/
build.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
const chalk = require( 'chalk' );
const log = console.log;
const util = require( 'util' );
const fs = require( 'fs' );
const logger = {
title: val => {
const prefix = '| ';
const suffix = ' |';
const charTotal = prefix.length + val.length + suffix.length;
let underline = '|';
for ( let i = 0; i < charTotal - 2; i++ ) {
underline += '-';
}
underline += '|';
log( chalk.white.bgGreen.bold( `${ underline }` ) );
log( chalk.white.bgGreen.bold( `${ prefix }${ val }${ suffix }` ) );
log( chalk.white.bgGreen.bold( `${ underline }` ) );
log( '\r' );
},
separator: () => {
const charTotal = 84;
let underline = '';
for ( let i = 0; i < charTotal; i++ ) {
underline += '-';
}
log( chalk.green( `${ underline }` ) );
},
congrats: msg => {
log( '\r' );
log( chalk.white.bgGreen.bold( ` ☆ ${ util.inspect( msg.toUpperCase(), false, null ) } ☆ ` ) );
log( '\r' );
},
info: msg => log( chalk.white( ( `► ${ util.inspect( msg, false, null ) }` ) ) ),
done: msg => log( chalk.green( ( `✓ Done:\n ${ util.inspect( msg, false, null ) }` ) ) ),
error: err => log( chalk.red( ( `☹ Error:\n ${ util.inspect( err, false, null ) }` ) ) )
};
class Build {
constructor () {
logger.title( 'PREPARE BUILD' );
logger.separator();
this.loadPackage();
this.prepareAppInfo();
this.writeAppInfo();
}
loadPackage () {
logger.info( 'Load ./package.json' );
this.pkg = require( './package.json' );
logger.done( 'package.json is loaded' );
logger.separator();
}
prepareAppInfo () {
logger.info( 'Prepare app-info data file' );
const timestamp = Date.now();
this.contentFile = `window.AppInfo = { name: '${ this.pkg.name }', version: '${ this.pkg.version }', build: '${ timestamp }', dateBuild: '${ new Date( timestamp ).toISOString() }' };\n`;
logger.done( 'app-info.js ok' );
logger.separator();
}
writeAppInfo () {
logger.info( 'Writing content into file app-info.js' );
fs.writeFile( './src/js/app-info.js', `${ this.contentFile }`, err => {
if ( err ) {
logger.error( err );
return false;
}
logger.done( 'The file is saved!' );
logger.separator();
logger.congrats( 'MAZEL TOV!' );
} );
}
}
module.exports = ( () => {
return new Build();
} )();