-
Notifications
You must be signed in to change notification settings - Fork 36
/
Copy pathgulpfile.mjs
148 lines (125 loc) · 3.95 KB
/
gulpfile.mjs
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
import gulp from 'gulp'
import { spawn } from 'child_process'
import hugoPath from 'hugo-bin'
import postcss from 'gulp-postcss'
import cssImport from 'postcss-import'
import cssnext from 'postcss-cssnext'
import purgecss from 'gulp-purgecss'
import cleanCSS from 'gulp-clean-css'
import inlineCss from 'gulp-inline-css'
import gulpSass from 'gulp-sass'
import dartSass from 'sass'
const sass = gulpSass(dartSass)
import revall from 'gulp-rev-all'
import del from 'del'
import BrowserSync from 'browser-sync'
import webpack from 'webpack'
import webpackConfig from './webpack.conf.js'
const browserSync = BrowserSync.create()
// Hugo arguments
const hugoArgsDefault = ['-d', '../public', '-s', 'site']
// Development tasks
gulp.task('hugo', (cb) => buildSite(cb))
// Compile CSS with PostCSS
gulp.task('css', function buildCss () {
return gulp.src('./src/scss/*.scss')
.pipe(sass().on('error', sass.logError))
.pipe(postcss([cssImport({ from: './src/css/main.css' }), cssnext()]))
.pipe(gulp.dest('./public/css'))
.pipe(browserSync.stream())
})
// purgecss
gulp.task('purgecss', () => {
return gulp.src('./public/css/**/*.css')
.pipe(purgecss({
content: ['./public/**/*.html'],
safelist: [/dot--*/, /modal/, /DocSearch/, /copy-code-button-*/, /left-transform/, /right-transform/]
}))
.pipe(gulp.dest('./public/css'))
})
// minifycss
gulp.task('minify-css', () => {
return gulp.src('./public/css/*.css')
.pipe(cleanCSS({ debug: true }, (details) => {
console.log(`${details.name}: ${details.stats.originalSize}`)
console.log(`${details.name}: ${details.stats.minifiedSize}`)
}))
.pipe(gulp.dest('./public/css'))
})
// Compile Javascript
gulp.task('js', (cb) => {
const myConfig = Object.assign({}, webpackConfig)
webpack(myConfig, (err) => {
if (err) {
throw err
}
browserSync.reload()
cb()
})
})
// Move all fonts in a directory
gulp.task('fonts', () => (
gulp.src('./src/fonts/**/*')
.pipe(gulp.dest('./public/fonts'))
.pipe(browserSync.stream())
))
gulp.task('assets', () => (
gulp.src('./src/fonts/**/*')
.pipe(gulp.dest('./public/fonts'))
.pipe(browserSync.stream())
))
gulp.task('hash', () => {
return gulp.src('./public/**', { encoding: false })
.pipe(revall.revision({
dontRenameFile: [/^\/favicon.ico$/g, '.html', 'sitemap.xml', 'robots.txt', '.woff', '.eot', '.ttf', '.woff2'],
dontUpdateReference: ['.woff', '.eot', '.ttf', '.woff2']
}))
.pipe(gulp.dest('./public'))
})
gulp.task('inline', function () {
return gulp.src('./public/index.html')
.pipe(inlineCss())
.pipe(gulp.dest('./public/index.html'))
})
gulp.task('serve', (done) => {
browserSync.init({
server: {
baseDir: './public'
}
})
done()
})
gulp.task('reload', (done) => {
browserSync.reload()
done()
})
gulp.task('watch', () => {
gulp.watch('./src/js/**/*.js', gulp.series('js', 'reload'))
gulp.watch('./src/scss/**/*.scss', gulp.series('css', 'reload'))
gulp.watch('./src/fonts/**/*', gulp.series('fonts', 'reload'))
gulp.watch(['./site/content/**/*', './site/layouts/**/*'], gulp.series('hugo', 'reload'))
})
// Development server with browsersync
gulp.task('server', gulp.series(['hugo', 'css', 'js', 'fonts', 'purgecss', 'minify-css', 'serve', 'watch']))
gulp.task('clean', () => {
return del(['./public/**/*'])
})
// Build/production tasks
gulp.task('render', gulp.series(['css', 'js', 'fonts', 'hugo', 'purgecss', 'minify-css']))
gulp.task('build', gulp.series(['clean', 'render', 'hash']))
/**
* Run hugo and build the site
*/
function buildSite (cb, options, environment = 'development') {
const args = options ? hugoArgsDefault.concat(options) : hugoArgsDefault
process.env.NODE_ENV = environment
return spawn(hugoPath, args, { stdio: 'inherit' }).on('close', (code) => {
if (code === 0) {
browserSync.reload()
cb()
} else {
browserSync.notify('Hugo build failed :(')
cb(new Error('Hugo build failed'))
}
})
}