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:
parent
9a64c60dda
commit
14b31ae5a1
1 changed files with 46 additions and 51 deletions
|
@ -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);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue