/** * * Web Starter Kit * Copyright 2014 Google Inc. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License * */ 'use strict'; var gulp = require('gulp'); var $ = require('gulp-load-plugins')(); var rimraf = require('rimraf'); var browserSync = require('browser-sync'); var pagespeed = require('psi'); var reload = browserSync.reload; // public URL for your website var PUBLIC_URL = 'https://example.com'; // enable use of relative paths even though gulp is run in sub-directories process.chdir(__dirname); gulp.task('styles', function () { return gulp.src('app/styles/sass/styles.scss') .pipe($.rubySass({style: 'expanded', precision: 10})) .pipe($.autoprefixer('last 1 version')) .pipe(gulp.dest('dist/styles')) .pipe(reload({stream: true})) .pipe($.size({title: 'styles'})); }); gulp.task('jshint', function () { return gulp.src('app/scripts/**/*.js') .pipe($.jshint()) .pipe($.jshint.reporter('jshint-stylish')) .pipe($.jshint.reporter('fail')) .pipe(reload({stream: true, once: true})); }); gulp.task('html', ['styles'], function () { return gulp.src('app/**/*.html') .pipe($.useref.assets()) .pipe($.if('*.js', $.uglify())) .pipe($.if('*.css', $.csso())) .pipe($.useref.restore()) .pipe($.useref()) .pipe(gulp.dest('dist')) .pipe($.size({title: 'html'})); }); gulp.task('images', function () { return gulp.src('app/images/**/*') .pipe($.cache($.imagemin({ progressive: true, interlaced: true }))) .pipe(gulp.dest('dist/images')) .pipe(reload({stream: true, once: true})) .pipe($.size({title: 'images'})); }); gulp.task('pagespeed', pagespeed.bind(null, { // By default, we use the free (no API key) tier // You can use a Google Developer API key if you // have one. See http://goo.gl/RkN0vE for info // key: 'YOUR_API_KEY' url: PUBLIC_URL, strategy: 'mobile' })); gulp.task('clean', rimraf.bind(null, 'dist')); gulp.task('serve', ['styles'], function () { browserSync.init(null, { server: { baseDir: ['app'] } }); }); gulp.task('watch', ['serve'], function () { gulp.watch(['app/*.html'], reload); gulp.watch(['app/styles/**/*.{css,scss}'], ['styles']); gulp.watch(['app/scripts/**/*.js'], ['jshint']); gulp.watch(['app/images/**/*'], ['images']); }); gulp.task('build', ['jshint', 'html', 'images']); gulp.task('default', ['clean'], function (cb) { gulp.start('build', cb); });