-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
74 lines (64 loc) · 2 KB
/
gulpfile.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
'use strict';
const gulp = require( 'gulp' );
const postcss = require( 'gulp-postcss' );
// Use terser minifier with gulp-uglify for ES2015 support.
const composer = require( 'gulp-uglify/composer' );
const terser = require( 'terser' );
const minify = composer( terser, console );
const sourcemaps = require( 'gulp-sourcemaps' );
const paths = {
styles: {
src: 'assets/styles/portfolio.css',
dest: 'assets/styles/build/',
watch: 'assets/styles/*.css'
},
scripts: {
src: 'assets/scripts/*.js',
dest: 'assets/scripts/build/'
}
};
const processors = [
require( 'postcss-import' ),
require( 'postcss-nested' ),
require( 'postcss-custom-properties' ),
require( 'postcss-normalize' )( { forceImport: true } ),
require( 'css-mqpacker' )( { sort: true } ),
require( 'autoprefixer' ),
require( 'cssnano' )( {
preset: [ 'default', {
calc: false,
mergeLonghand: false // These conflict with processing nested calc() and env values().
} ]
} )
];
function styles() {
return gulp.src( paths.styles.src )
.pipe( sourcemaps.init() )
.pipe( postcss( processors ) )
.pipe( sourcemaps.write( './' ) )
.pipe (gulp.dest( paths.styles.dest ) );
}
function scripts() {
return gulp.src( paths.scripts.src )
.pipe( sourcemaps.init() )
.pipe( minify() )
.pipe( sourcemaps.write( './' ) )
.pipe( gulp.dest( paths.scripts.dest ) );
}
function watch() {
gulp.watch( paths.styles.watch, styles );
gulp.watch( paths.scripts.src, scripts );
}
// Workflows
// $ gulp: Builds, prefixes, and minifies CSS files; concencates and minifies JS files; watches for changes. The works.
const defaultTask = gulp.parallel( styles, scripts, watch );
// $ gulp build: Builds, prefixes, and minifies CSS files; concencates and minifies JS files. For const.
const buildTask = gulp.parallel( styles, scripts );
// Exports
// Externalise individual tasks.
exports.styles = styles;
exports.scripts = scripts;
exports.watch = watch;
// Externalise Workflows.
exports.build = buildTask;
exports.default = defaultTask;