-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
90 lines (74 loc) · 2.4 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
let gulp = require('gulp');
let plumber = require('gulp-plumber');
let sourcemaps = require('gulp-sourcemaps');
let concat = require('gulp-concat');
var webpack = require('webpack');
var gulpWebpack = require('gulp-webpack');
let named = require('vinyl-named');
let clean = require('gulp-clean');
let browserSync = require('browser-sync');
gulp.task('html', () => {
gulp.src('src/index.html')
.pipe(gulp.dest('dist'));
});
gulp.task('css', () => {
gulp.src('src/css/**/*.css')
.pipe(sourcemaps.init())
.pipe(plumber())
.pipe(concat('styles.css'))
.pipe(sourcemaps.write())
.pipe(gulp.dest('dist/css/'));
});
gulp.task('vendorCss', () => {
let libs = [
'node_modules/angular-material/angular-material.min.css',
'node_modules/angular-material-data-table/dist/md-data-table.min.css'
];
gulp.src(libs)
.pipe(concat('vendor.styles.css'))
.pipe(gulp.dest('dist/css/'));
});
gulp.task('app', () => {
let config = require('./webpack.config');
return gulp.src('src/app/root.module.js')
.pipe(named())
.pipe(gulpWebpack(config, webpack))
.pipe(gulp.dest('dist/app'))
});
gulp.task('vendorJs', () => {
let libs = [
'node_modules/angular/angular.min.js',
'node_modules/angular-aria/angular-aria.min.js',
'node_modules/angular-animate/angular-animate.min.js',
'node_modules/angular-material/angular-material.min.js',
'node_modules/md-data-table/dist/md-data-table-templates.js',
'node_modules/angular-material-data-table/dist/md-data-table.min.js',
'node_modules/angular-ui-router/release/angular-ui-router.min.js'
];
gulp.src(libs)
.pipe(concat('vendor.libs.js'))
.pipe(gulp.dest('dist/'));
});
gulp.task('clean', () => {
return gulp.src('dist', {read: false})
.pipe(clean());
});
gulp.task('builder', ['app', 'vendorJs', 'html', 'css', 'vendorCss']);
gulp.task('build', ['clean'], () => {
return gulp.start('builder');
});
gulp.task('watch', () => {
gulp.watch('src/**/*.html', ['html', 'app']);
gulp.watch('src/**/*.js', ['app']);
gulp.watch('src/**/*.css', ['css']);
gulp.watch('dist/**/*').on('change', browserSync.reload);
});
gulp.task('serve', () => {
browserSync({
port: 9000,
server: {
baseDir: 'dist'
}
});
});
gulp.task('default', ['watch', 'serve']);