You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
96 lines
2.5 KiB
96 lines
2.5 KiB
'use strict'; |
|
|
|
var gulp = require('gulp'); |
|
var browserSync = require('browser-sync').create(); |
|
var imagemin = require('gulp-imagemin'); |
|
var plumber = require('gulp-plumber'); |
|
var sass = require('gulp-sass'); |
|
var autoprefixer = require('gulp-autoprefixer'); |
|
var sourcemaps = require('gulp-sourcemaps'); |
|
var concat = require('gulp-concat'); |
|
//var cache = require('gulp-cache'); |
|
|
|
|
|
//=================== |
|
// Browsersync Proxy |
|
//=================== |
|
|
|
gulp.task('browser-sync', function() { |
|
browserSync.init({ |
|
proxy: "https://lmmijournal.researchspaces.ca", |
|
serveStatic: ['.'], |
|
files: ['./css/style.css','./js/js.js'], |
|
plugins: ['bs-rewrite-rules'], |
|
rewriteRules: [ |
|
{ |
|
match: '/themes/custom/lmmi_journal/js/', |
|
replace: '/js/' |
|
}, |
|
{ |
|
match: '/themes/custom/lmmi_journal/css/', |
|
replace: '/css/' |
|
} |
|
] |
|
}); |
|
}); |
|
|
|
|
|
//==================== |
|
// Sass Compilation |
|
//=================== |
|
|
|
gulp.task('sass', function () { |
|
return gulp.src('./src/scss/**/*.scss') |
|
.pipe(sass({ |
|
includePaths: ['./node_modules/breakpoint-sass/stylesheets'] |
|
})) |
|
.pipe(sourcemaps.init()) |
|
.pipe(sass().on('error', sass.logError)) |
|
.pipe(sourcemaps.write('.')) |
|
.pipe(gulp.dest('./css')); |
|
}); |
|
|
|
//==================== |
|
// JS Concatination |
|
//=================== |
|
|
|
gulp.task('js', function () { |
|
gulp.src('./src/js/*.js') // path to your files |
|
.pipe(concat('js.js')) // concat and name it "concat.js" |
|
.pipe(gulp.dest('./js/')); |
|
}); |
|
|
|
//==================== |
|
// Image Optimization |
|
//=================== |
|
|
|
gulp.task('images', function(){ |
|
gulp.src('src/img/**/*') |
|
//.pipe(imagemin({ optimizationLevel: 3, progressive: true, interlaced: true })) |
|
.pipe(imagemin([ |
|
imagemin.jpegtran({progressive: true}), |
|
imagemin.optipng({optimizationLevel: 5}), |
|
imagemin.svgo({ |
|
plugins: [ |
|
{removeViewBox: true}, |
|
{cleanupIDs: false} |
|
] |
|
}) |
|
])) |
|
.pipe(gulp.dest('img/')); |
|
}); |
|
|
|
//================== |
|
// Default Gulp Task |
|
//================= |
|
|
|
gulp.task ('default',['browser-sync'], function(){ |
|
//watch sass folder and compile changes |
|
gulp.watch('src/scss/**/*.scss', ['sass']); |
|
//watch js folder and compile changes |
|
gulp.watch('src/js/**/*.js', ['js']); |
|
//watch image folder and optimize |
|
gulp.watch('src/img/**/*', ['images']); |
|
}); |
|
|
|
|
|
|