var gulp = require('gulp');
-var plumber = require('gulp-plumber');
var sassLint = require('gulp-sass-lint');
var eslint = require('gulp-eslint');
var CONFIG = require('../config.js');
// Lints Sass and JavaScript files for formatting issues
gulp.task('lint', gulp.series('lint:sass', 'lint:javascript'));
-gulp.task('lint:sass', function() {
+// Lints Sass and Javascript without throwing error
+gulp.task('lint:graceful', gulp.series('lint:graceful:sass', 'lint:graceful:javascript'));
+
+function lintSass() {
return gulp.src(CONFIG.SASS_LINT_FILES)
- .pipe(plumber())
.pipe(sassLint({
config: './.sass-lint.yml'
}))
- .pipe(sassLint.format())
- .pipe(sassLint.failOnError())
-});
+ .pipe(sassLint.format());
+}
-gulp.task('lint:javascript', function () {
+function lintJavascript() {
return gulp.src(CONFIG.JS_FILES)
.pipe(eslint({
useEslintrc: true,
configFile: '.eslintrc'
}))
- .pipe(eslint.format())
- .pipe(eslint.failAfterError());
+ .pipe(eslint.format());
+}
+
+gulp.task('lint:sass', function () {
+ return lintSass()
+ .pipe(sassLint.failOnError());
});
+gulp.task('lint:javascript', function () {
+ return lintJavascript()
+ .pipe(eslint.failAfterError());
+});
+
+gulp.task('lint:graceful:sass', lintSass);
+gulp.task('lint:graceful:javascript', lintJavascript);
.pipe(sass().on('error', sass.logError))
.pipe(postcss([autoprefixer()])) // uses ".browserslistrc"
.pipe(sourcemaps.write('.'))
- .pipe(gulp.dest('_build/assets/css'))
- .on('finish', function() {
- gulp.src(CONFIG.SASS_LINT_FILES)
- .pipe(sassLint({
- config: './.sass-lint.yml'
- }))
- .pipe(sassLint.format());
- });
+ .pipe(gulp.dest('_build/assets/css'));
}));
// Compiles docs Sass (includes Foundation code also)
}
// Builds the documentation and framework files
-gulp.task('build', gulp.series('clean', 'copy', 'sass', 'javascript', 'docs:all'));
+gulp.task('build', gulp.series('clean', 'copy', 'sass', 'javascript', 'lint:graceful', 'docs:all'));
// Starts a BrowerSync instance
gulp.task('serve', gulp.series('build', function(done){
gulp.task('watch', function() {
gulp.watch('docs/**/*', gulp.series('docs', browserReloadSync));
gulp.watch(['docs/layout/*.html', 'docs/partials/*{html,hbs}', 'docs/assets/partials/*{html,hbs}', 'node_modules/foundation-docs/templates/*{html,hbs}'], gulp.series('docs:all', browserReloadSync));
- gulp.watch('scss/**/*', gulp.series('sass', browserReloadSync));
+ gulp.watch('scss/**/*', gulp.series('sass:foundation', browserReloadSync));
gulp.watch(['docs/assets/scss/**/*', 'node_modules/foundation-docs/scss/**/*'], gulp.series('sass:docs', browserReloadSync));
gulp.watch('js/**/*', gulp.series('javascript:foundation', browserReloadSync));
gulp.watch(['docs/assets/js/**/*', 'node_modules/foundation-docs/js/**/*'], gulp.series('javascript:docs', browserReloadSync));