2018-01-28 20:40:17 -06:00
|
|
|
/**
|
|
|
|
* Gulpfile for File Icon Vectors
|
|
|
|
*
|
|
|
|
* @author Daniel M. Hendricks
|
|
|
|
* @license MIT
|
2018-07-21 18:46:49 -05:00
|
|
|
* {@link https://github.com/dmhendricks/file-icon-vectors GitHub repository}
|
2018-01-28 20:40:17 -06:00
|
|
|
*/
|
|
|
|
|
|
|
|
var pkg = require( './package.json' );
|
|
|
|
var gulp = require( 'gulp' );
|
|
|
|
var rename = require( 'gulp-rename' );
|
|
|
|
var minifycss = require( 'gulp-uglifycss' );
|
2018-07-28 11:36:56 -05:00
|
|
|
var imagemin = require( 'gulp-imagemin' );
|
2018-01-28 20:40:17 -06:00
|
|
|
var sass = require( 'gulp-sass' );
|
|
|
|
var autoprefixer = require( 'gulp-autoprefixer' );
|
2018-07-28 11:36:56 -05:00
|
|
|
var cache = require( 'gulp-cache' );
|
2018-01-28 20:40:17 -06:00
|
|
|
var lineec = require( 'gulp-line-ending-corrector' );
|
|
|
|
var filter = require( 'gulp-filter' );
|
|
|
|
var notify = require( 'gulp-notify' );
|
|
|
|
|
|
|
|
const AUTOPREFIXER_BROWSERS = [ 'last 2 version', '> 1%', 'ie >= 9', 'ie_mob >= 10', 'ff >= 30', 'chrome >= 34', 'safari >= 7', 'opera >= 23', 'ios >= 7', 'android >= 4', 'bb >= 10' ];
|
|
|
|
|
2018-07-28 11:36:56 -05:00
|
|
|
gulp.task( 'styles', function() {
|
|
|
|
return gulp
|
|
|
|
.src( [ './src/scss/*.scss', '!./src/scss/_*.scss' ] )
|
|
|
|
.pipe(
|
|
|
|
sass({
|
|
|
|
errLogToConsole: true,
|
|
|
|
outputStyle: 'expanded',
|
|
|
|
precision: 10
|
|
|
|
})
|
|
|
|
)
|
|
|
|
.on( 'error', sass.logError )
|
|
|
|
.pipe( autoprefixer( AUTOPREFIXER_BROWSERS ) )
|
|
|
|
.pipe( lineec() )
|
|
|
|
.pipe( gulp.dest( './dist' ) )
|
|
|
|
.pipe( filter( '**/*.css' ) )
|
|
|
|
.pipe( rename( { suffix: '.min' } ) )
|
|
|
|
.pipe( minifycss( { maxLineLen: 10 } ) )
|
|
|
|
.pipe( lineec() )
|
|
|
|
.pipe( gulp.dest( './dist' ) )
|
|
|
|
.pipe( notify({ message: 'TASK: "styles" completed', onLast: true }) );
|
2018-01-28 20:40:17 -06:00
|
|
|
});
|
|
|
|
|
2018-07-28 11:36:56 -05:00
|
|
|
gulp.task( 'svgmin', function() {
|
|
|
|
return gulp
|
|
|
|
.src( './dist/icons/**/*.svg' )
|
|
|
|
.pipe(
|
|
|
|
cache(
|
|
|
|
imagemin([
|
|
|
|
imagemin.svgo({
|
|
|
|
plugins: [ { removeViewBox: true }, { cleanupIDs: true } ]
|
|
|
|
})
|
|
|
|
])
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.pipe( gulp.dest( './dist/icons' ) )
|
|
|
|
.pipe( notify({ message: 'TASK: "svgmin" completed.', onLast: true }) );
|
2018-01-28 20:40:17 -06:00
|
|
|
});
|
2018-07-28 11:36:56 -05:00
|
|
|
|
|
|
|
gulp.task(
|
|
|
|
'default',
|
|
|
|
gulp.parallel(
|
|
|
|
'styles',
|
|
|
|
function watchFiles() {
|
|
|
|
gulp.watch( './assets/css/**/*.scss', gulp.parallel( 'styles' ) );
|
|
|
|
}
|
|
|
|
)
|
|
|
|
);
|