@hxui/angular
Version:
An Angular library based on the [HXUI design system](https://hxui.io).
258 lines (252 loc) • 28.1 kB
JavaScript
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":"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","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"]}