-
Notifications
You must be signed in to change notification settings - Fork 1
/
gulpfile.js
53 lines (45 loc) · 1.12 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
const gulp = require('gulp')
const twig = require('gulp-twig')
const sass = require('gulp-sass')
const rename = require('gulp-rename')
const autoprefixer = require('gulp-autoprefixer')
const cssnano = require('gulp-cssnano')
const browserSync = require('browser-sync')
const reload = browserSync.reload
const src = {
twig: {
watch: 'src/twig/**',
compile: 'src/twig/*.*'
},
scss: {
watch: 'src/scss/**',
compile: 'src/scss/*.*'
}
}
// SCSS to CSS
gulp.task('scss', () => {
return gulp.src(src.scss.compile)
.pipe(sass())
.pipe(autoprefixer())
.pipe(gulp.dest('./dist/css'))
// minified version
.pipe(cssnano())
.pipe(rename('styles.min.css'))
.pipe(gulp.dest('./dist/css'))
.pipe(reload({stream: true}))
})
// Twig to HTML
gulp.task('twig', () => {
return gulp.src(src.twig.compile)
.pipe(twig({ base: 'src/twig' }))
.pipe(gulp.dest('./dist'))
.on("end", reload)
})
gulp.task('serve', ['scss', 'twig'], () => {
browserSync({
server: './dist'
})
gulp.watch(src.scss.watch, ['scss'])
gulp.watch(src.twig.watch, ['twig'])
})
gulp.task('default', ['serve'])