Gulp build tasks for use across Fozzie modules.
First, add gulp
and gulp-build-fozzie
as dependencies
yarn add gulp @justeat/gulp-build-fozzie
Next, inside your gulpfile.js
, require the build function from @justeat/gulp-build-fozzie
, then pass gulp
as the first argument.
const gulp = require('gulp');
const { build } = require('@justeat/gulp-build-fozzie');
build(gulp, /*options*/);
You can optionally pass in options which will override the default config values.
That's it! You can now run any of the Gulp tasks.
To ensure that the scripts:bundle
task can transpile es2015 code, add the babel-preset-es2015
preset to the project:
yarn add babel-preset-es2015
Then add a .babelrc
file, with the babel-preset-es2015
preset, to the root of your project:
{
"presets": ["es2015"]
}
If you do not add a .babelrc
file (you may be writing es5 code for example) then the code will be bundled up as is.
Add an .eslintrc
file to the root of your project with the following content to use the JS linting rules we recommend when running the scripts:lint
task:
{
"extends": "@justeat/eslint-config-fozzie"
}
If you wish to extend or override these rules you can simply add them after the extends
line in the .eslintrc
file.
For more information on how you can configure eslint check out the documentation.
To use our recommended fozzie stylelint linting rules add the following into your package.json
file:
"stylelint": {
"extends": "@justeat/stylelint-config-fozzie"
}
If you wish to extend or override these rules you can simply add them after the extends
line in the package.json
file.
For more information on how you can configure stylelint check out the documentation.
You can also access the config
and pathBuilder
objects which are used inside of gulp-build-fozzie
by requiring them:
const { config, pathBuilder } = require('@justeat/gulp-build-fozzie');
These are exposed for convenience, and means that you do not need to manually build paths and maintain a separate config object for any custom tasks in your project. It also reduces duplication and prevents bugs which can arise from specifying incorrect paths.
This is the config object which is used inside of gulp-build-fozzie
, if you have passed any options via the build
method they will be available here.
See the Options section below for the details of this object.
The pathBuilder
object is used inside of gulp-build-fozzie
in order to build the paths used in the gulp tasks.
See the Path Builder section below for details on which paths are available.
Runs the following tasks
-
Lint all SCSS files in the source directory — this runs before the
css:bundle
task. -
Lint all CSS files in the dist directory — this runs after the
css:bundle
task. -
Removes any CSS already in the dist directory.
-
Removes any imported assets in the imported assets directory.
-
Copies assets from packages to the imported assets directory.
-
Performs a variety of tasks including;
- Pull in Eyeglass modules
- Run postcss plugins
- Minify the CSS
- Add hashed version to file name
- Output bundle to the dist directory
Runs the following tasks
-
Lint all JavaScript in the source directory.
-
Runs any unit tests found in the JavaScript source directory using Jest.
-
Removes any JavaScript already in the dist directory.
-
Performs a variety of tasks including;
- ES2015 transpilation using Babel
- Bundle all code into a single file
- Generate sourcemap files
- Minify the JavaScript
- Add hashed version to file name
- Output bundle to the dist directory
Runs the following tasks
-
Removes any images already in the dist directory.
-
Optimises all images found in the source directory then copies them to the dist directory.
Generate an SVG sprite and copy into the dist directory
Runs the following tasks
Discovers scripts in the service worker directory.
Copies the worker's internal scripts to the dist directory.
Generates a service worker to pre-cache the assets defined in the config.
Each of these tasks copies the specified set of assets from the src
to the dist
asset folders.
See the config section for details on how to configure these tasks.
Runs the default
task then the following watch tasks.
Runs the css
task when a CSS file is changed.
Runs the scripts
task when a JavaScript file is changed.
Runs the scripts:lint
and scripts:test
tasks when a JavaScript unit test file is changed.
Runs the images
task when an image file is changed.
Runs the same tasks as watch
as well as the following watch tasks.
Runs the assemble
task when documentation files are changed.
This will build a fresh copy of any documentation found in the docs
directory using Assemble, then call the watch
task which will watch for any file changes, and finally call the browserSync:docs
task which reloads the web page when changes are detected in the docs/dist
directory.
Removes document files already in the docs dist directory.
Refreshes the browser when changes to the docs dist directory are detected.
Generates the documentation files.
Here is the outline of the configuration options, descriptions of each are below.
{
webRootDir,
assetSrcDir,
assetDistDir,
css: {
scssDir,
cssDir,
lintPaths,
sourcemaps
},
js: {
srcFile,
jsDir,
lintPaths,
distFile,
applyRevision
},
img: {
imgDir,
svgSpriteFilename
},
importedAssets: {
importedAssetsDir,
importedAssetsSrcGlob
},
sw: {
isEnabled,
swDir,
outputFile,
staticFileGlobs,
dynamicFileRegex,
dynamicFileStrategy,
importScripts,
cacheId
},
copy: {
js,
css,
img,
fonts
},
docs: {
rootDir,
srcDir,
distDir,
assetDir,
templDir,
dataDir,
outputAssets,
remoteBase,
helpers
},
fonts: {
fontsDir
},
misc: {
showFileSize,
showFiles
},
gulp: {
changeEvent,
onError
},
isProduction,
isDev
}
Type: string
Default: '.'
The root directory of your website.
Type: string
Default: 'src'
Root source directory for your assets.
Type: string
Default: 'dist'
Root dist directory for your assets.
-
Type:
string
Default:
'scss'
The directory where your SCSS files reside.
-
Type:
string
Default:
'css'
The bundled CSS file will be output to this directory.
-
Type:
array
Default:
['']
Allows additional paths to be included or excluded from the linting task.
By default, the task will lint all
.scss
files within thescssDir
directory. -
Type:
boolean
Default:
isDev
Turns sourcemaps on or off.
-
Type:
string
Default:
'index.js'
The filename for the entry point to your es2015 code.
-
Type:
string
Default:
'js'
Name of the directory where your JavaScript files are kept.
Compiled JavaScript files will be placed inside a directory with the same name.
-
Type:
array
Default:
['']
Allows additional paths to be included or excluded from the JS linting task.
By default, the task will lint all files within the
jsDir
directory. -
Type:
string
Default:
'script.js'
The filename for the bundled JavaScript.
-
Type:
boolean
Default: true
Will add a content hash to the filename.
-
Type:
string
Default:
'img'
Name of the directory where your image files are kept.
Processed image files will be placed inside a directory with the same name.
-
Type:
string
Default:
'sprite.svg'
Filename of the SVG sprite which is generated from any SVG assets found in the image directory.
-
Type:
string
Default:
'imported-assets'
Name of the directory where assets from node_modules will be copied to.
-
Type:
string
Default:
'node_modules/@justeat/*/'
Glob of packages containing assets to be copied to
importedAssetsDir
.
-
Type:
boolean
Default:
false
Determines whether the service worker is generated or not.
-
Type:
string
Default:
'sw'
Name of the directory where your service worker's custom internal scripts are kept in.
Scripts here will be placed inside a directory with the same name.
-
Type:
string
Default:
'service-worker.js'
The name of the generated service worker file, to be placed in the root of your application.
-
Type:
array
Default:
[]
The static files in your application to be cached by the service worker.
-
Type:
array
Default:
[]
An array of regex to match the dynamic content or API calls to cache e.g.
[/^https:\/\/example\.com\/api/, /^https:\/\/fonts.googleapis.com\/css/]
. -
Type:
string
Default:
cacheFirst
The cache strategy to be used for content matched by
dynamicFileRegex
- these correspond to the sw-toolbox handlers. -
Type:
array
Default:
[]
Any additional internal scripts to include, aside from those in
swDir
. -
Type:
string
Default:
''
An optional string used to differentiate caches on the same origin during local development.
-
Type:
Object
Default:
{}
copy.js
,copy.css
,copy.img
andcopy.fonts
each take an object list of assets in the format:copy: js: { prism: { path: '/libs/**/*', dest: '/libs', revision: false } } }
In which:
path
is a string specifying the path within the relevant assetsrc
folder of the asset to be copied.dest
is a string specifying that destination folder for the asset to be copied to, within the relevant assetdist
folder.revision
is a boolean such that if it is true, the asset will be revision hashed when copied to it’s destination.
path
anddest
must always be defined for each asset you wish to copy.The object key (which in the above example is
prism
) of each asset is simply for your own use to identify each asset in your config.
-
Type:
string
Default:
'./docs'
Root directory where your documentation files reside.
By default your source files will be searched for in
docs/src
, and the generated content will be output todocs/dist
. -
Type:
string
Default:
'src'
The source directory for your documentation template files.
By default the documentation task will use the path
docs/src
– with thesrc
part of this path controlled by this config variable. -
Type:
string
Default:
'dist'
The directory your documentation will be compiled to.
By default the documentation task will use
docs/dist
– with thedist
part of this path controlled by this config variable. -
Type:
string
Default:
'assets/'
The directory your generated assets will be placed inside the documentation directory.
By default the documentation task will use
docs/dist/assets/
– with theassets/
part of this path controlled by this config variable. -
Type:
string
Default:
'templates'
The name of the directory where your documentation template files are kept.
-
Type:
string
Default:
'data'
The name of the directory where your documentation data files are kept.
-
Type:
boolean
Default:
false
Indicates whether or not the JavaScript, CSS and image files should be placed into the
docs/dist/assets/
directory. -
Type:
string
Default:
''
Applies a base path to asset URLs when publishing documentation to Github pages. By default this is set to be an empty string.
-
Type:
object
Default:
{ }
Can pass in an object set of functions, which will be exposed in handlebars as helper functions in the documentation tasks when called using their object key.
For example:
{ 'toLowercase': (input) => { return input.toLowerCase(); } }
Will expose the helper
toLowercase
so that using{{toLowercase name}}
within a handlebars template will convert the handlebars stringname
to lowercase.
-
Type:
string
Default:
'fonts'
Name of the directory where your font files are kept.
-
Type:
boolean
Default:
true
Should file sizes be displayed when a task is run?
-
Type:
boolean
Default:
true
Should file names be displayed when a task is run?
-
Type:
function
Event which fires when a file is modified.
-
Type:
function
Event which fires when an error occurs.
The following options are also present in the config but cannot be overridden.
-
Type:
boolean
Set to
true
when the--prod
flag is passed. -
Type:
boolean
Set to the opposite value of
isProduction
You can access the pathBuilder
paths like this.
const { pathBuilder } = require('@justeat/gulp-build-fozzie');
gulp.task('scss', () => gulp.src(`${pathBuilder.scssSrcDir}/**`)
...
These are the paths which the pathBuilder
object provides.
-
Default:
'src/scss'
-
Default:
'dist/css'
-
Default:
'src/js'
-
Default:
'dist/js'
-
Default:
'src/img'
-
Default:
'dist/img'
-
Default:
'dist/imported-assets'
-
Default:
'.'
-
Default:
'src/sw'
-
Default:
'dist/sw'
-
Default:
'./docs/src'
-
Default:
'./docs/dist'
-
Default:
'./docs/src/templates'
-
Default:
'./docs/src/data'
-
Default:
'./docs/dist/assets/css'
-
Default:
'./docs/dist/assets/js'
-
Default:
'./docs/dist/assets/img'
-
Default:
'src/fonts'
-
Default:
'dist/fonts'