Ghost-Admin/app/services/ui.js

96 lines
2.0 KiB
JavaScript

import Service from '@ember/service';
import injectService from 'ember-service/inject';
import {computed} from '@ember/object';
import {not, or, reads} from '@ember/object/computed';
export default Service.extend({
dropdown: injectService(),
mediaQueries: injectService(),
autoNav: false,
isFullScreen: false,
showMobileMenu: false,
showSettingsMenu: false,
hasSideNav: not('isSideNavHidden'),
isMobile: reads('mediaQueries.isMobile'),
isSideNavHidden: or('autoNav', 'isFullScreen', 'isMobile'),
autoNavOpen: computed('autoNav', {
get() {
return false;
},
set(key, value) {
if (this.get('autoNav')) {
return value;
}
return false;
}
}),
closeMenus() {
this.get('dropdown').closeDropdowns();
this.setProperties({
showSettingsMenu: false,
showMobileMenu: false
});
},
openAutoNav() {
this.set('autoNavOpen', true);
},
closeAutoNav() {
if (this.get('autoNavOpen')) {
this.get('dropdown').closeDropdowns();
}
this.set('autoNavOpen', false);
},
closeMobileMenu() {
this.set('showMobileMenu', false);
},
openMobileMenu() {
this.set('showMobileMenu', true);
},
openSettingsMenu() {
this.set('showSettingsMenu', true);
},
toggleAutoNav() {
this.toggleProperty('autoNav');
},
actions: {
closeMenus() {
this.closeMenus();
},
openAutoNav() {
this.openAutoNav();
},
closeAutoNav() {
this.closeAutoNav();
},
closeMobileMenu() {
this.closeMobileMenu();
},
openMobileMenu() {
this.openMobileMenu();
},
openSettingsMenu() {
this.openSettingsMenu();
},
toggleAutoNav() {
this.toggleAutoNav();
}
}
});