-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathgulpfile.js
267 lines (231 loc) · 8.13 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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
/* global require, console, process */
// OpenGarage
// 1. LIBRARIES
// - - - - - - - - - - - - - - -
var gulp = require( "gulp" ), // Gulp
gutil = require( "gulp-util" ), // Gulp Utilities
merge = require( "merge-stream" ), // Merge streams
bower = require( "bower" ), // Bower
fs = require( "fs-extra" ), // Node File Read/Write
minifyCss = require( "gulp-minify-css" ), // CSS Minification
notify = require( "gulp-notify" ), // Advanced Notifications
rename = require( "gulp-rename" ), // Rename Files & Directories
sass = require( "gulp-sass" )( require( "sass" ) ),// SASS Compilation
sh = require( "shelljs" ), // Command Line Tools
jshint = require( "gulp-jshint" ), // JSHint syntax check
jscs = require( "gulp-jscs" ), // Javascript style checker
sassLint = require( "gulp-sass-lint" ), // SASS syntax/style check
uglify = require( "gulp-uglify" ), // Javascript minification
concat = require( "gulp-concat" ), // Concatenate multiple files
sourcemaps = require( "gulp-sourcemaps" ), // Generate sourcemap for minfied JS
manifest = require( "gulp-manifest3" ),
replace = require( "gulp-replace" ),
argv = require( "yargs" ).argv,
pkg = require( "./package.json" );
// 2. SET VARIABLES
// - - - - - - - - - - - - - - -
var paths = {
sass: "./src/scss/**/*.s+(a|c)ss",
js: "./src/js/**/*.js"
};
// Suppress stdout on shell commands (comment to show errors)
sh.config.silent = true;
// If undefined in our process, load our local file
// (i.e. we aren't on an external server where we set these differently)
if ( !process.env.DEPLOY_HOST ) {
require( "dotenv" ).config();
}
// 3. TASKS
// - - - - - - - - - - - - - - -
gulp.task( "build", function( callback ) {
gulp.series( "default", "images", "clean", callback );
} );
gulp.task( "bump", function() {
var ver = pkg.version.split( "." ),
build = parseInt( pkg.build, 10 ) + 1,
// Defines the index to increment (2 = patch, 1 = minor, 0 = major)
type = 2;
if ( argv.major ) {
type = 0;
} else if ( argv.minor ) {
type = 1;
}
ver[ type ]++;
ver = ver.join( "." );
return gulp.src( "package.json" )
.pipe( replace( /(\"version\": \")[\d|\.]+(\")/, "$1" + ver + "$2" ) )
.pipe( replace( /(\"build\": \")\d+/g, "$1" + build ) )
.pipe( gulp.dest( "." ) );
} );
gulp.task( "parse-args", function() {
return merge(
gulp.src( "config.xml" )
.pipe( replace( /(version=\")[\d|\.]+(\"\n)/, "$1" + pkg.version + "$2" ) )
.pipe( replace( /(CFBundleVersion=\")[\d|\.]+(\"\n)/g, "$1" + pkg.version + "$2" ) )
.pipe( replace( /(versionCode=\")\d+/g, "$1" + parseInt( pkg.build, 10 ) ) )
.pipe( replace( /(<string>)\d+(<\/string>)/, "$1" + parseInt( pkg.build, 10 ) + "$2" ) )
.pipe( gulp.dest( "." ) ),
gulp.src( "www/index.html" )
.pipe( replace( /(window\.appVersion=){.*}/, "$1" + JSON.stringify( {
name: pkg.version,
number: parseInt( pkg.build, 10 )
} ) ) )
.pipe( gulp.dest( "www" ) )
);
} );
// Optimizes Images
gulp.task( "images", function( done ) {
var runner = gulp.src( "resources/**/**/*.*" )
.pipe( gulp.dest( "resources" ) );
runner.on( "end", function() {
gulp.src( "" ).pipe( notify( "Image processing complete..." ) );
done();
} );
} );
// Deploy application to the web
gulp.task( "deploy", function( done ) {
if ( !process.env.DEPLOY_HOST ) {
done();
return;
}
sh.exec( "cd www; rsync -azp --chmod=Du=rwx,Dg=rx,Do=rx,Fu=rw,Fg=r,Fo=r * " + process.env.DEPLOY_HOST,
function() {
gulp.src( "" ).pipe( notify( "Webapp deploy complete..." ) );
done();
}
);
} );
// Build Android package locally
gulp.task( "make-android", function( done ) {
sh.exec( "cordova build android --release", function() {
gulp.src( "platforms/android/build/outputs/apk/android-release-unsigned.apk" )
.pipe( rename( "opengarage-unsigned.apk" ) )
.pipe( gulp.dest( "build" ) )
.pipe( notify( "Android complete..." ) );
done();
} );
} );
// Build iOS package locally
gulp.task( "make-ios", function( done ) {
sh.exec( "cordova build ios --device", function() {
gulp.src( "platforms/ios/build/device/OpenGarage.ipa" )
.pipe( gulp.dest( "build" ) )
.pipe( notify( "iOS complete..." ) );
done();
} );
} );
// Build OS X application locally
gulp.task( "make-osx", function( done ) {
fs.removeSync( "platforms/osx/OpenGarage/Images.xcassets/AppIcon.appiconset" );
fs.copySync( "resources/osx/icon/AppIcon.appiconset", "platforms/osx/OpenGarage/Images.xcassets/AppIcon.appiconset" );
sh.exec( "cordova build osx", function() {
fs.copySync( "platforms/osx/build/OpenGarage.app", "build/OpenGarage.app" );
gulp.src( "" ).pipe( notify( "OS X complete..." ) );
done();
} );
} );
// Clean up after build (changes from `parse-args`)
gulp.task( "clean", function( done ) {
sh.exec( "git stash", function() {
done();
} );
} );
// SASS Compilation
// Compiles SASS & attaches vendor prefixes
gulp.task( "sass", function() {
return gulp.src( paths.sass )
// Use gulp-notify as SASS reporter
.pipe( sass.sync( {
style: "compressed",
errLogToConsole: false,
onError: function( err ) {
return notify().write( err );
}
} ) )
.pipe( minifyCss( {
keepBreaks:true
} ) )
.pipe( rename( { extname: ".min.css" } ) )
.pipe( gulp.dest( "./www/css/", { mode: "0755" } ) );
} );
// Lint task
gulp.task( "lint-syntax", function() {
return gulp.src( [ paths.js, "*.js", "./hooks/**/*.js", "!./hooks/after_prepare/uglify.js" ] )
.pipe( jshint() )
.pipe( jshint.reporter( "default" ) )
.pipe( jshint.reporter( "fail" ) );
} );
gulp.task( "lint-style", function() {
return gulp.src( [ paths.js, "*.js", "./hooks/**/*.js" ] )
.pipe( jscs() )
.pipe( jscs.reporter() )
.pipe( jscs.reporter( "fail" ) );
} );
gulp.task( "lint-sass", function() {
return gulp.src( "/src/scss/*.scss" )
.pipe( sassLint() )
.pipe( sassLint.format() )
.pipe( sassLint.failOnError() );
} );
gulp.task( "lint", gulp.series( "lint-syntax", "lint-style", "lint-sass" ) );
// Javascript minification
gulp.task( "uglify", function() {
return gulp.src( paths.js )
.pipe( concat( "app.min.js" ) )
.pipe( sourcemaps.init() )
.pipe( uglify( {
mangle: false
} ) )
.pipe( sourcemaps.write( "./" ) )
.pipe( gulp.dest( "www/js/" ) );
} );
// SASS Listener
gulp.task( "watch", function() {
gulp.watch( [ paths.sass, paths.js ], [ "sass", "uglify" ] );
} );
// Git
gulp.task( "git-check", function( done ) {
if ( !sh.which( "git" ) ) {
console.log(
" " + gutil.colors.red( "Git is not installed." ),
"\n Git, the version control system, is required to download Ionic.",
"\n Download git here:", gutil.colors.cyan( "http://git-scm.com/downloads" ) + ".",
"\n Once git is installed, run \'" + gutil.colors.cyan( "gulp install" ) + "\' again."
);
process.exit( 1 );
}
done();
} );
gulp.task( "install", gulp.series( "git-check", function() {
return bower.commands.install()
.on( "log", function( data ) {
gutil.log( "bower", gutil.colors.cyan( data.id ), data.message );
} );
} ) );
gulp.task( "manifest", function() {
return gulp.src( [
"www/css/{ionic.app.min,style.min}.css",
"www/img/**/*",
"www/js/app.min.js",
"www/templates/*.html",
"www/lib/ionic/js/ionic.bundle.min.js",
"www/lib/ionic/fonts/ionicons.eot",
"www/lib/ionic/fonts/ionicons.svg",
"www/lib/ionic/fonts/ionicons.ttf",
"www/lib/ionic/fonts/ionicons.woff",
"www/favicon.ico",
"www/index.html"
], {
base: "www"
} )
.pipe( manifest( {
hash: true,
preferOnline: false,
timestamp: false,
network: [ "*" ],
filename: "cache.manifest"
} ) )
.pipe( replace( /ionicons\.(eot|svg|ttf|woff)/g, "ionicons.$1?v=2.0.1" ) )
.pipe( gulp.dest( "www" ) );
} );
gulp.task( "default", gulp.series( "parse-args", "lint", "sass", "uglify", "manifest" ) );