This repository has been archived by the owner on Jul 6, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGruntfile.js
127 lines (121 loc) · 3.07 KB
/
Gruntfile.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
'use strict';
module.exports = function (grunt) {
require('matchdep').filterDev('grunt-*').forEach(grunt.loadNpmTasks);
// configurable paths
var hacksConfig = {
app: 'src',
dist: 'dist'
};
try {
hacksConfig.aws_s3 = require('./aws.json').aws_s3 || {};
hacksConfig.invalidate_cloudfront = require('./aws.json').invalidate_cloudfront || {};
} catch (e) {
}
grunt.initConfig({
hacksConfig: hacksConfig,
watch: {
compass: {
files: ['<%= hacksConfig.app %>/*.{scss,sass}'],
tasks: ['compass']
}
},
compass: {
options: {
sassDir: '<%= hacksConfig.app %>',
cssDir: '<%= hacksConfig.app %>'
},
dist: {}
},
jshint: {
options: {
jshintrc: '.jshintrc'
},
all: ['*.js']
},
clean: {
dist: ['.tmp', '<%= hacksConfig.dist %>/*']
},
copy: {
dist: {
files: [
{
expand: true,
dot: true,
cwd: '<%= hacksConfig.app %>',
dest: '<%= hacksConfig.dist %>',
src: ['*.{css,js,png,jpg,jpeg,gif,webp}', '!Gruntfile.js']
}
]
}
},
cssmin: {
dist: {
files: [{
expand: true,
cwd: '<%= hacksConfig.dist %>',
src: '*.css',
dest: '<%= hacksConfig.dist %>',
ext: '.css'
}]
}
},
uglify: {
dist: {
files: [{
expand: true,
cwd: '<%= hacksConfig.dist %>',
src: '*.js',
dest: '<%= hacksConfig.dist %>',
ext: '.js'
}]
}
},
invalidate_cloudfront: {
options: {
key: '<%= hacksConfig.invalidate_cloudfront.options.key %>',
secret: '<%= hacksConfig.invalidate_cloudfront.options.secret %>',
region: '<%= hacksConfig.invalidate_cloudfront.options.region %>',
distribution: '<%= hacksConfig.invalidate_cloudfront.options.distribution %>'
},
production: {
files: [{
expand: true,
cwd: '<%= hacksConfig.dist %>',
src: '*.{css,js,png,jpg,jpeg,gif,webp}',
filter: 'isFile',
dest: '<%= hacksConfig.aws_s3.options.dest %>'
}]
}
},
aws_s3: {
options: {
accessKeyId: '<%= hacksConfig.aws_s3.options.accessKeyId %>',
secretAccessKey: '<%= hacksConfig.aws_s3.options.secretAccessKey %>',
region: '<%= hacksConfig.aws_s3.options.region %>',
concurrency: 5 // 5 simultaneous upload
},
production: {
options: {
bucket: '<%= hacksConfig.aws_s3.options.bucket %>'
},
files: [{
expand: true,
cwd: '<%= hacksConfig.dist %>',
src: '*.{css,js,png,jpg,jpeg,gif,webp}',
dest: '<%= hacksConfig.aws_s3.options.dest %>'
}]
}
}
});
grunt.registerTask('deploy', [
'clean:dist',
'compass:dist',
'jshint',
'copy',
'uglify',
'cssmin:dist',
'aws_s3:production',
'invalidate_cloudfront'
]);
grunt.registerTask('default', ['jshint', 'watch']);
};