gulp-import-tasks
v0.1.1
Published
Import tasks from a local directory, rather than from your gulpfile.
Downloads
24
Readme
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.
// gulpfile.js
require('gulp-import-tasks')();
// tasks/default.js
module.exports = [
'clean'
];
// tasks/clean.js
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.
// gulpfile.js
require('gulp-import-tasks')('gulp/tasks');
Or, you can define it by passing in an options object instead. See advanced usage.
// gulpfile.js
require('gulp-import-tasks')({
dir: 'gulp/tasks'
});
Asynchronous Tasks
Not yet supported – accepting pull requests.
Advanced
Using the options parameter, you may specify permissible file extensions, as well as any additional function parameters.
Options
| Option | Type | Description | Default |
|:-------------|:-----------------|:---------------------------------------------------------------------|:----------|
| 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
// gulpfile.js
const config = {
build: 'dist'
};
require('gulp-import-tasks')({
dir: 'gulp/tasks',
extensions: ['.js'],
params: [
config
]
});
// gulp/tasks/default.js
module.exports = [
'clean'
];
// gulp/tasks/clean.js
const clean = require('gulp-clean');
module.exports = function (gulp, config) {
return gulp.clean(config.build, { read: false })
.pipe(clean());
};
Authors
License
MIT