I tried it by modifying the module ionic-gulp-browserify-typescript
var gulp = require('gulp'),
browserify = require('browserify'),
watchify = require('watchify'),
tsify = require('tsify'),
pretty = require('prettysize'),
merge = require('lodash.merge'),
source = require('vinyl-source-stream'),
buffer = require('vinyl-buffer'),
sourcemaps = require('gulp-sourcemaps'),
uglify = require('gulp-uglify'),
stream = require('stream'),
ng2TemplateParser = require('gulp-inline-ng2-template/parser')
through = require('through2');
var defaultOptions = {
watch: false,
src: ['./app/app.ts', './typings/index.d.ts'],
outputPath: 'www/build/js/',
outputFile: 'app.bundle.js',
minify: false,
browserifyOptions: {
cache: {},
packageCache: {},
debug: true
},
watchifyOptions: {},
tsifyOptions: {},
uglifyOptions: {},
onError: function(err){
console.error(err.toString());
this.emit('end');
},
onLog: function(log){
console.log((log = log.split(' '), log[0] = pretty(log[0]), log.join(' ')));
},
base: '/app',
useRelativePaths: true,
supportNonExistentFiles: false
}
module.exports = function(options) {
options = merge(defaultOptions, options);
var b = browserify(options.src, options.browserifyOptions)
.plugin(tsify, options.tsifyOptions)
.transform(inlineTransform);
if (options.watch) {
b = watchify(b, options.watchifyOptions);
b.on('update', bundle);
b.on('log', options.onLog);
}
return bundle();
function inlineTransform(file) {
return through(function (buf, enc, next) {
ng2TemplateParser({ contents: buf, path: file }, options)((err, result) => {
this.push(result);
process.nextTick(next);
});
});
}
function bundle() {
var debug = options.browserifyOptions.debug;
return b.bundle()
.on('error', options.onError)
.pipe(source(options.outputFile))
.pipe(buffer())
.pipe(debug ? sourcemaps.init({ loadMaps: true }) : noop())
.pipe(options.minify ? uglify(options.uglifyOptions) : noop())
.pipe(debug ? sourcemaps.write('./',{includeContent:true, sourceRoot:'../../../'}) : noop())
.pipe(gulp.dest(options.outputPath));
}
function noop(){
return new stream.PassThrough({ objectMode: true });
}
}
And removed the “copyhtml” from gulpfile, it work like a charm.
I’m considering not using ionic-gulp-browserify-typescript
and create a clone, or maybe create a pr for it if it’s not alreay done
EDIT: Somebody has subbmited a PR Browserify relative template paths by michaelknoch · Pull Request #35 · ionic-team/ionic-gulp-tasks · GitHub