A wrapper for gulp-concat that performs additional runtime configuration checks along with creating a separate task/stream for all the pieces you're attempting to build. Utilizing a JSON based configuration, the module will combine/concat and uglify bundles of javascript. In addition to processing javascript gulp-bundle-files will also combine/concat, autoprefix, and minify css.
By defining your "bundles" in a properly formatted JSON configuration file and passing your config to gulp-bundle-files you'll be dynamically creating a task for every bundle. Each of these tasks is appended into gulp's run sequence. Basically the task you define for gulp-bundle-files adds a gulp.task for every bundle defined in your application's configuration, then all the dynamic tasks get run once the plugin finishes. Each of these tasks will be added into gulps sequence in the order your 'default' task defines, using the plugin will just insert these tasks wherever it gets called in your build order.
var gulp = require('gulp'),
gulpBundleFiles = require('gulp-bundle-files'),
bundles = require('./sample-options.json');
gulp.task('bundle', function() {
gulpBundleFiles(bundles);
});
gulp.task('default', ['bundle']);
The plugin assumes your task for bundling is named "bundle" if you have a different name, just specify it in the config. This prevents the dynamic tasks from being called in the wrong contexts when using gulp watch.
{
"parentTaskName": "bundle",
"concat": {
"active": true,
"config": {}
},
"uglify": {
"active": false,
"config": {}
},
"sourcemap": {
"active": true,
"config": {}
},
"destinationFolder": "dist",
"newLine": ";",
"files": {
"js/test.js": [
"tests/fixtures.js",
"tests/main.js"
],
"js/test2.js": [
"tests/fixtures.js",
"tests/main.js"
],
"css/test.css": [
"tests/css/test.css",
"tests/css/test2.css"
]
}
}
Used to specify whether or not concat is active along with the configuration for concat, the config's format should match the options outlined here: https://github.com/contra/gulp-concat
Used to specify whether or not uglify is active along with the configuration for uglify, the config's format should match the options outlined here: https://github.com/terinjokes/gulp-uglify
User to specify whether or not sourcemaps is active along with the configuration for sourcemaps, the config's format should match the options outlined here: https://github.com/floridoo/gulp-sourcemaps
This option specifies the location where your completed bundles are going to be written to, it's relative to the current working directory, in most cases this would be your project's directory
This option is used to configure what bundles you're going to be creating with Gulp. These end up being key/value paired object literals whose value is an array of files the bundle will contain. In this case the key will be the file containing all of the value's parts, or the built file.
Anyone and everyone is welcome to contribute. Please take a moment to review the guidelines for contributing.