7 lines
8.9 KiB
JavaScript
7 lines
8.9 KiB
JavaScript
|
|
/*!
|
||
|
|
* AngularJS Material Design
|
||
|
|
* https://github.com/angular/material
|
||
|
|
* @license MIT
|
||
|
|
* v1.1.18-master-97a1616
|
||
|
|
*/
|
||
|
|
goog.provide("ngmaterial.components.menuBar"),goog.require("ngmaterial.components.icon"),goog.require("ngmaterial.components.menu"),goog.require("ngmaterial.core"),angular.module("material.components.menuBar",["material.core","material.components.icon","material.components.menu"]),MenuBarController.$inject=["$scope","$rootScope","$element","$attrs","$mdConstant","$document","$mdUtil","$timeout"],angular.module("material.components.menuBar").controller("MenuBarController",MenuBarController);var BOUND_MENU_METHODS=["handleKeyDown","handleMenuHover","scheduleOpenHoveredMenu","cancelScheduledOpen"];function MenuBarController(e,n,t,o,r,i,a,l){this.$element=t,this.$attrs=o,this.$mdConstant=r,this.$mdUtil=a,this.$document=i,this.$scope=e,this.$rootScope=n,this.$timeout=l;var u=this;angular.forEach(BOUND_MENU_METHODS,function(e){u[e]=angular.bind(u,u[e])})}function MenuBarDirective(t,r){return{restrict:"E",require:"mdMenuBar",controller:"MenuBarController",compile:function(e,n){return n.ariaRole||e[0].setAttribute("role","menubar"),angular.forEach(e[0].children,function(e){if("MD-MENU"==e.nodeName){e.hasAttribute("md-position-mode")||(e.setAttribute("md-position-mode","left bottom"),e.querySelector("button, a, md-button").setAttribute("role","menuitem"));var n=t.nodesToArray(e.querySelectorAll("md-menu-content"));angular.forEach(n,function(e){e.classList.add("md-menu-bar-menu"),e.classList.add("md-dense"),e.hasAttribute("width")||e.setAttribute("width",5)})}}),e.find("md-menu-item").addClass("md-in-menu-bar"),function(e,n,t,o){n.addClass("_md"),r(e,n),o.init()}}}}function MenuDividerDirective(){return{restrict:"E",compile:function(e,n){n.role||e[0].setAttribute("role","separator")}}}function MenuItemController(e,n,t){this.$element=n,this.$attrs=t,this.$scope=e}function MenuItemDirective(d,e,c){return{controller:"MenuItemController",require:["mdMenuItem","?ngModel"],priority:e.BEFORE_NG_ARIA,compile:function(o,e){var n,t,r=e.type,i="md-in-menu-bar";if("checkbox"!==r&&"radio"!==r||!o.hasClass(i))s("role","menuitem",o[0].querySelector("md-button, button, a"));else{var a=o[0].textContent,l=angular.element('<md-button type="button"></md-button>'),u='<md-icon md-svg-src="'+c.mdChecked+'"></md-icon>';l.html(a),l.attr("tabindex","0"),angular.isDefined(e.mdPreventMenuClose)&&l.attr("md-prevent-menu-close",e.mdPreventMenuClose),o.html(""),o.append(angular.element(u)),o.append(l),o.addClass("md-indent").removeClass(i),s("role","checkbox"===r?"menuitemcheckbox":"menuitemradio",l),n="ng-disabled",t=d.prefixer(n),angular.forEach(t,function(e){if(o[0].hasAttribute(e)){var n=o[0].getAttribute(e);l[0].setAttribute(e,n),o[0].removeAttribute(e)}})}return function(e,n,t,o){var r=o[0],i=o[1];r.init(i)};function s(e,n,t){(t=t||o)instanceof angular.element&&(t=t[0]),t.hasAttribute(e)||t.setAttribute(e,n)}}}}MenuBarController.prototype.init=function(){var i=this.$element,a=this.$mdUtil,e=this.$scope,l=this,n=[];i.on("keydown",this.handleKeyDown),this.parentToolbar=a.getClosest(i,"MD-TOOLBAR"),n.push(this.$rootScope.$on("$mdMenuOpen",function(e,n){-1!=l.getMenus().indexOf(n[0])&&(i[0].classList.add("md-open"),n[0].classList.add("md-open"),l.currentlyOpenMenu=n.controller("mdMenu"),l.currentlyOpenMenu.registerContainerProxy(l.handleKeyDown),l.enableOpenOnHover())})),n.push(this.$rootScope.$on("$mdMenuClose",function(e,n,t){var o=l.getMenus();if(-1!=o.indexOf(n[0])&&(i[0].classList.remove("md-open"),n[0].classList.remove("md-open")),i[0].contains(n[0])){for(var r=n[0];r&&-1==o.indexOf(r);)r=a.getClosest(r,"MD-MENU",!0);r&&(t.skipFocus||r.querySelector("button:not([disabled])").focus(),l.currentlyOpenMenu=void 0,l.disableOpenOnHover(),l.setKeyboardMode(!0))}})),e.$on("$destroy",function(){for(l.disableOpenOnHover();n.length;)n.shift()()}),this.setKeyboardMode(!0)},MenuBarController.prototype.setKeyboardMode=function(e){e?this.$element[0].classList.add("md-keyboard-mode"):this.$element[0].classList.remove("md-keyboard-mode")},MenuBarController.prototype.enableOpenOnHover=function(){if(!this.openOnHoverEnabled){var e=this;e.openOnHoverEnabled=!0,e.parentToo
|