UNPKG

@ng-bootstrap/ng-bootstrap

Version:
149 lines 15.5 kB
import { Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core'; import { toString } from '../util/util'; import { NgbHighlight } from './highlight'; import { NgFor, NgTemplateOutlet } from '@angular/common'; import * as i0 from "@angular/core"; class NgbTypeaheadWindow { constructor() { this.activeIdx = 0; /** * Flag indicating if the first row should be active initially */ this.focusFirst = true; /** * A function used to format a given result before display. This function should return a formatted string without any * HTML markup */ this.formatter = toString; /** * Event raised when user selects a particular result row */ this.selectEvent = new EventEmitter(); this.activeChangeEvent = new EventEmitter(); } hasActive() { return this.activeIdx > -1 && this.activeIdx < this.results.length; } getActive() { return this.results[this.activeIdx]; } markActive(activeIdx) { this.activeIdx = activeIdx; this._activeChanged(); } next() { if (this.activeIdx === this.results.length - 1) { this.activeIdx = this.focusFirst ? (this.activeIdx + 1) % this.results.length : -1; } else { this.activeIdx++; } this._activeChanged(); } prev() { if (this.activeIdx < 0) { this.activeIdx = this.results.length - 1; } else if (this.activeIdx === 0) { this.activeIdx = this.focusFirst ? this.results.length - 1 : -1; } else { this.activeIdx--; } this._activeChanged(); } resetActive() { this.activeIdx = this.focusFirst ? 0 : -1; this._activeChanged(); } select(item) { this.selectEvent.emit(item); } ngOnInit() { this.resetActive(); } _activeChanged() { this.activeChangeEvent.emit(this.activeIdx >= 0 ? this.id + '-' + this.activeIdx : undefined); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbTypeaheadWindow, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.6", type: NgbTypeaheadWindow, isStandalone: true, selector: "ngb-typeahead-window", inputs: { id: "id", focusFirst: "focusFirst", results: "results", term: "term", formatter: "formatter", resultTemplate: "resultTemplate", popupClass: "popupClass" }, outputs: { selectEvent: "select", activeChangeEvent: "activeChange" }, host: { attributes: { "role": "listbox" }, listeners: { "mousedown": "$event.preventDefault()" }, properties: { "class": "\"dropdown-menu show\" + (popupClass ? \" \" + popupClass : \"\")", "id": "id" } }, exportAs: ["ngbTypeaheadWindow"], ngImport: i0, template: ` <ng-template #rt let-result="result" let-term="term" let-formatter="formatter"> <ngb-highlight [result]="formatter(result)" [term]="term"></ngb-highlight> </ng-template> <ng-template ngFor [ngForOf]="results" let-result let-idx="index"> <button type="button" class="dropdown-item" role="option" [id]="id + '-' + idx" [class.active]="idx === activeIdx" (mouseenter)="markActive(idx)" (click)="select(result)" > <ng-template [ngTemplateOutlet]="resultTemplate || rt" [ngTemplateOutletContext]="{ result: result, term: term, formatter: formatter }" ></ng-template> </button> </ng-template> `, isInline: true, dependencies: [{ kind: "component", type: NgbHighlight, selector: "ngb-highlight", inputs: ["highlightClass", "result", "term", "accentSensitive"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], encapsulation: i0.ViewEncapsulation.None }); } } export { NgbTypeaheadWindow }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbTypeaheadWindow, decorators: [{ type: Component, args: [{ selector: 'ngb-typeahead-window', exportAs: 'ngbTypeaheadWindow', standalone: true, imports: [NgbHighlight, NgFor, NgTemplateOutlet], encapsulation: ViewEncapsulation.None, host: { '(mousedown)': '$event.preventDefault()', '[class]': '"dropdown-menu show" + (popupClass ? " " + popupClass : "")', role: 'listbox', '[id]': 'id', }, template: ` <ng-template #rt let-result="result" let-term="term" let-formatter="formatter"> <ngb-highlight [result]="formatter(result)" [term]="term"></ngb-highlight> </ng-template> <ng-template ngFor [ngForOf]="results" let-result let-idx="index"> <button type="button" class="dropdown-item" role="option" [id]="id + '-' + idx" [class.active]="idx === activeIdx" (mouseenter)="markActive(idx)" (click)="select(result)" > <ng-template [ngTemplateOutlet]="resultTemplate || rt" [ngTemplateOutletContext]="{ result: result, term: term, formatter: formatter }" ></ng-template> </button> </ng-template> `, }] }], propDecorators: { id: [{ type: Input }], focusFirst: [{ type: Input }], results: [{ type: Input }], term: [{ type: Input }], formatter: [{ type: Input }], resultTemplate: [{ type: Input }], popupClass: [{ type: Input }], selectEvent: [{ type: Output, args: ['select'] }], activeChangeEvent: [{ type: Output, args: ['activeChange'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typeahead-window.js","sourceRoot":"","sources":["../../../../src/typeahead/typeahead-window.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, TemplateRef, ViewEncapsulation } from '@angular/core';\n\nimport { toString } from '../util/util';\nimport { NgbHighlight } from './highlight';\nimport { NgFor, NgTemplateOutlet } from '@angular/common';\n\n/**\n * The context for the typeahead result template in case you want to override the default one.\n */\nexport interface ResultTemplateContext {\n\t/**\n\t * Your typeahead result item.\n\t */\n\tresult: any;\n\n\t/**\n\t * Search term from the `<input>` used to get current result.\n\t */\n\tterm: string;\n\n\t/**\n\t * The function which transforms the result into a string\n\t */\n\tformatter: (result: any) => string;\n}\n\n@Component({\n\tselector: 'ngb-typeahead-window',\n\texportAs: 'ngbTypeaheadWindow',\n\tstandalone: true,\n\timports: [NgbHighlight, NgFor, NgTemplateOutlet],\n\tencapsulation: ViewEncapsulation.None,\n\thost: {\n\t\t'(mousedown)': '$event.preventDefault()',\n\t\t'[class]': '\"dropdown-menu show\" + (popupClass ? \" \" + popupClass : \"\")',\n\t\trole: 'listbox',\n\t\t'[id]': 'id',\n\t},\n\ttemplate: `\n\t\t<ng-template #rt let-result=\"result\" let-term=\"term\" let-formatter=\"formatter\">\n\t\t\t<ngb-highlight [result]=\"formatter(result)\" [term]=\"term\"></ngb-highlight>\n\t\t</ng-template>\n\t\t<ng-template ngFor [ngForOf]=\"results\" let-result let-idx=\"index\">\n\t\t\t<button\n\t\t\t\ttype=\"button\"\n\t\t\t\tclass=\"dropdown-item\"\n\t\t\t\trole=\"option\"\n\t\t\t\t[id]=\"id + '-' + idx\"\n\t\t\t\t[class.active]=\"idx === activeIdx\"\n\t\t\t\t(mouseenter)=\"markActive(idx)\"\n\t\t\t\t(click)=\"select(result)\"\n\t\t\t>\n\t\t\t\t<ng-template\n\t\t\t\t\t[ngTemplateOutlet]=\"resultTemplate || rt\"\n\t\t\t\t\t[ngTemplateOutletContext]=\"{ result: result, term: term, formatter: formatter }\"\n\t\t\t\t></ng-template>\n\t\t\t</button>\n\t\t</ng-template>\n\t`,\n})\nexport class NgbTypeaheadWindow implements OnInit {\n\tactiveIdx = 0;\n\n\t/**\n\t *  The id for the typeahead window. The id should be unique and the same\n\t *  as the associated typeahead's id.\n\t */\n\t@Input() id: string;\n\n\t/**\n\t * Flag indicating if the first row should be active initially\n\t */\n\t@Input() focusFirst = true;\n\n\t/**\n\t * Typeahead match results to be displayed\n\t */\n\t@Input() results;\n\n\t/**\n\t * Search term used to get current results\n\t */\n\t@Input() term: string;\n\n\t/**\n\t * A function used to format a given result before display. This function should return a formatted string without any\n\t * HTML markup\n\t */\n\t@Input() formatter = toString;\n\n\t/**\n\t * A template to override a matching result default display\n\t */\n\t@Input() resultTemplate: TemplateRef<ResultTemplateContext>;\n\n\t/**\n\t * A custom class to append to the typeahead window\n\t *\n\t * @since 9.1.0\n\t */\n\t@Input() popupClass: string;\n\n\t/**\n\t * Event raised when user selects a particular result row\n\t */\n\t@Output('select') selectEvent = new EventEmitter();\n\n\t@Output('activeChange') activeChangeEvent = new EventEmitter();\n\n\thasActive() {\n\t\treturn this.activeIdx > -1 && this.activeIdx < this.results.length;\n\t}\n\n\tgetActive() {\n\t\treturn this.results[this.activeIdx];\n\t}\n\n\tmarkActive(activeIdx: number) {\n\t\tthis.activeIdx = activeIdx;\n\t\tthis._activeChanged();\n\t}\n\n\tnext() {\n\t\tif (this.activeIdx === this.results.length - 1) {\n\t\t\tthis.activeIdx = this.focusFirst ? (this.activeIdx + 1) % this.results.length : -1;\n\t\t} else {\n\t\t\tthis.activeIdx++;\n\t\t}\n\t\tthis._activeChanged();\n\t}\n\n\tprev() {\n\t\tif (this.activeIdx < 0) {\n\t\t\tthis.activeIdx = this.results.length - 1;\n\t\t} else if (this.activeIdx === 0) {\n\t\t\tthis.activeIdx = this.focusFirst ? this.results.length - 1 : -1;\n\t\t} else {\n\t\t\tthis.activeIdx--;\n\t\t}\n\t\tthis._activeChanged();\n\t}\n\n\tresetActive() {\n\t\tthis.activeIdx = this.focusFirst ? 0 : -1;\n\t\tthis._activeChanged();\n\t}\n\n\tselect(item) {\n\t\tthis.selectEvent.emit(item);\n\t}\n\n\tngOnInit() {\n\t\tthis.resetActive();\n\t}\n\n\tprivate _activeChanged() {\n\t\tthis.activeChangeEvent.emit(this.activeIdx >= 0 ? this.id + '-' + this.activeIdx : undefined);\n\t}\n}\n"]}