2015-08-21 13:35:15 +00:00
// Defining base pathes
var basePaths = {
2016-03-20 08:49:32 +00:00
bower : './bower_components/' ,
2016-09-13 10:59:14 +00:00
node : './node_modules/' ,
2016-03-20 09:40:38 +00:00
dev : './src/'
2015-08-21 13:35:15 +00:00
} ;
2016-12-22 08:55:28 +00:00
2016-04-15 21:06:10 +00:00
// browser-sync watched files
// automatically reloads the page when files changed
var browserSyncWatchFiles = [
'./css/*.min.css' ,
'./js/*.min.js' ,
2016-10-27 15:05:22 +00:00
'./**/*.php'
2016-04-15 21:06:10 +00:00
] ;
2016-12-22 08:55:28 +00:00
2016-04-15 21:06:10 +00:00
// browser-sync options
// see: https://www.browsersync.io/docs/options/
var browserSyncOptions = {
2016-11-04 01:27:07 +00:00
proxy : "localhost/wordpress/" ,
2016-04-15 21:06:10 +00:00
notify : false
} ;
2016-12-22 08:55:28 +00:00
2015-08-21 13:35:15 +00:00
// Defining requirements
2015-08-12 06:13:10 +00:00
var gulp = require ( 'gulp' ) ;
2015-08-12 07:06:27 +00:00
var plumber = require ( 'gulp-plumber' ) ;
2015-08-12 06:13:10 +00:00
var sass = require ( 'gulp-sass' ) ;
2015-08-12 07:06:27 +00:00
var watch = require ( 'gulp-watch' ) ;
2016-02-15 12:30:16 +00:00
var cssnano = require ( 'gulp-cssnano' ) ;
2015-08-12 07:06:27 +00:00
var rename = require ( 'gulp-rename' ) ;
var concat = require ( 'gulp-concat' ) ;
var uglify = require ( 'gulp-uglify' ) ;
var merge2 = require ( 'merge2' ) ;
2017-03-21 13:53:49 +00:00
var imagemin = require ( 'gulp-imagemin' ) ;
2015-08-12 07:06:27 +00:00
var ignore = require ( 'gulp-ignore' ) ;
var rimraf = require ( 'gulp-rimraf' ) ;
2016-08-02 12:24:45 +00:00
var clone = require ( 'gulp-clone' ) ;
var merge = require ( 'gulp-merge' ) ;
2016-08-01 15:30:37 +00:00
var sourcemaps = require ( 'gulp-sourcemaps' ) ;
2016-04-15 21:06:10 +00:00
var browserSync = require ( 'browser-sync' ) . create ( ) ;
2017-01-17 14:49:36 +00:00
var del = require ( 'del' ) ;
2017-04-21 12:08:39 +00:00
var cleanCSS = require ( 'gulp-clean-css' ) ;
2015-08-12 07:06:27 +00:00
2016-08-02 12:24:45 +00:00
2016-11-04 01:27:07 +00:00
// Run:
2016-08-02 12:24:45 +00:00
// gulp sass + cssnano + rename
2017-03-08 12:13:16 +00:00
// Prepare the min.css for production (with 2 pipes to be sure that "theme.css" == "theme.min.css")
2016-08-02 12:24:45 +00:00
gulp . task ( 'scss-for-prod' , function ( ) {
var source = gulp . src ( './sass/*.scss' )
2017-04-21 16:55:44 +00:00
. pipe ( plumber ( {
errorHandler : function ( err ) {
console . log ( err ) ;
this . emit ( 'end' ) ;
}
} ) )
2016-08-02 12:24:45 +00:00
. pipe ( sourcemaps . init ( { loadMaps : true } ) )
. pipe ( sass ( ) ) ;
var pipe1 = source . pipe ( clone ( ) )
. pipe ( sourcemaps . write ( undefined , { sourceRoot : null } ) )
2017-01-18 07:45:50 +00:00
. pipe ( gulp . dest ( './css' ) )
. pipe ( rename ( 'custom-editor-style.css' ) )
2017-03-08 12:13:16 +00:00
2016-08-02 12:24:45 +00:00
var pipe2 = source . pipe ( clone ( ) )
2017-04-21 12:08:39 +00:00
. pipe ( minify - css ( ) )
2016-11-04 01:27:07 +00:00
. pipe ( rename ( { suffix : '.min' } ) )
2016-08-02 12:24:45 +00:00
. pipe ( gulp . dest ( './css' ) ) ;
return merge ( pipe1 , pipe2 ) ;
} ) ;
2016-11-04 01:27:07 +00:00
// Run:
2016-08-02 12:24:45 +00:00
// gulp sourcemaps + sass + reload(browserSync)
2016-12-29 14:01:26 +00:00
// Prepare the child-theme.css for the development environment
2016-08-02 12:24:45 +00:00
gulp . task ( 'scss-for-dev' , function ( ) {
gulp . src ( './sass/*.scss' )
2017-04-21 16:55:44 +00:00
. pipe ( plumber ( {
errorHandler : function ( err ) {
console . log ( err ) ;
this . emit ( 'end' ) ;
}
} ) )
2016-08-02 12:24:45 +00:00
. pipe ( sourcemaps . init ( { loadMaps : true } ) )
. pipe ( sass ( ) )
. pipe ( sourcemaps . write ( undefined , { sourceRoot : null } ) )
. pipe ( gulp . dest ( './css' ) )
} ) ;
gulp . task ( 'watch-scss' , [ 'browser-sync' ] , function ( ) {
gulp . watch ( './sass/**/*.scss' , [ 'scss-for-dev' ] ) ;
} ) ;
2016-11-04 01:27:07 +00:00
// Run:
2016-01-18 13:57:52 +00:00
// gulp sass
// Compiles SCSS files in CSS
2015-08-12 06:13:10 +00:00
gulp . task ( 'sass' , function ( ) {
2017-01-18 07:45:50 +00:00
var stream = gulp . src ( './sass/*.scss' )
2017-04-21 16:55:44 +00:00
. pipe ( plumber ( {
errorHandler : function ( err ) {
console . log ( err ) ;
this . emit ( 'end' ) ;
}
} ) )
2015-08-12 06:13:10 +00:00
. pipe ( sass ( ) )
2017-01-18 07:45:50 +00:00
. pipe ( gulp . dest ( './css' ) )
. pipe ( rename ( 'custom-editor-style.css' ) )
return stream ;
2015-08-12 06:13:10 +00:00
} ) ;
2016-12-22 08:55:28 +00:00
2016-11-04 01:27:07 +00:00
// Run:
2016-01-18 13:57:52 +00:00
// gulp watch
// Starts watcher. Watcher runs gulp sass task on changes
2015-08-12 07:06:27 +00:00
gulp . task ( 'watch' , function ( ) {
gulp . watch ( './sass/**/*.scss' , [ 'sass' ] ) ;
2017-04-21 12:08:39 +00:00
gulp . watch ( './css/theme.css' , [ 'minify-css' ] ) ;
2017-03-21 13:53:49 +00:00
gulp . watch ( [ basePaths . dev + 'js/**/*.js' , 'js/**/*.js' , '!js/theme.js' , '!js/theme.min.js' ] , [ 'scripts' ] ) ;
//Inside the watch task.
2017-03-21 14:02:29 +00:00
gulp . watch ( './img/**' , [ 'imagemin' ] )
2017-03-21 13:53:49 +00:00
} ) ;
// Run:
// gulp imagemin
// Running image optimizing task
gulp . task ( 'imagemin' , function ( ) {
2017-03-21 14:02:29 +00:00
gulp . src ( 'img/**' )
2017-03-21 13:53:49 +00:00
. pipe ( imagemin ( ) )
. pipe ( gulp . dest ( 'img' ) )
2015-08-12 07:06:27 +00:00
} ) ;
2016-12-22 08:55:28 +00:00
2016-11-04 01:27:07 +00:00
// Run:
2016-12-29 14:01:26 +00:00
// gulp cssnano
2016-01-18 13:57:52 +00:00
// Minifies CSS files
2017-02-09 14:32:51 +00:00
gulp . task ( 'cssnano' , function ( ) {
2016-12-19 12:33:38 +00:00
return gulp . src ( './css/theme.css' )
2016-08-01 15:30:37 +00:00
. pipe ( sourcemaps . init ( { loadMaps : true } ) )
2017-04-21 16:55:44 +00:00
. pipe ( plumber ( {
errorHandler : function ( err ) {
console . log ( err ) ;
this . emit ( 'end' ) ;
}
} ) )
2015-08-12 07:06:27 +00:00
. pipe ( rename ( { suffix : '.min' } ) )
2016-02-15 12:30:16 +00:00
. pipe ( cssnano ( { discardComments : { removeAll : true } } ) )
2016-08-02 06:44:36 +00:00
. pipe ( sourcemaps . write ( './' ) )
2016-04-15 21:06:10 +00:00
. pipe ( gulp . dest ( './css/' ) )
2016-11-04 01:27:07 +00:00
} ) ;
2016-02-15 12:30:16 +00:00
2017-04-21 12:08:39 +00:00
gulp . task ( 'minify-css' , function ( ) {
return gulp . src ( './css/theme.css' )
. pipe ( cleanCSS ( { compatibility : 'ie8' } ) )
2017-04-21 16:55:44 +00:00
. pipe ( plumber ( {
errorHandler : function ( err ) {
console . log ( err ) ;
this . emit ( 'end' ) ;
}
} ) )
2017-04-21 12:08:39 +00:00
. pipe ( rename ( { suffix : '.min' } ) )
. pipe ( gulp . dest ( './css/' ) ) ;
} ) ;
2015-08-12 07:06:27 +00:00
gulp . task ( 'cleancss' , function ( ) {
2016-11-04 01:27:07 +00:00
return gulp . src ( './css/*.min.css' , { read : false } ) // much faster
2015-08-12 07:06:27 +00:00
. pipe ( ignore ( 'theme.css' ) )
. pipe ( rimraf ( ) ) ;
} ) ;
2016-12-22 08:55:28 +00:00
2016-11-04 01:27:07 +00:00
// Run:
2016-04-15 21:06:10 +00:00
// gulp browser-sync
// Starts browser-sync task for starting the server.
gulp . task ( 'browser-sync' , function ( ) {
browserSync . init ( browserSyncWatchFiles , browserSyncOptions ) ;
} ) ;
2016-12-22 08:55:28 +00:00
2016-11-04 01:27:07 +00:00
// Run:
2016-04-15 21:06:10 +00:00
// gulp watch-bs
// Starts watcher with browser-sync. Browser-sync reloads page automatically on your browser
2017-04-21 12:08:39 +00:00
gulp . task ( 'watch-bs' , [ 'browser-sync' , 'watch' , 'minify-css' , 'scripts' ] , function ( ) { } ) ;
2016-04-15 21:06:10 +00:00
2016-12-22 08:55:28 +00:00
2016-12-28 10:33:00 +00:00
// Run:
// gulp scripts.
2016-03-20 09:33:18 +00:00
// Uglifies and concat all JS files into one
gulp . task ( 'scripts' , function ( ) {
2016-12-28 10:33:00 +00:00
var scripts = [
basePaths . dev + 'js/tether.js' , // Must be loaded before BS4
2016-04-29 09:23:13 +00:00
2016-12-28 10:33:00 +00:00
// Start - All BS4 stuff
basePaths . dev + 'js/bootstrap4/bootstrap.js' ,
2016-05-06 06:23:13 +00:00
2016-12-28 10:33:00 +00:00
// End - All BS4 stuff
2016-04-29 09:23:13 +00:00
2016-12-28 10:33:00 +00:00
basePaths . dev + 'js/skip-link-focus-fix.js'
] ;
gulp . src ( scripts )
2016-03-20 08:49:32 +00:00
. pipe ( concat ( 'theme.min.js' ) )
. pipe ( uglify ( ) )
2016-04-15 21:06:10 +00:00
. pipe ( gulp . dest ( './js/' ) ) ;
2016-06-23 09:21:57 +00:00
2016-12-28 10:33:00 +00:00
gulp . src ( scripts )
2016-12-29 08:41:30 +00:00
. pipe ( concat ( 'theme.js' ) )
2016-06-23 09:21:57 +00:00
. pipe ( gulp . dest ( './js/' ) ) ;
2016-03-20 08:49:32 +00:00
} ) ;
2017-01-18 06:51:37 +00:00
// Deleting any file inside the /src folder
2017-01-17 14:49:36 +00:00
gulp . task ( 'clean-source' , function ( ) {
return del ( [ 'src/**/*' , ] ) ;
} ) ;
2016-12-22 08:55:28 +00:00
2016-11-04 01:27:07 +00:00
// Run:
// gulp copy-assets.
2015-09-15 14:59:29 +00:00
// Copy all needed dependency assets files from bower_component assets to themes /js, /scss and /fonts folder. Run this task after bower install or bower update
2016-01-18 13:57:52 +00:00
2016-04-26 12:09:19 +00:00
////////////////// All Bootstrap SASS Assets /////////////////////////
2017-01-17 14:49:36 +00:00
gulp . task ( 'copy-assets' , [ 'clean-source' ] , function ( ) {
2016-04-06 07:54:31 +00:00
////////////////// All Bootstrap 4 Assets /////////////////////////
2016-11-04 01:27:07 +00:00
// Copy all Bootstrap JS files
2017-01-18 07:45:50 +00:00
var stream = gulp . src ( basePaths . node + 'bootstrap/dist/js/**/*.js' )
2016-04-06 07:54:31 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/js/bootstrap4' ) ) ;
2017-01-18 07:45:50 +00:00
2016-04-06 07:54:31 +00:00
// Copy all Bootstrap SCSS files
2016-09-13 13:28:53 +00:00
gulp . src ( basePaths . node + 'bootstrap/scss/**/*.scss' )
2016-04-06 07:54:31 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/sass/bootstrap4' ) ) ;
2017-01-18 07:45:50 +00:00
2016-04-06 07:54:31 +00:00
////////////////// End Bootstrap 4 Assets /////////////////////////
2016-01-18 13:25:55 +00:00
2016-01-18 13:57:52 +00:00
// Copy all Font Awesome Fonts
2016-09-13 10:59:14 +00:00
gulp . src ( basePaths . node + 'font-awesome/fonts/**/*.{ttf,woff,woff2,eof,svg}' )
2015-08-12 07:06:27 +00:00
. pipe ( gulp . dest ( './fonts' ) ) ;
2016-01-18 13:25:55 +00:00
2016-01-18 13:57:52 +00:00
// Copy all Font Awesome SCSS files
2016-09-13 10:59:14 +00:00
gulp . src ( basePaths . node + 'font-awesome/scss/*.scss' )
2016-03-20 08:49:32 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/sass/fontawesome' ) ) ;
2016-01-18 13:25:55 +00:00
2016-01-18 13:57:52 +00:00
// Copy jQuery
2016-09-13 13:28:53 +00:00
gulp . src ( basePaths . node + 'jquery/dist/*.js' )
2016-03-20 08:49:32 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/js' ) ) ;
2016-01-18 13:36:23 +00:00
2016-11-24 10:58:11 +00:00
// _s SCSS files
gulp . src ( basePaths . node + 'undescores-for-npm/sass/**/*.scss' )
. pipe ( gulp . dest ( basePaths . dev + '/sass/underscores' ) ) ;
2016-01-18 13:57:52 +00:00
// _s JS files
2016-11-24 10:58:11 +00:00
gulp . src ( basePaths . node + 'undescores-for-npm/js/*.js' )
2016-03-20 08:49:32 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/js' ) ) ;
2016-04-29 09:23:13 +00:00
// Copy Tether JS files
2016-09-13 13:28:53 +00:00
gulp . src ( basePaths . node + 'tether/dist/js/*.js' )
2016-04-29 09:23:13 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/js' ) ) ;
// Copy Tether CSS files
2016-09-13 13:28:53 +00:00
gulp . src ( basePaths . node + 'tether/dist/css/*.css' )
2016-04-29 09:23:13 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/css' ) ) ;
2017-01-18 07:45:50 +00:00
return stream ;
2016-08-01 15:30:37 +00:00
} ) ;
2016-09-02 13:21:26 +00:00
2016-12-22 08:55:28 +00:00
2016-11-04 01:27:07 +00:00
// Run
// gulp dist
2017-04-21 12:33:06 +00:00
// Copies the files to the /dist folder for distributon as simple theme
2017-01-27 17:31:54 +00:00
gulp . task ( 'dist' , [ 'clean-dist' ] , function ( ) {
2017-02-09 14:55:27 +00:00
gulp . src ( [ '**/*' , '!bower_components' , '!bower_components/**' , '!node_modules' , '!node_modules/**' , '!src' , '!src/**' , '!dist' , '!dist/**' , '!dist-product' , '!dist-product/**' , '!sass' , '!sass/**' , '!readme.txt' , '!readme.md' , '!package.json' , '!gulpfile.js' , '!CHANGELOG.md' , '!.travis.yml' , '!jshintignore' , '!codesniffer.ruleset.xml' , '*' ] )
2016-11-04 01:27:07 +00:00
. pipe ( gulp . dest ( 'dist/' ) )
} ) ;
2017-01-18 07:45:50 +00:00
2017-01-27 17:31:54 +00:00
// Deleting any file inside the /src folder
gulp . task ( 'clean-dist' , function ( ) {
return del ( [ 'dist/**/*' , ] ) ;
} ) ;
// Run
// gulp dist-product
2017-04-21 12:33:06 +00:00
// Copies the files to the /dist-prod folder for distributon as theme with all assets
2017-01-27 17:31:54 +00:00
gulp . task ( 'dist-product' , [ 'clean-dist-product' ] , function ( ) {
2017-04-21 12:33:06 +00:00
gulp . src ( [ '**/*' , '!bower_components' , '!bower_components/**' , '!node_modules' , '!node_modules/**' , '!dist' , '!dist/**' , '!dist-product' , '!dist-product/**' , '*' ] )
2017-01-27 17:31:54 +00:00
. pipe ( gulp . dest ( 'dist-product/' ) )
} ) ;
// Deleting any file inside the /src folder
gulp . task ( 'clean-dist-product' , function ( ) {
return del ( [ 'dist-product/**/*' , ] ) ;
} ) ;