forked from mebibou/mdl-selectfield
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgulpfile.js
115 lines (103 loc) · 3.25 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
(function() {
'use strict';
var gulp = require('gulp'),
concat = require('gulp-concat'),
rename = require('gulp-rename'),
sass = require('gulp-sass'),
sourcemaps = require('gulp-sourcemaps'),
sassFiles = [
'./src/global.scss',
'./src/**/*.scss'
],
uglify = require('gulp-uglifyjs'),
jsFiles = ['src/**/*.js'];
/* encapsulation PATCH
*/
var replace = require('gulp-replace');
var runSequence = require('run-sequence');
var vendor = "'Google'";
var vendorPrefix = 'mdl';
var dependency = "'encapsulated-mdl'";
gulp.task('sass-compress', function() {
gulp
.src(sassFiles)
.pipe(concat('file.scss'))
.pipe(sourcemaps.init())
.pipe(sass({
outputStyle: 'compressed'
}).on('error', sass.logError))
.pipe(rename(function(path) {
path.dirname = '';
path.basename = 'mdl-selectfield';
path.extname = '.min.css';
}))
.pipe(sourcemaps.write('./'))
.pipe(replace('.mdl-', '.' + vendorPrefix + '-'))
.pipe(gulp.dest('./dist'));
});
gulp.task('sass', function () {
gulp
.src(sassFiles)
.pipe(concat('mdl-selectfield.scss'))
.pipe(sass({
sourceComments: false
}).on('error', sass.logError))
.pipe(replace('.mdl-', '.' + vendorPrefix + '-'))
.pipe(gulp.dest('./dist'));
});
gulp.task('js-compress', function() {
gulp
.src(jsFiles)
.pipe(replace('mdl-', vendorPrefix + '-'))
.pipe(replace('$$vendorName$$', vendor))
.pipe(replace('$$mdlDepName$$', dependency))
.pipe(uglify('mdl-selectfield.min.js', {
outSourceMap: true
}))
.pipe(gulp.dest('./dist'));
});
gulp.task('js', function() {
gulp
.src(jsFiles)
.pipe(replace('mdl-', vendorPrefix + '-'))
.pipe(replace('$$vendorName$$', vendor))
.pipe(replace('$$mdlDepName$$', dependency))
.pipe(rename(function(path) {
path.dirname = '';
path.basename = 'mdl-selectfield';
path.extname = '.js';
}))
.pipe(gulp.dest('./dist'));
});
gulp.task('watch', function () {
gulp.watch(sassFiles, ['sass', 'sass-compress']);
gulp.watch(jsFiles, ['js', 'js-compress']);
});
gulp.task('build', ['sass', 'sass-compress', 'js', 'js-compress']);
/**
* Build encapsulated production files
* The task accepts:
* -v [VENDOR_NAME] parameter, default "Google"
* -p [PREFIX] parameter, default is mdl
* -d [DEPENDENCY] parameter, to be injected into the module, default is "encapsulated-mdl".
* MDL is encapsulated inside window[vendor].mdl or exposed as cjs/amd module
* If cjs/amd is not available, the global window[VENDOR_NAME].mdl.componentHandler is expected.
*/
gulp.task('build:encap', function () {
let i = process.argv.indexOf('-v');
if (i > -1) {
vendor = '"' + process.argv[i + 1] + '"';
}
i = process.argv.indexOf('-p');
if (i > -1) {
vendorPrefix = process.argv[i + 1];
}
i = process.argv.indexOf('-d');
if (i > -1) {
dependency = '"' + process.argv[i + 1] + '"';
}
runSequence(['build']);
});
// The default task (called when you run `gulp` from cli)
gulp.task('default', ['watch']);
})();