ngx-bootstrap
Version:
Native Angular Bootstrap Components
566 lines • 47.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
// tslint:disable:max-file-line-count max-line-length
import { Component, ElementRef, HostListener, QueryList, Renderer2, ViewChild, ViewChildren } from '@angular/core';
import { isBs3, Utils } from 'ngx-bootstrap/utils';
import { PositioningService } from 'ngx-bootstrap/positioning';
import { latinize } from './typeahead-utils';
import { typeaheadAnimation } from './typeahead-animations';
import { take } from 'rxjs/operators';
var TypeaheadContainerComponent = /** @class */ (function () {
function TypeaheadContainerComponent(positionService, renderer, element) {
this.positionService = positionService;
this.renderer = renderer;
this.element = element;
this.isFocused = false;
this.visibility = 'hidden';
this.height = 0;
this._matches = [];
this.isScrolledIntoView = (/**
* @param {?} elem
* @return {?}
*/
function (elem) {
/** @type {?} */
var containerViewTop = this.ulElement.nativeElement.scrollTop;
/** @type {?} */
var containerViewBottom = containerViewTop + Number(this.ulElement.nativeElement.offsetHeight);
/** @type {?} */
var elemTop = elem.offsetTop;
/** @type {?} */
var elemBottom = elemTop + elem.offsetHeight;
return ((elemBottom <= containerViewBottom) && (elemTop >= containerViewTop));
});
}
Object.defineProperty(TypeaheadContainerComponent.prototype, "isBs4", {
get: /**
* @return {?}
*/
function () {
return !isBs3();
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "active", {
get: /**
* @return {?}
*/
function () {
return this._active;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "matches", {
get: /**
* @return {?}
*/
function () {
return this._matches;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
var _this = this;
this.positionService.setOptions({
modifiers: { flip: { enabled: this.adaptivePosition } },
allowedPositions: ['top', 'bottom']
});
this.positionService.event$
.pipe(take(1))
.subscribe((/**
* @return {?}
*/
function () {
_this.positionService.disable();
_this.visibility = _this.typeaheadScrollable ? 'hidden' : 'visible';
if (_this.isAnimated) {
_this.animationState = _this.isTopPosition ? 'animated-up' : 'animated-down';
return;
}
_this.animationState = 'unanimated';
}));
this._matches = value;
this.needScrollbar = this.typeaheadScrollable && this.typeaheadOptionsInScrollableView < this.matches.length;
if (this.typeaheadScrollable) {
setTimeout((/**
* @return {?}
*/
function () {
_this.setScrollableMode();
}));
}
if (this.typeaheadIsFirstItemActive && this._matches.length > 0) {
this._active = this._matches[0];
if (this._active.isHeader()) {
this.nextActiveMatch();
}
}
if (this._active && !this.typeaheadIsFirstItemActive) {
/** @type {?} */
var concurrency = this._matches.find((/**
* @param {?} match
* @return {?}
*/
function (match) { return match.value === _this._active.value; }));
if (concurrency) {
this.selectActive(concurrency);
return;
}
this._active = null;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "isTopPosition", {
get: /**
* @return {?}
*/
function () {
return this.element.nativeElement.classList.contains('top');
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "optionsListTemplate", {
// tslint:disable-next-line:no-any
get:
// tslint:disable-next-line:no-any
/**
* @return {?}
*/
function () {
return this.parent ? this.parent.optionsListTemplate : undefined;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "isAnimated", {
get: /**
* @return {?}
*/
function () {
return this.parent ? this.parent.isAnimated : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "adaptivePosition", {
get: /**
* @return {?}
*/
function () {
return this.parent ? this.parent.adaptivePosition : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "typeaheadScrollable", {
get: /**
* @return {?}
*/
function () {
return this.parent ? this.parent.typeaheadScrollable : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "typeaheadOptionsInScrollableView", {
get: /**
* @return {?}
*/
function () {
return this.parent ? this.parent.typeaheadOptionsInScrollableView : 5;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "typeaheadIsFirstItemActive", {
get: /**
* @return {?}
*/
function () {
return this.parent ? this.parent.typeaheadIsFirstItemActive : true;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TypeaheadContainerComponent.prototype, "itemTemplate", {
// tslint:disable-next-line:no-any
get:
// tslint:disable-next-line:no-any
/**
* @return {?}
*/
function () {
return this.parent ? this.parent.typeaheadItemTemplate : undefined;
},
enumerable: true,
configurable: true
});
/**
* @param {?=} isActiveItemChanged
* @return {?}
*/
TypeaheadContainerComponent.prototype.selectActiveMatch = /**
* @param {?=} isActiveItemChanged
* @return {?}
*/
function (isActiveItemChanged) {
if (this._active && this.parent.typeaheadSelectFirstItem) {
this.selectMatch(this._active);
}
if (!this.parent.typeaheadSelectFirstItem && isActiveItemChanged) {
this.selectMatch(this._active);
}
};
/**
* @return {?}
*/
TypeaheadContainerComponent.prototype.positionServiceEnable = /**
* @return {?}
*/
function () {
this.positionService.enable();
};
/**
* @return {?}
*/
TypeaheadContainerComponent.prototype.prevActiveMatch = /**
* @return {?}
*/
function () {
/** @type {?} */
var 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();
}
if (this.typeaheadScrollable) {
this.scrollPrevious(index);
}
};
/**
* @return {?}
*/
TypeaheadContainerComponent.prototype.nextActiveMatch = /**
* @return {?}
*/
function () {
/** @type {?} */
var 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();
}
if (this.typeaheadScrollable) {
this.scrollNext(index);
}
};
/**
* @param {?} value
* @return {?}
*/
TypeaheadContainerComponent.prototype.selectActive = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.isFocused = true;
this._active = value;
};
/**
* @param {?} match
* @param {?} query
* @return {?}
*/
TypeaheadContainerComponent.prototype.highlight = /**
* @param {?} match
* @param {?} query
* @return {?}
*/
function (match, query) {
/** @type {?} */
var itemStr = match.value;
/** @type {?} */
var itemStrHelper = (this.parent && this.parent.typeaheadLatinize
? latinize(itemStr)
: itemStr).toLowerCase();
/** @type {?} */
var startIdx;
/** @type {?} */
var tokenLen;
// Replaces the capture string with the same string inside of a "strong" tag
if (typeof query === 'object') {
/** @type {?} */
var queryLen = query.length;
for (var 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>" + 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>" + itemStr.substring(startIdx, startIdx + tokenLen) + "</strong>" +
("" + itemStr.substring(startIdx + tokenLen));
}
}
return itemStr;
};
/**
* @return {?}
*/
TypeaheadContainerComponent.prototype.focusLost = /**
* @return {?}
*/
function () {
this.isFocused = false;
};
/**
* @param {?} value
* @return {?}
*/
TypeaheadContainerComponent.prototype.isActive = /**
* @param {?} value
* @return {?}
*/
function (value) {
return this._active === value;
};
/**
* @param {?} value
* @param {?=} e
* @return {?}
*/
TypeaheadContainerComponent.prototype.selectMatch = /**
* @param {?} value
* @param {?=} e
* @return {?}
*/
function (value, e) {
var _this = this;
if (e === void 0) { e = void 0; }
if (e) {
e.stopPropagation();
e.preventDefault();
}
this.parent.changeModel(value);
setTimeout((/**
* @return {?}
*/
function () { return _this.parent.typeaheadOnSelect.emit(value); }), 0);
return false;
};
/**
* @return {?}
*/
TypeaheadContainerComponent.prototype.setScrollableMode = /**
* @return {?}
*/
function () {
if (!this.ulElement) {
this.ulElement = this.element;
}
if (this.liElements.first) {
/** @type {?} */
var ulStyles = Utils.getStyles(this.ulElement.nativeElement);
/** @type {?} */
var liStyles = Utils.getStyles(this.liElements.first.nativeElement);
/** @type {?} */
var ulPaddingBottom = parseFloat((ulStyles['padding-bottom'] ? ulStyles['padding-bottom'] : '')
.replace('px', ''));
/** @type {?} */
var ulPaddingTop = parseFloat((ulStyles['padding-top'] ? ulStyles['padding-top'] : '0')
.replace('px', ''));
/** @type {?} */
var optionHeight = parseFloat((liStyles.height ? liStyles.height : '0')
.replace('px', ''));
/** @type {?} */
var height = this.typeaheadOptionsInScrollableView * optionHeight;
this.guiHeight = height + ulPaddingTop + ulPaddingBottom + "px";
}
this.renderer.setStyle(this.element.nativeElement, 'visibility', 'visible');
};
/**
* @param {?} index
* @return {?}
*/
TypeaheadContainerComponent.prototype.scrollPrevious = /**
* @param {?} index
* @return {?}
*/
function (index) {
if (index === 0) {
this.scrollToBottom();
return;
}
if (this.liElements) {
/** @type {?} */
var liElement = this.liElements.toArray()[index - 1];
if (liElement && !this.isScrolledIntoView(liElement.nativeElement)) {
this.ulElement.nativeElement.scrollTop = liElement.nativeElement.offsetTop;
}
}
};
/**
* @param {?} index
* @return {?}
*/
TypeaheadContainerComponent.prototype.scrollNext = /**
* @param {?} index
* @return {?}
*/
function (index) {
if (index + 1 > this.matches.length - 1) {
this.scrollToTop();
return;
}
if (this.liElements) {
/** @type {?} */
var liElement = this.liElements.toArray()[index + 1];
if (liElement && !this.isScrolledIntoView(liElement.nativeElement)) {
this.ulElement.nativeElement.scrollTop =
liElement.nativeElement.offsetTop -
Number(this.ulElement.nativeElement.offsetHeight) +
Number(liElement.nativeElement.offsetHeight);
}
}
};
/**
* @private
* @return {?}
*/
TypeaheadContainerComponent.prototype.scrollToBottom = /**
* @private
* @return {?}
*/
function () {
this.ulElement.nativeElement.scrollTop = this.ulElement.nativeElement.scrollHeight;
};
/**
* @private
* @return {?}
*/
TypeaheadContainerComponent.prototype.scrollToTop = /**
* @private
* @return {?}
*/
function () {
this.ulElement.nativeElement.scrollTop = 0;
};
TypeaheadContainerComponent.decorators = [
{ type: Component, args: [{
selector: 'typeahead-container',
template: "<!-- inject options list template -->\n<ng-template [ngTemplateOutlet]=\"optionsListTemplate || (isBs4 ? bs4Template : bs3Template)\"\n [ngTemplateOutletContext]=\"{matches:matches, itemTemplate:itemTemplate, query:query}\"></ng-template>\n\n<!-- default options item template -->\n<ng-template #bsItemTemplate let-match=\"match\" let-query=\"query\"><span [innerHtml]=\"highlight(match, query)\"></span>\n</ng-template>\n\n<!-- Bootstrap 3 options list template -->\n<ng-template #bs3Template>\n <ul class=\"dropdown-menu\"\n #ulElement\n [style.overflow-y]=\"needScrollbar ? 'scroll': 'auto'\"\n [style.height]=\"needScrollbar ? guiHeight: 'auto'\">\n <ng-template ngFor let-match let-i=\"index\" [ngForOf]=\"matches\">\n <li #liElements *ngIf=\"match.isHeader()\" class=\"dropdown-header\">{{ match }}</li>\n <li #liElements\n *ngIf=\"!match.isHeader()\"\n [@typeaheadAnimation]=\"animationState\"\n (@typeaheadAnimation.done)=\"positionServiceEnable()\"\n [class.active]=\"isActive(match)\"\n (mouseenter)=\"selectActive(match)\">\n\n <a href=\"#\" (click)=\"selectMatch(match, $event)\" tabindex=\"-1\">\n <ng-template [ngTemplateOutlet]=\"itemTemplate || bsItemTemplate\"\n [ngTemplateOutletContext]=\"{item:match.item, index:i, match:match, query:query}\"></ng-template>\n </a>\n </li>\n </ng-template>\n </ul>\n</ng-template>\n\n<!-- Bootstrap 4 options list template -->\n<ng-template #bs4Template>\n <ng-template ngFor let-match let-i=\"index\" [ngForOf]=\"matches\">\n <h6 *ngIf=\"match.isHeader()\" class=\"dropdown-header\">{{ match }}</h6>\n <ng-template [ngIf]=\"!match.isHeader()\">\n <button #liElements\n [@typeaheadAnimation]=\"animationState\"\n (@typeaheadAnimation.done)=\"positionServiceEnable()\"\n class=\"dropdown-item\"\n (click)=\"selectMatch(match, $event)\"\n (mouseenter)=\"selectActive(match)\"\n [class.active]=\"isActive(match)\">\n <ng-template [ngTemplateOutlet]=\"itemTemplate || bsItemTemplate\"\n [ngTemplateOutletContext]=\"{item:match.item, index:i, match:match, query:query}\"></ng-template>\n </button>\n </ng-template>\n </ng-template>\n</ng-template>\n",
host: {
class: 'dropdown open bottom',
'[class.dropdown-menu]': 'isBs4',
'[style.overflow-y]': "isBs4 && needScrollbar ? 'scroll': 'visible'",
'[style.height]': "isBs4 && needScrollbar ? guiHeight: 'auto'",
'[style.visibility]': "visibility",
'[class.dropup]': 'dropup',
style: 'position: absolute;display: block;'
},
animations: [typeaheadAnimation],
styles: ["\n :host.dropdown {\n z-index: 1000;\n }\n "]
}] }
];
/** @nocollapse */
TypeaheadContainerComponent.ctorParameters = function () { return [
{ type: PositioningService },
{ type: Renderer2 },
{ type: ElementRef }
]; };
TypeaheadContainerComponent.propDecorators = {
ulElement: [{ type: ViewChild, args: ['ulElement', { static: false },] }],
liElements: [{ type: ViewChildren, args: ['liElements',] }],
focusLost: [{ type: HostListener, args: ['mouseleave',] }, { type: HostListener, args: ['blur',] }]
};
return TypeaheadContainerComponent;
}());
export { TypeaheadContainerComponent };
if (false) {
/** @type {?} */
TypeaheadContainerComponent.prototype.parent;
/** @type {?} */
TypeaheadContainerComponent.prototype.query;
/** @type {?} */
TypeaheadContainerComponent.prototype.isFocused;
/** @type {?} */
TypeaheadContainerComponent.prototype.top;
/** @type {?} */
TypeaheadContainerComponent.prototype.left;
/** @type {?} */
TypeaheadContainerComponent.prototype.display;
/** @type {?} */
TypeaheadContainerComponent.prototype.placement;
/** @type {?} */
TypeaheadContainerComponent.prototype.dropup;
/** @type {?} */
TypeaheadContainerComponent.prototype.guiHeight;
/** @type {?} */
TypeaheadContainerComponent.prototype.needScrollbar;
/** @type {?} */
TypeaheadContainerComponent.prototype.animationState;
/** @type {?} */
TypeaheadContainerComponent.prototype.visibility;
/** @type {?} */
TypeaheadContainerComponent.prototype.height;
/**
* @type {?}
* @protected
*/
TypeaheadContainerComponent.prototype._active;
/**
* @type {?}
* @protected
*/
TypeaheadContainerComponent.prototype._matches;
/**
* @type {?}
* @private
*/
TypeaheadContainerComponent.prototype.ulElement;
/**
* @type {?}
* @private
*/
TypeaheadContainerComponent.prototype.liElements;
/**
* @type {?}
* @private
*/
TypeaheadContainerComponent.prototype.isScrolledIntoView;
/**
* @type {?}
* @private
*/
TypeaheadContainerComponent.prototype.positionService;
/**
* @type {?}
* @private
*/
TypeaheadContainerComponent.prototype.renderer;
/** @type {?} */
TypeaheadContainerComponent.prototype.element;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typeahead-container.component.js","sourceRoot":"ng://ngx-bootstrap/typeahead/","sources":["typeahead-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable:max-file-line-count max-line-length\nimport {\n  Component,\n  ElementRef,\n  HostListener,\n  QueryList,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewChildren\n} from '@angular/core';\n\nimport { isBs3, Utils } from 'ngx-bootstrap/utils';\nimport { PositioningService } from 'ngx-bootstrap/positioning';\n\nimport { latinize } from './typeahead-utils';\nimport { TypeaheadMatch } from './typeahead-match.class';\nimport { TypeaheadDirective } from './typeahead.directive';\nimport { typeaheadAnimation } from './typeahead-animations';\n\nimport { take } from 'rxjs/operators';\n\n\n@Component({\n  selector: 'typeahead-container',\n  templateUrl: './typeahead-container.component.html',\n  host: {\n    class: 'dropdown open bottom',\n    '[class.dropdown-menu]': 'isBs4',\n    '[style.overflow-y]' : `isBs4 && needScrollbar ? 'scroll': 'visible'`,\n    '[style.height]': `isBs4 && needScrollbar ? guiHeight: 'auto'`,\n    '[style.visibility]': `visibility`,\n    '[class.dropup]': 'dropup',\n    style: 'position: absolute;display: block;'\n  },\n  styles: [\n    `\n    :host.dropdown {\n      z-index: 1000;\n    }\n  `\n  ],\n  animations: [typeaheadAnimation]\n})\nexport class TypeaheadContainerComponent {\n  parent: TypeaheadDirective;\n  query: string[] | string;\n  isFocused = false;\n  top: string;\n  left: string;\n  display: string;\n  placement: string;\n  dropup: boolean;\n  guiHeight: string;\n  needScrollbar: boolean;\n  animationState: string;\n  visibility = 'hidden';\n  height = 0;\n\n  get isBs4(): boolean {\n    return !isBs3();\n  }\n\n  protected _active: TypeaheadMatch;\n  protected _matches: TypeaheadMatch[] = [];\n\n  @ViewChild('ulElement', { static: false })\n  private ulElement: ElementRef;\n\n  @ViewChildren('liElements')\n  private liElements: QueryList<ElementRef>;\n\n  constructor(\n    private positionService: PositioningService,\n    private renderer: Renderer2,\n    public element: ElementRef\n  ) { }\n\n  get active(): TypeaheadMatch {\n    return this._active;\n  }\n\n  get matches(): TypeaheadMatch[] {\n    return this._matches;\n  }\n\n  set matches(value: TypeaheadMatch[]) {\n    this.positionService.setOptions({\n      modifiers: { flip: { enabled: this.adaptivePosition } },\n      allowedPositions: ['top', 'bottom']\n    });\n\n    this.positionService.event$\n      .pipe(\n        take(1)\n      )\n      .subscribe(() => {\n        this.positionService.disable();\n        this.visibility = this.typeaheadScrollable ? 'hidden' : 'visible';\n\n        if (this.isAnimated) {\n          this.animationState = this.isTopPosition ? 'animated-up' : 'animated-down';\n\n          return;\n        }\n\n        this.animationState = 'unanimated';\n      });\n\n    this._matches = value;\n\n    this.needScrollbar = this.typeaheadScrollable && this.typeaheadOptionsInScrollableView < this.matches.length;\n\n    if (this.typeaheadScrollable) {\n      setTimeout(() => {\n        this.setScrollableMode();\n      });\n    }\n\n    if (this.typeaheadIsFirstItemActive && this._matches.length > 0) {\n      this._active = this._matches[0];\n\n      if (this._active.isHeader()) {\n        this.nextActiveMatch();\n      }\n    }\n\n    if (this._active && !this.typeaheadIsFirstItemActive) {\n      const concurrency = this._matches.find(match => match.value === this._active.value);\n\n      if (concurrency) {\n        this.selectActive(concurrency);\n\n        return;\n      }\n\n      this._active = null;\n    }\n  }\n\n  get isTopPosition(): boolean {\n    return this.element.nativeElement.classList.contains('top');\n  }\n\n  // tslint:disable-next-line:no-any\n  get optionsListTemplate(): TemplateRef<any> {\n    return this.parent ? this.parent.optionsListTemplate : undefined;\n  }\n\n  get isAnimated(): boolean {\n    return this.parent ? this.parent.isAnimated : false;\n  }\n\n  get adaptivePosition(): boolean {\n    return this.parent ? this.parent.adaptivePosition : false;\n  }\n\n  get typeaheadScrollable(): boolean {\n    return this.parent ? this.parent.typeaheadScrollable : false;\n  }\n\n  get typeaheadOptionsInScrollableView(): number {\n    return this.parent ? this.parent.typeaheadOptionsInScrollableView : 5;\n  }\n\n  get typeaheadIsFirstItemActive(): boolean {\n    return this.parent ? this.parent.typeaheadIsFirstItemActive : true;\n  }\n// tslint:disable-next-line:no-any\n  get itemTemplate(): TemplateRef<any> {\n    return this.parent ? this.parent.typeaheadItemTemplate : undefined;\n  }\n\n  selectActiveMatch(isActiveItemChanged?: boolean): void {\n    if (this._active && this.parent.typeaheadSelectFirstItem) {\n      this.selectMatch(this._active);\n    }\n\n    if (!this.parent.typeaheadSelectFirstItem && isActiveItemChanged) {\n      this.selectMatch(this._active);\n    }\n  }\n\n  positionServiceEnable(): void {\n    this.positionService.enable();\n  }\n\n  prevActiveMatch(): void {\n    const index = this.matches.indexOf(this._active);\n\n    this._active = this.matches[\n      index - 1 < 0 ? this.matches.length - 1 : index - 1\n    ];\n\n    if (this._active.isHeader()) {\n      this.prevActiveMatch();\n    }\n\n    if (this.typeaheadScrollable) {\n      this.scrollPrevious(index);\n    }\n  }\n\n  nextActiveMatch(): void {\n    const index = this.matches.indexOf(this._active);\n\n    this._active = this.matches[\n      index + 1 > this.matches.length - 1 ? 0 : index + 1\n    ];\n\n    if (this._active.isHeader()) {\n      this.nextActiveMatch();\n    }\n\n    if (this.typeaheadScrollable) {\n      this.scrollNext(index);\n    }\n  }\n\n  selectActive(value: TypeaheadMatch): void {\n    this.isFocused = true;\n    this._active = value;\n  }\n\n  highlight(match: TypeaheadMatch, query: string[] | string): string {\n    let itemStr: string = match.value;\n    let itemStrHelper: string = (this.parent && this.parent.typeaheadLatinize\n      ? latinize(itemStr)\n      : itemStr).toLowerCase();\n    let startIdx: number;\n    let tokenLen: number;\n    // Replaces the capture string with the same string inside of a \"strong\" tag\n    if (typeof query === 'object') {\n      const queryLen: number = query.length;\n      for (let i = 0; i < queryLen; i += 1) {\n        // query[i] is already latinized and lower case\n        startIdx = itemStrHelper.indexOf(query[i]);\n        tokenLen = query[i].length;\n        if (startIdx >= 0 && tokenLen > 0) {\n          itemStr =\n            `${itemStr.substring(0, startIdx)}<strong>${itemStr.substring(startIdx, startIdx + tokenLen)}</strong>` +\n            `${itemStr.substring(startIdx + tokenLen)}`;\n          itemStrHelper =\n            `${itemStrHelper.substring(0, startIdx)}        ${' '.repeat(tokenLen)}         ` +\n            `${itemStrHelper.substring(startIdx + tokenLen)}`;\n        }\n      }\n    } else if (query) {\n      // query is already latinized and lower case\n      startIdx = itemStrHelper.indexOf(query);\n      tokenLen = query.length;\n      if (startIdx >= 0 && tokenLen > 0) {\n        itemStr =\n          `${itemStr.substring(0, startIdx)}<strong>${itemStr.substring(startIdx, startIdx + tokenLen)}</strong>` +\n          `${itemStr.substring(startIdx + tokenLen)}`;\n      }\n    }\n\n    return itemStr;\n  }\n\n  @HostListener('mouseleave')\n  @HostListener('blur')\n  focusLost(): void {\n    this.isFocused = false;\n  }\n\n  isActive(value: TypeaheadMatch): boolean {\n    return this._active === value;\n  }\n\n  selectMatch(value: TypeaheadMatch, e: Event = void 0): boolean {\n    if (e) {\n      e.stopPropagation();\n      e.preventDefault();\n    }\n    this.parent.changeModel(value);\n    setTimeout(() => this.parent.typeaheadOnSelect.emit(value), 0);\n\n    return false;\n  }\n\n  setScrollableMode(): void {\n    if (!this.ulElement) {\n      this.ulElement = this.element;\n    }\n    if (this.liElements.first) {\n      const ulStyles = Utils.getStyles(this.ulElement.nativeElement);\n      const liStyles = Utils.getStyles(this.liElements.first.nativeElement);\n      const ulPaddingBottom = parseFloat((ulStyles['padding-bottom'] ? ulStyles['padding-bottom'] : '')\n        .replace('px', ''));\n      const ulPaddingTop = parseFloat((ulStyles['padding-top'] ? ulStyles['padding-top'] : '0')\n        .replace('px', ''));\n      const optionHeight = parseFloat((liStyles.height ? liStyles.height : '0')\n        .replace('px', ''));\n      const height = this.typeaheadOptionsInScrollableView * optionHeight;\n      this.guiHeight = `${height + ulPaddingTop + ulPaddingBottom}px`;\n    }\n    this.renderer.setStyle(this.element.nativeElement, 'visibility', 'visible');\n  }\n\n  scrollPrevious(index: number): void {\n    if (index === 0) {\n      this.scrollToBottom();\n\n      return;\n    }\n    if (this.liElements) {\n      const liElement = this.liElements.toArray()[index - 1];\n      if (liElement && !this.isScrolledIntoView(liElement.nativeElement)) {\n        this.ulElement.nativeElement.scrollTop = liElement.nativeElement.offsetTop;\n      }\n    }\n  }\n\n  scrollNext(index: number): void {\n    if (index + 1 > this.matches.length - 1) {\n      this.scrollToTop();\n\n      return;\n    }\n    if (this.liElements) {\n      const liElement = this.liElements.toArray()[index + 1];\n      if (liElement && !this.isScrolledIntoView(liElement.nativeElement)) {\n        this.ulElement.nativeElement.scrollTop =\n          liElement.nativeElement.offsetTop -\n          Number(this.ulElement.nativeElement.offsetHeight) +\n          Number(liElement.nativeElement.offsetHeight);\n      }\n    }\n  }\n\n\n  private isScrolledIntoView = function (elem: HTMLElement) {\n    const containerViewTop: number = this.ulElement.nativeElement.scrollTop;\n    const containerViewBottom = containerViewTop + Number(this.ulElement.nativeElement.offsetHeight);\n    const elemTop = elem.offsetTop;\n    const elemBottom = elemTop + elem.offsetHeight;\n\n    return ((elemBottom <= containerViewBottom) && (elemTop >= containerViewTop));\n  };\n\n  private scrollToBottom(): void {\n    this.ulElement.nativeElement.scrollTop = this.ulElement.nativeElement.scrollHeight;\n  }\n\n  private scrollToTop(): void {\n    this.ulElement.nativeElement.scrollTop = 0;\n  }\n}\n"]}