-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGruntfile.js
81 lines (70 loc) · 2.24 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
module.exports = function(grunt) {
// 1. All configuration goes here
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
postcss: {
options: {
processors: [
require('pixrem')(), // add fallbacks for rem units
require('autoprefixer-core')({browsers: 'last 3 versions'}), // add vendor prefixes
require('cssnano')() // minify the result
]
},
dist: {
src: 'style.css'
}
},
concat: {
dist: {
src: [
'bower_components/jquery/dist/jquery.min.js',
'js/site.js',
],
dest: 'js/build/production.js',
nonull: true
}
},
uglify: {
build: {
src: 'js/build/production.js',
dest: 'js/build/production.min.js'
}
},
sass: {
dist: {
options: {
style: 'compressed'
},
files: {
'style.css': 'style.scss'
}
}
},
watch: {
scripts: {
files: ['js/*.js','**/*.twig'],
tasks: ['concat', 'uglify'],
options: {
livereload: true,
},
},
css: {
files: ['**/*.scss'],
/*
the streamline is: sass compiles and put the
compiled css into style.css then postcss put
prefixes and magic in front of every element
*/
tasks: ['sass', 'postcss']
}
},
});
// 3. Where we tell Grunt we plan to use this plug-in.
grunt.loadNpmTasks('grunt-postcss');
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-contrib-sass');
grunt.loadNpmTasks('grunt-contrib-watch');
// 4. Where we tell Grunt what to do when we type "grunt" into the terminal.
grunt.registerTask('default', ['sass', 'postcss', 'concat', 'uglify', 'watch']);
};