const {
src,
dest,
series,
parallel
} = require('gulp');
const csso = require('gulp-csso');
const concat = require('gulp-concat');
const uglify = require('gulp-uglify');
const replace = require('gulp-replace');
const htmlmin = require('gulp-htmlmin');
const watch = require('gulp-watch');
const clean = require('gulp-clean');
const path = {
src: 'src',
dev: 'dev',
build: 'build/web',
nodeModules: 'node_modules',
}
const filename = {
css: "nighttab.min.css",
jsDependencies: "nighttab.dependencies.js",
jsFiles: "nighttab.files.js",
js: "nighttab.min.js"
}
const jsDependencies = [
path.nodeModules + '/html5sortable/dist/html5sortable.min.js',
path.nodeModules + '/invert-color/lib/invert.min.js'
]
const jsFiles = [
path.src + '/js/helper.js',
path.src + '/js/data.js',
path.src + '/js/fontawesome.js',
path.src + '/js/update.js',
path.src + '/js/state.js',
path.src + '/js/bookmarks.js',
path.src + '/js/control.js',
path.src + '/js/menu.js',
path.src + '/js/header.js',
path.src + '/js/modal.js',
path.src + '/js/tip.js',
path.src + '/js/shade.js',
path.src + '/js/theme.js',
path.src + '/js/date.js',
path.src + '/js/greeting.js',
path.src + '/js/transitional.js',
path.src + '/js/clock.js',
path.src + '/js/search.js',
path.src + '/js/link.js',
path.src + '/js/version.js',
path.src + '/js/keyboard.js',
path.src + '/js/background.js',
path.src + '/js/layout.js',
path.src + '/js/auto-suggest.js',
path.src + '/js/pagelock.js',
path.src + '/js/edge.js',
path.src + '/js/init.js'
]
const build = {
manifest: function() {
return src(path.src + '/manifest.json')
.pipe(dest(path.build))
},
html: function() {
return src(path.src + '/index.html')
.pipe(replace(/\<\!\-\-\ css\-block\ \-\-\>([\s\S]*)\<\!\-\-\ end\-css\-block\ \-\-\>/mg, ''))
.pipe(replace(/\<\!\-\-\ js\-block\ \-\-\>([\s\S]*)\<\!\-\-\ end\-js\-block\ \-\-\>/mg, ''))
.pipe(htmlmin({
collapseWhitespace: true
}))
.pipe(dest(path.build))
},
fonts: function() {
return src(path.src + '/fonts/**/*.*')
.pipe(dest(path.build + '/fonts'))
},
icons: function() {
return src(path.src + '/icons/**/*.*')
.pipe(dest(path.build + '/icons'))
},
css: function() {
return src(path.src + '/css/*.css')
.pipe(concat(filename.css))
.pipe(csso())
.pipe(dest(path.build + '/css'))
},
jsDependencies: function() {
return src(jsDependencies)
.pipe(concat(filename.jsDependencies))
.pipe(dest(path.build + '/js'))
},
jsFiles: function() {
return src(jsFiles)
.pipe(concat(filename.jsFiles))
.pipe(uglify())
.pipe(dest(path.build + '/js', {
sourcemaps: '.'
}))
},
js: function() {
return src([path.build + '/js/' + filename.jsDependencies, path.build + '/js/' + filename.jsFiles])
.pipe(concat(filename.js))
.pipe(dest(path.build + '/js', {
sourcemaps: '.'
}))
},
jsClean: function() {
return src([path.build + '/js/' + filename.jsDependencies, path.build + '/js/' + filename.jsFiles])
.pipe(clean())
}
}
const dev = {
manifest: function() {
watch(path.src + '/manifest.json', {
ignoreInitial: false
}, function() {
return src(path.src + '/manifest.json')
.pipe(dest(path.dev))
})
},
html: function() {
watch(path.src + '/index.html', {
ignoreInitial: false
}, function() {
return src(path.src + '/index.html')
.pipe(dest(path.dev))
})
},
fonts: function() {
watch(path.src + '/fonts/**/*.*', {
ignoreInitial: false
}, function() {
return src(path.src + '/fonts/**/*.*')
.pipe(dest(path.dev + '/fonts'))
})
},
icons: function() {
watch(path.src + '/icons/**/*.*', {
ignoreInitial: false
}, function() {
return src(path.src + '/icons/**/*.*')
.pipe(dest(path.dev + '/icons'))
})
},
css: function() {
watch(path.src + '/css/*.css', {
ignoreInitial: false
}, function() {
return src(path.src + '/css/*.css')
.pipe(dest(path.dev + '/css'))
})
},
js: function() {
watch(jsFiles, {
ignoreInitial: false
}, function() {
return src(jsFiles)
.pipe(dest(path.dev + '/js'))
})
}
}
exports.dev = parallel(dev.manifest, dev.html, dev.fonts, dev.icons, dev.css, dev.js)
exports.build = series(parallel(build.manifest, build.html, build.fonts, build.icons, build.css), series(build.jsDependencies, build.jsFiles, build.js), build.jsClean)