2016-10-06 12:14:33 +02:00
|
|
|
/*
|
2017-01-06 19:11:18 +01:00
|
|
|
* Copyright (c) 2016-2017 Martin Donath <martin.donath@squidfunk.com>
|
2016-10-06 12:14:33 +02:00
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
* of this software and associated documentation files (the "Software"), to
|
|
|
|
* deal in the Software without restriction, including without limitation the
|
|
|
|
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
|
|
* sell copies of the Software, and to permit persons to whom the Software is
|
|
|
|
* furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
|
|
* IN THE SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import gulp from "gulp"
|
|
|
|
import notifier from "node-notifier"
|
|
|
|
import plumber from "gulp-plumber"
|
|
|
|
import util from "gulp-util"
|
|
|
|
import yargs from "yargs"
|
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------------
|
|
|
|
* Configuration and arguments
|
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
const config = {
|
|
|
|
assets: {
|
|
|
|
src: "src/assets", /* Source directory for assets */
|
|
|
|
build: "material/assets" /* Target directory for assets */
|
|
|
|
},
|
2017-01-18 23:23:45 +01:00
|
|
|
lib: "lib", /* Libraries and tasks */
|
|
|
|
tests: {
|
2017-01-28 20:25:30 +01:00
|
|
|
visual: "tests/visual" /* Base directory for visual tests */
|
2017-01-18 23:23:45 +01:00
|
|
|
},
|
2016-10-06 12:14:33 +02:00
|
|
|
views: {
|
|
|
|
src: "src", /* Source directory for views */
|
|
|
|
build: "material" /* Target directory for views */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-02 00:40:36 +01:00
|
|
|
let args = yargs
|
2016-10-06 12:14:33 +02:00
|
|
|
.default("clean", false) /* Clean before build */
|
2016-10-10 12:35:25 +02:00
|
|
|
.default("karma", true) /* Karma watchdog */
|
2016-10-06 12:14:33 +02:00
|
|
|
.default("lint", true) /* Lint sources */
|
2016-10-10 12:35:25 +02:00
|
|
|
.default("mkdocs", true) /* MkDocs watchdog */
|
|
|
|
.default("optimize", false) /* Optimize sources */
|
|
|
|
.default("revision", false) /* Revision assets */
|
2016-10-06 12:14:33 +02:00
|
|
|
.default("sourcemaps", false) /* Create sourcemaps */
|
|
|
|
.argv
|
|
|
|
|
2017-02-02 00:40:36 +01:00
|
|
|
/* Only use the last value seen, so overrides are possible */
|
|
|
|
args = Object.keys(args).reduce((result, arg) => {
|
|
|
|
result[arg] = [].concat(args[arg]).pop()
|
|
|
|
return result
|
|
|
|
}, {})
|
|
|
|
|
2016-10-06 12:14:33 +02:00
|
|
|
/* ----------------------------------------------------------------------------
|
|
|
|
* Overrides and helpers
|
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Override gulp.src() for nicer error handling.
|
|
|
|
*/
|
|
|
|
const src = gulp.src
|
2016-10-31 09:58:43 +01:00
|
|
|
gulp.src = (...glob) => {
|
|
|
|
return src.apply(gulp, glob)
|
2016-10-06 12:14:33 +02:00
|
|
|
.pipe(
|
|
|
|
plumber(function(error) {
|
|
|
|
util.log(util.colors.red(
|
|
|
|
`Error (${error.plugin}): ${error.message}`
|
|
|
|
))
|
|
|
|
|
|
|
|
/* Extract file where error happened, if existent */
|
|
|
|
const file = error.relativePath
|
|
|
|
? error.relativePath.split("/").pop()
|
|
|
|
: ""
|
|
|
|
|
|
|
|
/* Dispatch system-level notification */
|
|
|
|
notifier.notify({
|
|
|
|
title: `Error (${error.plugin}): ${file}`,
|
|
|
|
message: error.messageOriginal
|
|
|
|
})
|
|
|
|
|
|
|
|
// eslint-disable-next-line no-invalid-this
|
|
|
|
this.emit("end")
|
|
|
|
|
|
|
|
/* Throw error and abort, if not in watch mode */
|
|
|
|
if (args._[0] !== "watch")
|
|
|
|
throw error
|
|
|
|
}))
|
2016-10-31 09:58:43 +01:00
|
|
|
}
|
2016-10-06 12:14:33 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Helper function to load a task
|
|
|
|
*/
|
2016-10-31 09:58:43 +01:00
|
|
|
const load = task => {
|
2017-01-28 20:25:30 +01:00
|
|
|
return done => {
|
|
|
|
return require(`./${config.lib}/tasks/${task}`)
|
|
|
|
.call(gulp, gulp, config, args)(done)
|
|
|
|
}
|
2016-10-31 09:58:43 +01:00
|
|
|
}
|
2016-10-06 12:14:33 +02:00
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------------
|
|
|
|
* Images
|
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copy favicon
|
|
|
|
*/
|
|
|
|
gulp.task("assets:images:build:ico",
|
|
|
|
load("assets/images/build/ico"))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copy and minify vector graphics
|
|
|
|
*/
|
|
|
|
gulp.task("assets:images:build:svg",
|
|
|
|
load("assets/images/build/svg"))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copy images
|
|
|
|
*/
|
|
|
|
gulp.task("assets:images:build", args.clean ? [
|
|
|
|
"assets:images:clean"
|
2016-10-31 09:58:43 +01:00
|
|
|
] : [], () => {
|
|
|
|
return gulp.start([
|
2016-10-06 12:14:33 +02:00
|
|
|
"assets:images:build:ico",
|
|
|
|
"assets:images:build:svg"
|
|
|
|
])
|
2016-10-31 09:58:43 +01:00
|
|
|
})
|
2016-10-06 12:14:33 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Clean images generated by build
|
|
|
|
*/
|
|
|
|
gulp.task("assets:images:clean",
|
|
|
|
load("assets/images/clean"))
|
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------------
|
2016-12-15 15:55:40 +01:00
|
|
|
* JavaScript
|
2016-10-06 12:14:33 +02:00
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Build application logic
|
|
|
|
*/
|
|
|
|
gulp.task("assets:javascripts:build:application",
|
|
|
|
load("assets/javascripts/build/application"))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Build custom modernizr
|
|
|
|
*/
|
|
|
|
gulp.task("assets:javascripts:build:modernizr", [
|
|
|
|
"assets:stylesheets:build"
|
|
|
|
], load("assets/javascripts/build/modernizr"))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Build application logic and modernizr
|
|
|
|
*/
|
|
|
|
gulp.task("assets:javascripts:build", (args.clean ? [
|
|
|
|
"assets:javascripts:clean"
|
|
|
|
] : []).concat(args.lint ? [
|
|
|
|
"assets:javascripts:lint"
|
|
|
|
] : []), () => {
|
2016-10-31 09:58:43 +01:00
|
|
|
return gulp.start([
|
2016-10-06 12:14:33 +02:00
|
|
|
"assets:javascripts:build:application",
|
|
|
|
"assets:javascripts:build:modernizr"
|
|
|
|
])
|
|
|
|
})
|
|
|
|
|
|
|
|
/*
|
2016-12-15 15:55:40 +01:00
|
|
|
* Clean JavaScript generated by build
|
2016-10-06 12:14:33 +02:00
|
|
|
*/
|
|
|
|
gulp.task("assets:javascripts:clean",
|
|
|
|
load("assets/javascripts/clean"))
|
|
|
|
|
|
|
|
/*
|
2016-12-15 15:55:40 +01:00
|
|
|
* Lint JavaScript
|
2016-10-06 12:14:33 +02:00
|
|
|
*/
|
|
|
|
gulp.task("assets:javascripts:lint",
|
|
|
|
load("assets/javascripts/lint"))
|
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------------
|
|
|
|
* Stylesheets
|
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Build stylesheets from SASS source
|
|
|
|
*/
|
|
|
|
gulp.task("assets:stylesheets:build", (args.clean ? [
|
|
|
|
"assets:stylesheets:clean"
|
|
|
|
] : []).concat(args.lint ? [
|
|
|
|
"assets:stylesheets:lint"
|
|
|
|
] : []),
|
|
|
|
load("assets/stylesheets/build"))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Clean stylesheets generated by build
|
|
|
|
*/
|
|
|
|
gulp.task("assets:stylesheets:clean",
|
|
|
|
load("assets/stylesheets/clean"))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Lint SASS sources
|
|
|
|
*/
|
|
|
|
gulp.task("assets:stylesheets:lint",
|
|
|
|
load("assets/stylesheets/lint"))
|
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------------
|
|
|
|
* Assets
|
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Build assets
|
|
|
|
*/
|
|
|
|
gulp.task("assets:build", [
|
|
|
|
"assets:images:build",
|
|
|
|
"assets:javascripts:build",
|
|
|
|
"assets:stylesheets:build"
|
|
|
|
])
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Clean files generated by build
|
|
|
|
*/
|
|
|
|
gulp.task("assets:clean", [
|
|
|
|
"assets:images:clean",
|
|
|
|
"assets:javascripts:clean",
|
|
|
|
"assets:stylesheets:clean"
|
|
|
|
])
|
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------------
|
|
|
|
* Views
|
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Minify views
|
|
|
|
*/
|
|
|
|
gulp.task("views:build", (args.revision ? [
|
2017-01-18 23:23:45 +01:00
|
|
|
"assets:build"
|
2016-10-06 12:14:33 +02:00
|
|
|
] : []).concat(args.clean ? [
|
|
|
|
"views:clean"
|
2017-01-18 23:23:45 +01:00
|
|
|
] : []),
|
|
|
|
load("views/build"))
|
2016-10-06 12:14:33 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Clean views
|
|
|
|
*/
|
|
|
|
gulp.task("views:clean",
|
|
|
|
load("views/clean"))
|
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------------
|
|
|
|
* MkDocs
|
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Build documentation
|
|
|
|
*/
|
|
|
|
gulp.task("mkdocs:build", [
|
|
|
|
"assets:build",
|
|
|
|
"views:build",
|
|
|
|
"mkdocs:clean"
|
|
|
|
], load("mkdocs/build"))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Clean documentation build
|
|
|
|
*/
|
|
|
|
gulp.task("mkdocs:clean",
|
|
|
|
load("mkdocs/clean"))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Restart MkDocs server
|
|
|
|
*/
|
|
|
|
gulp.task("mkdocs:serve",
|
|
|
|
load("mkdocs/serve"))
|
|
|
|
|
2016-10-07 16:38:13 +02:00
|
|
|
/* ----------------------------------------------------------------------------
|
2017-01-28 20:25:30 +01:00
|
|
|
* Visual tests
|
2016-10-07 16:38:13 +02:00
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
2017-01-28 20:25:30 +01:00
|
|
|
/*
|
|
|
|
* Generate visual tests
|
|
|
|
*/
|
2017-02-02 00:40:36 +01:00
|
|
|
gulp.task("tests:visual:generate", [
|
|
|
|
].concat(args.clean ? [
|
2017-02-05 22:46:45 +01:00
|
|
|
"tests:visual:clean",
|
2017-02-02 00:40:36 +01:00
|
|
|
"assets:build",
|
|
|
|
"views:build"
|
2017-01-28 20:25:30 +01:00
|
|
|
] : []),
|
|
|
|
load("tests/visual/generate"))
|
|
|
|
|
2017-01-18 23:23:45 +01:00
|
|
|
/*
|
|
|
|
* Run visual tests
|
|
|
|
*/
|
|
|
|
gulp.task("tests:visual:run", [
|
2017-01-28 20:25:30 +01:00
|
|
|
"tests:visual:generate"
|
2017-01-18 23:23:45 +01:00
|
|
|
], load("tests/visual/run"))
|
|
|
|
|
2016-10-07 16:38:13 +02:00
|
|
|
/*
|
2017-01-28 20:25:30 +01:00
|
|
|
* Update reference images for visual tests
|
|
|
|
*/
|
|
|
|
gulp.task("tests:visual:update",
|
|
|
|
load("tests/visual/update"))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Clean files generated by visual tests
|
2016-10-07 16:38:13 +02:00
|
|
|
*/
|
2017-01-28 20:25:30 +01:00
|
|
|
gulp.task("tests:visual:clean",
|
|
|
|
load("tests/visual/clean"))
|
2016-10-07 16:38:13 +02:00
|
|
|
|
2017-02-09 11:12:56 +01:00
|
|
|
/*
|
|
|
|
* Open a SauceConnect session for manual testing
|
|
|
|
*/
|
2017-02-10 16:01:38 +01:00
|
|
|
gulp.task("tests:visual:session", [
|
|
|
|
"tests:visual:generate"
|
|
|
|
], load("tests/visual/session"))
|
2017-02-09 11:12:56 +01:00
|
|
|
|
2016-10-06 12:14:33 +02:00
|
|
|
/* ----------------------------------------------------------------------------
|
|
|
|
* Interface
|
|
|
|
* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Build assets and documentation
|
|
|
|
*/
|
|
|
|
gulp.task("build", [
|
2016-10-21 21:13:47 +02:00
|
|
|
"assets:build",
|
|
|
|
"views:build"
|
2017-01-18 23:23:45 +01:00
|
|
|
].concat(args.mkdocs ? [
|
|
|
|
"mkdocs:build"
|
|
|
|
] : []))
|
2016-10-06 12:14:33 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Clean assets and documentation
|
|
|
|
*/
|
|
|
|
gulp.task("clean", [
|
|
|
|
"assets:clean",
|
|
|
|
"views:clean",
|
|
|
|
"mkdocs:clean"
|
|
|
|
])
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Watch for changes and rebuild assets on the fly
|
|
|
|
*/
|
|
|
|
gulp.task("watch", [
|
|
|
|
"assets:build",
|
|
|
|
"views:build"
|
|
|
|
], () => {
|
2016-10-10 12:35:25 +02:00
|
|
|
process.env.WATCH = true
|
2016-10-07 16:38:13 +02:00
|
|
|
|
|
|
|
/* Start MkDocs server */
|
2016-10-06 12:14:33 +02:00
|
|
|
if (args.mkdocs)
|
|
|
|
gulp.start("mkdocs:serve")
|
|
|
|
|
2016-10-07 16:38:13 +02:00
|
|
|
/* Start karma test runner */
|
2017-01-02 23:18:44 +01:00
|
|
|
// if (args.karma)
|
|
|
|
// gulp.start("tests:unit:watch")
|
2016-10-07 16:38:13 +02:00
|
|
|
|
2016-10-06 12:14:33 +02:00
|
|
|
/* Rebuild stylesheets */
|
|
|
|
gulp.watch([
|
|
|
|
`${config.assets.src}/stylesheets/**/*.scss`
|
|
|
|
], ["assets:stylesheets:build"])
|
|
|
|
|
2016-12-15 15:55:40 +01:00
|
|
|
/* Rebuild JavaScript */
|
2016-10-06 12:14:33 +02:00
|
|
|
gulp.watch([
|
2016-10-30 10:36:18 +01:00
|
|
|
`${config.assets.src}/javascripts/**/*.{js,jsx}`
|
2016-10-06 12:14:33 +02:00
|
|
|
], ["assets:javascripts:build:application"])
|
|
|
|
|
|
|
|
/* Copy images */
|
|
|
|
gulp.watch([
|
|
|
|
`${config.assets.src}/images/**/*`
|
|
|
|
], ["assets:images:build"])
|
|
|
|
|
|
|
|
/* Minify views */
|
|
|
|
gulp.watch([
|
|
|
|
`${config.views.src}/**/*.html`
|
|
|
|
], ["views:build"])
|
|
|
|
})
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Build assets by default
|
|
|
|
*/
|
|
|
|
gulp.task("default", ["build"])
|