UNPKG

angular-material

Version:

This repository publishes the AngularJS Material v1.x library and localized installs using `npm`. You can find the component source-code for this library in the [AngularJS Material repository](https://github.com/angular/material).

7 lines 21 kB
/*! * AngularJS Material Design * https://github.com/angular/material * @license MIT * v1.2.0-master-93518bb */ !function(e,ue){"use strict";ue.module("material.components.autocomplete",["material.core","material.components.icon","material.components.virtualRepeat"]),t.$inject=["$scope","$element","$mdUtil","$mdConstant","$mdTheming","$window","$animate","$rootElement","$attrs","$q","$log","$mdLiveAnnouncer"],ue.module("material.components.autocomplete").controller("MdAutocompleteCtrl",t);var se=48,me=5,pe=8,he=2,fe="standard",ge="virtual";function t(p,h,f,t,e,n,o,i,g,a,l,r){var c,d,u,s=this,m=p.itemsExpr.split(/ in /i),$=m[1],C=null,x={},v=!1,b=[],A=!1,w=0,T=null,y=null,M=f.debounce(function(){s.hidden||O()}),I=ge;s.documentElement=ue.element(document.documentElement),c="hidden",d=function(e,t){var n;C&&(n=ue.element(C.scrollContainer));!e&&t?(O(),oe(!0,L.Count|L.Selected),C&&(f.disableScrollAround(C.scrollContainer),T=function(e){var t=ue.element(e);return t.on("wheel touchmove",B),function(){t.off("wheel touchmove",B)}}(C.wrap),f.isIos&&(s.documentElement.on("touchend",F),n&&n.on("touchstart touchmove touchend",N)),s.index=W(),f.nextTick(function(){k(),ie()}))):e&&!t&&(f.isIos&&(s.documentElement.off("touchend",F),n&&n.off("touchstart touchmove touchend",N)),f.enableScrolling(),T&&(T(),T=null))},u=!0,Object.defineProperty(s,c,{get:function(){return u},set:function(e){var t=u;d(u=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=f.nextUid(),s.isDisabled=null,s.isRequired=null,s.isReadonly=null,s.hasNotFound=!1,s.selectedMessage=p.selectedMessage||"selected",s.defaultEscapeOptions="clear",s.keydown=function(e){switch(e.keyCode){case t.KEY_CODE.DOWN_ARROW:if(s.loading||Q())return;e.stopPropagation(),e.preventDefault(),s.index=s.index+1>s.matches.length-1?0:Math.min(s.index+1,s.matches.length-1),f.nextTick(k),ie();break;case t.KEY_CODE.UP_ARROW:if(s.loading||Q())return;e.stopPropagation(),e.preventDefault(),s.index=s.index-1<0?s.matches.length-1:Math.max(0,s.index-1),f.nextTick(k),ie();break;case t.KEY_CODE.TAB:if(P(),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(Q())return;e.stopImmediatePropagation(),e.preventDefault(),ee(s.index);break;case t.KEY_CODE.ESCAPE:if(e.preventDefault(),!(G("blur")||!s.hidden||s.loading||G("clear")&&p.searchText))return;e.stopPropagation(),te(),p.searchText&&G("clear")&&ne(),s.hidden=!0,G("blur")&&H(!0)}},s.blur=function(e){A=!1,v||(s.hidden=K(),de("ngBlur",{$event:e}))},s.focus=function(e){A=!0,Y()&&Z()&&re();s.hidden=K(),de("ngFocus",{$event:e})},s.clear=function(e){e&&e.stopPropagation();te(),ne()},s.select=ee,s.listEnter=function(){v=!0},s.listLeave=P,s.focusInput=R,s.getCurrentDisplayValue=X,s.registerSelectedItemWatcher=function(e){-1===b.indexOf(e)&&b.push(e)},s.unregisterSelectedItemWatcher=function(e){var t=b.indexOf(e);-1!==t&&b.splice(t,1)},s.notFoundVisible=ae,s.loadingIsVisible=function(){return s.loading&&!Q()},s.positionDropdown=O;var E,L={Count:1,Selected:2};return f.initOptionalProperties(p,g,{searchText:"",selectedItem:null,clearButton:!1,disableVirtualRepeat:!1}),e(h),E=parseInt(p.delay,10)||0,g.$observe("disabled",function(e){s.isDisabled=f.parseAttributeBoolean(e,!1)}),g.$observe("required",function(e){s.isRequired=f.parseAttributeBoolean(e,!1)}),g.$observe("readonly",function(e){s.isReadonly=f.parseAttributeBoolean(e,!1)}),p.$watch("searchText",E?f.debounce(V,E):V),p.$watch("selectedItem",q),ue.element(n).on("resize",M),void p.$on("$destroy",S),void f.nextTick(function(){!function(){var e=function(){var e,t;for(e=h;e.length&&(t=e.attr("md-autocomplete-snap"),!ue.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]=ue.element(e[n]));return t}(C),I=C.scrollContainer.classList.contains("md-standard-list-container")?fe:ge,y=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",R),p.autofocus&&h.on("focus",R),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 D(){p.requireMatch&&y&&y.$setValidity("md-require-match",!!p.selectedItem||!p.searchText)}function O(){if(!C)return f.nextTick(O,!1,p);var e,t=(p.dropdownItems||me)*se,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,d=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}(),u=p.dropdownPosition,s=i.bottom-o.bottom-pe+f.getViewportTop(),m=o.top-pe;u=u||(t<s?"bottom":t<m?"top":s<m?"top":"bottom"),g.mdFloatingLabel&&(r+=he,c-=2*he),e={left:r+"px",minWidth:c+"px",maxWidth:Math.max(n.right-i.left,i.right-n.left)-pe+"px"},"top"===u?(e.top="auto",e.bottom=a+"px",e.maxHeight=Math.min(t,m)+"px"):(s=i.bottom-n.bottom-pe+f.getViewportTop(),e.top=l-d+"px",e.bottom="auto",e.maxHeight=Math.min(t,s)+"px"),C.$.scrollContainer.css(e),f.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 R(){C.input.focus()}function k(){var e=C.scroller.querySelector(".selected");s.activeOption=e?e.id:null}function S(){if(s.hidden||f.enableScrolling(),ue.element(n).off("resize",M),C){ue.forEach(["ul","scroller","scrollContainer","input"],function(e){C.$[e].remove()})}}function B(e){e.preventDefault()}function N(e){e.stopPropagation()}function F(e){H(s.hidden=!0)}function P(){A||s.hidden||C.input.focus(),v=!1,s.hidden=K()}function q(t,n){D(),t?j(t).then(function(e){p.searchText=e,function(t,n){b.forEach(function(e){e(t,n)})}(t,n)}):n&&p.searchText&&j(n).then(function(e){ue.isString(p.searchText)&&e.toString().toLowerCase()===p.searchText.toLowerCase()&&(p.searchText="")}),t!==n&&ue.isFunction(p.itemChange)&&p.itemChange(U(p.selectedItem))}function V(t,n){s.index=W(),t!==n&&(D(),j(p.selectedItem).then(function(e){t!==e&&(p.selectedItem=null,t!==n&&ue.isFunction(p.textChange)&&p.textChange(),Z()?re():(_(!(s.matches=[])),oe(!0,L.Count)))}))}function H(e){e&&(A=v=!1),C.input.blur()}function z(){return ue.isNumber(p.minLength)?p.minLength:1}function j(e){return a.when(((t=e)&&p.itemText?p.itemText(U(t)):null)||e).then(function(e){return e&&!ue.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 U(e){if(e){var t={};return s.itemName&&(t[s.itemName]=e),t}}function W(){return p.autoselect?0:-1}function _(e){s.loading!==e&&(s.loading=e),s.hidden=K()}function K(){return!function(){{if(s.isReadonly)return!1;if(!Y())return!1}return Z()&&J()||ae()}()}function Y(){return!(s.loading&&!J())&&(!Q()&&!!A)}function G(e){return ue.isString(p.escapeOptions)?-1!==p.escapeOptions.toLowerCase().indexOf(e):-1!==s.defaultEscapeOptions.indexOf(e)}function J(){return!!s.matches.length}function Q(){return!!s.scope.selectedItem}function X(){return j(s.matches[s.index])}function Z(){return(p.searchText||"").length>=z()}function ee(e){f.nextTick(function(){j(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],_(!1)})},!1)}function te(){s.index=-1,f.nextTick(k),s.matches=[]}function ne(){_(!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&L.Selected&&-1!==s.index&&o.push(X()),t&L.Count&&o.push(a.resolve(function(){switch(s.matches.length){case 0:return"There are no matches available.";case 1:return"There is 1 match available.";default:return"There are "+s.matches.length+" matches available."}}())),a.all(o).then(function(e){r.announce(e.join(" "),n)})}function ie(){C.li[0]&&(I===fe?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){I===fe?C.scrollContainer.scrollTop=e:C.$.scrollContainer.controller("mdVirtualRepeatContainer").scrollTo(e)}function ae(){var e=(s.scope.searchText||"").length;return s.hasNotFound&&!J()&&(!s.loading||0!==w)&&e>=z()&&(A||v)&&!Q()}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=ue.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),w++,_(!0),f.nextTick(function(){e.then(l).finally(function(){0==--w&&_(!1)})},!0,p)}(e)}(e),s.hidden=K()}function ce(e){s.matches=e,s.hidden=K(),s.loading&&_(!1),p.selectOnMatch&&function(){var n=p.searchText,e=s.matches,t=e[0];1===e.length&&j(t).then(function(e){var t=n===e;p.matchInsensitive&&!t&&(t=n.toLowerCase()===e.toLowerCase()),t&&ee(0)})}(),O(),oe(!0,L.Count)}function de(e,t){g[e]&&p.$parent.$eval(g[e],t||{})}}function n(d){var u="virtual",t=["standard",u];function s(e){return e?(e=e.toLowerCase(),-1<t.indexOf(e)?e:u):u}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",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"),ue.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="'+d.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)!==u}}}}function o(e,u){return{restrict:"AE",compile:function(e,t,d){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){u.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}),d(a,function(e){t.after(e)})}},terminal:!0,transclude:"element"}}function i(e,t,n,o){this.$scope=e,this.$element=t,this.$attrs=n,this.$mdUtil=o,this.regex=null}function l(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)}}}}n.$inject=["$$mdSvgRegistry"],ue.module("material.components.autocomplete").directive("mdAutocomplete",n),o.$inject=["$compile","$mdUtil"],ue.module("material.components.autocomplete").directive("mdAutocompleteParentScope",o),i.$inject=["$scope","$element","$attrs","$mdUtil"],ue.module("material.components.autocomplete").controller("MdHighlightCtrl",i),i.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)},i.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)},i.prototype.applyRegex=function(e){var t=this.resolveTokens(e);this.$element.empty(),t.forEach(function(e){if(e.isMatch){var t=ue.element('<span class="highlight">').text(e.text);this.$element.append(t)}else this.$element.append(document.createTextNode(e))}.bind(this))},i.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)}},i.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,""))},l.$inject=["$interpolate","$parse"],ue.module("material.components.autocomplete").directive("mdHighlightText",l)}(window,window.angular);