diff --git a/.gitignore b/.gitignore index 1a360a8..ba97a2a 100644 --- a/.gitignore +++ b/.gitignore @@ -1,9 +1,6 @@ # Include your project-specific ignores in this file # Read about how to use .gitignore: https://help.github.com/articles/ignoring-files -node_modules -assets/vendor -assets/css/main.css.map -assets/css/*main*.css -assets/js/*scripts*.js -assets/js/vendor/modernizr.min.js +assets/dist assets/rev-manifest.json +bower_components +node_modules diff --git a/assets/less/_bootstrap.less b/assets/less/_bootstrap.less deleted file mode 100644 index 425658e..0000000 --- a/assets/less/_bootstrap.less +++ /dev/null @@ -1,92 +0,0 @@ -// -// Bootstrap -// -// Comment out any unused components -// -------------------------------------------------- - -// Variables -@import "../vendor/bootstrap/less/variables"; - -// Mixins: Utilities -@import "../vendor/bootstrap/less/mixins/hide-text"; -@import "../vendor/bootstrap/less/mixins/opacity"; -@import "../vendor/bootstrap/less/mixins/image"; -@import "../vendor/bootstrap/less/mixins/labels"; -@import "../vendor/bootstrap/less/mixins/reset-filter"; -@import "../vendor/bootstrap/less/mixins/resize"; -@import "../vendor/bootstrap/less/mixins/responsive-visibility"; -@import "../vendor/bootstrap/less/mixins/size"; -@import "../vendor/bootstrap/less/mixins/tab-focus"; -@import "../vendor/bootstrap/less/mixins/text-emphasis"; -@import "../vendor/bootstrap/less/mixins/text-overflow"; -@import "../vendor/bootstrap/less/mixins/vendor-prefixes"; - -// Mixins: Components -@import "../vendor/bootstrap/less/mixins/alerts"; -@import "../vendor/bootstrap/less/mixins/buttons"; -@import "../vendor/bootstrap/less/mixins/panels"; -@import "../vendor/bootstrap/less/mixins/pagination"; -@import "../vendor/bootstrap/less/mixins/list-group"; -@import "../vendor/bootstrap/less/mixins/nav-divider"; -@import "../vendor/bootstrap/less/mixins/forms"; -@import "../vendor/bootstrap/less/mixins/progress-bar"; -@import "../vendor/bootstrap/less/mixins/table-row"; - -// Mixins: Skins -@import "../vendor/bootstrap/less/mixins/background-variant"; -@import "../vendor/bootstrap/less/mixins/border-radius"; -@import "../vendor/bootstrap/less/mixins/gradients"; - -// Mixins: Layout -@import "../vendor/bootstrap/less/mixins/clearfix"; -@import "../vendor/bootstrap/less/mixins/center-block"; -@import "../vendor/bootstrap/less/mixins/nav-vertical-align"; -@import "../vendor/bootstrap/less/mixins/grid-framework"; -@import "../vendor/bootstrap/less/mixins/grid"; - -// Reset -@import "../vendor/bootstrap/less/normalize"; -@import "../vendor/bootstrap/less/print"; -@import "../vendor/bootstrap/less/glyphicons"; - -// Core CSS -@import "../vendor/bootstrap/less/scaffolding"; -@import "../vendor/bootstrap/less/type"; -@import "../vendor/bootstrap/less/code"; -@import "../vendor/bootstrap/less/grid"; -@import "../vendor/bootstrap/less/tables"; -@import "../vendor/bootstrap/less/forms"; -@import "../vendor/bootstrap/less/buttons"; - -// Components -@import "../vendor/bootstrap/less/component-animations"; -@import "../vendor/bootstrap/less/dropdowns"; -@import "../vendor/bootstrap/less/button-groups"; -@import "../vendor/bootstrap/less/input-groups"; -@import "../vendor/bootstrap/less/navs"; -@import "../vendor/bootstrap/less/navbar"; -@import "../vendor/bootstrap/less/breadcrumbs"; -@import "../vendor/bootstrap/less/pagination"; -@import "../vendor/bootstrap/less/pager"; -@import "../vendor/bootstrap/less/labels"; -@import "../vendor/bootstrap/less/badges"; -@import "../vendor/bootstrap/less/jumbotron"; -@import "../vendor/bootstrap/less/thumbnails"; -@import "../vendor/bootstrap/less/alerts"; -@import "../vendor/bootstrap/less/progress-bars"; -@import "../vendor/bootstrap/less/media"; -@import "../vendor/bootstrap/less/list-group"; -@import "../vendor/bootstrap/less/panels"; -@import "../vendor/bootstrap/less/responsive-embed"; -@import "../vendor/bootstrap/less/wells"; -@import "../vendor/bootstrap/less/close"; - -// Components w/ JavaScript -@import "../vendor/bootstrap/less/modals"; -@import "../vendor/bootstrap/less/tooltip"; -@import "../vendor/bootstrap/less/popovers"; -@import "../vendor/bootstrap/less/carousel"; - -// Utility classes -@import "../vendor/bootstrap/less/utilities"; -@import "../vendor/bootstrap/less/responsive-utilities"; diff --git a/assets/fonts/.gitkeep b/assets/src/fonts/.gitkeep similarity index 100% rename from assets/fonts/.gitkeep rename to assets/src/fonts/.gitkeep diff --git a/assets/img/.gitignore b/assets/src/img/.gitkeep similarity index 100% rename from assets/img/.gitignore rename to assets/src/img/.gitkeep diff --git a/assets/js/_main.js b/assets/src/js/main.js similarity index 100% rename from assets/js/_main.js rename to assets/src/js/main.js diff --git a/assets/src/less/_bootstrap.less b/assets/src/less/_bootstrap.less new file mode 100644 index 0000000..6825f08 --- /dev/null +++ b/assets/src/less/_bootstrap.less @@ -0,0 +1,92 @@ +// +// Bootstrap +// +// Comment out any unused components +// -------------------------------------------------- + +// Variables +@import "../../../bower_components/bootstrap/less/variables"; + +// Mixins: Utilities +@import "../../../bower_components/bootstrap/less/mixins/hide-text"; +@import "../../../bower_components/bootstrap/less/mixins/opacity"; +@import "../../../bower_components/bootstrap/less/mixins/image"; +@import "../../../bower_components/bootstrap/less/mixins/labels"; +@import "../../../bower_components/bootstrap/less/mixins/reset-filter"; +@import "../../../bower_components/bootstrap/less/mixins/resize"; +@import "../../../bower_components/bootstrap/less/mixins/responsive-visibility"; +@import "../../../bower_components/bootstrap/less/mixins/size"; +@import "../../../bower_components/bootstrap/less/mixins/tab-focus"; +@import "../../../bower_components/bootstrap/less/mixins/text-emphasis"; +@import "../../../bower_components/bootstrap/less/mixins/text-overflow"; +@import "../../../bower_components/bootstrap/less/mixins/vendor-prefixes"; + +// Mixins: Components +@import "../../../bower_components/bootstrap/less/mixins/alerts"; +@import "../../../bower_components/bootstrap/less/mixins/buttons"; +@import "../../../bower_components/bootstrap/less/mixins/panels"; +@import "../../../bower_components/bootstrap/less/mixins/pagination"; +@import "../../../bower_components/bootstrap/less/mixins/list-group"; +@import "../../../bower_components/bootstrap/less/mixins/nav-divider"; +@import "../../../bower_components/bootstrap/less/mixins/forms"; +@import "../../../bower_components/bootstrap/less/mixins/progress-bar"; +@import "../../../bower_components/bootstrap/less/mixins/table-row"; + +// Mixins: Skins +@import "../../../bower_components/bootstrap/less/mixins/background-variant"; +@import "../../../bower_components/bootstrap/less/mixins/border-radius"; +@import "../../../bower_components/bootstrap/less/mixins/gradients"; + +// Mixins: Layout +@import "../../../bower_components/bootstrap/less/mixins/clearfix"; +@import "../../../bower_components/bootstrap/less/mixins/center-block"; +@import "../../../bower_components/bootstrap/less/mixins/nav-vertical-align"; +@import "../../../bower_components/bootstrap/less/mixins/grid-framework"; +@import "../../../bower_components/bootstrap/less/mixins/grid"; + +// Reset +@import "../../../bower_components/bootstrap/less/normalize"; +@import "../../../bower_components/bootstrap/less/print"; +@import "../../../bower_components/bootstrap/less/glyphicons"; + +// Core CSS +@import "../../../bower_components/bootstrap/less/scaffolding"; +@import "../../../bower_components/bootstrap/less/type"; +@import "../../../bower_components/bootstrap/less/code"; +@import "../../../bower_components/bootstrap/less/grid"; +@import "../../../bower_components/bootstrap/less/tables"; +@import "../../../bower_components/bootstrap/less/forms"; +@import "../../../bower_components/bootstrap/less/buttons"; + +// Components +@import "../../../bower_components/bootstrap/less/component-animations"; +@import "../../../bower_components/bootstrap/less/dropdowns"; +@import "../../../bower_components/bootstrap/less/button-groups"; +@import "../../../bower_components/bootstrap/less/input-groups"; +@import "../../../bower_components/bootstrap/less/navs"; +@import "../../../bower_components/bootstrap/less/navbar"; +@import "../../../bower_components/bootstrap/less/breadcrumbs"; +@import "../../../bower_components/bootstrap/less/pagination"; +@import "../../../bower_components/bootstrap/less/pager"; +@import "../../../bower_components/bootstrap/less/labels"; +@import "../../../bower_components/bootstrap/less/badges"; +@import "../../../bower_components/bootstrap/less/jumbotron"; +@import "../../../bower_components/bootstrap/less/thumbnails"; +@import "../../../bower_components/bootstrap/less/alerts"; +@import "../../../bower_components/bootstrap/less/progress-bars"; +@import "../../../bower_components/bootstrap/less/media"; +@import "../../../bower_components/bootstrap/less/list-group"; +@import "../../../bower_components/bootstrap/less/panels"; +@import "../../../bower_components/bootstrap/less/responsive-embed"; +@import "../../../bower_components/bootstrap/less/wells"; +@import "../../../bower_components/bootstrap/less/close"; + +// Components w/ JavaScript +@import "../../../bower_components/bootstrap/less/modals"; +@import "../../../bower_components/bootstrap/less/tooltip"; +@import "../../../bower_components/bootstrap/less/popovers"; +@import "../../../bower_components/bootstrap/less/carousel"; + +// Utility classes +@import "../../../bower_components/bootstrap/less/utilities"; +@import "../../../bower_components/bootstrap/less/responsive-utilities"; diff --git a/assets/less/_global.less b/assets/src/less/_global.less similarity index 100% rename from assets/less/_global.less rename to assets/src/less/_global.less diff --git a/assets/less/_variables.less b/assets/src/less/_variables.less similarity index 100% rename from assets/less/_variables.less rename to assets/src/less/_variables.less diff --git a/assets/less/components/_buttons.less b/assets/src/less/components/_buttons.less similarity index 100% rename from assets/less/components/_buttons.less rename to assets/src/less/components/_buttons.less diff --git a/assets/less/components/_forms.less b/assets/src/less/components/_forms.less similarity index 100% rename from assets/less/components/_forms.less rename to assets/src/less/components/_forms.less diff --git a/assets/less/components/_media.less b/assets/src/less/components/_media.less similarity index 100% rename from assets/less/components/_media.less rename to assets/src/less/components/_media.less diff --git a/assets/less/components/_wp-classes.less b/assets/src/less/components/_wp-classes.less similarity index 100% rename from assets/less/components/_wp-classes.less rename to assets/src/less/components/_wp-classes.less diff --git a/assets/css/editor-style.css b/assets/src/less/editor-style.less similarity index 100% rename from assets/css/editor-style.css rename to assets/src/less/editor-style.less diff --git a/assets/less/layouts/_footer.less b/assets/src/less/layouts/_footer.less similarity index 100% rename from assets/less/layouts/_footer.less rename to assets/src/less/layouts/_footer.less diff --git a/assets/less/layouts/_general.less b/assets/src/less/layouts/_general.less similarity index 100% rename from assets/less/layouts/_general.less rename to assets/src/less/layouts/_general.less diff --git a/assets/less/layouts/_header.less b/assets/src/less/layouts/_header.less similarity index 100% rename from assets/less/layouts/_header.less rename to assets/src/less/layouts/_header.less diff --git a/assets/less/layouts/_pages.less b/assets/src/less/layouts/_pages.less similarity index 100% rename from assets/less/layouts/_pages.less rename to assets/src/less/layouts/_pages.less diff --git a/assets/less/layouts/_posts.less b/assets/src/less/layouts/_posts.less similarity index 100% rename from assets/less/layouts/_posts.less rename to assets/src/less/layouts/_posts.less diff --git a/assets/less/layouts/_sidebar.less b/assets/src/less/layouts/_sidebar.less similarity index 100% rename from assets/less/layouts/_sidebar.less rename to assets/src/less/layouts/_sidebar.less diff --git a/assets/less/layouts/pages/_home.less b/assets/src/less/layouts/pages/_home.less similarity index 100% rename from assets/less/layouts/pages/_home.less rename to assets/src/less/layouts/pages/_home.less diff --git a/assets/less/main.less b/assets/src/less/main.less similarity index 97% rename from assets/less/main.less rename to assets/src/less/main.less index 5affb9f..aec9850 100644 --- a/assets/less/main.less +++ b/assets/src/less/main.less @@ -2,7 +2,7 @@ @import "_bootstrap"; // Variable overrides and custom variables -@import "_variables"; +@import "_variables"; // Roots @import "_global"; // Base styling & custom mixins diff --git a/gulpfile.js b/gulpfile.js index 6ea429c..acfb254 100644 --- a/gulpfile.js +++ b/gulpfile.js @@ -1,35 +1,27 @@ /*global $:true*/ var gulp = require('gulp'); var $ = require('gulp-load-plugins')(); +var plugins = require('gulp-load-plugins')(); + var pngcrush = require('imagemin-pngcrush'); + var mainBowerFiles = require('main-bower-files'); +var pkg = require('./package.json'); + var paths = { scripts: [ - 'assets/js/**/*.js', - '!assets/js/vendor/**/*', - '!assets/js/scripts*.js' + 'assets/src/js/**/*' ], jshint: [ 'gulpfile.js', - 'assets/js/*.js', - '!assets/js/scripts.js', - '!assets/js/scripts.min.js', - '!assets/js/vendor/**/*', - '!assets/**/*.min-*' + 'assets/src/js/**/*' ], - less: 'assets/less/main.less', + less: 'assets/src/less/main.less', bower: mainBowerFiles() }; -var destination = { - css: 'assets/css', - scripts: 'assets/js', - modernizr: 'assets/vendor/modernizr', - vendor: 'assets/js/vendor' -}; - -gulp.task('less', function() { +gulp.task('less:dev', function() { return gulp.src(paths.less) .pipe($.plumber()) .pipe($.sourcemaps.init()) @@ -37,15 +29,24 @@ gulp.task('less', function() { console.warn(err.message); }) .pipe($.autoprefixer('last 2 versions', 'ie 8', 'ie 9', 'android 2.3', 'android 4', 'opera 12')) - .pipe($.rename('./main.css')) .pipe($.sourcemaps.write()) - .pipe(gulp.dest(destination.css)) - .pipe($.minifyCss()) - .pipe($.rename('./main.min.css')) - .pipe(gulp.dest(destination.css)) + .pipe($.rename('./main.css')) + .pipe(gulp.dest('assets/dist/css')) .pipe($.livereload({ auto: false })); }); +gulp.task('less:build', function() { + return gulp.src(paths.less) + .pipe($.plumber()) + .pipe($.less()).on('error', function(err) { + console.warn(err.message); + }) + .pipe($.autoprefixer('last 2 versions', 'ie 9', 'android 2.3', 'android 4', 'opera 12')) + .pipe($.rename('./main.min.css')) + .pipe(gulp.dest('assets/dist/css')) + .pipe($.minifyCss()); +}); + gulp.task('jshint', function() { return gulp.src(paths.jshint) .pipe($.jshint()) @@ -53,45 +54,53 @@ gulp.task('jshint', function() { .pipe($.jshint.reporter('fail')); }); -gulp.task('js', ['jshint'], function() { +gulp.task('js:dev', ['jshint'], function() { return gulp.src(paths.bower.concat(paths.scripts)) - .pipe($.filter(['**/*.js', '!jquery.js', '!modernizr.js'])) .pipe($.concat('./scripts.js')) - .pipe(gulp.dest(destination.scripts)) - .pipe($.uglify()) - .pipe($.rename('./scripts.min.js')) - .pipe(gulp.dest(destination.scripts)) + .pipe(gulp.dest('assets/dist/js')) .pipe($.livereload({ auto: false })); }); -gulp.task('modernizr', function() { - return gulp.src( - ['assets/js/scripts.min.js'], - ['assets/css/main.min.css'] - ) - .pipe($.modernizr()) - .pipe(gulp.dest(destination.modernizr)) +gulp.task('js:build', ['jshint'], function() { + return gulp.src(paths.bower.concat(paths.scripts)) + .pipe($.concat('./scripts.min.js')) .pipe($.uglify()) - .pipe($.rename('./modernizr.min.js')) - .pipe(gulp.dest(destination.vendor)); + .pipe(gulp.dest('assets/dist/js')); }); -gulp.task('images', function () { - return gulp.src('assets/img/**/*') +gulp.task('copy:fonts', function() { + return gulp.src(['bower_components/bootstrap/fonts/*', 'assets/src/fonts/*']) + .pipe(gulp.dest('assets/dist/fonts')); +}); + +gulp.task('copy:jquery', function() { + return gulp.src(['bower_components/jquery/dist/jquery.min.js']) + .pipe($.rename('jquery-' + pkg.devDependencies.jquery + '.min.js')) + .pipe(gulp.dest('assets/dist/js')); +}); + +gulp.task('images', function() { + return gulp.src('assets/src/img/**/*') .pipe($.imagemin({ progressive: true, interlaced: true, use: [pngcrush()] })) - .pipe(gulp.dest('assets/img')); + .pipe(gulp.dest('assets/dist/img')); }); -gulp.task('bust', function () { - $.cache.clearAll(); +gulp.task('modernizr', function() { + return gulp.src( + ['assets/dist/js/scripts.min.js'], + ['assets/dist/css/main.min.css'] + ) + .pipe($.modernizr('modernizr.min.js')) + .pipe($.uglify()) + .pipe(gulp.dest('assets/dist/js')); }); gulp.task('version', function() { - return gulp.src(['assets/css/main.min.css', 'assets/js/scripts.min.js'], { base: 'assets' }) + return gulp.src(['assets/dist/css/main.min.css', 'assets/dist/js/scripts.min.js'], { base: 'assets' }) .pipe($.rev()) .pipe(gulp.dest('assets')) .pipe($.rev.manifest()) @@ -100,13 +109,13 @@ gulp.task('version', function() { gulp.task('watch', function() { $.livereload.listen(); - gulp.watch('assets/less/**/*.less', ['less']); - gulp.watch('assets/js/**/*.js', ['jshint', 'js']); + gulp.watch('assets/src/less/**/*', ['less:dev']); + gulp.watch('assets/src/js/**/*', ['jshint', 'js:dev']); gulp.watch('**/*.php').on('change', function(file) { $.livereload.changed(file.path); }); }); -gulp.task('default', ['less', 'jshint', 'js', 'modernizr']); +gulp.task('default', ['less:dev', 'jshint', 'js:dev']); gulp.task('dev', ['default']); -gulp.task('build', ['less', 'jshint', 'js', 'modernizr', 'version']); +gulp.task('build', ['less:build', 'js:build', 'copy:fonts', 'copy:jquery', 'images', 'modernizr', 'version']); diff --git a/lib/scripts.php b/lib/scripts.php index d84eaec..6854c8b 100644 --- a/lib/scripts.php +++ b/lib/scripts.php @@ -3,12 +3,12 @@ * Scripts and stylesheets * * Enqueue stylesheets in the following order: - * 1. /theme/assets/css/main.css + * 1. /theme/assets/dist/css/main.css * * Enqueue scripts in the following order: * 1. jquery-1.11.1.min.js via Google CDN - * 2. /theme/assets/js/vendor/modernizr.min.js - * 3. /theme/assets/js/scripts.js + * 2. /theme/assets/dist/js/modernizr.min.js + * 3. /theme/assets/dist/js/scripts.js * * Google Analytics is loaded after enqueued scripts if: * - An ID has been defined in config.php @@ -21,18 +21,18 @@ function roots_scripts() { */ if (WP_ENV === 'development') { $assets = array( - 'css' => '/assets/css/main.css', - 'js' => '/assets/js/scripts.js', - 'modernizr' => '/assets/vendor/modernizr/modernizr.js', + 'css' => '/assets/dist/css/main.css', + 'js' => '/assets/dist/js/scripts.js', + 'modernizr' => '/assets/dist/js/modernizr.min.js', 'jquery' => '//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.js' ); } else { $get_assets = file_get_contents(get_template_directory() . '/assets/rev-manifest.json'); $assets = json_decode($get_assets, true); $assets = array( - 'css' => '/assets/' . $assets[get_template_directory() . '/assets/css/main.min.css'], - 'js' => '/assets/' . $assets[get_template_directory() . '/assets/js/scripts.min.js'], - 'modernizr' => '/assets/js/vendor/modernizr.min.js', + 'css' => '/assets/' . $assets[get_template_directory() . '/assets/dist/css/main.min.css'], + 'js' => '/assets/' . $assets[get_template_directory() . '/assets/dist/js/scripts.min.js'], + 'modernizr' => '/assets/dist/js/modernizr.min.js', 'jquery' => '//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js' ); } @@ -65,7 +65,7 @@ function roots_jquery_local_fallback($src, $handle = null) { static $add_jquery_fallback = false; if ($add_jquery_fallback) { - echo '' . "\n"; + echo '' . "\n"; $add_jquery_fallback = false; } diff --git a/package.json b/package.json index 5be6590..3cf7835 100644 --- a/package.json +++ b/package.json @@ -27,7 +27,6 @@ "gulp": "^3.8.7", "gulp-autoprefixer": "^0.0.7", "gulp-concat": "^2.3.4", - "gulp-filter": "^0.5.0", "gulp-grunt": "^0.5.2", "gulp-imagemin": "^0.6.0", "gulp-jshint": "^1.8.4", @@ -38,11 +37,13 @@ "gulp-modernizr": "https://github.com/doctyper/gulp-modernizr/tarball/develop", "gulp-plumber": "^0.6.3", "gulp-rename": "^1.2.0", - "gulp-rev": "^1.1.0", + "gulp-rev": "^2.0.1", "gulp-sourcemaps": "^1.1.1", "gulp-uglify": "^0.3.1", "imagemin-pngcrush": "^1.0.0", "jshint-stylish": "^0.4.0", + "jquery": "1.11.1", + "lodash": "^2.4.1", "main-bower-files": "^1.0.1" } }