Skip to content

Instantly share code, notes, and snippets.

@iflamed
Created September 20, 2015 14:57
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save iflamed/cc8bd0b571a115626fcd to your computer and use it in GitHub Desktop.
Save iflamed/cc8bd0b571a115626fcd to your computer and use it in GitHub Desktop.
Laravel gulp webpack watch the vuejs vue file
// this.registerWatcher('webpack', [config.assetsDir + '/**/*.js',config.assetsDir + '/**/*.vue']);
var gulp = require('gulp'),
webpack = require('gulp-webpack'),
gulpIf = require('gulp-if'),
uglify = require('gulp-uglify'),
gulpIgnore = require('gulp-ignore'),
_ = require('underscore'),
elixir = require('laravel-elixir'),
utilities = require('laravel-elixir/ingredients/commands/Utilities'),
notification = require('laravel-elixir/ingredients/commands/Notification');
elixir.extend('webpack', function (src, options) {
var config = this;
options = _.extend({
debug: ! config.production,
srcDir: config.assetsDir + 'js',
outputDir: config.jsOutput,
}, options);
src = "./" + utilities.buildGulpSrc(src, options.srcDir);
gulp.task('webpack', function () {
var onError = function(e) {
new notification().error(e, 'Webpack Compilation Failed!');
this.emit('end');
};
return gulp.src(src)
.pipe(webpack(options)).on('error', onError)
.pipe(gulpIgnore.include('*.js'))
.pipe(gulpIf(! options.debug, uglify()))
.pipe(gulp.dest(options.outputDir))
.pipe(new notification().message('Webpack Compiled!'));
});
this.registerWatcher('webpack', [config.assetsDir + '/**/*.js',config.assetsDir + '/**/*.vue']);
return this.queueTask('webpack');
});
@iflamed
Copy link
Author

iflamed commented Sep 20, 2015

add vue file when register watcher

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment