2016-08-22 18:02:02 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var gulp = require('gulp');
|
|
|
|
var plugins = require('gulp-load-plugins')();
|
|
|
|
var del = require('del');
|
|
|
|
|
2017-01-26 19:28:43 +00:00
|
|
|
var config = {
|
|
|
|
fontsDir: 'source/assets/fonts',
|
|
|
|
js: {
|
|
|
|
sourceDir: 'assets/js',
|
|
|
|
pattern: '/**/*.js',
|
|
|
|
outputDir: 'source/assets/js',
|
|
|
|
},
|
|
|
|
production: !!plugins.util.env.production,
|
|
|
|
sass: {
|
|
|
|
sourceDir: 'assets/sass',
|
|
|
|
pattern: '/**/*.sass',
|
|
|
|
outputDir: 'source/assets/css',
|
|
|
|
}
|
|
|
|
};
|
2016-12-13 23:57:59 +00:00
|
|
|
|
2017-05-21 21:04:57 +00:00
|
|
|
var app = {};
|
|
|
|
|
|
|
|
app.sass = function (sourceFiles, filename) {
|
|
|
|
return gulp.src(sourceFiles)
|
2016-08-22 18:02:02 +00:00
|
|
|
.pipe(plugins.plumber())
|
|
|
|
.pipe(plugins.if(!config.production, plugins.sourcemaps.init()))
|
|
|
|
.pipe(plugins.sassGlob())
|
2017-01-07 22:37:12 +00:00
|
|
|
.pipe(plugins.sass())
|
2016-12-04 08:29:50 +00:00
|
|
|
.pipe(plugins.autoprefixer({
|
2017-01-26 19:28:43 +00:00
|
|
|
browsers: ["last 2 versions", "> 5%"],
|
2016-12-04 08:29:50 +00:00
|
|
|
cascade: false
|
|
|
|
}))
|
2017-05-21 21:04:57 +00:00
|
|
|
.pipe(plugins.concat(filename))
|
2017-03-18 22:51:05 +00:00
|
|
|
.pipe(plugins.if(config.production, plugins.purifycss([
|
2017-03-10 18:07:00 +00:00
|
|
|
'source/**/*.html',
|
|
|
|
'source/**/*.md',
|
|
|
|
'source/**/*.twig',
|
2017-03-10 18:06:39 +00:00
|
|
|
])))
|
2017-01-07 22:37:12 +00:00
|
|
|
.pipe(plugins.if(config.production, plugins.cleanCss()))
|
2016-08-22 18:02:02 +00:00
|
|
|
.pipe(plugins.if(!config.production, plugins.sourcemaps.write('.')))
|
|
|
|
.pipe(plugins.if(!config.production, plugins.refresh()))
|
2017-01-26 19:28:43 +00:00
|
|
|
.pipe(gulp.dest(config.sass.outputDir));
|
2017-05-21 21:04:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
gulp.task('styles', function () {
|
|
|
|
app.sass([
|
2017-06-15 17:22:11 +00:00
|
|
|
'node_modules/font-awesome/css/font-awesome.css',
|
2017-07-14 22:10:27 +00:00
|
|
|
'node_modules/prism/themes/prism-twilight.css',
|
2017-05-21 21:04:57 +00:00
|
|
|
config.sass.sourceDir + '/main.sass'
|
|
|
|
], 'main.css');
|
2017-01-26 19:20:21 +00:00
|
|
|
});
|
2016-08-22 18:02:02 +00:00
|
|
|
|
2017-04-30 10:53:30 +00:00
|
|
|
gulp.task('scripts', function () {
|
2017-01-26 19:20:21 +00:00
|
|
|
return gulp.src([
|
2017-06-18 17:13:14 +00:00
|
|
|
'node_modules/jquery/dist/jquery.js',
|
2017-06-15 17:22:11 +00:00
|
|
|
'node_modules/bootstrap-sass/assets/javascripts/bootstrap.js',
|
|
|
|
'node_modules/prism/prism.js',
|
|
|
|
'node_modules/prism/components/prism-{apacheconf,bash,css,diff,ini,json,nginx,php,sass,scss,sql,less,twig,xml,yaml}.js',
|
2017-04-30 10:53:30 +00:00
|
|
|
config.js.sourceDir + config.js.pattern
|
|
|
|
])
|
2016-08-22 18:02:02 +00:00
|
|
|
.pipe(plugins.plumber())
|
|
|
|
.pipe(plugins.if(!config.production, plugins.sourcemaps.init()))
|
2017-01-26 19:20:21 +00:00
|
|
|
.pipe(plugins.concat('site.js'))
|
2016-08-22 18:02:02 +00:00
|
|
|
.pipe(plugins.if(config.production, plugins.uglify()))
|
|
|
|
.pipe(plugins.if(!config.production, plugins.sourcemaps.write('.')))
|
2017-01-26 19:28:43 +00:00
|
|
|
.pipe(gulp.dest(config.js.outputDir));
|
2017-01-26 19:20:21 +00:00
|
|
|
});
|
2016-08-22 18:02:02 +00:00
|
|
|
|
2017-04-30 10:53:30 +00:00
|
|
|
gulp.task('fonts', function () {
|
2017-06-15 17:22:11 +00:00
|
|
|
return gulp.src('node_modules/font-awesome/fonts/*')
|
2017-01-26 19:28:43 +00:00
|
|
|
.pipe(gulp.dest(config.fontsDir));
|
2017-01-26 19:20:21 +00:00
|
|
|
});
|
2016-08-22 18:02:02 +00:00
|
|
|
|
2017-04-30 10:53:30 +00:00
|
|
|
gulp.task('clean', function () {
|
2017-01-26 19:28:43 +00:00
|
|
|
del.sync(config.fontsDir);
|
|
|
|
del.sync(config.js.outputDir);
|
|
|
|
del.sync(config.sass.outputDir);
|
2017-03-16 08:15:03 +00:00
|
|
|
del.sync('output_*/assets/{css,fonts,js}');
|
2016-08-22 18:02:02 +00:00
|
|
|
});
|
|
|
|
|
2017-01-26 19:06:42 +00:00
|
|
|
gulp.task('default', ['clean', 'fonts', 'styles', 'scripts']);
|
2016-08-22 18:02:02 +00:00
|
|
|
|
2017-04-30 10:53:30 +00:00
|
|
|
gulp.task('watch', ['default'], function () {
|
2016-12-02 19:57:15 +00:00
|
|
|
plugins.refresh.listen();
|
2016-08-22 18:02:02 +00:00
|
|
|
|
2017-01-26 19:28:43 +00:00
|
|
|
gulp.watch(config.sass.sourceDir + config.sass.pattern, ['styles']);
|
|
|
|
gulp.watch(config.js.sourceDir + config.js.pattern, ['scripts']);
|
2016-12-02 19:57:15 +00:00
|
|
|
});
|