-
Notifications
You must be signed in to change notification settings - Fork 1
/
Gruntfile.js
122 lines (107 loc) · 3.19 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
'use strict';
var path = require('path');
var lrSnippet = require('grunt-contrib-livereload/lib/utils').livereloadSnippet;
var folderMount = function folderMount(connect, point) {
return connect.static(path.resolve(point));
};
module.exports = function(grunt) {
// Project config
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
// Use grunt-contrib-connect to launch a web server at port 9001
// Inject the livereloadSnippet via middleware to update the files
connect: {
livereload: {
options: {
port: 9001,
middleware: function(connect, options) {
return [lrSnippet, folderMount(connect, '.')]
}
}
}
},
// Opens up the browser to the localhost along with the port defined above
open: {
dev: {
path: 'http://127.0.0.1:<%= connect.livereload.options.port %>/'
}
},
// Observe the js/html/css files for changes and execute the tasks
regarde: {
js: {
files: ['**/*.js', '!**/node_modules/**'],
tasks: ['jshint', 'uglify', 'livereload'],
},
html: {
files: '**/*.html',
tasks: ['livereload']
},
css: {
files: '**/*.css',
tasks: ['livereload']
},
scss: {
files: '**/*.scss',
tasks: ['sass', 'livereload']
},
img: {
files: ['**/*.png', '**/*.jpg', '**/*.jpeg', '**/*.gif'],
tasks: ['livereload']
}
},
// Check for ghetto js in the plugin
jshint: {
files: ['js/placard.js']
},
// Minify the file and add a comment banner at the top with settings from package.json
uglify: {
options: {
banner: '/**\n' +
' * <%= pkg.name %> - v<%= pkg.version %>\n' +
' * <%= grunt.template.today("yyyy-mm-dd") %>\n' +
' * <%= pkg.description %>\n' +
' * <%= pkg.repository.docs %>\n' +
' *\n' +
' * Copyright <%= grunt.template.today("yyyy") %> <%= pkg.author %>\n' +
' */\n'
},
placard: {
files: {
'js/placard.min.js': ['js/placard.js']
}
}
},
sass: {
placard: {
options: {
style: 'compressed'
},
files: {
'css/placard.min.css': ['scss/placard.scss']
}
},
pages: {
options: {
style: 'nested'
},
files: {
'css/main.css': ['scss/_normalize.scss', 'scss/_clearfix.scss', 'scss/main.scss']
}
}
}
});
// Load the grunt plugins
grunt.loadNpmTasks('grunt-regarde');
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-contrib-connect');
grunt.loadNpmTasks('grunt-contrib-livereload');
grunt.loadNpmTasks('grunt-contrib-sass');
grunt.loadNpmTasks('grunt-open');
// $ grunt
// Checks the js and minifies it
grunt.registerTask('default', ['jshint', 'uglify', 'sass']);
// $ grunt server
// Checks the js, minfies it, starts livereload, connects to a local server, opens the browser and watches for changes
grunt.registerTask('server', ['default', 'livereload-start', 'connect', 'open:dev', 'regarde']);
};