mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-01 22:02:11 +03:00
6619f09eca
no issue - add functionality for night mode feature flag using alternate stylesheets - modify lazy loader service to work with alternate stylesheets - update feature service to use user accessibility property & add tests
70 lines
2.0 KiB
JavaScript
70 lines
2.0 KiB
JavaScript
import $ from 'jquery';
|
|
import Ember from 'ember';
|
|
import RSVP from 'rsvp';
|
|
import Service from 'ember-service';
|
|
import injectService from 'ember-service/inject';
|
|
|
|
const {testing} = Ember;
|
|
|
|
export default Service.extend({
|
|
ajax: injectService(),
|
|
ghostPaths: injectService(),
|
|
|
|
// This is needed so we can disable it in unit tests
|
|
testing,
|
|
|
|
scriptPromises: {},
|
|
|
|
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;
|
|
},
|
|
|
|
loadStyle(key, url, alternate = false) {
|
|
if (this.get('testing') || $(`#${key}-styles`).length) {
|
|
return RSVP.resolve();
|
|
}
|
|
|
|
return new RSVP.Promise((resolve, reject) => {
|
|
let link = document.createElement('link');
|
|
link.id = `${key}-styles`;
|
|
link.rel = alternate ? 'alternate stylesheet' : 'stylesheet';
|
|
link.href = `${this.get('ghostPaths.adminRoot')}${url}`;
|
|
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();
|
|
};
|
|
link.onerror = reject;
|
|
|
|
if (alternate) {
|
|
link.title = key;
|
|
}
|
|
|
|
$('head').append($(link));
|
|
});
|
|
}
|
|
});
|