source: trip-planner-front/node_modules/angular-material/modules/closure/autocomplete/autocomplete.min.js@ 6a3a178

Last change on this file since 6a3a178 was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 21.9 KB
Line 
1/*!
2 * AngularJS Material Design
3 * https://github.com/angular/material
4 * @license MIT
5 * v1.2.2-master-0a06f99
6 */
7goog.provide("ngmaterial.components.autocomplete"),goog.require("ngmaterial.components.icon"),goog.require("ngmaterial.components.virtualRepeat"),goog.require("ngmaterial.core"),angular.module("material.components.autocomplete",["material.core","material.components.icon","material.components.virtualRepeat"]),MdAutocompleteCtrl.$inject=["$scope","$element","$mdUtil","$mdConstant","$mdTheming","$window","$animate","$rootElement","$attrs","$q","$log","$mdLiveAnnouncer"],angular.module("material.components.autocomplete").controller("MdAutocompleteCtrl",MdAutocompleteCtrl);var ITEM_HEIGHT=48,MAX_ITEMS=5,MENU_PADDING=8,INPUT_PADDING=2,MODE_STANDARD="standard",MODE_VIRTUAL="virtual";function MdAutocompleteCtrl(p,h,g,t,e,n,o,i,f,a,l,r){var c,u,d,s=this,m=p.itemsExpr.split(/ in /i),$=m[1],C=null,x={},A=!1,v=[],M=!1,b=0,T=null,D=null,I=g.debounce(function(){s.hidden||O()}),w=MODE_VIRTUAL;s.documentElement=angular.element(document.documentElement),c="hidden",u=function(e,t){var n;C&&(n=angular.element(C.scrollContainer));!e&&t?(O(),oe(!0,y.Count|y.Selected),C&&(g.disableScrollAround(C.scrollContainer),T=function(e){var t=angular.element(e);return t.on("wheel touchmove",k),function(){t.off("wheel touchmove",k)}}(C.wrap),g.isIos&&(s.documentElement.on("touchend",H),n&&n.on("touchstart touchmove touchend",P)),s.index=j(),g.nextTick(function(){S(),ie()}))):e&&!t&&(g.isIos&&(s.documentElement.off("touchend",H),n&&n.off("touchstart touchmove touchend",P)),g.enableScrolling(),T&&(T(),T=null))},d=!0,Object.defineProperty(s,c,{get:function(){return d},set:function(e){var t=d;u(d=e,t)}}),s.scope=p,s.parent=p.$parent,s.itemName=m[0],s.matches=[],s.loading=!1,s.hidden=!0,s.index=-1,s.activeOption=null,s.id=g.nextUid(),s.isDisabled=null,s.isRequired=null,s.isReadonly=null,s.hasNotFound=!1,s.selectedMessage=p.selectedMessage||"selected",s.noMatchMessage=p.noMatchMessage||"There are no matches available.",s.singleMatchMessage=p.singleMatchMessage||"There is 1 match available.",s.multipleMatchStartMessage=p.multipleMatchStartMessage||"There are ",s.multipleMatchEndMessage=p.multipleMatchEndMessage||" matches available.",s.defaultEscapeOptions="clear",s.keydown=function(e){switch(e.keyCode){case t.KEY_CODE.DOWN_ARROW:if(s.loading||J())return;e.stopPropagation(),e.preventDefault(),s.index=s.index+1>s.matches.length-1?0:Math.min(s.index+1,s.matches.length-1),g.nextTick(S),ie();break;case t.KEY_CODE.UP_ARROW:if(s.loading||J())return;e.stopPropagation(),e.preventDefault(),s.index=s.index-1<0?s.matches.length-1:Math.max(0,s.index-1),g.nextTick(S),ie();break;case t.KEY_CODE.TAB:if(_(),s.hidden||s.loading||s.index<0||s.matches.length<1)return;ee(s.index);break;case t.KEY_CODE.ENTER:if(s.hidden||s.loading||s.index<0||s.matches.length<1)return;if(J())return;e.stopImmediatePropagation(),e.preventDefault(),ee(s.index);break;case t.KEY_CODE.ESCAPE:if(e.preventDefault(),!(Y("blur")||!s.hidden||s.loading||Y("clear")&&p.searchText))return;e.stopPropagation(),te(),p.searchText&&Y("clear")&&ne(),s.hidden=!0,Y("blur")&&U(!0)}},s.blur=function(e){M=!1,A?angular.isObject(e)&&e.stopImmediatePropagation():(s.hidden=W(),ue("ngBlur",{$event:e}))},s.focus=function(e){M=!0,K()&&Z()&&re();s.hidden=W(),ue("ngFocus",{$event:e})},s.clear=function(e){e&&e.stopPropagation();te(),ne()},s.select=ee,s.listEnter=function(){A=!0},s.listLeave=_,s.focusInput=N,s.getCurrentDisplayValue=Q,s.registerSelectedItemWatcher=function(e){-1===v.indexOf(e)&&v.push(e)},s.unregisterSelectedItemWatcher=function(e){var t=v.indexOf(e);-1!==t&&v.splice(t,1)},s.notFoundVisible=ae,s.loadingIsVisible=function(){return s.loading&&!J()},s.positionDropdown=O;var E,y={Count:1,Selected:2};return g.initOptionalProperties(p,f,{searchText:"",selectedItem:null,clearButton:!1,disableVirtualRepeat:!1}),e(h),E=parseInt(p.delay,10)||0,f.$observe("disabled",function(e){s.isDisabled=g.parseAttributeBoolean(e,!1)}),f.$observe("required",function(e){s.isRequired=g.parseAttributeBoolean(e,!1)}),f.$observe("readonly",function(e){s.isReadonly=g.parseAttributeBoolean(e,!1)}),p.$watch("searchText",E?g.debounce(q,E):q),p.$watch("selectedItem",B),angular.element(n).on("resize",I),void p.$on("$destroy",R),void g.nextTick(function(){!function(){var e=function(){var e,t;for(e=h;e.length&&(t=e.attr("md-autocomplete-snap"),!angular.isDefined(t));e=e.parent());if(e.length)return{snap:e[0],wrap:"width"===t.toLowerCase()?e[0]:h.find("md-autocomplete-wrap")[0]};var n=h.find("md-autocomplete-wrap")[0];return{snap:n,wrap:n}}();(C={main:h[0],scrollContainer:h[0].querySelector(".md-virtual-repeat-container, .md-standard-list-container"),scroller:h[0].querySelector(".md-virtual-repeat-scroller, .md-standard-list-scroller"),ul:h.find("ul")[0],input:h.find("input")[0],wrap:e.wrap,snap:e.snap,root:document.body}).li=C.ul.getElementsByTagName("li"),C.$=function(e){var t={};for(var n in e)e.hasOwnProperty(n)&&(t[n]=angular.element(e[n]));return t}(C),w=C.scrollContainer.classList.contains("md-standard-list-container")?MODE_STANDARD:MODE_VIRTUAL,D=C.$.input.controller("ngModel")}(),C.$.root.length&&(e(C.$.scrollContainer),C.$.scrollContainer.detach(),C.$.root.append(C.$.scrollContainer),o.pin&&o.pin(C.$.scrollContainer,i)),h.on("touchstart",N),p.autofocus&&h.on("focus",N),p.inputAriaDescribedBy&&C.input.setAttribute("aria-describedby",p.inputAriaDescribedBy),p.floatingLabel||(p.inputAriaLabel?C.input.setAttribute("aria-label",p.inputAriaLabel):p.inputAriaLabelledBy?C.input.setAttribute("aria-labelledby",p.inputAriaLabelledBy):p.placeholder&&C.input.setAttribute("aria-label",p.placeholder))});function L(){p.requireMatch&&D&&D.$setValidity("md-require-match",!!p.selectedItem||!p.searchText)}function O(){if(!C)return g.nextTick(O,!1,p);var e,t=(p.dropdownItems||MAX_ITEMS)*ITEM_HEIGHT,n=C.wrap.getBoundingClientRect(),o=C.snap.getBoundingClientRect(),i=C.root.getBoundingClientRect(),l=o.bottom-i.top,a=i.bottom-o.top,r=n.left-i.left,c=n.width,u=function(){var e=0,t=h.find("md-input-container");if(t.length){var n=t.find("input");e=t.prop("offsetHeight"),e-=n.prop("offsetTop"),e-=n.prop("offsetHeight"),e+=t.prop("offsetTop")}return e}(),d=p.dropdownPosition,s=i.bottom-o.bottom-MENU_PADDING+g.getViewportTop(),m=o.top-MENU_PADDING;d=d||(t<s?"bottom":t<m?"top":s<m?"top":"bottom"),f.mdFloatingLabel&&(r+=INPUT_PADDING,c-=2*INPUT_PADDING),e={left:r+"px",minWidth:c+"px",maxWidth:Math.max(n.right-i.left,i.right-n.left)-MENU_PADDING+"px"},"top"===d?(e.top="auto",e.bottom=a+"px",e.maxHeight=Math.min(t,m)+"px"):(s=i.bottom-n.bottom-MENU_PADDING+g.getViewportTop(),e.top=l-u+"px",e.bottom="auto",e.maxHeight=Math.min(t,s)+"px"),C.$.scrollContainer.css(e),g.nextTick(function(){var e=C.scrollContainer.getBoundingClientRect(),t={};e.right>i.right&&(t.left=n.right-e.width+"px");C.$.scrollContainer.css(t)},!1,p)}function N(){C.input.focus()}function S(){var e=C.scroller.querySelector(".selected");s.activeOption=e?e.id:null}function R(){if(s.hidden||g.enableScrolling(),angular.element(n).off("resize",I),C){angular.forEach(["ul","scroller","scrollContainer","input"],function(e){C.$[e].remove()})}}function k(e){e.preventDefault()}function P(e){e.stopPropagation()}function H(e){U(s.hidden=!0)}function _(){M||s.hidden||C.input.focus(),A=!1,s.hidden=W()}function B(t,n){L(),t?V(t).then(function(e){p.searchText=e,function(t,n){v.forEach(function(e){e(t,n)})}(t,n)}):n&&p.searchText&&V(n).then(function(e){angular.isString(p.searchText)&&e.toString().toLowerCase()===p.searchText.toLowerCase()&&(p.searchText="")}),t!==n&&angular.isFunction(p.itemChange)&&p.itemChange(G(p.selectedItem))}function q(t,n){s.index=j(),t!==n&&(L(),V(p.selectedItem).then(function(e){t!==e&&(p.selectedItem=null,t!==n&&angular.isFunction(p.textChange)&&p.textChange(),Z()?re():(z(!(s.matches=[])),oe(!0,y.Count)))}))}function U(e){e&&(M=A=!1),C.input.blur()}function F(){return angular.isNumber(p.minLength)?p.minLength:1}function V(e){return a.when(((t=e)&&p.itemText?p.itemText(G(t)):null)||e).then(function(e){return e&&!angular.isString(e)&&l.warn("md-autocomplete: Could not resolve display value to a string. Please check the `md-item-text` attribute."),e});var t}function G(e){if(e){var t={};return s.itemName&&(t[s.itemName]=e),t}}function j(){return p.autoselect?0:-1}function z(e){s.loading!==e&&(s.loading=e),s.hidden=W()}function W(){return!function(){{if(s.isReadonly)return!1;if(!K())return!1}return Z()&&X()||ae()}()}function K(){return!(s.loading&&!X())&&(!J()&&!!M)}function Y(e){return angular.isString(p.escapeOptions)?-1!==p.escapeOptions.toLowerCase().indexOf(e):-1!==s.defaultEscapeOptions.indexOf(e)}function X(){return!!s.matches.length}function J(){return!!s.scope.selectedItem}function Q(){return V(s.matches[s.index])}function Z(){return(p.searchText||"").length>=F()}function ee(e){g.nextTick(function(){V(s.matches[e]).then(function(e){var t=C.$.input.controller("ngModel");r.announce(e+" "+s.selectedMessage,"assertive"),t.$setViewValue(e),t.$render()}).finally(function(){p.selectedItem=s.matches[e],z(!1)})},!1)}function te(){s.index=-1,g.nextTick(S),s.matches=[]}function ne(){z(!0),p.searchText="";var e=document.createEvent("CustomEvent");e.initCustomEvent("change",!0,!0,{value:""}),C.input.dispatchEvent(e),C.input.blur(),p.searchText="",C.input.focus()}function oe(e,t){var n=e?"polite":"assertive",o=[];t&y.Selected&&-1!==s.index&&o.push(Q()),t&y.Count&&o.push(a.resolve(function(){switch(s.matches.length){case 0:return s.noMatchMessage;case 1:return s.singleMatchMessage;default:return s.multipleMatchStartMessage+s.matches.length+s.multipleMatchEndMessage}}())),a.all(o).then(function(e){r.announce(e.join(" "),n)})}function ie(){C.li[0]&&(w===MODE_STANDARD?function(){var e=C.li[Math.max(0,s.index)],t=C.scrollContainer.offsetHeight,n=e&&e.offsetTop||0,o=n+e.clientHeight,i=C.scrollContainer.scrollTop;n<i?le(n):i+t<o&&le(o-t)}():function(){var e=C.li[0].offsetHeight,t=e*Math.max(0,s.index),n=t+e,o=C.scroller.clientHeight,i=C.scroller.scrollTop;t<i?le(t):i+o<n&&le(n-o)}())}function le(e){w===MODE_STANDARD?C.scrollContainer.scrollTop=e:C.$.scrollContainer.controller("mdVirtualRepeatContainer").scrollTo(e)}function ae(){var e=(s.scope.searchText||"").length;return s.hasNotFound&&!X()&&(!s.loading||0!==b)&&e>=F()&&(M||A)&&!J()}function re(){var e=p.searchText||"",t=e.toLowerCase();!p.noCache&&x[t]?ce(x[t]):function(t){var e=p.$parent.$eval($),n=t.toLowerCase(),o=angular.isArray(e),i=!!e.then;function l(e){x[n]=e,(t||"")===(p.searchText||"")&&ce(e)}o?l(e):i&&function(e){if(!e)return;e=a.when(e),b++,z(!0),g.nextTick(function(){e.then(l).finally(function(){0==--b&&z(!1)})},!0,p)}(e)}(e),s.hidden=W()}function ce(e){s.matches=e,s.hidden=W(),s.loading&&z(!1),p.selectOnMatch&&function(){var n=p.searchText,e=s.matches,t=e[0];1===e.length&&V(t).then(function(e){var t=n===e;p.matchInsensitive&&!t&&(t=n.toLowerCase()===e.toLowerCase()),t&&ee(0)})}(),O(),oe(!0,y.Count)}function ue(e,t){f[e]&&p.$parent.$eval(f[e],t||{})}}function MdAutocomplete(u){var d="virtual",t=["standard",d];function s(e){return e?(e=e.toLowerCase(),-1<t.indexOf(e)?e:d):d}return{controller:"MdAutocompleteCtrl",controllerAs:"$mdAutocompleteCtrl",scope:{inputName:"@mdInputName",inputMinlength:"@mdInputMinlength",inputMaxlength:"@mdInputMaxlength",searchText:"=?mdSearchText",selectedItem:"=?mdSelectedItem",itemsExpr:"@mdItems",itemText:"&mdItemText",placeholder:"@placeholder",inputAriaDescribedBy:"@?inputAriaDescribedby",inputAriaLabelledBy:"@?inputAriaLabelledby",inputAriaLabel:"@?inputAriaLabel",noCache:"=?mdNoCache",requireMatch:"=?mdRequireMatch",selectOnMatch:"=?mdSelectOnMatch",matchInsensitive:"=?mdMatchCaseInsensitive",itemChange:"&?mdSelectedItemChange",textChange:"&?mdSearchTextChange",minLength:"=?mdMinLength",delay:"=?mdDelay",autofocus:"=?mdAutofocus",floatingLabel:"@?mdFloatingLabel",autoselect:"=?mdAutoselect",menuClass:"@?mdMenuClass",menuContainerClass:"@?mdMenuContainerClass",inputClass:"@?mdInputClass",inputId:"@?mdInputId",escapeOptions:"@?mdEscapeOptions",dropdownItems:"=?mdDropdownItems",dropdownPosition:"@?mdDropdownPosition",clearButton:"=?mdClearButton",selectedMessage:"@?mdSelectedMessage",noMatchMessage:"@?mdNoMatchMessage",singleMatchMessage:"@?mdSingleMatchMessage",multipleMatchStartMessage:"@?mdMultipleMatchStartMessage",multipleMatchEndMessage:"@?mdMultipleMatchEndMessage",mdMode:"=?mdMode"},compile:function(e,n){var o=e.find("input");return["md-select-on-focus","md-no-asterisk","ng-trim","ng-pattern"].forEach(function(e){var t=n[n.$normalize(e)];null!==t&&o.attr(e,t)}),function(e,t,n,o){o.hasNotFound=!!t.attr("md-has-not-found"),angular.isDefined(n.mdClearButton)||e.floatingLabel||(e.clearButton=!0),e.mdMode=s(n.mdMode),t.on("click touchstart touchend",function(e){e.stopPropagation()})}},template:function(n,e){var t,o,i=(t=n.find("md-not-found").detach(),(o=t.length?t.html():"")?'<li ng-if="$mdAutocompleteCtrl.notFoundVisible()" class="md-autocomplete-suggestion" md-autocomplete-parent-scope>'+o+"</li>":""),l=function(){var e=n.find("md-item-template").detach(),t=e.length?e.html():n.html();e.length||n.empty();return"<md-autocomplete-parent-scope md-autocomplete-replace>"+t+"</md-autocomplete-parent-scope>"}(),a=n.html(),r=e.tabindex;return i&&n.attr("md-has-not-found",!0),n.attr("tabindex","-1")," <md-autocomplete-wrap ng-class=\"{ 'md-whiteframe-z1': !floatingLabel, 'md-menu-showing': !$mdAutocompleteCtrl.hidden, 'md-show-clear-button': !!clearButton }\"> "+(e.mdFloatingLabel?' <md-input-container ng-if="floatingLabel"> <label>{{floatingLabel}}</label> <input type="text" '+(null!=r?'tabindex="'+r+'"':"")+' id="{{inputId || \'fl-input-\' + $mdAutocompleteCtrl.id}}" name="{{inputName || \'fl-input-\' + $mdAutocompleteCtrl.id }}" ng-class="::inputClass" autocomplete="off" ng-required="$mdAutocompleteCtrl.isRequired" ng-readonly="$mdAutocompleteCtrl.isReadonly" ng-minlength="inputMinlength" ng-maxlength="inputMaxlength" ng-disabled="$mdAutocompleteCtrl.isDisabled" ng-model="$mdAutocompleteCtrl.scope.searchText" ng-model-options="{ allowInvalid: true }" ng-mousedown="$mdAutocompleteCtrl.focusInput()" ng-keydown="$mdAutocompleteCtrl.keydown($event)" ng-blur="$mdAutocompleteCtrl.blur($event)" ng-focus="$mdAutocompleteCtrl.focus($event)" aria-label="{{floatingLabel}}" ng-attr-aria-autocomplete="{{$mdAutocompleteCtrl.isDisabled ? undefined : \'list\'}}" ng-attr-role="{{$mdAutocompleteCtrl.isDisabled ? undefined : \'combobox\'}}" aria-haspopup="{{!$mdAutocompleteCtrl.isDisabled}}" aria-expanded="{{!$mdAutocompleteCtrl.hidden}}" ng-attr-aria-owns="{{$mdAutocompleteCtrl.hidden || $mdAutocompleteCtrl.isDisabled ? undefined : \'ul-\' + $mdAutocompleteCtrl.id}}" ng-attr-aria-activedescendant="{{!$mdAutocompleteCtrl.hidden && $mdAutocompleteCtrl.activeOption ? $mdAutocompleteCtrl.activeOption : undefined}}"> <div md-autocomplete-parent-scope md-autocomplete-replace>'+a+"</div> </md-input-container>":' <input type="text" '+(null!=r?'tabindex="'+r+'"':"")+' id="{{inputId || \'input-\' + $mdAutocompleteCtrl.id}}" name="{{inputName || \'input-\' + $mdAutocompleteCtrl.id }}" ng-class="::inputClass" ng-if="!floatingLabel" autocomplete="off" ng-required="$mdAutocompleteCtrl.isRequired" ng-disabled="$mdAutocompleteCtrl.isDisabled" ng-readonly="$mdAutocompleteCtrl.isReadonly" ng-minlength="inputMinlength" ng-maxlength="inputMaxlength" ng-model="$mdAutocompleteCtrl.scope.searchText" ng-mousedown="$mdAutocompleteCtrl.focusInput()" ng-keydown="$mdAutocompleteCtrl.keydown($event)" ng-blur="$mdAutocompleteCtrl.blur($event)" ng-focus="$mdAutocompleteCtrl.focus($event)" placeholder="{{placeholder}}" aria-label="{{placeholder}}" ng-attr-aria-autocomplete="{{$mdAutocompleteCtrl.isDisabled ? undefined : \'list\'}}" ng-attr-role="{{$mdAutocompleteCtrl.isDisabled ? undefined : \'combobox\'}}" aria-haspopup="{{!$mdAutocompleteCtrl.isDisabled}}" aria-expanded="{{!$mdAutocompleteCtrl.hidden}}" ng-attr-aria-owns="{{$mdAutocompleteCtrl.hidden || $mdAutocompleteCtrl.isDisabled ? undefined : \'ul-\' + $mdAutocompleteCtrl.id}}" ng-attr-aria-activedescendant="{{!$mdAutocompleteCtrl.hidden && $mdAutocompleteCtrl.activeOption ? $mdAutocompleteCtrl.activeOption : undefined}}">')+' <button type="button" aria-label="Clear Input" tabindex="0" ng-if="clearButton && $mdAutocompleteCtrl.scope.searchText" ng-click="$mdAutocompleteCtrl.clear($event)"><md-icon md-svg-src="'+u.mdClose+'"></md-icon></button> <md-progress-linear class="'+(e.mdFloatingLabel?"md-inline":"")+'" ng-if="$mdAutocompleteCtrl.loadingIsVisible()" md-mode="indeterminate"></md-progress-linear> '+function(e,t){if(e=e?" "+e:"",c(t))return' <div ng-hide="$mdAutocompleteCtrl.hidden" class="md-standard-list-container md-autocomplete-suggestions-container md-whiteframe-z1'+e+'" ng-class="{ \'md-not-found\': $mdAutocompleteCtrl.notFoundVisible() }" ng-mouseenter="$mdAutocompleteCtrl.listEnter()" ng-mouseleave="$mdAutocompleteCtrl.listLeave()" role="presentation"> <div class="md-standard-list-scroller" role="presentation">';return' <md-virtual-repeat-container md-auto-shrink md-auto-shrink-min="1" ng-hide="$mdAutocompleteCtrl.hidden" class="md-virtual-repeat-container md-autocomplete-suggestions-container md-whiteframe-z1'+e+'" ng-class="{ \'md-not-found\': $mdAutocompleteCtrl.notFoundVisible() }" ng-mouseenter="$mdAutocompleteCtrl.listEnter()" ng-mouseleave="$mdAutocompleteCtrl.listLeave()" role="presentation">'}(e.mdMenuContainerClass,e.mdMode)+' <ul class="md-autocomplete-suggestions" ng-class="::menuClass" id="ul-{{$mdAutocompleteCtrl.id}}" ng-mouseup="$mdAutocompleteCtrl.focusInput()" role="listbox"> <li class="md-autocomplete-suggestion" '+(c(e.mdMode)?"ng-repeat":"md-virtual-repeat")+' ="item in $mdAutocompleteCtrl.matches" ng-class="{ selected: $index === $mdAutocompleteCtrl.index }" ng-attr-id="{{\'md-option-\' + $mdAutocompleteCtrl.id + \'-\' + $index}}" ng-click="$mdAutocompleteCtrl.select($index)" role="option" aria-setsize="{{$mdAutocompleteCtrl.matches.length}}" aria-posinset="{{$index+1}}" aria-selected="{{$index === $mdAutocompleteCtrl.index ? true : false}}" md-extra-name="$mdAutocompleteCtrl.itemName"> '+l+" </li>"+i+" </ul> "+(c(e.mdMode)?" </div> </div> </div>":"</md-virtual-repeat-container>")+" </md-autocomplete-wrap>";function c(e){return s(e)!==d}}}}function MdAutocompleteItemScopeDirective(e,d){return{restrict:"AE",compile:function(e,t,u){return function(n,t,e){var o,i,l=n.$mdAutocompleteCtrl,a=l.parent.$new(),r=l.itemName;function c(e,t){a[t]=n[e],n.$watch(e,function(e){d.nextTick(function(){a[t]=e})})}c("$index","$index"),c("item",r),i=o=!1,n.$watch(function(){i||o||(o=!0,n.$$postDigest(function(){i||a.$digest(),o=i=!1}))}),a.$watch(function(){i=!0}),u(a,function(e){t.after(e)})}},terminal:!0,transclude:"element"}}function MdHighlightCtrl(e,t,n,o){this.$scope=e,this.$element=t,this.$attrs=n,this.$mdUtil=o,this.regex=null}function MdHighlight(n,o){return{terminal:!0,controller:"MdHighlightCtrl",compile:function(e,t){var i=o(t.mdHighlightText),l=n(e.html());return function(e,t,n,o){o.init(i,l)}}}}MdAutocomplete.$inject=["$$mdSvgRegistry"],angular.module("material.components.autocomplete").directive("mdAutocomplete",MdAutocomplete),MdAutocompleteItemScopeDirective.$inject=["$compile","$mdUtil"],angular.module("material.components.autocomplete").directive("mdAutocompleteParentScope",MdAutocompleteItemScopeDirective),MdHighlightCtrl.$inject=["$scope","$element","$attrs","$mdUtil"],angular.module("material.components.autocomplete").controller("MdHighlightCtrl",MdHighlightCtrl),MdHighlightCtrl.prototype.init=function(t,n){this.flags=this.$attrs.mdHighlightFlags||"",this.unregisterFn=this.$scope.$watch(function(e){return{term:t(e),contentText:n(e)}}.bind(this),this.onRender.bind(this),!0),this.$element.on("$destroy",this.unregisterFn)},MdHighlightCtrl.prototype.onRender=function(e,t){var n=e.contentText;null!==this.regex&&e.term===t.term||(this.regex=this.createRegex(e.term,this.flags)),e.term?this.applyRegex(n):this.$element.text(n)},MdHighlightCtrl.prototype.applyRegex=function(e){var t=this.resolveTokens(e);this.$element.empty(),t.forEach(function(e){if(e.isMatch){var t=angular.element('<span class="highlight">').text(e.text);this.$element.append(t)}else this.$element.append(document.createTextNode(e))}.bind(this))},MdHighlightCtrl.prototype.resolveTokens=function(o){var i=[],n=0;return o.replace(this.regex,function(e,t){l(n,t),i.push({text:e,isMatch:!0}),n=t+e.length}),l(n),i;function l(e,t){var n=o.slice(e,t);n&&i.push(n)}},MdHighlightCtrl.prototype.createRegex=function(e,t){var n="",o="",i=this.$mdUtil.sanitize(e);return 0<=t.indexOf("^")&&(n="^"),0<=t.indexOf("$")&&(o="$"),new RegExp(n+i+o,t.replace(/[$^]/g,""))},MdHighlight.$inject=["$interpolate","$parse"],angular.module("material.components.autocomplete").directive("mdHighlightText",MdHighlight),ngmaterial.components.autocomplete=angular.module("material.components.autocomplete");
Note: See TracBrowser for help on using the repository browser.