mirror of
https://github.com/inverse-inc/sogo.git
synced 2026-07-05 16:35:10 +00:00
Add breakpoints management librairies
Add grunt-contrib-compass (required) Edit gruntfile.js (add compass tasks) --don't forget to update bower components
This commit is contained in:
committed by
Francis Lachapelle
parent
6153e88f62
commit
818af41ea6
@@ -1,107 +1,142 @@
|
||||
module.exports = function(grunt) {
|
||||
grunt.initConfig({
|
||||
pkg: grunt.file.readJSON('package.json'),
|
||||
|
||||
sass: {
|
||||
options: {
|
||||
loadPath: ['scss'],
|
||||
style: 'expanded'
|
||||
},
|
||||
dist: {
|
||||
files: {
|
||||
'css/styles.css': 'scss/styles.scss'
|
||||
}
|
||||
}
|
||||
},
|
||||
postcss: {
|
||||
options: {
|
||||
map: true,
|
||||
processors: [
|
||||
require('autoprefixer-core')({browsers: '> 1%, last 2 versions, last 3 Firefox versions'}).postcss,
|
||||
// We may consider using css grace (https://github.com/cssdream/cssgrace) for larger support
|
||||
require('csswring').postcss
|
||||
]
|
||||
},
|
||||
dist: {
|
||||
src: 'css/styles.css'
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
grunt: { files: ['Gruntfile.js'] },
|
||||
|
||||
sass: {
|
||||
files: 'scss/**/*.scss',
|
||||
tasks: ['sass']
|
||||
}
|
||||
grunt.initConfig({
|
||||
pkg: grunt.file.readJSON('package.json'),
|
||||
compass: {
|
||||
dist: {
|
||||
options: {
|
||||
sassDir: 'scss',
|
||||
cssDir: 'css',
|
||||
specify: 'scss/styles.scss',
|
||||
outputStyle: 'compact', // will be compressed by postcss
|
||||
environment: 'production'
|
||||
}
|
||||
});
|
||||
},
|
||||
dev: {
|
||||
options: {
|
||||
force: true,
|
||||
sassDir: 'scss',
|
||||
cssDir: 'css',
|
||||
importPath: [
|
||||
'bower_components/compass-mixins/lib',
|
||||
'bower_components/compass-breakpoint/stylesheets',
|
||||
'bower_components/breakpoint-slicer/stylesheets',
|
||||
'bower_components/breakpoint-slicer/stylesheets/breakpoint-slicer',
|
||||
'bower_components/sassy-maps/sass'
|
||||
],
|
||||
noLineComments: true,
|
||||
sourcemap: true,
|
||||
specify: 'scss/styles.scss',
|
||||
raw: 'sass_options = {:cache => false\n}',
|
||||
outputStyle: 'expanded'
|
||||
}
|
||||
}
|
||||
},
|
||||
sass: {
|
||||
options: {
|
||||
cache: false,
|
||||
loadPath: ['scss', 'bower_components/compass-mixins/lib',
|
||||
'bower_components/compass-breakpoint/stylesheets',
|
||||
'bower_components/breakpoint-slicer/stylesheets',
|
||||
'bower_components/sassy-maps/sass'],
|
||||
style: 'expanded'
|
||||
},
|
||||
dist: {
|
||||
files: {
|
||||
'css/styles.css': 'scss/styles.scss'
|
||||
}
|
||||
}
|
||||
},
|
||||
postcss: {
|
||||
options: {
|
||||
map: true,
|
||||
processors: [
|
||||
require('autoprefixer-core')({browsers: '> 1%, last 2 versions, last 3 Firefox versions'}).postcss,
|
||||
// We may consider using css grace (https://github.com/cssdream/cssgrace) for larger support
|
||||
require('csswring').postcss
|
||||
]
|
||||
},
|
||||
dist: {
|
||||
src: 'css/styles.css'
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
grunt: {files: ['Gruntfile.js']},
|
||||
|
||||
grunt.loadNpmTasks('grunt-contrib-sass');
|
||||
grunt.loadNpmTasks('grunt-postcss');
|
||||
grunt.loadNpmTasks('grunt-contrib-watch');
|
||||
sass: {
|
||||
files: 'scss/**/*.scss',
|
||||
tasks: ['sass']
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
grunt.loadNpmTasks('grunt-contrib-sass');
|
||||
grunt.loadNpmTasks('grunt-postcss');
|
||||
grunt.loadNpmTasks('grunt-contrib-watch');
|
||||
grunt.loadNpmTasks('grunt-contrib-compass');
|
||||
|
||||
grunt.task.registerTask('static', function() {
|
||||
var options = {
|
||||
'src': 'bower_components',
|
||||
'js_dest': 'js/vendor/',
|
||||
'fonts_dest': 'fonts/',
|
||||
'css_dest': 'css/'
|
||||
};
|
||||
grunt.log.subhead('Copying JavaScript files');
|
||||
var js = [
|
||||
'<%= src %>/angular/angular{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-animate/angular-animate{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-sanitize/angular-sanitize{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-aria/angular-aria{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-material/angular-material{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-ui-router/release/angular-ui-router{,.min}.js',
|
||||
'<%= src %>/angular-recursion/angular-recursion{,.min}.js',
|
||||
'<%= src %>/angular-vs-repeat/src/angular-vs-repeat{,.min}.js',
|
||||
'<%= src %>/angular-file-upload/angular-file-upload{,.min}.js{,map}',
|
||||
'<%= src %>/ng-tags-input/ng-tags-input{,.min}.js',
|
||||
'<%= src %>/underscore/underscore-min.{js,map}'
|
||||
];
|
||||
for (var j = 0; j < js.length; j++) {
|
||||
var files = grunt.file.expand(grunt.template.process(js[j], {data: options}));
|
||||
for (var i = 0; i < files.length; i++) {
|
||||
var src = files[i];
|
||||
var paths = src.split('/');
|
||||
var dest = options.js_dest + paths[paths.length-1];
|
||||
grunt.file.copy(src, dest);
|
||||
var options = {
|
||||
'src': 'bower_components',
|
||||
'js_dest': 'js/vendor/',
|
||||
'fonts_dest': 'fonts/',
|
||||
'css_dest': 'css/'
|
||||
};
|
||||
grunt.log.subhead('Copying JavaScript files');
|
||||
var js = [
|
||||
'<%= src %>/angular/angular{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-animate/angular-animate{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-sanitize/angular-sanitize{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-aria/angular-aria{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-material/angular-material{,.min}.js{,.map}',
|
||||
'<%= src %>/angular-ui-router/release/angular-ui-router{,.min}.js',
|
||||
'<%= src %>/angular-recursion/angular-recursion{,.min}.js',
|
||||
'<%= src %>/angular-vs-repeat/src/angular-vs-repeat{,.min}.js',
|
||||
'<%= src %>/angular-file-upload/angular-file-upload{,.min}.js{,map}',
|
||||
'<%= src %>/ng-tags-input/ng-tags-input{,.min}.js',
|
||||
'<%= src %>/underscore/underscore-min.{js,map}'
|
||||
];
|
||||
for (var j = 0; j < js.length; j++) {
|
||||
var files = grunt.file.expand(grunt.template.process(js[j], {data: options}));
|
||||
for (var i = 0; i < files.length; i++) {
|
||||
var src = files[i];
|
||||
var paths = src.split('/');
|
||||
var dest = options.js_dest + paths[paths.length - 1];
|
||||
grunt.file.copy(src, dest);
|
||||
grunt.log.ok("copy " + src + " => " + dest);
|
||||
}
|
||||
}
|
||||
grunt.log.subhead('Copying font files');
|
||||
var fonts = [
|
||||
'<%= src %>/ionic/release/fonts/ionicons.*',
|
||||
'<%= src %>/material-design-iconic-font/fonts/Material-Design-Iconic-Font.*'
|
||||
];
|
||||
for (var j = 0; j < fonts.length; j++) {
|
||||
var files = grunt.file.expand(grunt.template.process(fonts[j], {data: options}));
|
||||
for (var i = 0; i < files.length; i++) {
|
||||
var src = files[i];
|
||||
var paths = src.split('/');
|
||||
var dest = options.fonts_dest + paths[paths.length-1];
|
||||
grunt.file.copy(src, dest);
|
||||
}
|
||||
}
|
||||
grunt.log.subhead('Copying font files');
|
||||
var fonts = [
|
||||
'<%= src %>/ionic/release/fonts/ionicons.*',
|
||||
'<%= src %>/material-design-iconic-font/fonts/Material-Design-Iconic-Font.*'
|
||||
];
|
||||
for (var j = 0; j < fonts.length; j++) {
|
||||
var files = grunt.file.expand(grunt.template.process(fonts[j], {data: options}));
|
||||
for (var i = 0; i < files.length; i++) {
|
||||
var src = files[i];
|
||||
var paths = src.split('/');
|
||||
var dest = options.fonts_dest + paths[paths.length - 1];
|
||||
grunt.file.copy(src, dest);
|
||||
grunt.log.ok("copy " + src + " => " + dest);
|
||||
}
|
||||
}
|
||||
grunt.log.subhead('Copying CSS files');
|
||||
var css = [
|
||||
'<%= src %>/ng-tags-input/ng-tags-input*.css' // This is no longer needed, ng-tags css is integrated to scss
|
||||
];
|
||||
for (var j = 0; j < css.length; j++) {
|
||||
var files = grunt.file.expand(grunt.template.process(css[j], {data: options}));
|
||||
for (var i = 0; i < files.length; i++) {
|
||||
var src = files[i];
|
||||
var paths = src.split('/');
|
||||
var dest = options.css_dest + paths[paths.length-1];
|
||||
grunt.file.copy(src, dest);
|
||||
}
|
||||
}
|
||||
grunt.log.subhead('Copying CSS files');
|
||||
var css = [
|
||||
'<%= src %>/ng-tags-input/ng-tags-input*.css' // This is no longer needed, ng-tags css is integrated to scss
|
||||
];
|
||||
for (var j = 0; j < css.length; j++) {
|
||||
var files = grunt.file.expand(grunt.template.process(css[j], {data: options}));
|
||||
for (var i = 0; i < files.length; i++) {
|
||||
var src = files[i];
|
||||
var paths = src.split('/');
|
||||
var dest = options.css_dest + paths[paths.length - 1];
|
||||
grunt.file.copy(src, dest);
|
||||
grunt.log.ok("copy " + src + " => " + dest);
|
||||
}
|
||||
}
|
||||
});
|
||||
grunt.task.registerTask('build', ['static', 'sass']);
|
||||
grunt.task.registerTask('default', ['build','watch']);
|
||||
grunt.task.registerTask('css', ['sass', 'postcss']);
|
||||
}
|
||||
}
|
||||
});
|
||||
grunt.task.registerTask('build', ['static', 'sass']);
|
||||
grunt.task.registerTask('default', ['build', 'watch']);
|
||||
grunt.task.registerTask('css', ['sass', 'postcss']);
|
||||
grunt.task.registerTask('sass-compass', ['compass:dev', 'postcss']);
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user