Make bower automatic, add gulp build task to build less file into css

This commit is contained in:
terakilobyte
2015-06-12 23:31:42 -04:00
parent cf47e5374f
commit 320d84c3c1
2 changed files with 60 additions and 48 deletions

View File

@ -1,16 +1,18 @@
var gulp = require('gulp'), var gulp = require('gulp'),
debug = require('debug')('freecc:gulp'), debug = require('debug')('freecc:gulp'),
bower = require('bower-main-files'), bower = require('bower-main-files'),
nodemon = require('gulp-nodemon'), nodemon = require('gulp-nodemon'),
sync = require('browser-sync'), sync = require('browser-sync'),
reload = sync.reload, reload = sync.reload,
inject = require('gulp-inject'), inject = require('gulp-inject'),
reloadDelay = 1000, reloadDelay = 1000,
eslint = require('gulp-eslint'); less = require('gulp-less'),
path = require('path'),
eslint = require('gulp-eslint');
var paths = { var paths = {
server: './server/server.js', server: './server/server.js',
serverIgnore: [] serverIgnore: []
}; };
gulp.task('inject', function() { gulp.task('inject', function() {
@ -22,50 +24,58 @@ gulp.task('inject', function() {
}); });
gulp.task('serve', function(cb) { gulp.task('serve', function(cb) {
var called = false; var called = false;
nodemon({ nodemon({
script: paths.server, script: paths.server,
ext: '.js', ext: '.js',
ignore: paths.serverIgnore, ignore: paths.serverIgnore,
env: { env: {
'NODE_ENV': 'development', 'NODE_ENV': 'development',
'DEBUG': process.env.DEBUG || 'freecc:*' 'DEBUG': process.env.DEBUG || 'freecc:*'
} }
})
.on('start', function() {
if (!called) {
called = true;
setTimeout(function() {
cb();
}, reloadDelay);
}
}) })
.on('start', function() { .on('restart', function(files) {
if (!called) { if (files) {
called = true; debug('Files that changes: ', files);
setTimeout(function() { }
cb(); setTimeout(function() {
}, reloadDelay); debug('Restarting browsers');
} reload();
}) }, reloadDelay);
.on('restart', function(files) { });
if (files) {
debug('Files that changes: ', files);
}
setTimeout(function() {
debug('Restarting browsers');
reload();
}, reloadDelay);
});
}); });
gulp.task('sync', ['serve'], function() { gulp.task('sync', ['serve'], function() {
sync.init(null, { sync.init(null, {
proxy: 'http://localhost:3000', proxy: 'http://localhost:3000',
logLeval: 'debug', logLeval: 'debug',
files: ['public/js/lib/*/*.{js, jsx}'], files: ['public/js/lib/*/*.{js, jsx}'],
port: 3001, port: 3001,
open: false, open: false,
reloadDelay: reloadDelay reloadDelay: reloadDelay
}); });
}); });
gulp.task('lint', function() { gulp.task('lint', function() {
return gulp.src(['public/js/lib/**/*']) return gulp.src(['public/js/lib/**/*'])
.pipe(eslint()) .pipe(eslint())
.pipe(eslint.format()); .pipe(eslint.format());
}); });
gulp.task('default', ['serve', 'sync']); gulp.task('build', function() {
return gulp.src('./public/css/*.less')
.pipe(less({
paths: [ path.join(__dirname, 'less', 'includes') ]
}))
.pipe(gulp.dest('./public/css/'));
});
gulp.task('default', ['build', 'serve', 'sync']);

View File

@ -12,7 +12,8 @@
"scripts": { "scripts": {
"start": "node server/server.js", "start": "node server/server.js",
"lint": "eslint --ext=.js,.jsx .", "lint": "eslint --ext=.js,.jsx .",
"test": "mocha" "test": "mocha",
"postinstall": "bower cache clean && bower install"
}, },
"license": "BSD-3-Clause", "license": "BSD-3-Clause",
"contributors": [ "contributors": [
@ -50,6 +51,7 @@
"forever": "~0.14.1", "forever": "~0.14.1",
"frameguard": "^0.2.2", "frameguard": "^0.2.2",
"github-api": "~0.7.0", "github-api": "~0.7.0",
"gulp-less": "^3.0.3",
"gulp-minify-css": "~0.5.1", "gulp-minify-css": "~0.5.1",
"helmet": "~0.9.0", "helmet": "~0.9.0",
"helmet-csp": "^0.2.3", "helmet-csp": "^0.2.3",