Use gulp-rev for versioning CSS and JS

This commit is contained in:
Ben Word
2014-08-24 16:51:08 -05:00
parent ed7a0d75c6
commit 534fef3262
3 changed files with 15 additions and 14 deletions

4
.gitignore vendored
View File

@@ -1,9 +1,9 @@
# Include your project-specific ignores in this file # Include your project-specific ignores in this file
# Read about how to use .gitignore: https://help.github.com/articles/ignoring-files # Read about how to use .gitignore: https://help.github.com/articles/ignoring-files
node_modules node_modules
assets/vendor/* assets/vendor
assets/css/main.css.map assets/css/main.css.map
assets/css/*main*.css assets/css/*main*.css
assets/js/*scripts*.js assets/js/*scripts*.js
assets/js/vendor/modernizr.min.js assets/js/vendor/modernizr.min.js
assets/manifest.json assets/rev-manifest.json

View File

@@ -9,11 +9,9 @@ var gulp = require('gulp'),
uglify = require('gulp-uglify'), uglify = require('gulp-uglify'),
livereload = require('gulp-livereload'), livereload = require('gulp-livereload'),
stylish = require('jshint-stylish'), stylish = require('jshint-stylish'),
rev = require('gulp-rev');
modernizr = require('gulp-modernizr'); modernizr = require('gulp-modernizr');
// add all the gruntfile tasks to gulp
require('gulp-grunt')(gulp);
var paths = { var paths = {
scripts: [ scripts: [
'assets/vendor/bootstrap/js/transition.js', 'assets/vendor/bootstrap/js/transition.js',
@@ -35,7 +33,7 @@ var paths = {
'gulpfile.js', 'gulpfile.js',
'assets/js/*.js', 'assets/js/*.js',
'!assets/js/scripts.js', '!assets/js/scripts.js',
'!assets/**/*.min.*' '!assets/**/*.min-*'
], ],
less: 'assets/less/main.less' less: 'assets/less/main.less'
}; };
@@ -44,10 +42,9 @@ var destination = {
css: 'assets/css', css: 'assets/css',
scripts: 'assets/js', scripts: 'assets/js',
modernizr: 'assets/vendor/modernizr', modernizr: 'assets/vendor/modernizr',
vendor: 'assets/vendor' vendor: 'assets/js/vendor'
}; };
gulp.task('less', function () { gulp.task('less', function () {
return gulp.src(paths.less) return gulp.src(paths.less)
.pipe(sourcemaps.init()) .pipe(sourcemaps.init())
@@ -91,7 +88,11 @@ gulp.task('modernizr', function() {
}); });
gulp.task('version', function() { gulp.task('version', function() {
gulp.run('grunt-version'); return gulp.src(['assets/css/main.min.css', 'assets/js/scripts.min.js'], { base: 'assets' })
.pipe(rev())
.pipe(gulp.dest('assets'))
.pipe(rev.manifest())
.pipe(gulp.dest('assets'));
}); });
gulp.task('watch', function() { gulp.task('watch', function() {
@@ -107,4 +108,4 @@ gulp.task('watch', function() {
gulp.task('default', ['less', 'jshint', 'js', 'modernizr']); gulp.task('default', ['less', 'jshint', 'js', 'modernizr']);
gulp.task('dev', ['default']); gulp.task('dev', ['default']);
gulp.task('build', ['less', 'jshint', 'js', 'modernizr', 'version']); gulp.task('build', ['less', 'jshint', 'js', 'modernizr', 'version']);

View File

@@ -27,11 +27,11 @@ function roots_scripts() {
'jquery' => '//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.js' 'jquery' => '//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.js'
); );
} else { } else {
$get_assets = file_get_contents(get_template_directory() . '/assets/manifest.json'); $get_assets = file_get_contents(get_template_directory() . '/assets/rev-manifest.json');
$assets = json_decode($get_assets, true); $assets = json_decode($get_assets, true);
$assets = array( $assets = array(
'css' => '/assets/css/main.min.css?' . $assets['assets/css/main.min.css']['hash'], 'css' => '/assets/' . $assets[get_template_directory() . '/assets/css/main.min.css'],
'js' => '/assets/js/scripts.min.js?' . $assets['assets/js/scripts.min.js']['hash'], 'js' => '/assets/' . $assets[get_template_directory() . '/assets/js/scripts.min.js'],
'modernizr' => '/assets/js/vendor/modernizr.min.js', 'modernizr' => '/assets/js/vendor/modernizr.min.js',
'jquery' => '//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js' 'jquery' => '//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js'
); );
@@ -79,7 +79,7 @@ add_action('wp_head', 'roots_jquery_local_fallback');
/** /**
* Google Analytics snippet from HTML5 Boilerplate * Google Analytics snippet from HTML5 Boilerplate
* *
* Cookie domain is 'auto' configured. See: http://goo.gl/VUCHKM * Cookie domain is 'auto' configured. See: http://goo.gl/VUCHKM
*/ */
function roots_google_analytics() { ?> function roots_google_analytics() { ?>