-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.babel.js
117 lines (103 loc) · 2.67 KB
/
gulpfile.babel.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
// Development Mode
const devMode = false
// Common
import gulp from 'gulp'
import concat from 'gulp-concat'
// HTML
import pug from 'gulp-pug'
// CSS
import sass from 'gulp-sass'
import postcss from 'gulp-postcss'
import comments from 'postcss-discard-comments'
import cssnano from 'cssnano'
import autoprefixer from 'autoprefixer'
import purgecss from 'gulp-purgecss'
// JavaScript
import babel from 'gulp-babel'
import terser from 'gulp-terser'
// IMG
import imagemin from 'gulp-imagemin'
// Browser Sync
import { init as server, stream, reload } from 'browser-sync'
gulp.task('html', () => {
return gulp
.src('src/views/pages/**/*.pug')
.pipe(pug({ pretty: devMode }))
.pipe(gulp.dest('docs'))
})
gulp.task('css', () => {
if (devMode) {
return gulp
.src('src/scss/styles.scss')
.pipe(sass())
.pipe(gulp.dest('docs/css'))
.pipe(stream())
} else {
return gulp
.src('src/scss/styles.scss')
.pipe(sass())
.pipe(
purgecss({
content: ['docs/**/*.html', 'docs/js/*.js'],
variables: true,
})
)
.pipe(postcss([comments({ removeAll: true }), cssnano(), autoprefixer()]))
.pipe(gulp.dest('docs/css'))
.pipe(stream())
}
})
const filesJs = [
'src/js/scroll-behavior-smooth.js',
'src/js/scroll-shot.js',
'src/js/scroll-show.js',
'src/js/lazy-load.js',
'src/js/custom.js',
]
gulp.task('js', () => {
if (devMode) {
return gulp
.src(filesJs)
.pipe(concat('scripts.js'))
.pipe(gulp.src('src/js/smooth-scroll.min.js'))
.pipe(gulp.dest('docs/js'))
} else {
return gulp
.src(filesJs)
.pipe(babel())
.pipe(concat('scripts.js'))
.pipe(gulp.src('src/js/smooth-scroll.min.js'))
.pipe(terser())
.pipe(gulp.dest('docs/js'))
}
})
gulp.task('img', () => {
return gulp
.src('src/img/**/*')
.pipe(
imagemin([
imagemin.gifsicle({ interlaced: true }),
imagemin.mozjpeg({ quality: 50, progressive: true }),
imagemin.optipng({ optimizationLevel: 1 }),
imagemin.svgo({
plugins: [{ removeViewBox: true }, { cleanupIDs: false }],
}),
])
)
.pipe(gulp.dest('docs/img'))
})
gulp.task('rest', () => {
return (
gulp.src(['src/*.*', 'src/.*', 'src/*']).pipe(gulp.dest('docs')),
gulp.src('src/fuentes/*.*').pipe(gulp.dest('docs/fuentes'))
)
})
gulp.task('all', gulp.series('html', 'css', 'js', 'img', 'rest'))
gulp.task('default', () => {
server({
server: 'docs',
})
gulp.watch('src/views/**/*.pug', gulp.series('html', reload))
gulp.watch('src/js/**/*.js', gulp.series('js', reload))
gulp.watch('src/scss/**/*.scss', gulp.series('css'))
})