2016-07-05 19:30:14 +03:00
|
|
|
import $ from 'jquery';
|
|
|
|
import Ember from 'ember';
|
|
|
|
import RSVP from 'rsvp';
|
2017-10-30 12:38:01 +03:00
|
|
|
import Service, {inject as service} from '@ember/service';
|
2016-07-05 19:30:14 +03:00
|
|
|
|
|
|
|
export default Service.extend({
|
2017-10-30 12:38:01 +03:00
|
|
|
ajax: service(),
|
|
|
|
ghostPaths: service(),
|
2016-07-05 19:30:14 +03:00
|
|
|
|
|
|
|
// This is needed so we can disable it in unit tests
|
2018-01-02 13:19:59 +03:00
|
|
|
testing: undefined,
|
2016-07-05 19:30:14 +03:00
|
|
|
|
2017-11-24 21:53:19 +03:00
|
|
|
scriptPromises: null,
|
|
|
|
|
|
|
|
init() {
|
|
|
|
this._super(...arguments);
|
|
|
|
this.scriptPromises = {};
|
2018-01-02 13:19:59 +03:00
|
|
|
|
|
|
|
if (this.testing === undefined) {
|
|
|
|
this.testing = Ember.testing; // eslint-disable-line
|
|
|
|
}
|
2017-11-24 21:53:19 +03:00
|
|
|
},
|
2016-07-05 19:30:14 +03:00
|
|
|
|
|
|
|
loadScript(key, url) {
|
|
|
|
if (this.get('testing')) {
|
|
|
|
return RSVP.resolve();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.get(`scriptPromises.${key}`)) {
|
|
|
|
// Script is already loaded/in the process of being loaded,
|
|
|
|
// so return that promise
|
|
|
|
return this.get(`scriptPromises.${key}`);
|
|
|
|
}
|
|
|
|
|
|
|
|
let ajax = this.get('ajax');
|
|
|
|
let adminRoot = this.get('ghostPaths.adminRoot');
|
|
|
|
|
|
|
|
let scriptPromise = ajax.request(`${adminRoot}${url}`, {
|
|
|
|
dataType: 'script',
|
|
|
|
cache: true
|
|
|
|
});
|
|
|
|
|
|
|
|
this.set(`scriptPromises.${key}`, scriptPromise);
|
|
|
|
|
|
|
|
return scriptPromise;
|
|
|
|
},
|
|
|
|
|
2017-03-03 19:14:33 +03:00
|
|
|
loadStyle(key, url, alternate = false) {
|
2017-03-03 19:13:22 +03:00
|
|
|
if (this.get('testing') || $(`#${key}-styles`).length) {
|
2016-07-05 19:30:14 +03:00
|
|
|
return RSVP.resolve();
|
|
|
|
}
|
|
|
|
|
2017-03-03 19:13:22 +03:00
|
|
|
return new RSVP.Promise((resolve, reject) => {
|
|
|
|
let link = document.createElement('link');
|
|
|
|
link.id = `${key}-styles`;
|
2017-03-03 19:14:33 +03:00
|
|
|
link.rel = alternate ? 'alternate stylesheet' : 'stylesheet';
|
2017-03-03 19:13:22 +03:00
|
|
|
link.href = `${this.get('ghostPaths.adminRoot')}${url}`;
|
2017-03-03 19:14:33 +03:00
|
|
|
link.onload = () => {
|
|
|
|
if (alternate) {
|
|
|
|
// If stylesheet is alternate and we disable the stylesheet before injecting into the DOM,
|
|
|
|
// the onload handler never gets called. Thus, we should disable the link after it has finished loading
|
|
|
|
link.disabled = true;
|
|
|
|
}
|
|
|
|
resolve();
|
|
|
|
};
|
2017-03-03 19:13:22 +03:00
|
|
|
link.onerror = reject;
|
2017-03-03 19:14:33 +03:00
|
|
|
|
|
|
|
if (alternate) {
|
|
|
|
link.title = key;
|
|
|
|
}
|
|
|
|
|
2017-03-03 19:13:22 +03:00
|
|
|
$('head').append($(link));
|
|
|
|
});
|
2016-07-05 19:30:14 +03:00
|
|
|
}
|
|
|
|
});
|