mirror of
https://github.com/BobbyWibowo/lolisafe.git
synced 2025-01-22 02:51:34 +00:00
225 lines
5.6 KiB
JavaScript
225 lines
5.6 KiB
JavaScript
const { exec } = require('child_process')
|
|
const path = require('path')
|
|
const gulp = require('gulp')
|
|
const cssnano = require('cssnano')
|
|
const buble = require('gulp-buble')
|
|
const eslint = require('gulp-eslint-new')
|
|
const gulpif = require('gulp-if')
|
|
const jetpack = require('fs-jetpack')
|
|
const nodemon = require('gulp-nodemon')
|
|
const postcss = require('gulp-postcss')
|
|
const postcssPresetEnv = require('postcss-preset-env')
|
|
const replace = require('gulp-replace')
|
|
const sass = require('gulp-dart-sass')
|
|
const sassCompiler = require('sass')
|
|
const sourcemaps = require('gulp-sourcemaps')
|
|
const stylelint = require('@ronilaukkarinen/gulp-stylelint')
|
|
const terser = require('gulp-terser')
|
|
|
|
let sassEmbeddedCompiler
|
|
try {
|
|
sassEmbeddedCompiler = require('sass-embedded')
|
|
console.log('Using "sass-embedded" package to compile sass\u2026')
|
|
} catch (_) {}
|
|
|
|
// Put built files for development on a Git-ignored directory.
|
|
// This will prevent IDE's Git from unnecessarily
|
|
// building diff's during development.
|
|
const dist = process.env.NODE_ENV === 'development'
|
|
? path.join(__dirname, 'dist-dev')
|
|
: path.join(__dirname, 'dist')
|
|
|
|
// Ensure dist directory exists.
|
|
jetpack.dir(dist)
|
|
|
|
const postcssPlugins = [
|
|
postcssPresetEnv()
|
|
]
|
|
|
|
sass.compiler = sassEmbeddedCompiler || sassCompiler
|
|
|
|
// Minify on production
|
|
if (process.env.NODE_ENV !== 'development') {
|
|
postcssPlugins.push(cssnano())
|
|
}
|
|
|
|
/** TASKS: LINT */
|
|
|
|
gulp.task('lint:style', () => {
|
|
return gulp.src([
|
|
'./src/**/*.css',
|
|
'./src/**/*.scss'
|
|
])
|
|
.pipe(stylelint({
|
|
failAfterError: true,
|
|
reporters: [{ formatter: 'string', console: true }]
|
|
}))
|
|
})
|
|
|
|
gulp.task('lint:js', () => {
|
|
return gulp.src([
|
|
'./*.js',
|
|
'./{controllers,database,routes,scripts,src}/**/*.js'
|
|
], {
|
|
ignore: [
|
|
'./src/libs/**/*'
|
|
]
|
|
})
|
|
.pipe(eslint())
|
|
.pipe(eslint.format('stylish'))
|
|
.pipe(eslint.failAfterError())
|
|
})
|
|
|
|
// Set _settle to true, so that if one of the parallel tasks fails,
|
|
// the other one won't exit prematurely (this is a bit awkward).
|
|
// https://github.com/gulpjs/gulp/issues/1487#issuecomment-466621047
|
|
gulp._settle = true
|
|
gulp.task('lint', gulp.parallel('lint:style', 'lint:js'))
|
|
gulp._settle = false
|
|
|
|
/** TASKS: CLEAN */
|
|
|
|
gulp.task('clean:style', async () => {
|
|
return jetpack.findAsync(dist, {
|
|
matching: '**/*.css*(.map)'
|
|
}).then(files =>
|
|
Promise.all(files.map(file =>
|
|
jetpack.removeAsync(file)
|
|
))
|
|
)
|
|
})
|
|
|
|
gulp.task('clean:js', () => {
|
|
return jetpack.findAsync(dist, {
|
|
matching: '**/*.js*(.map)'
|
|
}).then(files =>
|
|
Promise.all(files.map(file =>
|
|
jetpack.removeAsync(file)
|
|
))
|
|
)
|
|
})
|
|
|
|
gulp.task('clean:rest', () => {
|
|
// Delete all other files and sub-directories
|
|
return jetpack.findAsync(dist, {
|
|
directories: true
|
|
}).then(files =>
|
|
Promise.all(files.map(file =>
|
|
jetpack.removeAsync(file)
|
|
))
|
|
)
|
|
})
|
|
|
|
gulp.task('clean', gulp.series(gulp.parallel('clean:style', 'clean:js'), 'clean:rest'))
|
|
|
|
/** TASKS: BUILD */
|
|
|
|
gulp.task('build:sass', function () {
|
|
return gulp.src('./src/**/*.scss', {
|
|
ignore: '_*.scss'
|
|
})
|
|
.pipe(sourcemaps.init())
|
|
.pipe(sass().on('error', sass.logError))
|
|
.pipe(postcss(postcssPlugins))
|
|
.pipe(sourcemaps.write('.'))
|
|
.pipe(gulp.dest(dist))
|
|
})
|
|
|
|
gulp.task('build:css', () => {
|
|
return gulp.src('./src/**/*.css', {
|
|
ignore: './src/libs/fontello/fontello.css'
|
|
})
|
|
.pipe(sourcemaps.init())
|
|
.pipe(postcss(postcssPlugins))
|
|
.pipe(sourcemaps.write('.'))
|
|
.pipe(gulp.dest(dist))
|
|
})
|
|
|
|
gulp.task('build:fontello', () => {
|
|
const version = require('./src/versions.json')[5]
|
|
return gulp.src('./src/libs/fontello/fontello.css')
|
|
.pipe(sourcemaps.init())
|
|
.pipe(gulpif(version !== undefined, replace(/(fontello\.(eot|woff2?|woff|ttf|svg))/g, `$1?_=${version}`)))
|
|
.pipe(postcss(postcssPlugins))
|
|
.pipe(sourcemaps.write('.'))
|
|
.pipe(gulp.dest(`${dist}/libs/fontello`))
|
|
})
|
|
|
|
gulp.task('build:js', () => {
|
|
return gulp.src('./src/**/*.js')
|
|
.pipe(sourcemaps.init())
|
|
.pipe(buble())
|
|
// Minify on production
|
|
.pipe(gulpif(process.env.NODE_ENV !== 'development', terser()))
|
|
.pipe(sourcemaps.write('.'))
|
|
.pipe(gulp.dest(dist))
|
|
})
|
|
|
|
gulp.task('build', gulp.parallel('build:sass', 'build:css', 'build:fontello', 'build:js'))
|
|
|
|
gulp.task('build-dev', gulp.series('clean', 'build'))
|
|
|
|
/** TASKS: VERSION STRINGS */
|
|
|
|
gulp.task('exec:bump-versions', cb => {
|
|
exec('node ./scripts/bump-versions.js 1', (error, stdout, stderr) => {
|
|
if (stdout) process.stdout.write(stdout)
|
|
if (stderr) process.stderr.write(stderr)
|
|
cb(error)
|
|
})
|
|
})
|
|
|
|
gulp.task('default', gulp.series('lint', 'clean', 'build', 'exec:bump-versions'))
|
|
|
|
/** TASKS: WATCH (SKIP LINTER) */
|
|
|
|
gulp.task('watch:scss', () => {
|
|
return gulp.watch([
|
|
'src/**/*.scss'
|
|
], gulp.series('build:sass'))
|
|
})
|
|
|
|
gulp.task('watch:css', () => {
|
|
return gulp.watch([
|
|
'src/**/*.css'
|
|
], {
|
|
ignored: [
|
|
'src/libs/fontello/fontello.css'
|
|
]
|
|
}, gulp.series('build:css'))
|
|
})
|
|
gulp.task('watch:fontello', () => {
|
|
return gulp.watch([
|
|
'src/libs/fontello/fontello.css'
|
|
], gulp.series('build:fontello'))
|
|
})
|
|
|
|
gulp.task('watch:js', () => {
|
|
return gulp.watch([
|
|
'src/**/*.js'
|
|
], gulp.series('build:js'))
|
|
})
|
|
|
|
gulp.task('watch:src', gulp.parallel('watch:css', 'watch:scss', 'watch:fontello', 'watch:js'))
|
|
|
|
gulp.task('nodemon', cb => {
|
|
return nodemon({
|
|
script: './lolisafe.js',
|
|
env: process.env,
|
|
watch: [
|
|
'controllers/',
|
|
'routes/',
|
|
'views/_globals.njk',
|
|
'views/_layout.njk',
|
|
'views/album.njk',
|
|
'config.js',
|
|
'logger.js',
|
|
'lolisafe.js'
|
|
],
|
|
ext: 'js',
|
|
done: cb
|
|
})
|
|
})
|
|
|
|
gulp.task('watch', gulp.series('clean', 'build', gulp.parallel('nodemon', 'watch:src')))
|