-
Notifications
You must be signed in to change notification settings - Fork 901
/
gulpfile.js
130 lines (115 loc) · 3.79 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
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
/*
* Here are all the gulp tasks you can use to help manage your blog
* Use `npm install` to install all the dependencies located in package.json
* If you have an issue with sharp, try: `npm rebuild`.
* Then `gulp default` to minimize css and images.
*/
const gulp = require('gulp');
const concat = require('gulp-concat');
const uglify = require('gulp-uglify-es').default;
const less = require('gulp-less');
const cleanCSS = require('gulp-clean-css');
const replace = require('gulp-replace');
const webp = require('gulp-webp');
const fs = require('fs');
// Use it gulp post -n <title of the post>
gulp.task('post', function (callback) {
let args = process.argv;
let title = args[args.length - 1];
let filename = new Date().toLocaleDateString('en-CA') + '-' + title.replace(/ /g, '-') + '.md';
let content = '---\n' +
'layout: post\n' +
'title: ' + title + '\n' +
//'feature-img: "assets/img/"\n' +
//'thumbnail: "assets/img/thumbnails/"\n' +
'tags: []\n' +
'---';
console.log('[' + new Date().toLocaleTimeString('en-CA', {hour12: false}) + '] File created: _posts/' + filename);
fs.writeFile(__dirname + '/../_posts/' + filename, content, callback);
});
gulp.task('js', function minijs() {
return gulp.src(['js/partials/**.js'])
.pipe(concat('main.min.js'))
.pipe(uglify())
.on('error', (err) => {
console.log(err.toString())
})
.pipe(gulp.dest("js/"))
});
gulp.task("img", async function imging() {
const imagemin = await import('gulp-imagemin');
return gulp.src('img/**/*.{png,svg,jpg,webp,jpeg,gif}')
.pipe(imagemin.default())
.on('error', (err) => {
console.log(err.toString())
})
.pipe(gulp.dest('img/'))
});
// Alternative using "sharp" in case "imagemin" does not work, supported formats: heic, heif, jpeg, jpg, png, raw, tiff, webp
gulp.task('sharp_img', async function () {
const responsive = await import('gulp-responsive');
let settings = {
quality: 85,
progressive: true,
compressionLevel: 6,
};
return gulp.src('img/**/*.{png,jpg,webp,jpeg}')
.pipe(responsive({
'**/*.*': settings,
'*.*': settings,
}))
.pipe(gulp.dest('img'))
});
gulp.task('thumbnails', async function () {
const responsive = await import('gulp-responsive');
let settings = {
width: '50%',
//format: 'jpeg', // convert to jpeg format
};
return gulp.src('img/feature-img/*')
.pipe(responsive({
'**/*.*': settings,
'*.*': settings,
}))
.pipe(gulp.dest('img/thumbnails/feature-img'))
});
gulp.task('thumbnails-all', async function () {
const responsive = await import('gulp-responsive');
let settings = {
width: '50%',
//format: 'jpeg', // convert to jpeg format
};
return gulp.src('img/*.{png,jpg,webp,jpeg}')
.pipe(responsive({'*.*': settings}))
.pipe(gulp.dest('img/thumbnails')) &&
gulp.src('img/!(thumbnails)/*.{png,jpg,webp,jpeg}')
.pipe(responsive({'**/*.*': settings}))
.pipe(gulp.dest('img/thumbnails'))
});
gulp.task('webp', () =>
gulp.src('img/**/*.{png,svg,jpg,jpeg,gif}')
.pipe(webp({
quality: 85,
preset: 'photo',
method: 6
}))
.pipe(gulp.dest('img'))
);
gulp.task('css', function minicss() {
return gulp.src('css/vendor/bootstrap-iso.css')
.pipe(cleanCSS())
.on('error', (err) => {
console.log(err.toString())
})
.pipe(concat('bootstrap-iso.min.css'))
.pipe(gulp.dest('css/vendor/'));
});
gulp.task('isolate', function isolateBootstrap() {
return gulp.src('css/bootstrap-iso.less')
.pipe(less({strictMath: 'on'}))
.pipe(replace('.bootstrap-iso html', ''))
.pipe(replace('.bootstrap-iso body', ''))
.pipe(gulp.dest('css/vendor/'));
});
gulp.task("isolate-bootstrap-css", gulp.series('isolate', 'css'));
gulp.task("default", gulp.series(gulp.parallel('js', 'css', 'img')));