gulp-import-tasks
Imports Gulp tasks from a local directory, rather than from your gulpfile.
Based on gulp-load-tasks, but better (and actively maintained)!
Install
$ npm install gulp-import-tasks
Note: gulp
is a required peer dependency.
Usage
Quick Start
Simply require the package within your gulpfile.js
. By default, this will load all Gulp tasks that exist within a local tasks
directory.
require('gulp-import-tasks')();
module.exports = [
'clean'
];
const clean = require('gulp-clean');
module.exports = function (gulp) {
return gulp.clean('dist', { read: false })
.pipe(clean());
};
As you can see above, gulp-import-tasks
will automatically send gulp
as the first function parameter. You can add additional parameters using advanced options.
Custom Directory
You can customize the tasks directory by passing in the name of your custom directory as the first parameter. The following will check for tasks within the gulp/tasks
directory.
require('gulp-import-tasks')('gulp/tasks');
Or, you can define it by passing in an options object instead. See advanced usage.
require('gulp-import-tasks')({
dir: 'gulp/tasks'
});
Asynchronous Tasks
Gulp will automatically send an asynchronous callback function as the last parameter in your task definition. Use this to make your task asynchronous! Read more about asynchronous tasks in the Gulp docs here.
module.exports = function (gulp, done) {
doSomethingAsync(() => {
done();
});
};
Advanced
Using the options parameter, you may specify permissible file extensions, as well as any additional function parameters.
Options
dir | string | The directory that contains your Gulp tasks. | tasks |
extensions | Array.<string> | Only load files from the tasks directory that have these extensions. | ['.js'] |
params | Array.<any> | Additional parameters to pass into imported task. | [] |
Example
const config = {
build: 'dist'
};
require('gulp-import-tasks')({
dir: 'gulp/tasks',
extensions: ['.js'],
params: [
config
]
});
module.exports = [
'clean'
];
const clean = require('gulp-clean');
module.exports = function (gulp, config) {
return gulp.clean(config.build, { read: false })
.pipe(clean());
};
module.exports = function (gulp, config, done) {
doSomethingAsync(() => {
done();
});
};
Authors
License
MIT