UNPKG

ionic-angular

Version:

A powerful framework for building mobile and progressive web apps with JavaScript and Angular 2

329 lines 9.39 kB
import { removeArrayItem } from '../../util/util'; /** * \@name MenuController * \@description * The MenuController is a provider which makes it easy to control a [Menu](../Menu). * Its methods can be used to display the menu, enable the menu, toggle the menu, and more. * The controller will grab a reference to the menu by the `side`, `id`, or, if neither * of these are passed to it, it will grab the first menu it finds. * * * \@usage * * Add a basic menu component to start with. See the [Menu](../Menu) API docs * for more information on adding menu components. * * ```html * <ion-menu [content]="mycontent"> * <ion-content> * <ion-list> * ... * </ion-list> * </ion-content> * </ion-menu> * * <ion-nav #mycontent [root]="rootPage"></ion-nav> * ``` * * To call the controller methods, inject the `MenuController` provider * into the page. Then, create some methods for opening, closing, and * toggling the menu. * * ```ts * import { Component } from '\@angular/core'; * import { MenuController } from 'ionic-angular'; * * \@Component({...}) * export class MyPage { * * constructor(public menuCtrl: MenuController) { * * } * * openMenu() { * this.menuCtrl.open(); * } * * closeMenu() { * this.menuCtrl.close(); * } * * toggleMenu() { * this.menuCtrl.toggle(); * } * * } * ``` * * Since only one menu exists, the `MenuController` will grab the * correct menu and call the correct method for each. * * * ### Multiple Menus on Different Sides * * For applications with both a left and right menu, the desired menu can be * grabbed by passing the `side` of the menu. If nothing is passed, it will * default to the `"left"` menu. * * ```html * <ion-menu side="left" [content]="mycontent">...</ion-menu> * <ion-menu side="right" [content]="mycontent">...</ion-menu> * <ion-nav #mycontent [root]="rootPage"></ion-nav> * ``` * * ```ts * toggleLeftMenu() { * this.menuCtrl.toggle(); * } * * toggleRightMenu() { * this.menuCtrl.toggle('right'); * } * ``` * * * ### Multiple Menus on the Same Side * * An application can have multiple menus on the same side. In order to determine * the menu to control, an `id` should be passed. In the example below, the menu * with the `authenticated` id will be enabled, and the menu with the `unauthenticated` * id will be disabled. * * ```html * <ion-menu id="authenticated" side="left" [content]="mycontent">...</ion-menu> * <ion-menu id="unauthenticated" side="left" [content]="mycontent">...</ion-menu> * <ion-nav #mycontent [root]="rootPage"></ion-nav> * ``` * * ```ts * enableAuthenticatedMenu() { * this.menuCtrl.enable(true, 'authenticated'); * this.menuCtrl.enable(false, 'unauthenticated'); * } * ``` * * Note: if an app only has one menu, there is no reason to pass an `id`. * * * \@demo /docs/v2/demos/src/menu/ * * @see {\@link /docs/v2/components#menus Menu Component Docs} * @see {\@link ../Menu Menu API Docs} * */ export class MenuController { constructor() { this._menus = []; } /** * Programatically open the Menu. * @param {?=} menuId * @return {?} */ open(menuId) { const /** @type {?} */ menu = this.get(menuId); if (menu && !this.isAnimating()) { let /** @type {?} */ openedMenu = this.getOpen(); if (openedMenu && menu !== openedMenu) { openedMenu.setOpen(false, false); } return menu.open(); } return Promise.resolve(false); } /** * Programatically close the Menu. If no `menuId` is given as the first * argument then it'll close any menu which is open. If a `menuId` * is given then it'll close that exact menu. * @param {?=} menuId * @return {?} */ close(menuId) { let /** @type {?} */ menu; if (menuId) { // find the menu by its id menu = this.get(menuId); } else { // find the menu that is open menu = this.getOpen(); } if (menu) { // close the menu return menu.close(); } return Promise.resolve(false); } /** * Toggle the menu. If it's closed, it will open, and if opened, it * will close. * @param {?=} menuId * @return {?} */ toggle(menuId) { const /** @type {?} */ menu = this.get(menuId); if (menu && !this.isAnimating()) { var /** @type {?} */ openedMenu = this.getOpen(); if (openedMenu && menu !== openedMenu) { openedMenu.setOpen(false, false); } return menu.toggle(); } return Promise.resolve(false); } /** * Used to enable or disable a menu. For example, there could be multiple * left menus, but only one of them should be able to be opened at the same * time. If there are multiple menus on the same side, then enabling one menu * will also automatically disable all the others that are on the same side. * @param {?} shouldEnable * @param {?=} menuId * @return {?} */ enable(shouldEnable, menuId) { const /** @type {?} */ menu = this.get(menuId); if (menu) { return menu.enable(shouldEnable); } } /** * Used to enable or disable the ability to swipe open the menu. * @param {?} shouldEnable * @param {?=} menuId * @return {?} */ swipeEnable(shouldEnable, menuId) { const /** @type {?} */ menu = this.get(menuId); if (menu) { return menu.swipeEnable(shouldEnable); } } /** * If the menuId is not specified, it returns true if ANY menu is currenly open. * @param {?=} menuId * @return {?} */ isOpen(menuId) { if (menuId) { var /** @type {?} */ menu = this.get(menuId); return menu && menu.isOpen || false; } else { return !!this.getOpen(); } } /** * @param {?=} menuId * @return {?} */ isEnabled(menuId) { const /** @type {?} */ menu = this.get(menuId); return menu && menu.enabled || false; } /** * Used to get a menu instance. If a `menuId` is not provided then it'll * return the first menu found. If a `menuId` is `left` or `right`, then * it'll return the enabled menu on that side. Otherwise, if a `menuId` is * provided, then it'll try to find the menu using the menu's `id` * property. If a menu is not found then it'll return `null`. * @param {?=} menuId * @return {?} */ get(menuId) { var /** @type {?} */ menu; if (menuId === 'left' || menuId === 'right') { // there could be more than one menu on the same side // so first try to get the enabled one menu = this._menus.find(m => m.side === menuId && m.enabled); if (menu) return menu; // didn't find a menu side that is enabled // so try to get the first menu side found return this._menus.find(m => m.side === menuId) || null; } else if (menuId) { // the menuId was not left or right // so try to get the menu by its "id" return this._menus.find(m => m.id === menuId) || null; } // return the first enabled menu menu = this._menus.find(m => m.enabled); if (menu) { return menu; } // get the first menu in the array, if one exists return (this._menus.length ? this._menus[0] : null); } /** * @return {?} */ getOpen() { return this._menus.find(m => m.isOpen); } /** * @return {?} */ getMenus() { return this._menus; } /** * @return {?} */ isAnimating() { return this._menus.some(menu => menu.isAnimating()); } /** * @param {?} menu * @return {?} */ _register(menu) { (void 0) /* assert */; this._menus.push(menu); } /** * @param {?} menu * @return {?} */ _unregister(menu) { (void 0) /* assert */; removeArrayItem(this._menus, menu); } /** * @param {?} menu * @return {?} */ _setActiveMenu(menu) { (void 0) /* assert */; (void 0) /* assert */; // if this menu should be enabled // then find all the other menus on this same side // and automatically disable other same side menus const /** @type {?} */ side = menu.side; this._menus .filter(m => m.side === side && m !== menu) .map(m => m.enable(false)); } /** * @param {?} name * @param {?} cls * @return {?} */ static registerType(name, cls) { menuTypes[name] = cls; } /** * @param {?} type * @param {?} menuCmp * @param {?} plt * @return {?} */ static create(type, menuCmp, plt) { return new menuTypes[type](menuCmp, plt); } } function MenuController_tsickle_Closure_declarations() { /** @type {?} */ MenuController.prototype._menus; } let /** @type {?} */ menuTypes = {}; //# sourceMappingURL=menu-controller.js.map