This repository has been archived by the owner on Feb 18, 2024. It is now read-only.
/
gulpfile.js
92 lines (84 loc) · 2.48 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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
const gulp = require('gulp');
const rename = require('gulp-rename');
const pump = require('pump');
const lec = require('gulp-line-ending-corrector');
const header = require('gulp-header');
const version = require('./package.json').version;
const autoprefixer = require('gulp-autoprefixer');
const cleanCss = require('gulp-clean-css');
const sourcemaps = require('gulp-sourcemaps');
const uglify = require('gulp-uglify');
const concatJS = require('gulp-concat');
const babel = require('gulp-babel');
/**
* PATHS
*/
// CSS
const mainCss = './src/css/image-comparer.css';
const cssInput = './src/css/**/*.css';
const cssOutput = './dist/css';
// JavaScript
const jsInput = ['./src/js/**/*.js', '!./src/js/**/_*.js'];
const jsOutput = './dist/js/';
// docs
const docsOutput = './docs';
/**
* LICENSE
*/
const licenseHeader = [
'/**',
' * Image Comparer - A little plugin that implements a image comparer.',
' * @version v' + version + '',
' * @author Eduardo Oliveira (EduardoJM) <eduardo_y05@outlook.com>.',
' * @link https://github.com/EduardoJM/Image-Comparer',
' * ',
' * Licensed under the MIT License (https://github.com/EduardoJM/Image-Comparer/blob/master/LICENSE).',
' */',
'\n'
].join('\n');
function onError(err) {
console.log(err);
this.emit('end');
}
gulp.task('css', function (callback) {
pump([
gulp.src(mainCss),
lec(),
sourcemaps.init(),
autoprefixer(),
header(licenseHeader),
rename("image-comparer.css"),
gulp.dest(cssOutput),
gulp.dest(`${docsOutput}/css`),
sourcemaps.write(),
cleanCss(),
rename("image-comparer.min.css"),
header(licenseHeader),
gulp.dest(cssOutput),
gulp.dest(`${docsOutput}/css`),
], callback);
});
gulp.task('js', function (callback) {
pump([
gulp.src(jsInput),
concatJS('image-comparer.js'),
babel({
presets: ['@babel/env'],
plugins: ['@babel/plugin-proposal-class-properties']
}),
header(licenseHeader),
gulp.dest(jsOutput),
gulp.dest(`${docsOutput}/js`),
uglify().on('error', onError),
rename("image-comparer.min.js"),
header(licenseHeader),
gulp.dest(jsOutput),
gulp.dest(`${docsOutput}/js`),
], callback);
});
gulp.task('watchJS', function () {
return gulp.watch(jsInput, gulp.series(['js']));
});
gulp.task('watchCSS', function() {
return gulp.watch(cssInput, gulp.series(['css']));
});