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-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' ,
'./*.php'
] ;
// browser-sync options
// see: https://www.browsersync.io/docs/options/
var browserSyncOptions = {
proxy : "localhost/theme_test/" ,
notify : false
} ;
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' ) ;
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 ( ) ;
2016-08-02 07:24:07 +00:00
var reload = browserSync . reload ;
2015-08-12 07:06:27 +00:00
2016-08-02 12:24:45 +00:00
// Run:
// gulp sass + cssnano + rename
// Prepare the min.css for production (with 2 pipes to be sure that "child-theme.css" == "child-theme.min.css")
gulp . task ( 'scss-for-prod' , function ( ) {
var source = gulp . src ( './sass/*.scss' )
. pipe ( plumber ( ) )
. pipe ( sourcemaps . init ( { loadMaps : true } ) )
. pipe ( sass ( ) ) ;
var pipe1 = source . pipe ( clone ( ) )
. pipe ( sourcemaps . write ( undefined , { sourceRoot : null } ) )
. pipe ( gulp . dest ( './css' ) ) ;
var pipe2 = source . pipe ( clone ( ) )
. pipe ( cssnano ( ) )
. pipe ( rename ( { suffix : '.min' } ) )
. pipe ( gulp . dest ( './css' ) ) ;
return merge ( pipe1 , pipe2 ) ;
} ) ;
// Run:
// gulp sourcemaps + sass + reload(browserSync)
// Prepare the child-theme.css for the developpment environment
gulp . task ( 'scss-for-dev' , function ( ) {
gulp . src ( './sass/*.scss' )
. pipe ( plumber ( ) )
. pipe ( sourcemaps . init ( { loadMaps : true } ) )
. pipe ( sass ( ) )
. pipe ( sourcemaps . write ( undefined , { sourceRoot : null } ) )
. pipe ( gulp . dest ( './css' ) )
. pipe ( reload ( { stream : true } ) ) ;
} ) ;
gulp . task ( 'watch-scss' , [ 'browser-sync' ] , function ( ) {
gulp . watch ( './sass/**/*.scss' , [ 'scss-for-dev' ] ) ;
} ) ;
2016-01-18 13:57:52 +00:00
// Run:
// gulp sass
// Compiles SCSS files in CSS
2015-08-12 06:13:10 +00:00
gulp . task ( 'sass' , function ( ) {
gulp . src ( './sass/*.scss' )
2015-08-12 07:06:27 +00:00
. pipe ( plumber ( ) )
2015-08-12 06:13:10 +00:00
. pipe ( sass ( ) )
. pipe ( gulp . dest ( './css' ) ) ;
} ) ;
2016-01-18 13:57:52 +00:00
// Run:
// 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' ] ) ;
2016-02-15 12:30:16 +00:00
gulp . watch ( './css/theme.css' , [ 'cssnano' ] ) ;
2015-08-12 07:06:27 +00:00
} ) ;
2016-01-18 13:57:52 +00:00
// Run:
2016-02-15 12:30:16 +00:00
// gulp nanocss
2016-01-18 13:57:52 +00:00
// Minifies CSS files
2016-02-15 12:30:16 +00:00
gulp . task ( 'cssnano' , [ 'cleancss' ] , function ( ) {
2015-08-12 07:10:10 +00:00
return gulp . src ( './css/*.css' )
2016-08-01 15:30:37 +00:00
. pipe ( sourcemaps . init ( { loadMaps : true } ) )
2015-08-12 07:06:27 +00:00
. pipe ( plumber ( ) )
. 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-08-02 07:24:07 +00:00
. pipe ( reload ( { stream : true } ) ) ;
2015-08-12 07:06:27 +00:00
} ) ;
2016-02-15 12:30:16 +00:00
2015-08-12 07:06:27 +00:00
gulp . task ( 'cleancss' , function ( ) {
return gulp . src ( './css/*.min.css' , { read : false } ) // much faster
. pipe ( ignore ( 'theme.css' ) )
. pipe ( rimraf ( ) ) ;
} ) ;
2016-04-15 21:06:10 +00:00
// Run:
// gulp browser-sync
// Starts browser-sync task for starting the server.
gulp . task ( 'browser-sync' , function ( ) {
browserSync . init ( browserSyncWatchFiles , browserSyncOptions ) ;
} ) ;
// Run:
// gulp watch-bs
// Starts watcher with browser-sync. Browser-sync reloads page automatically on your browser
gulp . task ( 'watch-bs' , [ 'browser-sync' , 'watch' , 'cssnano' ] , function ( ) { } ) ;
2016-03-20 08:49:32 +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 ( ) {
gulp . src ( [
2016-04-29 09:23:13 +00:00
basePaths . dev + 'js/owl.carousel.min.js' , // Must be loaded before BS4
2016-05-06 06:23:13 +00:00
basePaths . dev + 'js/tether.js' , // Must be loaded before BS4
2016-04-29 09:23:13 +00:00
// Start - All BS4 stuff
basePaths . dev + 'js/bootstrap4/bootstrap.js' ,
2016-05-06 06:23:13 +00:00
2016-04-29 09:23:13 +00:00
// End - All BS4 stuff
2016-03-20 09:33:18 +00:00
basePaths . dev + 'js/skip-link-focus-fix.js'
] )
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
gulp . src ( [
basePaths . dev + 'js/owl.carousel.min.js' , // Must be loaded before BS4
basePaths . dev + 'js/tether.js' , // Must be loaded before BS4
// Start - All BS4 stuff
basePaths . dev + 'js/bootstrap4/bootstrap.js' ,
// End - All BS4 stuff
basePaths . dev + 'js/skip-link-focus-fix.js'
] )
. pipe ( concat ( 'theme.js' ) )
. pipe ( gulp . dest ( './js/' ) ) ;
2016-03-20 08:49:32 +00:00
} ) ;
2016-01-18 13:57:52 +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 /////////////////////////
2015-08-12 07:06:27 +00:00
gulp . task ( 'copy-assets' , function ( ) {
2016-04-06 07:54:31 +00:00
////////////////// All Bootstrap 4 Assets /////////////////////////
// Copy all Bootstrap JS files
2016-09-13 13:28:53 +00:00
gulp . src ( basePaths . node + 'bootstrap/dist/js/**/*.js' )
2016-04-06 07:54:31 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/js/bootstrap4' ) ) ;
// 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' ) ) ;
////////////////// 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-02-22 13:01:26 +00:00
// owl JS files
2016-09-13 13:28:53 +00:00
gulp . src ( basePaths . node + 'owl.carousel/dist/*.js' )
2016-03-20 08:49:32 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/js' ) ) ;
2016-02-22 13:01:26 +00:00
// Copy all Owl2 SCSS files
2016-09-13 13:28:53 +00:00
gulp . src ( basePaths . node + 'owl.carousel/src/scss/*.scss' )
2016-03-20 09:33:18 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/sass/owl-carousel2' ) ) ;
// Copy all Owl2 CSS files
2016-09-13 13:28:53 +00:00
gulp . src ( basePaths . node + 'owl.carousel/dist/assets/*.css' )
2016-03-20 09:33:18 +00:00
. pipe ( gulp . dest ( basePaths . dev + '/css' ) ) ;
2016-02-22 13:01:26 +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-01-18 13:57:52 +00:00
// _s JS files
2016-09-13 13:28:53 +00:00
gulp . src ( basePaths . node + 'underscores-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' ) ) ;
2016-08-01 15:30:37 +00:00
} ) ;
2016-09-02 13:21:26 +00:00
2016-09-13 14:17:15 +00:00
// Run
// gulp dist
// Copies the files to the /dist folder for distributon
2016-09-02 13:21:26 +00:00
gulp . task ( 'dist' , function ( ) {
gulp . src ( [ '!sass' , '!bower_components' , '!node_modules' , '!src' , '!dist' , '!bower.json' , '!gulpfile.js' , '!package.json' , '*' ] )
. pipe ( gulp . dest ( 'dist/' ) )
} ) ;