Ghost/core/client/app/components/gh-menu-toggle.js

43 lines
1021 B
JavaScript
Raw Normal View History

import Ember from 'ember';
2016-01-19 16:03:27 +03:00
const {
Component,
computed,
inject: {service}
} = Ember;
/*
This cute little component has two jobs.
On desktop, it toggles autoNav behaviour. It tracks
that state via the maximise property, and uses the
state to render the appropriate icon.
On mobile, it renders a closing icon, and clicking it
closes the mobile menu
*/
export default Component.extend({
classNames: ['gh-menu-toggle'],
2016-01-19 16:03:27 +03:00
mediaQueries: service(),
isMobile: computed.reads('mediaQueries.isMobile'),
maximise: false,
iconClass: computed('maximise', 'isMobile', function () {
if (this.get('maximise') && !this.get('isMobile')) {
return 'icon-maximise';
} else {
return 'icon-minimise';
}
}),
click() {
if (this.get('isMobile')) {
this.sendAction('mobileAction');
} else {
this.toggleProperty('maximise');
this.sendAction('desktopAction');
}
}
});