UNPKG

@hxui/angular

Version:

An Angular library based on the [HXUI design system](https://hxui.io).

258 lines (252 loc) 28.1 kB
import { ChangeDetectorRef, Component, ElementRef, HostListener, ViewEncapsulation } from '@angular/core'; import { Subject } from 'rxjs'; import { latinize } from './typeahead-utils'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class TypeaheadContainerComponent { constructor(element, _changeDetectionRef) { this.element = element; this._changeDetectionRef = _changeDetectionRef; this.isFocused = false; this._matches = []; /** Subject for notifying that the tooltip has been hidden from the view */ this._onHide = new Subject(); } get active() { return this._active; } get matches() { return this._matches; } set matches(value) { this._matches = value; if (this._matches.length > 0) { this._active = this._matches[0]; if (this._active.isHeader()) { this.nextActiveMatch(); } } } get optionsListTemplate() { return this.parent ? this.parent.optionsListTemplate : undefined; } get itemTemplate() { return this.parent ? this.parent.typeaheadItemTemplate : undefined; } selectActiveMatch() { this.selectMatch(this._active); } prevActiveMatch() { let index = this.matches.indexOf(this._active); this._active = this.matches[index - 1 < 0 ? this.matches.length - 1 : index - 1]; if (this._active.isHeader()) { this.prevActiveMatch(); } } nextActiveMatch() { let index = this.matches.indexOf(this._active); this._active = this.matches[index + 1 > this.matches.length - 1 ? 0 : index + 1]; if (this._active.isHeader()) { this.nextActiveMatch(); } } selectActive(value) { this.isFocused = true; this._active = value; } hightlight(match, query) { let itemStr = match.value; let itemStrHelper = (this.parent && this.parent.typeaheadLatinize ? latinize(itemStr) : itemStr).toLowerCase(); let startIdx; let tokenLen; // Replaces the capture string with the same string inside of a "strong" tag if (typeof query === 'object') { let queryLen = query.length; for (let i = 0; i < queryLen; i += 1) { // query[i] is already latinized and lower case startIdx = itemStrHelper.indexOf(query[i]); tokenLen = query[i].length; if (startIdx >= 0 && tokenLen > 0) { itemStr = itemStr.substring(0, startIdx) + '<strong class="is-matched">' + itemStr.substring(startIdx, startIdx + tokenLen) + '</strong>' + itemStr.substring(startIdx + tokenLen); itemStrHelper = itemStrHelper.substring(0, startIdx) + ' ' + ' '.repeat(tokenLen) + ' ' + itemStrHelper.substring(startIdx + tokenLen); } } } else if (query) { // query is already latinized and lower case startIdx = itemStrHelper.indexOf(query); tokenLen = query.length; if (startIdx >= 0 && tokenLen > 0) { itemStr = itemStr.substring(0, startIdx) + '<strong class="is-matched">' + itemStr.substring(startIdx, startIdx + tokenLen) + '</strong>' + itemStr.substring(startIdx + tokenLen); } } return itemStr; } focusLost() { this.isFocused = false; } isActive(value) { return this._active === value; } selectMatch(value, e = void 0) { if (e) { e.stopPropagation(); e.preventDefault(); } this.parent.changeModel(value); setTimeout(() => this.parent.typeaheadOnSelect.emit(value), 0); return false; } show(delay) { // Cancel the delayed hide if it is scheduled if (this._hideTimeoutId) { clearTimeout(this._hideTimeoutId); } this._showTimeoutId = window.setTimeout(() => { // Schedule for change detection incase the tooltip is used within a // component with OnPush change detection this._changeDetectionRef.markForCheck(); //this.visibility = Visibility.Visible; }, delay); } /** * Hide the tooltip after the provided delay in ms. * @param delay Amount of milliseconds to delay hiding the tooltip. */ hide(delay) { // Cancel the delayed show if it is scheduled if (this._showTimeoutId) { clearTimeout(this._showTimeoutId); } this._hideTimeoutId = window.setTimeout(() => { // this.visibility = Visibility.Hidden; this._onHide.next(true); }, delay); } /** Returns an observable that notifies when the dropdown has been hidden from view. */ afterHidden() { return this._onHide.asObservable(); } } TypeaheadContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TypeaheadContainerComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); TypeaheadContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: TypeaheadContainerComponent, selector: "hx-typeahead-container", host: { listeners: { "mouseleave": "focusLost()", "blur": "focusLost()" }, classAttribute: "hx-dropdown-menu" }, ngImport: i0, template: ` <!-- inject options list template --> <ng-template [ngTemplateOutlet]="optionsListTemplate || optionListTemplate" [ngTemplateOutletContext]="{ matches: matches, itemTemplate: itemTemplate, query: query }" ></ng-template> <!-- default options item template --> <ng-template #hxItemTemplate let-match="match" let-query="query" ><span [innerHtml]="hightlight(match, query)"></span ></ng-template> <!-- options list template --> <ng-template #optionListTemplate> <ng-template ngFor let-match let-i="index" [ngForOf]="matches"> <h6 *ngIf="match.isHeader()" class="hx-dropdown-header">{{ match }}</h6> <ng-template [ngIf]="!match.isHeader()"> <a href="#" class="hx-dropdown-item" (click)="selectMatch(match, $event)" (mouseenter)="selectActive(match)" [class.active]="isActive(match)" > <ng-template [ngTemplateOutlet]="itemTemplate || hxItemTemplate" [ngTemplateOutletContext]="{ item: match.item, index: i, match: match, query: query }" ></ng-template> </a> </ng-template> </ng-template> </ng-template> `, isInline: true, styles: ["strong.is-matched{background-color:#23312b3b}\n", ".hx-dropdown-item{font-weight:300}\n"], directives: [{ type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TypeaheadContainerComponent, decorators: [{ type: Component, args: [{ selector: 'hx-typeahead-container', // eslint-disable-next-line template: ` <!-- inject options list template --> <ng-template [ngTemplateOutlet]="optionsListTemplate || optionListTemplate" [ngTemplateOutletContext]="{ matches: matches, itemTemplate: itemTemplate, query: query }" ></ng-template> <!-- default options item template --> <ng-template #hxItemTemplate let-match="match" let-query="query" ><span [innerHtml]="hightlight(match, query)"></span ></ng-template> <!-- options list template --> <ng-template #optionListTemplate> <ng-template ngFor let-match let-i="index" [ngForOf]="matches"> <h6 *ngIf="match.isHeader()" class="hx-dropdown-header">{{ match }}</h6> <ng-template [ngIf]="!match.isHeader()"> <a href="#" class="hx-dropdown-item" (click)="selectMatch(match, $event)" (mouseenter)="selectActive(match)" [class.active]="isActive(match)" > <ng-template [ngTemplateOutlet]="itemTemplate || hxItemTemplate" [ngTemplateOutletContext]="{ item: match.item, index: i, match: match, query: query }" ></ng-template> </a> </ng-template> </ng-template> </ng-template> `, /* eslint-disable */ host: { class: 'hx-dropdown-menu' }, // tslint: enable encapsulation: ViewEncapsulation.None, styles: [ 'strong.is-matched { background-color: rgba(35, 49, 43, .23) }', '.hx-dropdown-item { font-weight: 300 }' ] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { focusLost: [{ type: HostListener, args: ['mouseleave'] }, { type: HostListener, args: ['blur'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typeahead-container.component.js","sourceRoot":"","sources":["../../../../../projects/hx-ui/src/lib/typeahead/typeahead-container.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EAEZ,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAE3C,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;;;AA4D7C,MAAM,OAAO,2BAA2B;IAqBtC,YACU,OAAmB,EACnB,mBAAsC;QADtC,YAAO,GAAP,OAAO,CAAY;QACnB,wBAAmB,GAAnB,mBAAmB,CAAmB;QApBzC,cAAS,GAAY,KAAK,CAAC;QAOxB,aAAQ,GAAqB,EAAE,CAAC;QAE1C,2EAA2E;QAC1D,YAAO,GAAiB,IAAI,OAAO,EAAE,CAAC;IAWpD,CAAC;IAEJ,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IAAW,OAAO,CAAC,KAAuB;QACxC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QAEtB,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YAC5B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAChC,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE;gBAC3B,IAAI,CAAC,eAAe,EAAE,CAAC;aACxB;SACF;IACH,CAAC;IAED,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC;IACnE,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC,CAAC,SAAS,CAAC;IACrE,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAEM,eAAe;QACpB,IAAI,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC/C,IAAI,CAAC,OAAO;YACV,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QACpE,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE;YAC3B,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;IACH,CAAC;IAEM,eAAe;QACpB,IAAI,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC/C,IAAI,CAAC,OAAO;YACV,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QACpE,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE;YAC3B,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;IACH,CAAC;IAEM,YAAY,CAAC,KAAqB;QACvC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAEM,UAAU,CAAC,KAAqB,EAAE,KAAU;QACjD,IAAI,OAAO,GAAW,KAAK,CAAC,KAAK,CAAC;QAClC,IAAI,aAAa,GAAW,CAC1B,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAC3E,CAAC,WAAW,EAAE,CAAC;QAChB,IAAI,QAAgB,CAAC;QACrB,IAAI,QAAgB,CAAC;QACrB,4EAA4E;QAC5E,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,IAAI,QAAQ,GAAW,KAAK,CAAC,MAAM,CAAC;YACpC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,EAAE,CAAC,IAAI,CAAC,EAAE;gBACpC,+CAA+C;gBAC/C,QAAQ,GAAG,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC3C,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;gBAC3B,IAAI,QAAQ,IAAI,CAAC,IAAI,QAAQ,GAAG,CAAC,EAAE;oBACjC,OAAO;wBACL,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC;4BAC9B,6BAA6B;4BAC7B,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,QAAQ,GAAG,QAAQ,CAAC;4BAChD,WAAW;4BACX,OAAO,CAAC,SAAS,CAAC,QAAQ,GAAG,QAAQ,CAAC,CAAC;oBACzC,aAAa;wBACX,aAAa,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC;4BACpC,UAAU;4BACV,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC;4BACpB,WAAW;4BACX,aAAa,CAAC,SAAS,CAAC,QAAQ,GAAG,QAAQ,CAAC,CAAC;iBAChD;aACF;SACF;aAAM,IAAI,KAAK,EAAE;YAChB,4CAA4C;YAC5C,QAAQ,GAAG,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACxC,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC;YACxB,IAAI,QAAQ,IAAI,CAAC,IAAI,QAAQ,GAAG,CAAC,EAAE;gBACjC,OAAO;oBACL,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC;wBAC9B,8BAA8B;wBAC9B,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,QAAQ,GAAG,QAAQ,CAAC;wBAChD,WAAW;wBACX,OAAO,CAAC,SAAS,CAAC,QAAQ,GAAG,QAAQ,CAAC,CAAC;aAC1C;SACF;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAIM,SAAS;QACd,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAEM,QAAQ,CAAC,KAAqB;QACnC,OAAO,IAAI,CAAC,OAAO,KAAK,KAAK,CAAC;IAChC,CAAC;IAEM,WAAW,CAAC,KAAqB,EAAE,IAAW,KAAK,CAAC;QACzD,IAAI,CAAC,EAAE;YACL,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,CAAC,CAAC,cAAc,EAAE,CAAC;SACpB;QACD,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAC/B,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/D,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,CAAC,KAAa;QAChB,6CAA6C;QAC7C,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YAC3C,oEAAoE;YACpE,yCAAyC;YACzC,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,CAAC;YACxC,uCAAuC;QACzC,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAED;;;OAGG;IACH,IAAI,CAAC,KAAa;QAChB,6CAA6C;QAC7C,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACnC;QAED,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YAC3C,uCAAuC;YACvC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1B,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAED,uFAAuF;IACvF,WAAW;QACT,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;;yHAjLU,2BAA2B;6GAA3B,2BAA2B,+KAtD5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CT;4FAYU,2BAA2B;kBAzDvC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,2BAA2B;oBAC3B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CT;oBACD,oBAAoB;oBACpB,IAAI,EAAE;wBACJ,KAAK,EAAE,kBAAkB;qBAC1B;oBACD,iBAAiB;oBACjB,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,MAAM,EAAE;wBACN,+DAA+D;wBAC/D,wCAAwC;qBACzC;iBACF;iIAgIQ,SAAS;sBAFf,YAAY;uBAAC,YAAY;;sBACzB,YAAY;uBAAC,MAAM","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  TemplateRef,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { TypeaheadMatch } from './typeahead-match.class';\r\nimport { latinize } from './typeahead-utils';\r\nimport { TypeaheadDirective } from './typeahead.directive';\r\n\r\n@Component({\r\n  selector: 'hx-typeahead-container',\r\n  // eslint-disable-next-line\r\n  template: `\r\n    <!-- inject options list template -->\r\n    <ng-template\r\n      [ngTemplateOutlet]=\"optionsListTemplate || optionListTemplate\"\r\n      [ngTemplateOutletContext]=\"{\r\n        matches: matches,\r\n        itemTemplate: itemTemplate,\r\n        query: query\r\n      }\"\r\n    ></ng-template>\r\n\r\n    <!-- default options item template -->\r\n    <ng-template #hxItemTemplate let-match=\"match\" let-query=\"query\"\r\n      ><span [innerHtml]=\"hightlight(match, query)\"></span\r\n    ></ng-template>\r\n\r\n    <!-- options list template -->\r\n    <ng-template #optionListTemplate>\r\n      <ng-template ngFor let-match let-i=\"index\" [ngForOf]=\"matches\">\r\n        <h6 *ngIf=\"match.isHeader()\" class=\"hx-dropdown-header\">{{ match }}</h6>\r\n\r\n        <ng-template [ngIf]=\"!match.isHeader()\">\r\n          <a\r\n            href=\"#\"\r\n            class=\"hx-dropdown-item\"\r\n            (click)=\"selectMatch(match, $event)\"\r\n            (mouseenter)=\"selectActive(match)\"\r\n            [class.active]=\"isActive(match)\"\r\n          >\r\n            <ng-template\r\n              [ngTemplateOutlet]=\"itemTemplate || hxItemTemplate\"\r\n              [ngTemplateOutletContext]=\"{\r\n                item: match.item,\r\n                index: i,\r\n                match: match,\r\n                query: query\r\n              }\"\r\n            ></ng-template>\r\n          </a>\r\n        </ng-template>\r\n      </ng-template>\r\n    </ng-template>\r\n  `,\r\n  /* eslint-disable */\r\n  host: {\r\n    class: 'hx-dropdown-menu'\r\n  },\r\n  // tslint: enable\r\n  encapsulation: ViewEncapsulation.None,\r\n  styles: [\r\n    'strong.is-matched { background-color: rgba(35, 49, 43, .23) }',\r\n    '.hx-dropdown-item { font-weight: 300 }'\r\n  ]\r\n})\r\nexport class TypeaheadContainerComponent {\r\n  public parent: TypeaheadDirective;\r\n  public query: any;\r\n  public isFocused: boolean = false;\r\n  public top: string;\r\n  public left: string;\r\n  public display: string;\r\n  public placement: string;\r\n\r\n  protected _active: TypeaheadMatch;\r\n  protected _matches: TypeaheadMatch[] = [];\r\n\r\n  /** Subject for notifying that the tooltip has been hidden from the view */\r\n  private readonly _onHide: Subject<any> = new Subject();\r\n\r\n  /** The timeout ID of any current timer set to show the tooltip */\r\n  private _showTimeoutId: number;\r\n\r\n  /** The timeout ID of any current timer set to hide the tooltip */\r\n  private _hideTimeoutId: number;\r\n\r\n  public constructor(\r\n    private element: ElementRef,\r\n    private _changeDetectionRef: ChangeDetectorRef\r\n  ) {}\r\n\r\n  public get active(): TypeaheadMatch {\r\n    return this._active;\r\n  }\r\n\r\n  public get matches(): TypeaheadMatch[] {\r\n    return this._matches;\r\n  }\r\n\r\n  public set matches(value: TypeaheadMatch[]) {\r\n    this._matches = value;\r\n\r\n    if (this._matches.length > 0) {\r\n      this._active = this._matches[0];\r\n      if (this._active.isHeader()) {\r\n        this.nextActiveMatch();\r\n      }\r\n    }\r\n  }\r\n\r\n  public get optionsListTemplate(): TemplateRef<any> {\r\n    return this.parent ? this.parent.optionsListTemplate : undefined;\r\n  }\r\n\r\n  public get itemTemplate(): TemplateRef<any> {\r\n    return this.parent ? this.parent.typeaheadItemTemplate : undefined;\r\n  }\r\n\r\n  public selectActiveMatch(): void {\r\n    this.selectMatch(this._active);\r\n  }\r\n\r\n  public prevActiveMatch(): void {\r\n    let index = this.matches.indexOf(this._active);\r\n    this._active =\r\n      this.matches[index - 1 < 0 ? this.matches.length - 1 : index - 1];\r\n    if (this._active.isHeader()) {\r\n      this.prevActiveMatch();\r\n    }\r\n  }\r\n\r\n  public nextActiveMatch(): void {\r\n    let index = this.matches.indexOf(this._active);\r\n    this._active =\r\n      this.matches[index + 1 > this.matches.length - 1 ? 0 : index + 1];\r\n    if (this._active.isHeader()) {\r\n      this.nextActiveMatch();\r\n    }\r\n  }\r\n\r\n  public selectActive(value: TypeaheadMatch): void {\r\n    this.isFocused = true;\r\n    this._active = value;\r\n  }\r\n\r\n  public hightlight(match: TypeaheadMatch, query: any): string {\r\n    let itemStr: string = match.value;\r\n    let itemStrHelper: string = (\r\n      this.parent && this.parent.typeaheadLatinize ? latinize(itemStr) : itemStr\r\n    ).toLowerCase();\r\n    let startIdx: number;\r\n    let tokenLen: number;\r\n    // Replaces the capture string with the same string inside of a \"strong\" tag\r\n    if (typeof query === 'object') {\r\n      let queryLen: number = query.length;\r\n      for (let i = 0; i < queryLen; i += 1) {\r\n        // query[i] is already latinized and lower case\r\n        startIdx = itemStrHelper.indexOf(query[i]);\r\n        tokenLen = query[i].length;\r\n        if (startIdx >= 0 && tokenLen > 0) {\r\n          itemStr =\r\n            itemStr.substring(0, startIdx) +\r\n            '<strong class=\"is-matched\">' +\r\n            itemStr.substring(startIdx, startIdx + tokenLen) +\r\n            '</strong>' +\r\n            itemStr.substring(startIdx + tokenLen);\r\n          itemStrHelper =\r\n            itemStrHelper.substring(0, startIdx) +\r\n            '        ' +\r\n            ' '.repeat(tokenLen) +\r\n            '         ' +\r\n            itemStrHelper.substring(startIdx + tokenLen);\r\n        }\r\n      }\r\n    } else if (query) {\r\n      // query is already latinized and lower case\r\n      startIdx = itemStrHelper.indexOf(query);\r\n      tokenLen = query.length;\r\n      if (startIdx >= 0 && tokenLen > 0) {\r\n        itemStr =\r\n          itemStr.substring(0, startIdx) +\r\n          '<strong  class=\"is-matched\">' +\r\n          itemStr.substring(startIdx, startIdx + tokenLen) +\r\n          '</strong>' +\r\n          itemStr.substring(startIdx + tokenLen);\r\n      }\r\n    }\r\n    return itemStr;\r\n  }\r\n\r\n  @HostListener('mouseleave')\r\n  @HostListener('blur')\r\n  public focusLost(): void {\r\n    this.isFocused = false;\r\n  }\r\n\r\n  public isActive(value: TypeaheadMatch): boolean {\r\n    return this._active === value;\r\n  }\r\n\r\n  public selectMatch(value: TypeaheadMatch, e: Event = void 0): boolean {\r\n    if (e) {\r\n      e.stopPropagation();\r\n      e.preventDefault();\r\n    }\r\n    this.parent.changeModel(value);\r\n    setTimeout(() => this.parent.typeaheadOnSelect.emit(value), 0);\r\n    return false;\r\n  }\r\n\r\n  show(delay: number): void {\r\n    // Cancel the delayed hide if it is scheduled\r\n    if (this._hideTimeoutId) {\r\n      clearTimeout(this._hideTimeoutId);\r\n    }\r\n    this._showTimeoutId = window.setTimeout(() => {\r\n      // Schedule for change detection incase the tooltip is used within a\r\n      // component with OnPush change detection\r\n      this._changeDetectionRef.markForCheck();\r\n      //this.visibility = Visibility.Visible;\r\n    }, delay);\r\n  }\r\n\r\n  /**\r\n   * Hide the tooltip after the provided delay in ms.\r\n   * @param delay Amount of milliseconds to delay hiding the tooltip.\r\n   */\r\n  hide(delay: number): void {\r\n    // Cancel the delayed show if it is scheduled\r\n    if (this._showTimeoutId) {\r\n      clearTimeout(this._showTimeoutId);\r\n    }\r\n\r\n    this._hideTimeoutId = window.setTimeout(() => {\r\n      // this.visibility = Visibility.Hidden;\r\n      this._onHide.next(true);\r\n    }, delay);\r\n  }\r\n\r\n  /** Returns an observable that notifies when the dropdown has been hidden from view. */\r\n  afterHidden(): Observable<void> {\r\n    return this._onHide.asObservable();\r\n  }\r\n}\r\n"]}