saudade/supernova/gulpfile.js

87 lines
2 KiB
JavaScript

const {src, dest, watch, parallel} = require('gulp')
const posthtml = require('gulp-posthtml')
const rename = require('gulp-rename')
const browserSync = require('browser-sync').create()
const sourcemaps = require('gulp-sourcemaps')
const htmlFiles = [
'supernova/**/*.html',
'!supernova/**/index.html',
'!supernova/includes/**/*'
]
const posthtmlPlugins = [
require('posthtml-urls')({
eachURL: (url) => {
if (url.endsWith('?@root')) {
return url.replace('?@root', '')
} else if (url.startsWith('/')) {
return `/supernova${url}`
} else {
return url
}
},
})
]
const postcssPlugins = [
require('postcss-preset-env')({
enableClientSidePolyfills: true,
}),
require('cssnano')({
preset: 'default'
})
]
function html() {
const stream = src(htmlFiles)
.pipe(posthtml([
...posthtmlPlugins,
require('posthtml-modules')({
root: 'supernova',
plugins: posthtmlPlugins
}),
require('posthtml-postcss')(postcssPlugins, {}, /^text\/css$/),
]))
.pipe(rename(path => {
path.basename = 'index'
}))
.pipe(dest('supernova'))
if (browserSync.active) {
stream.pipe(browserSync.stream())
}
return stream
}
const cssFiles = [
'supernova/**/*.css',
'!supernova/**/style.css',
]
function css() {
const stream = src(cssFiles)
.pipe(sourcemaps.init())
.pipe(require('gulp-postcss')(postcssPlugins))
.pipe(rename(path => {
path.basename = 'style'
}))
.pipe(sourcemaps.write())
.pipe(dest('supernova'))
if (browserSync.active) {
stream.pipe(browserSync.stream())
}
return stream
}
exports.watch = function () {
browserSync.init(require('../bs-config'))
watch(htmlFiles, {ignoreInitial: false}, html)
watch(cssFiles, {ignoreInitial: false}, css)
}
exports.build = parallel(html, css)