@@ -78,6 +78,7 @@ You now have all the necessary dependencies to run the build process.
|
|||||||
|
|
||||||
* `gulp` — Compile and optimize the files in your assets directory
|
* `gulp` — Compile and optimize the files in your assets directory
|
||||||
* `gulp watch` — Compile assets when file changes are made
|
* `gulp watch` — Compile assets when file changes are made
|
||||||
|
* `gulp --production` — Compile assets for production (no source maps).
|
||||||
* `gulp --tasks` — Lists all the available tasks and what they do
|
* `gulp --tasks` — Lists all the available tasks and what they do
|
||||||
|
|
||||||
## Documentation
|
## Documentation
|
||||||
|
|||||||
@@ -1,22 +1,28 @@
|
|||||||
{
|
{
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"theme": {
|
"app.js": {
|
||||||
"scripts": [
|
"files": [
|
||||||
"scripts/**/*",
|
"scripts/**/*",
|
||||||
"scripts/main.js"
|
"scripts/main.js"
|
||||||
],
|
],
|
||||||
"styles": "styles/main.less",
|
"main": true
|
||||||
"editorStyle": "styles/editor-style.less"
|
|
||||||
},
|
},
|
||||||
"vendor": {
|
"main.css": {
|
||||||
"scripts": [],
|
"files": [
|
||||||
"styles": []
|
"styles/main.less"
|
||||||
|
],
|
||||||
|
"main": true
|
||||||
|
},
|
||||||
|
"editor-style.css": {
|
||||||
|
"files": [
|
||||||
|
"styles/editor-style.less"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"jquery.js": {
|
||||||
|
"bower": ["jquery"]
|
||||||
|
},
|
||||||
|
"modernizr.js": {
|
||||||
|
"bower": ["modernizr"]
|
||||||
}
|
}
|
||||||
},
|
|
||||||
"ignoreDependencies": {
|
|
||||||
"bower": [
|
|
||||||
"jquery",
|
|
||||||
"modernizr"
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,6 +13,9 @@
|
|||||||
"bootstrap": "3.3.1"
|
"bootstrap": "3.3.1"
|
||||||
},
|
},
|
||||||
"overrides": {
|
"overrides": {
|
||||||
|
"modernizr": {
|
||||||
|
"main": "./modernizr.js"
|
||||||
|
},
|
||||||
"bootstrap": {
|
"bootstrap": {
|
||||||
"main": [
|
"main": [
|
||||||
"./less/bootstrap.less",
|
"./less/bootstrap.less",
|
||||||
|
|||||||
91
gulpfile.js
91
gulpfile.js
@@ -1,55 +1,63 @@
|
|||||||
/*global $:true*/
|
/*global $:true*/
|
||||||
var $ = require('gulp-load-plugins')();
|
var $ = require('gulp-load-plugins')();
|
||||||
var _ = require('lodash');
|
var _ = require('lodash');
|
||||||
var autoprefixer = require('autoprefixer-core');
|
var argv = require('yargs').argv;
|
||||||
var csswring = require('csswring');
|
var gulp = require('gulp');
|
||||||
var gulp = require('gulp');
|
var lazypipe = require('lazypipe');
|
||||||
var lazypipe = require('lazypipe');
|
|
||||||
var mainBowerFiles = require('main-bower-files');
|
|
||||||
var obj = require('object-path');
|
|
||||||
|
|
||||||
var manifest = require('asset-builder')('./assets/manifest.json');
|
var manifest = require('asset-builder')('./assets/manifest.json');
|
||||||
|
var merge = require('merge-stream');
|
||||||
|
|
||||||
var path = manifest.buildPaths;
|
var mapsEnabled = !argv.production;
|
||||||
|
var path = manifest.paths;
|
||||||
var globs = manifest.globs;
|
var globs = manifest.globs;
|
||||||
|
var project = manifest.getProjectGlobs();
|
||||||
|
|
||||||
var cssTasks = function(filename) {
|
var cssTasks = function(filename) {
|
||||||
var processors = [
|
|
||||||
autoprefixer({browsers: ['last 2 versions', 'ie 8', 'ie 9', 'android 2.3', 'android 4', 'opera 12']}),
|
|
||||||
csswring
|
|
||||||
];
|
|
||||||
|
|
||||||
return lazypipe()
|
return lazypipe()
|
||||||
.pipe($.plumber)
|
.pipe($.plumber)
|
||||||
.pipe($.sourcemaps.init)
|
.pipe(function () {
|
||||||
|
return $.if(mapsEnabled, $.sourcemaps.init());
|
||||||
|
})
|
||||||
.pipe(function() {
|
.pipe(function() {
|
||||||
return $.if('*.less', $.less().on('error', function(err) {
|
return $.if('*.less', $.less().on('error', function(err) {
|
||||||
console.warn(err.message);
|
console.warn(err.message);
|
||||||
}));
|
}));
|
||||||
})
|
})
|
||||||
.pipe(function() {
|
.pipe(function() {
|
||||||
return $.if('*.scss', $.sass());
|
return $.if('*.scss', $.sass({
|
||||||
|
outputStyle: 'nested', // libsass doesn't support expanded yet
|
||||||
|
precision: 10,
|
||||||
|
includePaths: ['.'],
|
||||||
|
onError: console.error.bind(console, 'Sass error:')
|
||||||
|
}));
|
||||||
})
|
})
|
||||||
.pipe($.concat, filename)
|
.pipe($.concat, filename)
|
||||||
.pipe($.postcss, processors)
|
.pipe($.pleeease, {
|
||||||
.pipe($.sourcemaps.write, '.')
|
autoprefixer: {
|
||||||
|
browsers: [
|
||||||
|
'last 2 versions', 'ie 8', 'ie 9', 'android 2.3', 'android 4', 'opera 12'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.pipe(function () {
|
||||||
|
return $.if(mapsEnabled, $.sourcemaps.write('.'));
|
||||||
|
})
|
||||||
.pipe(gulp.dest, path.dist + 'styles')();
|
.pipe(gulp.dest, path.dist + 'styles')();
|
||||||
};
|
};
|
||||||
|
|
||||||
gulp.task('styles', ['wiredep', 'styles:editorStyle'], function() {
|
gulp.task('styles', ['wiredep'], function() {
|
||||||
return gulp.src(globs.styles)
|
var merged = merge();
|
||||||
.pipe(cssTasks('main.css'));
|
manifest.forEachDependency('css', function (dep) {
|
||||||
});
|
merged.add(gulp.src(dep.globs)
|
||||||
|
.pipe(cssTasks(dep.name)));
|
||||||
gulp.task('styles:editorStyle', function() {
|
});
|
||||||
return gulp.src(globs.editorStyle)
|
return merged;
|
||||||
.pipe(cssTasks('editor-style.css'));
|
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('jshint', function() {
|
gulp.task('jshint', function() {
|
||||||
return gulp.src([
|
return gulp.src([
|
||||||
'bower.json', 'gulpfile.js'
|
'bower.json', 'gulpfile.js'
|
||||||
].concat(obj.get(manifest, 'dependencies.theme.scripts', [])))
|
].concat(project.js))
|
||||||
.pipe($.jshint())
|
.pipe($.jshint())
|
||||||
.pipe($.jshint.reporter('jshint-stylish'))
|
.pipe($.jshint.reporter('jshint-stylish'))
|
||||||
.pipe($.jshint.reporter('fail'));
|
.pipe($.jshint.reporter('fail'));
|
||||||
@@ -58,23 +66,26 @@ gulp.task('jshint', function() {
|
|||||||
var jsTasks = function(filename) {
|
var jsTasks = function(filename) {
|
||||||
var fn = filename;
|
var fn = filename;
|
||||||
return lazypipe()
|
return lazypipe()
|
||||||
.pipe($.sourcemaps.init)
|
.pipe(function () {
|
||||||
|
return $.if(mapsEnabled, $.sourcemaps.init());
|
||||||
|
})
|
||||||
.pipe(function() {
|
.pipe(function() {
|
||||||
return $.if(!!fn, $.concat(fn || 'all.js'));
|
return $.if(!!fn, $.concat(fn || 'all.js'));
|
||||||
})
|
})
|
||||||
.pipe($.uglify)
|
.pipe($.uglify)
|
||||||
.pipe($.sourcemaps.write, '.')
|
.pipe(function () {
|
||||||
|
return $.if(mapsEnabled, $.sourcemaps.write('.'));
|
||||||
|
})
|
||||||
.pipe(gulp.dest, path.dist + 'scripts')();
|
.pipe(gulp.dest, path.dist + 'scripts')();
|
||||||
};
|
};
|
||||||
|
|
||||||
gulp.task('scripts', ['jshint', 'scripts:ignored'], function() {
|
gulp.task('scripts', ['jshint'], function() {
|
||||||
return gulp.src(globs.scripts)
|
var merged = merge();
|
||||||
.pipe(jsTasks('app.js'));
|
manifest.forEachDependency('js', function (dep) {
|
||||||
});
|
merged.add(gulp.src(dep.globs)
|
||||||
|
.pipe(jsTasks(dep.name)));
|
||||||
gulp.task('scripts:ignored', function() {
|
});
|
||||||
return gulp.src(globs.scriptsIgnored)
|
return merged;
|
||||||
.pipe(jsTasks());
|
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('fonts', function() {
|
gulp.task('fonts', function() {
|
||||||
@@ -119,9 +130,9 @@ gulp.task('build', ['styles', 'scripts', 'fonts', 'images'], function() {
|
|||||||
|
|
||||||
gulp.task('wiredep', function() {
|
gulp.task('wiredep', function() {
|
||||||
var wiredep = require('wiredep').stream;
|
var wiredep = require('wiredep').stream;
|
||||||
gulp.src(globs.styles)
|
gulp.src(project.css)
|
||||||
.pipe(wiredep())
|
.pipe(wiredep())
|
||||||
.pipe(gulp.dest(path.dist + 'styles'));
|
.pipe(gulp.dest(path.source + 'styles'));
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('default', ['clean'], function() {
|
gulp.task('default', ['clean'], function() {
|
||||||
|
|||||||
20
package.json
20
package.json
@@ -24,21 +24,19 @@
|
|||||||
"node": ">= 0.10.0"
|
"node": ">= 0.10.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"asset-builder": "0.0.1",
|
"asset-builder": "~0.3.0",
|
||||||
"autoprefixer-core": "4.0.1",
|
"del": "^1.1.1",
|
||||||
"csswring": "^2.0.0",
|
|
||||||
"del": "^0.1.3",
|
|
||||||
"gulp": "^3.8.10",
|
"gulp": "^3.8.10",
|
||||||
"gulp-concat": "^2.3.4",
|
"gulp-concat": "^2.3.4",
|
||||||
"gulp-flatten": "0.0.4",
|
"gulp-flatten": "0.0.4",
|
||||||
"gulp-if": "^1.2.5",
|
"gulp-if": "^1.2.5",
|
||||||
"gulp-imagemin": "^2.0.0",
|
"gulp-imagemin": "^2.0.0",
|
||||||
"gulp-jshint": "^1.8.4",
|
"gulp-jshint": "^1.8.4",
|
||||||
"gulp-less": "^1.3.3",
|
"gulp-less": "^2.0.1",
|
||||||
"gulp-livereload": "^2.1.0",
|
"gulp-livereload": "^3.4.0",
|
||||||
"gulp-load-plugins": "^0.7.1",
|
"gulp-load-plugins": "^0.8.0",
|
||||||
|
"gulp-pleeease": "^1.1.0",
|
||||||
"gulp-plumber": "^0.6.3",
|
"gulp-plumber": "^0.6.3",
|
||||||
"gulp-postcss": "^3.0.0",
|
|
||||||
"gulp-rename": "^1.2.0",
|
"gulp-rename": "^1.2.0",
|
||||||
"gulp-rev": "^2.0.1",
|
"gulp-rev": "^2.0.1",
|
||||||
"gulp-sass": "^1.2.4",
|
"gulp-sass": "^1.2.4",
|
||||||
@@ -48,9 +46,9 @@
|
|||||||
"jshint-stylish": "^1.0.0",
|
"jshint-stylish": "^1.0.0",
|
||||||
"lazypipe": "^0.2.2",
|
"lazypipe": "^0.2.2",
|
||||||
"lodash": "^2.4.1",
|
"lodash": "^2.4.1",
|
||||||
"main-bower-files": "^2.4.0",
|
"merge-stream": "^0.1.7",
|
||||||
"object-path": "^0.8.0",
|
|
||||||
"traverse": "^0.6.6",
|
"traverse": "^0.6.6",
|
||||||
"wiredep": "^2.1.0"
|
"wiredep": "^2.1.0",
|
||||||
|
"yargs": "^1.3.3"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user