-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathgulpfile.js
99 lines (95 loc) · 3.36 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
var gulp = require('gulp');
var browserSync = require('browser-sync').create();
var $ = require('gulp-load-plugins')();
var autoprefixer = require('autoprefixer');
var rename = require('gulp-rename');
var uglify = require('gulp-uglify');
var concat = require('gulp-concat');
var imagemin = require('gulp-imagemin');
var cssmin = require('gulp-cssmin');
var sourcemaps = require('gulp-sourcemaps');
var gutil = require('gulp-util');
var template_name = 'cc-commoners-2019';
var sassPaths = [
'node_modules/foundation-sites/scss',
'node_modules/motion-ui/src'
];
var js = {
//JS Dependencies
fileList: [
'node_modules/foundation-sites/dist/js/plugins/foundation.core.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.util.mediaQuery.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.util.keyboard.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.util.triggers.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.util.box.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.util.motion.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.util.nest.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.sticky.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.tabs.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.equalizer.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.tooltip.js',
'node_modules/foundation-sites/dist/js/plugins/foundation.dropdown.js',
'node_modules/swipebox/src/js/jquery.swipebox.js',
'node_modules/slick-carousel/slick/slick.js',
],
//CSS Dependencies
styles: [
'node_modules/swipebox/src/css/swipebox.css',
'node_modules/slick-carousel/slick/slick.css',
'node_modules/slick-carousel/slick/slick-theme.css',
]
};
/* Build single JS dependencies file */
gulp.task('build-js', function () {
return gulp.src(js.fileList)
.pipe(sourcemaps.init())
.pipe(concat('dependencies.js'))
.pipe(uglify().on('error', gutil.log))
//.pipe( sourcemaps.write( '/' ) )
.pipe(gulp.dest('../assets/js'));
});
/* Theme Image optimization */
gulp.task('imgmin', function () {
gulp.src('../assets/img/*')
.pipe(imagemin())
.pipe(gulp.dest('../assets/img/'))
});
/* Build single CSS dependencies file */
gulp.task('build-css', function () {
return gulp.src(js.styles)
.pipe(sourcemaps.init())
.pipe(concat('dependencies.css'))
.pipe(cssmin())
//.pipe( sourcemaps.write( '/' ) )
.pipe(gulp.dest('../assets/css'));
});
function sass() {
return gulp.src('scss/app.scss')
.pipe($.sass({
includePaths: sassPaths,
//outputStyle: 'compressed' // if css compressed **file size**
})
.on('error', $.sass.logError))
.pipe($.postcss([
autoprefixer()
]))
//.pipe(gulp.dest('css'))
//.pipe(browserSync.stream());
.pipe(rename('style.css'))
.pipe(gulp.dest('../assets/css'))
.pipe(gulp.dest('./css'));
};
function serve() {
browserSync.init({
server: "./"
});
gulp.watch("scss/*.scss", sass);
gulp.watch("*.html").on('change', browserSync.reload);
}
function watch() {
gulp.watch("scss/*.scss", sass)
}
gulp.task('sass', sass);
gulp.task('watch', watch);
gulp.task('serve', gulp.series('sass', serve));
gulp.task('default', gulp.series('sass', serve));