ember-cli-inject-live-reload
Version:
Plugin for ember-cli that injects live-reload script into HTML content.
69 lines (58 loc) • 2.91 kB
JavaScript
const buildLiveReloadPath = require('clean-base-url');
const VersionChecker = require('ember-cli-version-checker');
module.exports = {
name: 'live-reload-middleware',
contentFor: function(type) {
let liveReloadPort = process.env.EMBER_CLI_INJECT_LIVE_RELOAD_PORT;
let baseURL = process.env.EMBER_CLI_INJECT_LIVE_RELOAD_BASEURL;
if (liveReloadPort && type === 'head') {
return '<script data-embroider-ignore src="' + baseURL + 'ember-cli-live-reload.js" type="text/javascript"></script>';
}
},
dynamicScript: function(options) {
let liveReloadOptions = options.liveReloadOptions;
if (liveReloadOptions && liveReloadOptions.snipver === undefined) {
liveReloadOptions.snipver = 1;
}
let liveReloadPath = buildLiveReloadPath(options.liveReloadPrefix) || '/';
let path = '';
if (options.isLatestEmber && options.liveReloadPrefix) {
path = `&path=${options.liveReloadPrefix}/livereload`;
}
return `(function() {${liveReloadOptions ? "\n window.LiveReloadOptions = " + JSON.stringify(liveReloadOptions) + ";" : ''}
var srcUrl = ${options.liveReloadJsUrl ? "'" + options.liveReloadJsUrl + "'" : null};
var host = location.hostname || 'localhost';
var useCustomPort = ${options.liveReloadPort !== options.port} || location.port !== ${options.liveReloadPort};
var defaultPort = location.port || (location.protocol === 'https:' ? 443 : 80);
var port = useCustomPort ? ${options.liveReloadPort} : defaultPort;
var path = '${path}';
var prefixURL = useCustomPort ? (location.protocol || 'http:') + '//' + host + ':' + ${options.liveReloadPort} : '';
var src = srcUrl || prefixURL + '${liveReloadPath + 'livereload.js?port='}' + port + '&host=' + host + path;
var script = document.createElement('script');
script.type = 'text/javascript';
script.src = src;
document.getElementsByTagName('head')[0].appendChild(script);
}());`;
},
serverMiddleware: function(config) {
let options = config.options;
let app = config.app;
let self = this;
// maintaining `baseURL` for backwards compatibility. See: http://emberjs.com/blog/2016/04/28/baseURL.html
let baseURL = options.liveReloadBaseUrl || options.rootURL || options.baseURL;
if (this.parent) {
let checker = new VersionChecker(this.parent);
let depedency = checker.for('ember-cli');
options.isLatestEmber = depedency.gt('3.5.0');
}
if (options.liveReload !== true) { return; }
process.env.EMBER_CLI_INJECT_LIVE_RELOAD_PORT = options.liveReloadPort;
process.env.EMBER_CLI_INJECT_LIVE_RELOAD_BASEURL = baseURL;
let baseURLWithoutHost = baseURL.replace(/^https?:\/\/[^/]+/, '');
app.use(baseURLWithoutHost + 'ember-cli-live-reload.js', function(request, response) {
response.contentType('text/javascript');
response.send(self.dynamicScript(options));
});
}
};
;