import { Directive, HostListener, Input, Optional } from '@angular/core'; import { Button } from '../button/button'; import { MenuController } from '../app/menu-controller'; import { Navbar } from '../toolbar/navbar'; import { ViewController } from '../../navigation/view-controller'; /** * @name MenuToggle * @description * The `menuToggle` directive can be placed on any button to toggle a menu open or closed. * If it is added to the [NavBar](../../toolbar/Navbar) of a page, the button will only appear * when the page it's in is currently a root page. See the [Menu Navigation Bar Behavior](../Menu#navigation-bar-behavior) * docs for more information. * * * @usage * * A simple `menuToggle` button can be added using the following markup: * * ```html * * ``` * * To toggle a specific menu by its id or side, give the `menuToggle` * directive a value. * * ```html * * ``` * * If placing the `menuToggle` in a navbar or toolbar, it should be * placed as a child of the `` or ``, and not in * the `` element: * * ```html * * * * * * * * * Title * * * * * * * * ``` * * Similar to ``, the `menuToggle` can be positioned using * `start`, `end`, `left`, or `right`: * * ```html * * * * Title * * * * * * ``` * * See the [Toolbar API docs](../../toolbar/Toolbar) for more information * on the different positions. * * @demo /docs/demos/src/menu/ * @see {@link /docs/components#menus Menu Component Docs} * @see {@link ../../menu/Menu Menu API Docs} */ export class MenuToggle { constructor(_menu, _viewCtrl, _button, _navbar) { this._menu = _menu; this._viewCtrl = _viewCtrl; this._button = _button; this._isButton = !!_button; this._inNavbar = !!_navbar; } ngAfterContentInit() { // Add the bar-button-menutoggle / button-menutoggle class if (this._isButton) { this._button._setClass('menutoggle', true); } } /** * @hidden */ toggle() { const menu = this._menu.get(this.menuToggle); menu && menu.toggle(); } /** * @hidden */ get isHidden() { const menu = this._menu.get(this.menuToggle); if (this._inNavbar && this._viewCtrl) { if (!menu || !menu._canOpen()) { return true; } if (this._viewCtrl.isFirst()) { // this is the first view, so it should always show return false; } if (menu) { // this is not the root view, so see if this menu // is configured to still be enabled if it's not the root view return !menu.persistent; } } return false; } } MenuToggle.decorators = [ { type: Directive, args: [{ selector: '[menuToggle]', host: { '[hidden]': 'isHidden' } },] }, ]; /** @nocollapse */ MenuToggle.ctorParameters = () => [ { type: MenuController, }, { type: ViewController, decorators: [{ type: Optional },] }, { type: Button, decorators: [{ type: Optional },] }, { type: Navbar, decorators: [{ type: Optional },] }, ]; MenuToggle.propDecorators = { 'menuToggle': [{ type: Input },], 'toggle': [{ type: HostListener, args: ['click',] },], }; //# sourceMappingURL=menu-toggle.js.map