-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
125 lines (120 loc) · 3.98 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
// import modules
var gulp = require('gulp');
var watch = require('gulp-watch');
var wiredep = require('wiredep').stream;
var inject = require('gulp-inject');
var sass = require('gulp-sass');
var browserSync = require('browser-sync').create();
var jshint = require('gulp-jshint');
var compass = require('compass-importer');
var series = require('stream-series');
var del = require('del');
var sourcemaps = require('gulp-sourcemaps');
var uglify = require('gulp-uglify');
var concat = require('gulp-concat');
var minifyCss = require('gulp-minify-css');
var runSequence = require('run-sequence');
var autoprefixer = require('gulp-autoprefixer');
var reload = browserSync.reload
// declare paths
var paths = {
html: './src/**/*.html',
index: './src/index.html',
scripts: ['./src/app/**/*.js', './src/assets/**/*.js'],
glob: './src/app/**/*.js',
assetsglob: './src/assets/**/*.js',
sass: './src/styles/sass/*.scss',
css: './src/styles/*.css'
}
//<======== Clean and Production ========>
// clean build
gulp.task('build-clean', function(cb){
del(['build'], cb);
});
// minify and copy js with sourcemaps
gulp.task('minify-scripts', ['build-clean'], function(){
var stream = gulp.src(paths.scripts, { base: 'src' })
.pipe(sourcemaps.init({loadMaps: true}))
.pipe(uglify())
.pipe(concat('all.min.js'))
.pipe(sourcemaps.write('../'))
.pipe(gulp.dest('build/js'));
return stream;
});
// minify and copy css
gulp.task('minify-css', ['build-clean'], function(){
var stream = gulp.src(paths.sass, { base: 'src' })
.pipe(sourcemaps.init({loadMaps: true}))
.pipe(sass({
includePaths: ['./bower_components/compass-mixins/lib']
}).on('error', sass.logError))
.pipe(minifyCss())
.pipe(concat('styles.css'))
.pipe(sourcemaps.write('../'))
.pipe(autoprefixer({
browsers: ['last 2 versions'],
cascade: false
}))
.pipe(gulp.dest('build/css'));
return stream;
});
gulp.task('build', function(){
runSequence('build-clean', ['minify-scripts', 'minify-css']);
});
//<=========== Set Up Index =============>
// wire dependencies to index.html
gulp.task('wiredep', function() {
return gulp.src(paths.index)
.pipe(wiredep())
.pipe(gulp.dest('./src'));
});
// injecting css and js href to index
gulp.task('inject-css', function() {
var sources = gulp.src(paths.css, {read: false});
return gulp.src(paths.index)
.pipe(inject(sources, {relative: true}))
.pipe(gulp.dest('./src'));
});
gulp.task('inject-js', function() {
var jsGlobSrc = gulp.src(paths.glob, {read: false});
var jsAssetsGlobSrc = gulp.src(paths.assetsglob, {read: false});
return gulp.src(paths.index)
.pipe(inject(series(jsAssetsGlobSrc, jsGlobSrc), {relative: true}))
.pipe(gulp.dest('./src'));
});
gulp.task('inject', function(){
runSequence('wiredep', 'inject-js', 'inject-css');
});
//<============= Watch and Sync=================>
// compile sass to css with browsersync
gulp.task('sass', function() {
return gulp.src(paths.sass)
.pipe(sass({
includePaths: ['./bower_components/compass-mixins/lib']
//importer: [compass]
}).on('error', sass.logError))
.pipe(gulp.dest('./src/styles'))
.pipe(browserSync.stream());
});
// lint js files
gulp.task('jshint', function() {
gulp.src(paths.scripts)
.pipe(jshint())
.pipe(jshint.reporter('jshint-stylish'));
});
// watch and lint js ; browsersync css/html
gulp.task('serve', ['sass', 'jshint'], function(){
browserSync.init({
server: {
baseDir: './src',
routes: {
'/bower_components': 'bower_components'
}
}
});
gulp.watch(paths.scripts, ['jshint']);
gulp.watch(paths.sass, ['sass']);
gulp.watch(paths.html).on('change', reload);
gulp.watch(paths.scripts).on('change', reload);
})
gulp.task('default', ['serve']);