-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathGruntfile.js
93 lines (81 loc) · 2.11 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
module.exports = function(grunt) {
// Load all grunt-* tasks (load-grunt-tasks plugin)
require('load-grunt-tasks')(grunt);
require('time-grunt')(grunt);
// Project configuration
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
sass: {
dist: {
options: {
// Generates expanded style.css in theme root
// cssmin will minify later
style: 'expanded'
},
files: {
'style.css': 'assets/css/scss/style.scss'
}
}
},
cssmin: {
combine: {
files: {
'assets/css/build/style.min.css': 'style.css'
}
}
},
jshint: {
beforeconcat: ['assets/js/*.js']
},
concat: {
dist: {
src: [
'assets/js/lib/*.js',
'assets/js/spring.js',
'assets/js/sidebar.js'
],
dest: 'assets/js/build/spring-production.js'
}
},
uglify: {
build: {
src: 'assets/js/build/spring-production.js',
dest: 'assets/js/build/spring-production.min.js'
}
},
// TODO: Let's discuss how we want to implement this
// imagemin: {
// dynamic: {
// files: [{
// expand: true,
// cwd: 'assets/img/',
// src: ['../../*.{png,jpg,gif}', '**/*.{png,jpg,gif}'],
// dest: 'assets/images/'
// }]
// }
// },
watch: {
options: {
livereload: true,
},
scripts: {
files: ['assets/js/*.js', 'assets/js/lib/*.js'],
tasks: ['jshint', 'concat'],
options: {
spawn: false
}
},
css: {
files: ['assets/css/scss/*.scss'],
tasks: ['sass'],
options: {
spawn: false
}
}
}
});
// Default task is to rebuild
grunt.registerTask('default', ['sass', 'concat']);
// Tasks for development
grunt.registerTask('build', ['sass', 'cssmin', 'concat', 'uglify']);
};