0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-02-24 23:48:13 -05:00

Migrated ui service to native class syntax

no issue

- switched to class syntax, tracked properties, getters, and dropped actions object for top-level action functions
This commit is contained in:
Kevin Ansfield 2021-07-01 10:11:08 +01:00
parent 9a64c60dda
commit 14b31ae5a1

View file

@ -1,7 +1,8 @@
import Service, {inject as service} from '@ember/service'; import Service, {inject as service} from '@ember/service';
import {action} from '@ember/object';
import {get} from '@ember/object'; import {get} from '@ember/object';
import {isEmpty} from '@ember/utils'; import {isEmpty} from '@ember/utils';
import {not, or, reads} from '@ember/object/computed'; import {tracked} from '@glimmer/tracking';
function collectMetadataClasses(transition, prop) { function collectMetadataClasses(transition, prop) {
let oldClasses = []; let oldClasses = [];
@ -33,23 +34,31 @@ function updateBodyClasses(transition) {
}); });
} }
export default Service.extend({ export default class UiService extends Service {
config: service(), @service config;
dropdown: service(), @service dropdown;
mediaQueries: service(), @service mediaQueries;
router: service(), @service router;
isFullScreen: false, @tracked isFullScreen = false;
showMobileMenu: false, @tracked mainClass = '';
showSettingsMenu: false, @tracked showMobileMenu = false;
mainClass: '', @tracked showSettingsMenu = false;
hasSideNav: not('isSideNavHidden'), get isMobile() {
isMobile: reads('mediaQueries.isMobile'), return this.mediaQueries.isMobile;
isSideNavHidden: or('isFullScreen', 'isMobile'), }
init() { get isSideNavHidden() {
this._super(...arguments); return this.isFullScreen || this.isMobile;
}
get hasSideNav() {
return !this.isSideNavHidden;
}
constructor() {
super(...arguments);
this.router.on('routeDidChange', (transition) => { this.router.on('routeDidChange', (transition) => {
updateBodyClasses(transition); updateBodyClasses(transition);
@ -57,30 +66,38 @@ export default Service.extend({
this.updateDocumentTitle(); this.updateDocumentTitle();
let {newClasses: mainClasses} = collectMetadataClasses(transition, 'mainClasses'); let {newClasses: mainClasses} = collectMetadataClasses(transition, 'mainClasses');
this.set('mainClass', mainClasses.join(' ')); this.mainClass = mainClasses.join(' ');
}); });
}, }
@action
closeMenus() { closeMenus() {
this.dropdown.closeDropdowns(); this.dropdown.closeDropdowns();
this.setProperties({ this.showSettingsMenu = false;
showSettingsMenu: false, this.showMobileMenu = false;
showMobileMenu: false }
});
},
@action
closeMobileMenu() { closeMobileMenu() {
this.set('showMobileMenu', false); this.showMobileMenu = false;
}, }
@action
openMobileMenu() { openMobileMenu() {
this.set('showMobileMenu', true); this.showMobileMenu = true;
}, }
@action
openSettingsMenu() { openSettingsMenu() {
this.set('showSettingsMenu', true); this.showSettingsMenu = true;
}, }
@action
setMainClass(mainClass) {
this.mainClass = mainClass;
}
@action
updateDocumentTitle() { updateDocumentTitle() {
let {currentRoute} = this.router; let {currentRoute} = this.router;
let tokens = []; let tokens = [];
@ -106,27 +123,5 @@ export default Service.extend({
} else { } else {
window.document.title = blogTitle; window.document.title = blogTitle;
} }
},
actions: {
closeMenus() {
this.closeMenus();
},
closeMobileMenu() {
this.closeMobileMenu();
},
openMobileMenu() {
this.openMobileMenu();
},
openSettingsMenu() {
this.openSettingsMenu();
},
setMainClass(cls) {
this.set('mainClass', cls);
} }
} }
});