diff --git a/Gulpfile.js b/Gulpfile.js index c5cc36c6d..278199504 100644 --- a/Gulpfile.js +++ b/Gulpfile.js @@ -1,5 +1,6 @@ // Require our dependencies const autoprefixer = require( 'autoprefixer' ); +const babel = require( 'gulp-babel' ); const bourbon = require( 'bourbon' ).includePaths; const browserSync = require( 'browser-sync' ); const cheerio = require( 'gulp-cheerio' ); @@ -43,7 +44,7 @@ const paths = { * Handle errors and alert the user. */ function handleErrors () { - var args = Array.prototype.slice.call( arguments ); + const args = Array.prototype.slice.call( arguments ); notify.onError( { 'title': 'Task Failed [<%= error.message %>', @@ -51,18 +52,18 @@ function handleErrors () { 'sound': 'Sosumi' // See: https://github.com/mikaelbr/node-notifier#all-notification-options-with-their-defaults } ).apply( this, args ); - gutil.beep(); // Beep 'sosumi' again + gutil.beep(); // Beep 'sosumi' again. - // Prevent the 'watch' task from stopping + // Prevent the 'watch' task from stopping. this.emit( 'end' ); } /** * Delete style.css and style.min.css before we minify and optimize */ -gulp.task( 'clean:styles', function () { - return del( [ 'style.css', 'style.min.css' ] ); -} ); +gulp.task( 'clean:styles', () => + del( [ 'style.css', 'style.min.css' ] ) +); /** * Compile Sass and run stylesheet through PostCSS. @@ -72,62 +73,62 @@ gulp.task( 'clean:styles', function () { * https://www.npmjs.com/package/gulp-autoprefixer * https://www.npmjs.com/package/css-mqpacker */ -gulp.task( 'postcss', [ 'clean:styles' ], function () { - return gulp.src( 'assets/sass/*.scss', paths.css ) +gulp.task( 'postcss', [ 'clean:styles' ], () => + gulp.src( 'assets/sass/*.scss', paths.css ) - // Deal with errors. - .pipe( plumber( {'errorHandler': handleErrors} ) ) + // Deal with errors. + .pipe( plumber( {'errorHandler': handleErrors} ) ) - // Wrap tasks in a sourcemap. - .pipe( sourcemaps.init() ) + // Wrap tasks in a sourcemap. + .pipe( sourcemaps.init() ) - // Compile Sass using LibSass. - .pipe( sass( { - 'includePaths': [].concat( bourbon, neat ), - 'errLogToConsole': true, - 'outputStyle': 'expanded' // Options: nested, expanded, compact, compressed - } ) ) + // Compile Sass using LibSass. + .pipe( sass( { + 'includePaths': [].concat( bourbon, neat ), + 'errLogToConsole': true, + 'outputStyle': 'expanded' // Options: nested, expanded, compact, compressed + } ) ) - // Parse with PostCSS plugins. - .pipe( postcss( [ - autoprefixer( { - 'browsers': [ 'last 2 version' ] - } ), - mqpacker( { - 'sort': true - } ) - ] ) ) - - // Create sourcemap. - .pipe( sourcemaps.write() ) - - // Create style.css. - .pipe( gulp.dest( './' ) ) - .pipe( browserSync.stream() ); -} ); + // Parse with PostCSS plugins. + .pipe( postcss( [ + autoprefixer( { + 'browsers': [ 'last 2 version' ] + } ), + mqpacker( { + 'sort': true + } ) + ] ) ) + + // Create sourcemap. + .pipe( sourcemaps.write() ) + + // Create style.css. + .pipe( gulp.dest( './' ) ) + .pipe( browserSync.stream() ) +); /** * Minify and optimize style.css. * * https://www.npmjs.com/package/gulp-cssnano */ -gulp.task( 'cssnano', [ 'postcss' ], function () { - return gulp.src( 'style.css' ) - .pipe( plumber( {'errorHandler': handleErrors} ) ) - .pipe( cssnano( { - 'safe': true // Use safe optimizations - } ) ) - .pipe( rename( 'style.min.css' ) ) - .pipe( gulp.dest( './' ) ) - .pipe( browserSync.stream() ); -} ); +gulp.task( 'cssnano', [ 'postcss' ], () => + gulp.src( 'style.css' ) + .pipe( plumber( {'errorHandler': handleErrors} ) ) + .pipe( cssnano( { + 'safe': true // Use safe optimizations. + } ) ) + .pipe( rename( 'style.min.css' ) ) + .pipe( gulp.dest( './' ) ) + .pipe( browserSync.stream() ) +); /** * Delete the svg-icons.svg before we minify, concat. */ -gulp.task( 'clean:icons', function () { - return del( [ 'assets/images/svg-icons.svg' ] ); -} ); +gulp.task( 'clean:icons', () => + del( [ 'assets/images/svg-icons.svg' ] ) +); /** * Minify, concatenate, and clean SVG icons. @@ -136,45 +137,57 @@ gulp.task( 'clean:icons', function () { * https://www.npmjs.com/package/gulp-svgstore * https://www.npmjs.com/package/gulp-cheerio */ -gulp.task( 'svg', [ 'clean:icons' ], function () { - return gulp.src( paths.icons ) - .pipe( plumber( {'errorHandler': handleErrors} ) ) - .pipe( svgmin() ) - .pipe( rename( {'prefix': 'icon-'} ) ) - .pipe( svgstore( {'inlineSvg': true} ) ) - .pipe( cheerio( { - 'run': function ( $, file ) { - $( 'svg' ).attr( 'style', 'display:none' ); - $( '[fill]' ).removeAttr( 'fill' ); - $( 'path' ).removeAttr( 'class' ); - }, - 'parserOptions': {'xmlMode': true} - } ) ) - .pipe( gulp.dest( 'assets/images/' ) ) - .pipe( browserSync.stream() ); -} ); +gulp.task( 'svg', [ 'clean:icons' ], () => + gulp.src( paths.icons ) + + // Deal with errors. + .pipe( plumber( {'errorHandler': handleErrors} ) ) + + // Minify SVGs. + .pipe( svgmin() ) + + // Add a prefix to SVG IDs. + .pipe( rename( {'prefix': 'icon-'} ) ) + + // Combine all SVGs into a single + .pipe( svgstore( {'inlineSvg': true} ) ) + + // Clean up the by removing the following cruft... + .pipe( cheerio( { + 'run': function ( $, file ) { + $( 'svg' ).attr( 'style', 'display:none' ); + $( '[fill]' ).removeAttr( 'fill' ); + $( 'path' ).removeAttr( 'class' ); + }, + 'parserOptions': {'xmlMode': true} + } ) ) + + // Save svg-icons.svg. + .pipe( gulp.dest( 'assets/images/' ) ) + .pipe( browserSync.stream() ) +); /** * Optimize images. * * https://www.npmjs.com/package/gulp-imagemin */ -gulp.task( 'imagemin', function () { - return gulp.src( paths.images ) - .pipe( plumber( {'errorHandler': handleErrors} ) ) - .pipe( imagemin( { - 'optimizationLevel': 5, - 'progressive': true, - 'interlaced': true - } ) ) - .pipe( gulp.dest( 'assets/images' ) ); -} ); +gulp.task( 'imagemin', () => + gulp.src( paths.images ) + .pipe( plumber( {'errorHandler': handleErrors} ) ) + .pipe( imagemin( { + 'optimizationLevel': 5, + 'progressive': true, + 'interlaced': true + } ) ) + .pipe( gulp.dest( 'assets/images' ) ) +); /** * Delete the sprites.png before rebuilding sprite. */ -gulp.task( 'clean:sprites', function () { - return del( [ 'assets/images/sprites.png' ] ); +gulp.task( 'clean:sprites', () => { + del( [ 'assets/images/sprites.png' ] ) } ); /** @@ -182,97 +195,118 @@ gulp.task( 'clean:sprites', function () { * * https://www.npmjs.com/package/gulp.spritesmith */ -gulp.task( 'spritesmith', [ 'clean:sprites' ], function () { - return gulp.src( paths.sprites ) - .pipe( plumber( {'errorHandler': handleErrors} ) ) - .pipe( spritesmith( { - 'imgName': 'sprites.png', - 'cssName': '../../assets/sass/base/_sprites.scss', - 'imgPath': 'assets/images/sprites.png', - 'algorithm': 'binary-tree' - } ) ) - .pipe( gulp.dest( 'assets/images/' ) ) - .pipe( browserSync.stream() ); -} ); +gulp.task( 'spritesmith', [ 'clean:sprites' ], () => + gulp.src( paths.sprites ) + .pipe( plumber( {'errorHandler': handleErrors} ) ) + .pipe( spritesmith( { + 'imgName': 'sprites.png', + 'cssName': '../../assets/sass/base/_sprites.scss', + 'imgPath': 'assets/images/sprites.png', + 'algorithm': 'binary-tree' + } ) ) + .pipe( gulp.dest( 'assets/images/' ) ) + .pipe( browserSync.stream() ) +); /** - * Concatenate javascript files into one. + * Concatenate and transform JavaScript. + * * https://www.npmjs.com/package/gulp-concat + * https://github.com/babel/gulp-babel + * https://www.npmjs.com/package/gulp-sourcemaps */ -gulp.task( 'concat', function () { - return gulp.src( paths.concat_scripts ) - .pipe( plumber( {'errorHandler': handleErrors} ) ) - .pipe( sourcemaps.init() ) - .pipe( concat( 'project.js' ) ) - .pipe( sourcemaps.write() ) - .pipe( gulp.dest( 'assets/scripts' ) ) - .pipe( browserSync.stream() ); -} ); +gulp.task( 'concat', () => + gulp.src( paths.concat_scripts ) + + // Deal with errors. + .pipe( plumber( + {'errorHandler': handleErrors} + ) ) + + // Start a sourcemap. + .pipe( sourcemaps.init() ) + + // Convert ES6+ to ES2015. + .pipe( babel( { + presets: [ 'es2015' ] + } ) ) + + // Concatenate partials into a single script. + .pipe( concat( 'project.js' ) ) + + // Append the sourcemap to project.js. + .pipe( sourcemaps.write() ) - /** - * Minify compiled javascript after concatenated. + // Save project.js + .pipe( gulp.dest( 'assets/scripts' ) ) + .pipe( browserSync.stream() ) +); + +/** + * Minify compiled JavaScript. + * * https://www.npmjs.com/package/gulp-uglify */ -gulp.task( 'uglify', [ 'concat' ], function () { - return gulp.src( paths.scripts ) - .pipe( rename( {'suffix': '.min'} ) ) - .pipe( uglify( { - 'mangle': false - } ) ) - .pipe( gulp.dest( 'assets/scripts' ) ); -} ); +gulp.task( 'uglify', [ 'concat' ], () => + gulp.src( paths.scripts ) + .pipe( rename( {'suffix': '.min'} ) ) + .pipe( uglify( { + 'mangle': false + } ) ) + .pipe( gulp.dest( 'assets/scripts' ) ) +); /** * Delete the theme's .pot before we create a new one. */ -gulp.task( 'clean:pot', function () { - return del( [ 'languages/_s.pot' ] ); -} ); +gulp.task( 'clean:pot', () => + del( [ 'languages/_s.pot' ] ) +); /** * Scan the theme and create a POT file. * * https://www.npmjs.com/package/gulp-wp-pot */ -gulp.task( 'wp-pot', [ 'clean:pot' ], function () { - return gulp.src( paths.php ) - .pipe( plumber( {'errorHandler': handleErrors} ) ) - .pipe( sort() ) - .pipe( wpPot( { - 'domain': '_s', - 'destFile': '_s.pot', - 'package': '_s', - 'bugReport': 'http://_s.com', - 'lastTranslator': 'John Doe ', - 'team': 'Team ' - } ) ) - .pipe( gulp.dest( 'languages/' ) ); -} ); +gulp.task( 'wp-pot', [ 'clean:pot' ], () => + gulp.src( paths.php ) + .pipe( plumber( {'errorHandler': handleErrors} ) ) + .pipe( sort() ) + .pipe( wpPot( { + 'domain': '_s', + 'destFile': '_s.pot', + 'package': '_s', + 'bugReport': 'http://_s.com', + 'lastTranslator': 'John Doe ', + 'team': 'Team ' + } ) ) + .pipe( gulp.dest( 'languages/' ) ) +); /** * Sass linting. * * https://www.npmjs.com/package/sass-lint */ -gulp.task( 'sass:lint', function () { +gulp.task( 'sass:lint', () => gulp.src( [ 'assets/sass/**/*.scss', '!assets/sass/base/_normalize.scss', '!assets/sass/base/_sprites.scss', '!node_modules/**' ] ) - .pipe( sassLint() ) - .pipe( sassLint.format() ) - .pipe( sassLint.failOnError() ); -} ); + .pipe( sassLint() ) + .pipe( sassLint.format() ) + .pipe( sassLint.failOnError() ) +); /** - * Javascript linting. + * JavaScript linting. * * https://www.npmjs.com/package/gulp-eslint */ -gulp.task( 'js:lint', function () { - return gulp.src( [ +gulp.task( 'js:lint', () => + gulp.src( [ 'assets/scripts/concat/*.js', 'assets/scripts/*.js', '!assets/scripts/project.js', @@ -281,10 +315,10 @@ gulp.task( 'js:lint', function () { '!Gulpfile.js', '!node_modules/**' ] ) - .pipe( eslint() ) - .pipe( eslint.format() ) - .pipe( eslint.failAfterError() ); -} ); + .pipe( eslint() ) + .pipe( eslint.format() ) + .pipe( eslint.failAfterError() ) +); /** * Process tasks and reload browsers on file changes. @@ -292,13 +326,14 @@ gulp.task( 'js:lint', function () { * https://www.npmjs.com/package/browser-sync */ gulp.task( 'watch', function () { + // Kick off BrowserSync. browserSync( { 'open': false, // Open project in a new tab? - 'injectChanges': true, // Auto inject changes instead of full reload - 'proxy': 'testing.dev', // Use http://_s.com:3000 to use BrowserSync + 'injectChanges': true, // Auto inject changes instead of full reload. + 'proxy': 'testing.dev', // Use http://_s.com:3000 to use BrowserSync. 'watchOptions': { - 'debounceDelay': 1000 // Wait 1 second before injecting + 'debounceDelay': 1000 // Wait 1 second before injecting. } } ); @@ -321,4 +356,4 @@ gulp.task( 'scripts', [ 'uglify' ] ); gulp.task( 'styles', [ 'cssnano' ] ); gulp.task( 'sprites', [ 'spritesmith' ] ); gulp.task( 'lint', [ 'sass:lint', 'js:lint' ] ); -gulp.task( 'default', [ 'sprites', 'i18n', 'icons', 'styles', 'scripts', 'imagemin', 'lint' ] ); +gulp.task( 'default', [ 'sprites', 'i18n', 'icons', 'styles', 'scripts', 'imagemin'] ); \ No newline at end of file diff --git a/assets/scripts/project.js b/assets/scripts/project.js index d38439e76..160f04358 100644 --- a/assets/scripts/project.js +++ b/assets/scripts/project.js @@ -1,9 +1,12 @@ +'use strict'; + /** * File js-enabled.js * * If Javascript is enabled, replace the class "no-js". */ -document.body.className = document.body.className.replace( 'no-js', 'js' ); +document.body.className = document.body.className.replace('no-js', 'js'); +'use strict'; /** * File modal.js @@ -12,12 +15,12 @@ document.body.className = document.body.className.replace( 'no-js', 'js' ); */ window.wdsModal = {}; -( function ( window, $, app ) { +(function (window, $, app) { // Constructor. app.init = function () { app.cache(); - if ( app.meetsRequirements() ) { + if (app.meetsRequirements()) { app.bindEvents(); } }; @@ -25,81 +28,82 @@ window.wdsModal = {}; // Cache all the things. app.cache = function () { app.$c = { - 'body': $( 'body' ) + 'body': $('body') }; }; // Do we meet the requirements? app.meetsRequirements = function () { - return $( '.modal-trigger' ).length; + return $('.modal-trigger').length; }; // Combine all events. app.bindEvents = function () { // Trigger a modal to open. - app.$c.body.on( 'click touchstart', '.modal-trigger', app.openModal ); + app.$c.body.on('click touchstart', '.modal-trigger', app.openModal); // Trigger the close button to close the modal. - app.$c.body.on( 'click touchstart', '.close', app.closeModal ); + app.$c.body.on('click touchstart', '.close', app.closeModal); // Allow the user to close the modal by hitting the esc key. - app.$c.body.on( 'keydown', app.escKeyClose ); + app.$c.body.on('keydown', app.escKeyClose); // Allow the user to close the modal by clicking outside of the modal. - app.$c.body.on( 'click touchstart', 'div.modal-open', app.closeModalByClick ); + app.$c.body.on('click touchstart', 'div.modal-open', app.closeModalByClick); }; // Open the modal. app.openModal = function () { // Figure out which modal we're opening and store the object. - var $modal = $( $( this ).data( 'target' ) ); + var $modal = $($(this).data('target')); // Display the modal. - $modal.addClass( 'modal-open' ); + $modal.addClass('modal-open'); // Add body class. - app.$c.body.addClass( 'modal-open' ); + app.$c.body.addClass('modal-open'); }; // Close the modal. app.closeModal = function () { // Figure the opened modal we're closing and store the object. - var $modal = $( $( 'div.modal-open .close' ).data( 'target' ) ); + var $modal = $($('div.modal-open .close').data('target')); // Find the iframe in the $modal object. - var $iframe = $modal.find( 'iframe' ); + var $iframe = $modal.find('iframe'); // Get the iframe src URL. - var url = $iframe.attr( 'src' ); + var url = $iframe.attr('src'); // Remove the source URL, then add it back, so the video can be played again later. - $iframe.attr( 'src', '' ).attr( 'src', url ); + $iframe.attr('src', '').attr('src', url); // Finally, hide the modal. - $modal.removeClass( 'modal-open' ); + $modal.removeClass('modal-open'); // Remove the body class. - app.$c.body.removeClass( 'modal-open' ); + app.$c.body.removeClass('modal-open'); }; // Close if "esc" key is pressed. - app.escKeyClose = function ( event ) { - if ( 27 === event.keyCode ) { + app.escKeyClose = function (event) { + if (27 === event.keyCode) { app.closeModal(); } }; // Close if the user clicks outside of the modal - app.closeModalByClick = function ( event ) { + app.closeModalByClick = function (event) { // If the parent container is NOT the modal dialog container, close the modal - if ( !$( event.target ).parents( 'div' ).hasClass( 'modal-dialog' ) ) { + if (!$(event.target).parents('div').hasClass('modal-dialog')) { app.closeModal(); } }; // Engage! - $( app.init ); -} )( window, jQuery, window.wdsModal ); + $(app.init); +})(window, jQuery, window.wdsModal); +'use strict'; /** * File search.js @@ -108,12 +112,12 @@ window.wdsModal = {}; */ window.wdsSearch = {}; -( function ( window, $, app ) { +(function (window, $, app) { // Constructor. app.init = function () { app.cache(); - if ( app.meetsRequirements() ) { + if (app.meetsRequirements()) { app.bindEvents(); } }; @@ -121,41 +125,42 @@ window.wdsSearch = {}; // Cache all the things. app.cache = function () { app.$c = { - 'body': $( 'body' ) + 'body': $('body') }; }; // Do we meet the requirements? app.meetsRequirements = function () { - return $( '.search-field' ).length; + return $('.search-field').length; }; // Combine all events. app.bindEvents = function () { // Remove placeholder text from search field on focus. - app.$c.body.on( 'focus', '.search-field', app.removePlaceholderText ); + app.$c.body.on('focus', '.search-field', app.removePlaceholderText); // Add placeholder text back to search field on blur. - app.$c.body.on( 'blur', '.search-field', app.addPlaceholderText ); + app.$c.body.on('blur', '.search-field', app.addPlaceholderText); }; // Remove placeholder text from search field. app.removePlaceholderText = function () { - var $search_field = $( this ); + var $search_field = $(this); - $search_field.data( 'placeholder', $search_field.attr( 'placeholder' ) ).attr( 'placeholder', '' ); + $search_field.data('placeholder', $search_field.attr('placeholder')).attr('placeholder', ''); }; // Replace placeholder text from search field. app.addPlaceholderText = function () { - var $search_field = $( this ); + var $search_field = $(this); - $search_field.attr( 'placeholder', $search_field.data( 'placeholder' ) ).data( 'placeholder', '' ); + $search_field.attr('placeholder', $search_field.data('placeholder')).data('placeholder', ''); }; // Engage! - $( app.init ); -} )( window, jQuery, window.wdsSearch ); + $(app.init); +})(window, jQuery, window.wdsSearch); +'use strict'; /** * File skip-link-focus-fix.js. @@ -164,32 +169,33 @@ window.wdsSearch = {}; * * Learn more: https://git.io/vWdr2 */ -( function () { - var isWebkit = navigator.userAgent.toLowerCase().indexOf( 'webkit' ) > -1, - isOpera = navigator.userAgent.toLowerCase().indexOf( 'opera' ) > -1, - isIe = navigator.userAgent.toLowerCase().indexOf( 'msie' ) > -1; +(function () { + var isWebkit = navigator.userAgent.toLowerCase().indexOf('webkit') > -1, + isOpera = navigator.userAgent.toLowerCase().indexOf('opera') > -1, + isIe = navigator.userAgent.toLowerCase().indexOf('msie') > -1; - if ( ( isWebkit || isOpera || isIe ) && document.getElementById && window.addEventListener ) { - window.addEventListener( 'hashchange', function () { - var id = location.hash.substring( 1 ), - element; + if ((isWebkit || isOpera || isIe) && document.getElementById && window.addEventListener) { + window.addEventListener('hashchange', function () { + var id = location.hash.substring(1), + element; - if ( !( /^[A-z0-9_-]+$/ ).test( id ) ) { + if (!/^[A-z0-9_-]+$/.test(id)) { return; } - element = document.getElementById( id ); + element = document.getElementById(id); - if ( element ) { - if ( !( /^(?:a|select|input|button|textarea)$/i ).test( element.tagName ) ) { + if (element) { + if (!/^(?:a|select|input|button|textarea)$/i.test(element.tagName)) { element.tabIndex = -1; } element.focus(); } - }, false ); + }, false); } -} )(); +})(); +'use strict'; /** * File window-ready.js @@ -197,7 +203,7 @@ window.wdsSearch = {}; * Add a "ready" class to when window is ready. */ window.wdsWindowReady = {}; -( function ( window, $, app ) { +(function (window, $, app) { // Constructor. app.init = function () { app.cache(); @@ -207,23 +213,22 @@ window.wdsWindowReady = {}; // Cache document elements. app.cache = function () { app.$c = { - 'window': $( window ), - 'body': $( document.body ) + 'window': $(window), + 'body': $(document.body) }; }; // Combine all events. app.bindEvents = function () { - app.$c.window.load( app.addBodyClass ); + app.$c.window.load(app.addBodyClass); }; // Add a class to . app.addBodyClass = function () { - app.$c.body.addClass( 'ready' ); + app.$c.body.addClass('ready'); }; // Engage! - $( app.init ); -} )( window, jQuery, window.wdsWindowReady ); - -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["js-enabled.js","modal.js","search.js","skip-link-focus-fix.js","window-ready.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC/FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"project.js","sourcesContent":["/**\n * File js-enabled.js\n *\n * If Javascript is enabled, replace the <body> class \"no-js\".\n */\ndocument.body.className = document.body.className.replace( 'no-js', 'js' );\n","/**\n * File modal.js\n *\n * Deal with multiple modals and their media.\n */\nwindow.wdsModal = {};\n\n( function ( window, $, app ) {\n\t// Constructor.\n\tapp.init = function () {\n\t\tapp.cache();\n\n\t\tif ( app.meetsRequirements() ) {\n\t\t\tapp.bindEvents();\n\t\t}\n\t};\n\n\t// Cache all the things.\n\tapp.cache = function () {\n\t\tapp.$c = {\n\t\t\t'body': $( 'body' )\n\t\t};\n\t};\n\n\t// Do we meet the requirements?\n\tapp.meetsRequirements = function () {\n\t\treturn $( '.modal-trigger' ).length;\n\t};\n\n\t// Combine all events.\n\tapp.bindEvents = function () {\n\t\t// Trigger a modal to open.\n\t\tapp.$c.body.on( 'click touchstart', '.modal-trigger', app.openModal );\n\n\t\t// Trigger the close button to close the modal.\n\t\tapp.$c.body.on( 'click touchstart', '.close', app.closeModal );\n\n\t\t// Allow the user to close the modal by hitting the esc key.\n\t\tapp.$c.body.on( 'keydown', app.escKeyClose );\n\n\t\t// Allow the user to close the modal by clicking outside of the modal.\n\t\tapp.$c.body.on( 'click touchstart', 'div.modal-open', app.closeModalByClick );\n\t};\n\n\t// Open the modal.\n\tapp.openModal = function () {\n\t\t// Figure out which modal we're opening and store the object.\n\t\tvar $modal = $( $( this ).data( 'target' ) );\n\n\t\t// Display the modal.\n\t\t$modal.addClass( 'modal-open' );\n\n\t\t// Add body class.\n\t\tapp.$c.body.addClass( 'modal-open' );\n\t};\n\n\t// Close the modal.\n\tapp.closeModal = function () {\n\t\t// Figure the opened modal we're closing and store the object.\n\t\tvar $modal = $( $( 'div.modal-open .close' ).data( 'target' ) );\n\n\t\t// Find the iframe in the $modal object.\n\t\tvar $iframe = $modal.find( 'iframe' );\n\n\t\t// Get the iframe src URL.\n\t\tvar url = $iframe.attr( 'src' );\n\n\t\t// Remove the source URL, then add it back, so the video can be played again later.\n\t\t$iframe.attr( 'src', '' ).attr( 'src', url );\n\n\t\t// Finally, hide the modal.\n\t\t$modal.removeClass( 'modal-open' );\n\n\t\t// Remove the body class.\n\t\tapp.$c.body.removeClass( 'modal-open' );\n\t};\n\n\t// Close if \"esc\" key is pressed.\n\tapp.escKeyClose = function ( event ) {\n\t\tif ( 27 === event.keyCode ) {\n\t\t\tapp.closeModal();\n\t\t}\n\t};\n\n\t// Close if the user clicks outside of the modal\n\tapp.closeModalByClick = function ( event ) {\n\t\t// If the parent container is NOT the modal dialog container, close the modal\n\t\tif ( !$( event.target ).parents( 'div' ).hasClass( 'modal-dialog' ) ) {\n\t\t\tapp.closeModal();\n\t\t}\n\t};\n\n\t// Engage!\n\t$( app.init );\n} )( window, jQuery, window.wdsModal );\n","/**\n * File search.js\n *\n * Deal with the search form.\n */\nwindow.wdsSearch = {};\n\n( function ( window, $, app ) {\n\t// Constructor.\n\tapp.init = function () {\n\t\tapp.cache();\n\n\t\tif ( app.meetsRequirements() ) {\n\t\t\tapp.bindEvents();\n\t\t}\n\t};\n\n\t// Cache all the things.\n\tapp.cache = function () {\n\t\tapp.$c = {\n\t\t\t'body': $( 'body' )\n\t\t};\n\t};\n\n\t// Do we meet the requirements?\n\tapp.meetsRequirements = function () {\n\t\treturn $( '.search-field' ).length;\n\t};\n\n\t// Combine all events.\n\tapp.bindEvents = function () {\n\t\t// Remove placeholder text from search field on focus.\n\t\tapp.$c.body.on( 'focus', '.search-field', app.removePlaceholderText );\n\n\t\t// Add placeholder text back to search field on blur.\n\t\tapp.$c.body.on( 'blur', '.search-field', app.addPlaceholderText );\n\t};\n\n\t// Remove placeholder text from search field.\n\tapp.removePlaceholderText = function () {\n\t\tvar $search_field = $( this );\n\n\t\t$search_field.data( 'placeholder', $search_field.attr( 'placeholder' ) ).attr( 'placeholder', '' );\n\t};\n\n\t// Replace placeholder text from search field.\n\tapp.addPlaceholderText = function () {\n\t\tvar $search_field = $( this );\n\n\t\t$search_field.attr( 'placeholder', $search_field.data( 'placeholder' ) ).data( 'placeholder', '' );\n\t};\n\n\t// Engage!\n\t$( app.init );\n} )( window, jQuery, window.wdsSearch );\n","/**\n * File skip-link-focus-fix.js.\n *\n * Helps with accessibility for keyboard only users.\n *\n * Learn more: https://git.io/vWdr2\n */\n( function () {\n\tvar isWebkit = navigator.userAgent.toLowerCase().indexOf( 'webkit' ) > -1,\n\t\tisOpera = navigator.userAgent.toLowerCase().indexOf( 'opera' ) > -1,\n\t\tisIe = navigator.userAgent.toLowerCase().indexOf( 'msie' ) > -1;\n\n\tif ( ( isWebkit || isOpera || isIe ) && document.getElementById && window.addEventListener ) {\n\t\twindow.addEventListener( 'hashchange', function () {\n\t\t\tvar id = location.hash.substring( 1 ),\n\t\t\t\telement;\n\n\t\t\tif ( !( /^[A-z0-9_-]+$/ ).test( id ) ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\telement = document.getElementById( id );\n\n\t\t\tif ( element ) {\n\t\t\t\tif ( !( /^(?:a|select|input|button|textarea)$/i ).test( element.tagName ) ) {\n\t\t\t\t\telement.tabIndex = -1;\n\t\t\t\t}\n\n\t\t\t\telement.focus();\n\t\t\t}\n\t\t}, false );\n\t}\n} )();\n","/**\n * File window-ready.js\n *\n * Add a \"ready\" class to <body> when window is ready.\n */\nwindow.wdsWindowReady = {};\n( function ( window, $, app ) {\n\t// Constructor.\n\tapp.init = function () {\n\t\tapp.cache();\n\t\tapp.bindEvents();\n\t};\n\n\t// Cache document elements.\n\tapp.cache = function () {\n\t\tapp.$c = {\n\t\t\t'window': $( window ),\n\t\t\t'body': $( document.body )\n\t\t};\n\t};\n\n\t// Combine all events.\n\tapp.bindEvents = function () {\n\t\tapp.$c.window.load( app.addBodyClass );\n\t};\n\n\t// Add a class to <body>.\n\tapp.addBodyClass = function () {\n\t\tapp.$c.body.addClass( 'ready' );\n\t};\n\n\t// Engage!\n\t$( app.init );\n} )( window, jQuery, window.wdsWindowReady );\n"],"sourceRoot":"/source/"} + $(app.init); +})(window, jQuery, window.wdsWindowReady); +//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["js-enabled.js","modal.js","search.js","skip-link-focus-fix.js","window-ready.js"],"names":["document","body","className","replace","window","wdsModal","$","app","init","cache","meetsRequirements","bindEvents","$c","length","on","openModal","closeModal","escKeyClose","closeModalByClick","$modal","data","addClass","$iframe","find","url","attr","removeClass","event","keyCode","target","parents","hasClass","jQuery","wdsSearch","removePlaceholderText","addPlaceholderText","$search_field","isWebkit","navigator","userAgent","toLowerCase","indexOf","isOpera","isIe","getElementById","addEventListener","id","location","hash","substring","element","test","tagName","tabIndex","focus","wdsWindowReady","load","addBodyClass"],"mappings":"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","file":"project.js","sourcesContent":["/**\n * File js-enabled.js\n *\n * If Javascript is enabled, replace the <body> class \"no-js\".\n */\ndocument.body.className = document.body.className.replace( 'no-js', 'js' );\n","/**\n * File modal.js\n *\n * Deal with multiple modals and their media.\n */\nwindow.wdsModal = {};\n\n( function ( window, $, app ) {\n\t// Constructor.\n\tapp.init = function () {\n\t\tapp.cache();\n\n\t\tif ( app.meetsRequirements() ) {\n\t\t\tapp.bindEvents();\n\t\t}\n\t};\n\n\t// Cache all the things.\n\tapp.cache = function () {\n\t\tapp.$c = {\n\t\t\t'body': $( 'body' )\n\t\t};\n\t};\n\n\t// Do we meet the requirements?\n\tapp.meetsRequirements = function () {\n\t\treturn $( '.modal-trigger' ).length;\n\t};\n\n\t// Combine all events.\n\tapp.bindEvents = function () {\n\t\t// Trigger a modal to open.\n\t\tapp.$c.body.on( 'click touchstart', '.modal-trigger', app.openModal );\n\n\t\t// Trigger the close button to close the modal.\n\t\tapp.$c.body.on( 'click touchstart', '.close', app.closeModal );\n\n\t\t// Allow the user to close the modal by hitting the esc key.\n\t\tapp.$c.body.on( 'keydown', app.escKeyClose );\n\n\t\t// Allow the user to close the modal by clicking outside of the modal.\n\t\tapp.$c.body.on( 'click touchstart', 'div.modal-open', app.closeModalByClick );\n\t};\n\n\t// Open the modal.\n\tapp.openModal = function () {\n\t\t// Figure out which modal we're opening and store the object.\n\t\tvar $modal = $( $( this ).data( 'target' ) );\n\n\t\t// Display the modal.\n\t\t$modal.addClass( 'modal-open' );\n\n\t\t// Add body class.\n\t\tapp.$c.body.addClass( 'modal-open' );\n\t};\n\n\t// Close the modal.\n\tapp.closeModal = function () {\n\t\t// Figure the opened modal we're closing and store the object.\n\t\tvar $modal = $( $( 'div.modal-open .close' ).data( 'target' ) );\n\n\t\t// Find the iframe in the $modal object.\n\t\tvar $iframe = $modal.find( 'iframe' );\n\n\t\t// Get the iframe src URL.\n\t\tvar url = $iframe.attr( 'src' );\n\n\t\t// Remove the source URL, then add it back, so the video can be played again later.\n\t\t$iframe.attr( 'src', '' ).attr( 'src', url );\n\n\t\t// Finally, hide the modal.\n\t\t$modal.removeClass( 'modal-open' );\n\n\t\t// Remove the body class.\n\t\tapp.$c.body.removeClass( 'modal-open' );\n\t};\n\n\t// Close if \"esc\" key is pressed.\n\tapp.escKeyClose = function ( event ) {\n\t\tif ( 27 === event.keyCode ) {\n\t\t\tapp.closeModal();\n\t\t}\n\t};\n\n\t// Close if the user clicks outside of the modal\n\tapp.closeModalByClick = function ( event ) {\n\t\t// If the parent container is NOT the modal dialog container, close the modal\n\t\tif ( !$( event.target ).parents( 'div' ).hasClass( 'modal-dialog' ) ) {\n\t\t\tapp.closeModal();\n\t\t}\n\t};\n\n\t// Engage!\n\t$( app.init );\n} )( window, jQuery, window.wdsModal );\n","/**\n * File search.js\n *\n * Deal with the search form.\n */\nwindow.wdsSearch = {};\n\n( function ( window, $, app ) {\n\t// Constructor.\n\tapp.init = function () {\n\t\tapp.cache();\n\n\t\tif ( app.meetsRequirements() ) {\n\t\t\tapp.bindEvents();\n\t\t}\n\t};\n\n\t// Cache all the things.\n\tapp.cache = function () {\n\t\tapp.$c = {\n\t\t\t'body': $( 'body' )\n\t\t};\n\t};\n\n\t// Do we meet the requirements?\n\tapp.meetsRequirements = function () {\n\t\treturn $( '.search-field' ).length;\n\t};\n\n\t// Combine all events.\n\tapp.bindEvents = function () {\n\t\t// Remove placeholder text from search field on focus.\n\t\tapp.$c.body.on( 'focus', '.search-field', app.removePlaceholderText );\n\n\t\t// Add placeholder text back to search field on blur.\n\t\tapp.$c.body.on( 'blur', '.search-field', app.addPlaceholderText );\n\t};\n\n\t// Remove placeholder text from search field.\n\tapp.removePlaceholderText = function () {\n\t\tvar $search_field = $( this );\n\n\t\t$search_field.data( 'placeholder', $search_field.attr( 'placeholder' ) ).attr( 'placeholder', '' );\n\t};\n\n\t// Replace placeholder text from search field.\n\tapp.addPlaceholderText = function () {\n\t\tvar $search_field = $( this );\n\n\t\t$search_field.attr( 'placeholder', $search_field.data( 'placeholder' ) ).data( 'placeholder', '' );\n\t};\n\n\t// Engage!\n\t$( app.init );\n} )( window, jQuery, window.wdsSearch );\n","/**\n * File skip-link-focus-fix.js.\n *\n * Helps with accessibility for keyboard only users.\n *\n * Learn more: https://git.io/vWdr2\n */\n( function () {\n\tvar isWebkit = navigator.userAgent.toLowerCase().indexOf( 'webkit' ) > -1,\n\t\tisOpera = navigator.userAgent.toLowerCase().indexOf( 'opera' ) > -1,\n\t\tisIe = navigator.userAgent.toLowerCase().indexOf( 'msie' ) > -1;\n\n\tif ( ( isWebkit || isOpera || isIe ) && document.getElementById && window.addEventListener ) {\n\t\twindow.addEventListener( 'hashchange', function () {\n\t\t\tvar id = location.hash.substring( 1 ),\n\t\t\t\telement;\n\n\t\t\tif ( !( /^[A-z0-9_-]+$/ ).test( id ) ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\telement = document.getElementById( id );\n\n\t\t\tif ( element ) {\n\t\t\t\tif ( !( /^(?:a|select|input|button|textarea)$/i ).test( element.tagName ) ) {\n\t\t\t\t\telement.tabIndex = -1;\n\t\t\t\t}\n\n\t\t\t\telement.focus();\n\t\t\t}\n\t\t}, false );\n\t}\n} )();\n","/**\n * File window-ready.js\n *\n * Add a \"ready\" class to <body> when window is ready.\n */\nwindow.wdsWindowReady = {};\n( function ( window, $, app ) {\n\t// Constructor.\n\tapp.init = function () {\n\t\tapp.cache();\n\t\tapp.bindEvents();\n\t};\n\n\t// Cache document elements.\n\tapp.cache = function () {\n\t\tapp.$c = {\n\t\t\t'window': $( window ),\n\t\t\t'body': $( document.body )\n\t\t};\n\t};\n\n\t// Combine all events.\n\tapp.bindEvents = function () {\n\t\tapp.$c.window.load( app.addBodyClass );\n\t};\n\n\t// Add a class to <body>.\n\tapp.addBodyClass = function () {\n\t\tapp.$c.body.addClass( 'ready' );\n\t};\n\n\t// Engage!\n\t$( app.init );\n} )( window, jQuery, window.wdsWindowReady );\n"]} diff --git a/assets/scripts/project.min.js b/assets/scripts/project.min.js index d43d0ac96..40f880c21 100644 --- a/assets/scripts/project.min.js +++ b/assets/scripts/project.min.js @@ -1 +1 @@ -document.body.className=document.body.className.replace("no-js","js"),window.wdsModal={},function(window,$,app){app.init=function(){app.cache(),app.meetsRequirements()&&app.bindEvents()},app.cache=function(){app.$c={body:$("body")}},app.meetsRequirements=function(){return $(".modal-trigger").length},app.bindEvents=function(){app.$c.body.on("click touchstart",".modal-trigger",app.openModal),app.$c.body.on("click touchstart",".close",app.closeModal),app.$c.body.on("keydown",app.escKeyClose),app.$c.body.on("click touchstart","div.modal-open",app.closeModalByClick)},app.openModal=function(){var $modal=$($(this).data("target"));$modal.addClass("modal-open"),app.$c.body.addClass("modal-open")},app.closeModal=function(){var $modal=$($("div.modal-open .close").data("target")),$iframe=$modal.find("iframe"),url=$iframe.attr("src");$iframe.attr("src","").attr("src",url),$modal.removeClass("modal-open"),app.$c.body.removeClass("modal-open")},app.escKeyClose=function(event){27===event.keyCode&&app.closeModal()},app.closeModalByClick=function(event){$(event.target).parents("div").hasClass("modal-dialog")||app.closeModal()},$(app.init)}(window,jQuery,window.wdsModal),window.wdsSearch={},function(window,$,app){app.init=function(){app.cache(),app.meetsRequirements()&&app.bindEvents()},app.cache=function(){app.$c={body:$("body")}},app.meetsRequirements=function(){return $(".search-field").length},app.bindEvents=function(){app.$c.body.on("focus",".search-field",app.removePlaceholderText),app.$c.body.on("blur",".search-field",app.addPlaceholderText)},app.removePlaceholderText=function(){var $search_field=$(this);$search_field.data("placeholder",$search_field.attr("placeholder")).attr("placeholder","")},app.addPlaceholderText=function(){var $search_field=$(this);$search_field.attr("placeholder",$search_field.data("placeholder")).data("placeholder","")},$(app.init)}(window,jQuery,window.wdsSearch),function(){var isWebkit=navigator.userAgent.toLowerCase().indexOf("webkit")>-1,isOpera=navigator.userAgent.toLowerCase().indexOf("opera")>-1,isIe=navigator.userAgent.toLowerCase().indexOf("msie")>-1;(isWebkit||isOpera||isIe)&&document.getElementById&&window.addEventListener&&window.addEventListener("hashchange",function(){var element,id=location.hash.substring(1);/^[A-z0-9_-]+$/.test(id)&&(element=document.getElementById(id),element&&(/^(?:a|select|input|button|textarea)$/i.test(element.tagName)||(element.tabIndex=-1),element.focus()))},!1)}(),window.wdsWindowReady={},function(window,$,app){app.init=function(){app.cache(),app.bindEvents()},app.cache=function(){app.$c={window:$(window),body:$(document.body)}},app.bindEvents=function(){app.$c.window.load(app.addBodyClass)},app.addBodyClass=function(){app.$c.body.addClass("ready")},$(app.init)}(window,jQuery,window.wdsWindowReady); \ No newline at end of file +"use strict";document.body.className=document.body.className.replace("no-js","js"),window.wdsModal={},function(window,$,app){app.init=function(){app.cache(),app.meetsRequirements()&&app.bindEvents()},app.cache=function(){app.$c={body:$("body")}},app.meetsRequirements=function(){return $(".modal-trigger").length},app.bindEvents=function(){app.$c.body.on("click touchstart",".modal-trigger",app.openModal),app.$c.body.on("click touchstart",".close",app.closeModal),app.$c.body.on("keydown",app.escKeyClose),app.$c.body.on("click touchstart","div.modal-open",app.closeModalByClick)},app.openModal=function(){var $modal=$($(this).data("target"));$modal.addClass("modal-open"),app.$c.body.addClass("modal-open")},app.closeModal=function(){var $modal=$($("div.modal-open .close").data("target")),$iframe=$modal.find("iframe"),url=$iframe.attr("src");$iframe.attr("src","").attr("src",url),$modal.removeClass("modal-open"),app.$c.body.removeClass("modal-open")},app.escKeyClose=function(event){27===event.keyCode&&app.closeModal()},app.closeModalByClick=function(event){$(event.target).parents("div").hasClass("modal-dialog")||app.closeModal()},$(app.init)}(window,jQuery,window.wdsModal),window.wdsSearch={},function(window,$,app){app.init=function(){app.cache(),app.meetsRequirements()&&app.bindEvents()},app.cache=function(){app.$c={body:$("body")}},app.meetsRequirements=function(){return $(".search-field").length},app.bindEvents=function(){app.$c.body.on("focus",".search-field",app.removePlaceholderText),app.$c.body.on("blur",".search-field",app.addPlaceholderText)},app.removePlaceholderText=function(){var $search_field=$(this);$search_field.data("placeholder",$search_field.attr("placeholder")).attr("placeholder","")},app.addPlaceholderText=function(){var $search_field=$(this);$search_field.attr("placeholder",$search_field.data("placeholder")).data("placeholder","")},$(app.init)}(window,jQuery,window.wdsSearch),function(){var isWebkit=navigator.userAgent.toLowerCase().indexOf("webkit")>-1,isOpera=navigator.userAgent.toLowerCase().indexOf("opera")>-1,isIe=navigator.userAgent.toLowerCase().indexOf("msie")>-1;(isWebkit||isOpera||isIe)&&document.getElementById&&window.addEventListener&&window.addEventListener("hashchange",function(){var element,id=location.hash.substring(1);/^[A-z0-9_-]+$/.test(id)&&(element=document.getElementById(id),element&&(/^(?:a|select|input|button|textarea)$/i.test(element.tagName)||(element.tabIndex=-1),element.focus()))},!1)}(),window.wdsWindowReady={},function(window,$,app){app.init=function(){app.cache(),app.bindEvents()},app.cache=function(){app.$c={window:$(window),body:$(document.body)}},app.bindEvents=function(){app.$c.window.load(app.addBodyClass)},app.addBodyClass=function(){app.$c.body.addClass("ready")},$(app.init)}(window,jQuery,window.wdsWindowReady); \ No newline at end of file diff --git a/package.json b/package.json index 070d4fb65..162155ba4 100644 --- a/package.json +++ b/package.json @@ -5,6 +5,7 @@ "main": "Gulpfile.js", "dependencies": { "autoprefixer": "^6.3.1", + "babel-preset-es2015": "^6.16.0", "bourbon": "^4.2.6", "bourbon-neat": "^1.7.2", "browser-sync": "^2.11.1", @@ -13,6 +14,7 @@ "eslint-config-wordpress": "^0.1.0", "glob": "^6.0.4", "gulp": "^3.9.1", + "gulp-babel": "^6.1.2", "gulp-cheerio": "^0.6.2", "gulp-concat": "^2.6.0", "gulp-cssnano": "^2.1.0",