carbon-components-angular
Version:
Next generation components
641 lines • 65.7 kB
JavaScript
import { Component, Input, Output, EventEmitter, ViewChild, ViewChildren } from "@angular/core";
import { Observable, isObservable, of } from "rxjs";
import { first } from "rxjs/operators";
import { AbstractDropdownView } from "../abstract-dropdown-view.class";
import { watchFocusJump } from "../dropdowntools";
import * as i0 from "@angular/core";
import * as i1 from "carbon-components-angular/i18n";
import * as i2 from "@angular/common";
import * as i3 from "carbon-components-angular/icon";
/**
* ```html
* <cds-dropdown-list [items]="listItems"></cds-dropdown-list>
* ```
* ```typescript
* listItems = [
* {
* content: "item one",
* selected: false
* },
* {
* content: "item two",
* selected: false,
* },
* {
* content: "item three",
* selected: false
* },
* {
* content: "item four",
* selected: false
* }
* ];
* ```
*/
export class DropdownList {
/**
* Creates an instance of `DropdownList`.
*/
constructor(elementRef, i18n, appRef) {
this.elementRef = elementRef;
this.i18n = i18n;
this.appRef = appRef;
this.ariaLabel = this.i18n.get().DROPDOWN_LIST.LABEL;
/**
* Template to bind to items in the `DropdownList` (optional).
*/
this.listTpl = null;
/**
* Event to emit selection of a list item within the `DropdownList`.
*/
this.select = new EventEmitter();
/**
* Event to emit scroll event of a list within the `DropdownList`.
*/
this.scroll = new EventEmitter();
/**
* Event to suggest a blur on the view.
* Emits _after_ the first/last item has been focused.
* ex.
* ArrowUp -> focus first item
* ArrowUp -> emit event
*
* When this event fires focus should be placed on some element outside of the list - blurring the list as a result
*/
this.blurIntent = new EventEmitter();
/**
* Defines whether or not the `DropdownList` supports selecting multiple items as opposed to single
* item selection.
*/
this.type = "single";
/**
* Defines whether to show title attribute or not
*/
this.showTitles = true;
/**
* Defines the rendering size of the `DropdownList` input component.
*/
this.size = "md";
this.listId = `listbox-${DropdownList.listCount++}`;
this.highlightedItem = null;
/**
* Holds the list of items that will be displayed in the `DropdownList`.
* It differs from the the complete set of items when filtering is used (but
* it is always a subset of the total items in `DropdownList`).
*/
this.displayItems = [];
/**
* Maintains the index for the selected item within the `DropdownList`.
*/
this.index = -1;
/**
* Useful representation of the items, should be accessed via `getListItems`.
*/
this._items = [];
}
/**
* The list items belonging to the `DropdownList`.
*/
set items(value) {
if (isObservable(value)) {
if (this._itemsSubscription) {
this._itemsSubscription.unsubscribe();
}
this._itemsReady = new Observable((observer) => {
this._itemsSubscription = value.subscribe(v => {
this.updateList(v);
observer.next(true);
observer.complete();
});
});
this.onItemsReady(null);
}
else {
this.updateList(value);
}
this._originalItems = value;
}
get items() {
return this._originalItems;
}
/**
* Retrieves array of list items and index of the selected item after view has rendered.
* Additionally, any Observables for the `DropdownList` are initialized.
*/
ngAfterViewInit() {
this.index = this.getListItems().findIndex(item => item.selected);
this.setupFocusObservable();
setTimeout(() => {
this.doEmitSelect(true);
});
}
/**
* Removes any Observables on destruction of the component.
*/
ngOnDestroy() {
if (this.focusJump) {
this.focusJump.unsubscribe();
}
if (this._itemsSubscription) {
this._itemsSubscription.unsubscribe();
}
}
doEmitSelect(isUpdate = true) {
if (this.type === "single") {
this.select.emit({ item: this._items.find(item => item.selected), isUpdate: isUpdate });
}
else {
// abuse javascripts object mutability until we can break the API and switch to
// { items: [], isUpdate: true }
const selected = this.getSelected() || [];
selected["isUpdate"] = isUpdate;
this.select.emit(selected);
}
}
getItemId(index) {
return `${this.listId}-${index}`;
}
/**
* Updates the displayed list of items and then retrieves the most current properties for the `DropdownList` from the DOM.
*/
updateList(items) {
this._items = items.map(item => Object.assign({}, item));
this.displayItems = this._items;
this.updateIndex();
this.setupFocusObservable();
this.doEmitSelect();
}
/**
* Filters the items being displayed in the DOM list.
*/
filterBy(query = "") {
if (query) {
this.displayItems = this.getListItems().filter(item => item.content.toLowerCase().includes(query.toLowerCase()));
// Reset index if items were found
// Prevent selecting index in list that are undefined.
if (this.displayItems) {
this.index = 0;
}
}
else {
this.displayItems = this.getListItems();
}
this.updateIndex();
}
/**
* Initializes (or re-initializes) the Observable that handles switching focus to an element based on
* key input matching the first letter of the item in the list.
*/
setupFocusObservable() {
if (!this.list) {
return;
}
if (this.focusJump) {
this.focusJump.unsubscribe();
}
let elList = Array.from(this.list.nativeElement.querySelectorAll("li"));
this.focusJump = watchFocusJump(this.list.nativeElement, elList)
.subscribe(el => {
el.focus();
});
}
/**
* Returns the `ListItem` that is subsequent to the selected item in the `DropdownList`.
*/
getNextItem() {
if (this.index < this.displayItems.length - 1) {
this.index++;
}
return this.displayItems[this.index];
}
/**
* Returns `true` if the selected item is not the last item in the `DropdownList`.
*/
hasNextElement() {
return this.index < this.displayItems.length - 1 &&
(!(this.index === this.displayItems.length - 2) || !this.displayItems[this.index + 1].disabled);
}
/**
* Returns the `HTMLElement` for the item that is subsequent to the selected item.
*/
getNextElement() {
// Only return native elements if they are rendered
const elemList = this.listElementList ? this.listElementList.toArray() : [];
if (!elemList.length) {
return null;
}
/**
* Start checking from next index
* Continue looping through the list until a non disabeled element is found or
* end of list is reached
*/
for (let i = this.index + 1; i < elemList.length; i++) {
// If the values in the list are not disabled
if (!this.displayItems[i].disabled) {
this.index = i;
return elemList[i].nativeElement;
}
}
return elemList[this.index]?.nativeElement;
}
/**
* Returns the `ListItem` that precedes the selected item within `DropdownList`.
*/
getPrevItem() {
if (this.index > 0) {
this.index--;
}
return this.displayItems[this.index];
}
/**
* Returns `true` if the selected item is not the first in the list.
*/
hasPrevElement() {
return this.index > 0 && (!(this.index === 1) || !this.displayItems[0].disabled);
}
/**
* Returns the `HTMLElement` for the item that precedes the selected item.
*/
getPrevElement() {
// Only return native elements if they are rendered
const elemList = this.listElementList ? this.listElementList.toArray() : [];
if (!elemList.length) {
return null;
}
/**
* Start checking from next index
* Continue looping through the list until a non disabeled element is found or
* end of list is reached
*/
for (let i = this.index - 1; i < this.index && i >= 0; i--) {
// If the values in the list are not disabled
if (!this.displayItems[i].disabled) {
this.index = i;
return elemList[i].nativeElement;
}
}
return elemList[this.index].nativeElement;
}
/**
* Returns the `ListItem` that is selected within `DropdownList`.
*/
getCurrentItem() {
if (this.index < 0) {
return this.displayItems[0];
}
return this.displayItems[this.index];
}
/**
* Returns the `HTMLElement` for the item that is selected within the `DropdownList`.
*/
getCurrentElement() {
if (this.index < 0) {
return this.listElementList.first.nativeElement;
}
return this.listElementList.toArray()[this.index].nativeElement;
}
/**
* Returns the items as an Array
*/
getListItems() {
return this._items;
}
/**
* Returns a list containing the selected item(s) in the `DropdownList`.
*/
getSelected() {
let selected = this.getListItems().filter(item => item.selected);
if (selected.length === 0) {
return [];
}
return selected;
}
/**
* Transforms array input list of items to the correct state by updating the selected item(s).
*/
propagateSelected(value) {
// if we get a non-array, log out an error (since it is one)
if (!Array.isArray(value)) {
console.error(`${this.constructor.name}.propagateSelected expects an Array<ListItem>, got ${JSON.stringify(value)}`);
}
this.onItemsReady(() => {
const selectedNewItems = [];
for (let newItem of value) {
if (newItem && newItem.selected) {
// copy the item
let tempNewItem = Object.assign({}, newItem);
// deleted selected because it's what we _want_ to change
delete tempNewItem.selected;
// stringify for compare later
tempNewItem = JSON.stringify(tempNewItem);
// add to the list of selected items
selectedNewItems.push(tempNewItem);
}
}
// loop through the list items and update the `selected` state for matching items in `value`
for (let oldItem of this.getListItems()) {
// fast path when no items are selected
if (selectedNewItems.length === 0) {
oldItem.selected = false;
continue;
}
// copy the item
let tempOldItem = Object.assign({}, oldItem);
// deleted selected because it's what we _want_ to change
delete tempOldItem.selected;
// stringify for compare
tempOldItem = JSON.stringify(tempOldItem);
for (let selectedNewItem of selectedNewItems) {
// do the compare
if (tempOldItem.includes(selectedNewItem)) {
oldItem.selected = true;
// if we've found a matching item, we can stop looping
break;
}
else {
oldItem.selected = false;
}
}
}
});
}
/**
* Initializes focus in the list, effectively a wrapper for `getCurrentElement().focus()`
*/
initFocus() {
if (this.index < 0) {
this.updateIndex();
}
this.list.nativeElement.focus();
setTimeout(() => {
this.highlightedItem = this.getItemId(this.index);
});
}
updateIndex() {
// initialize index on the first selected item or
// on the next non disabled item if no items are selected
// in case, if all items are disabled, the index value will remain same
const selected = this.getSelected();
if (selected.length) {
this.index = this.displayItems.indexOf(selected[0]);
}
else if (this.hasNextElement()) {
this.getNextElement();
}
}
/**
* Manages the keyboard accessibility for navigation and selection within a `DropdownList`.
*/
navigateList(event) {
if (event.key === "Enter" || event.key === " ") {
if (this.listElementList.some(option => option.nativeElement === event.target)) {
event.preventDefault();
}
if (event.key === "Enter") {
this.doClick(event, this.getCurrentItem());
}
}
else if (event.key === "ArrowDown" || event.key === "ArrowUp") {
event.preventDefault();
if (event.key === "ArrowDown") {
if (this.hasNextElement()) {
this.getNextElement()?.scrollIntoView({ block: "end" });
}
else {
this.blurIntent.emit("bottom");
}
}
else if (event.key === "ArrowUp") {
if (this.hasPrevElement()) {
this.getPrevElement().scrollIntoView({ block: "nearest" });
}
else {
this.blurIntent.emit("top");
}
}
setTimeout(() => {
this.highlightedItem = this.getItemId(this.index);
});
}
}
/**
* Emits the selected item or items after a mouse click event has occurred.
*/
doClick(event, item) {
event.preventDefault();
if (item && !item.disabled) {
this.list.nativeElement.focus();
if (this.type === "single") {
item.selected = true;
// reset the selection
for (let otherItem of this.getListItems()) {
if (item !== otherItem) {
otherItem.selected = false;
}
}
}
else {
item.selected = !item.selected;
}
this.index = this.displayItems.indexOf(item);
this.highlightedItem = this.getItemId(this.index);
this.doEmitSelect(false);
this.appRef.tick();
}
}
onItemFocus(index) {
const element = this.listElementList.toArray()[index].nativeElement;
element.classList.add("cds--list-box__menu-item--highlighted");
element.tabIndex = 0;
}
onItemBlur(index) {
const element = this.listElementList.toArray()[index].nativeElement;
element.classList.remove("cds--list-box__menu-item--highlighted");
element.tabIndex = -1;
}
/**
* Emits the scroll event of the options list
*/
emitScroll(event) {
const atTop = event.srcElement.scrollTop === 0;
const atBottom = event.srcElement.scrollHeight - event.srcElement.scrollTop === event.srcElement.clientHeight;
const customScrollEvent = { atTop, atBottom, event };
this.scroll.emit(customScrollEvent);
}
/**
* Subscribe the function passed to an internal observable that will resolve once the items are ready
*/
onItemsReady(subcription) {
// this subscription will auto unsubscribe because of the `first()` pipe
(this._itemsReady || of(true)).pipe(first()).subscribe(subcription);
}
reorderSelected(moveFocus = true) {
this.displayItems = [...this.getSelected(), ...this.getListItems().filter(item => !item.selected)];
if (moveFocus) {
setTimeout(() => {
this.updateIndex();
this.highlightedItem = this.getItemId(this.index);
});
}
}
}
DropdownList.listCount = 0;
DropdownList.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DropdownList, deps: [{ token: i0.ElementRef }, { token: i1.I18n }, { token: i0.ApplicationRef }], target: i0.ɵɵFactoryTarget.Component });
DropdownList.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: { ariaLabel: "ariaLabel", items: "items", listTpl: "listTpl", type: "type", showTitles: "showTitles" }, outputs: { select: "select", scroll: "scroll", blurIntent: "blurIntent" }, providers: [
{
provide: AbstractDropdownView,
useExisting: DropdownList
}
], viewQueries: [{ propertyName: "list", first: true, predicate: ["list"], descendants: true, static: true }, { propertyName: "listElementList", predicate: ["listItem"], descendants: true }], ngImport: i0, template: `
<ul
#list
[id]="listId"
role="listbox"
class="cds--list-box__menu cds--multi-select"
(scroll)="emitScroll($event)"
(keydown)="navigateList($event)"
tabindex="-1"
[attr.aria-label]="ariaLabel"
[attr.aria-activedescendant]="highlightedItem">
<li
role="option"
*ngFor="let item of displayItems; let i = index"
(click)="doClick($event, item)"
class="cds--list-box__menu-item"
[attr.aria-selected]="item.selected"
[id]="getItemId(i)"
[attr.title]=" showTitles ? item.content : null"
[attr.disabled]="item.disabled ? true : null"
[ngClass]="{
'cds--list-box__menu-item--active': item.selected,
'cds--list-box__menu-item--highlighted': highlightedItem === getItemId(i)
}">
<div
#listItem
tabindex="-1"
class="cds--list-box__menu-item__option">
<div
*ngIf="!listTpl && type === 'multi'"
class="cds--form-item cds--checkbox-wrapper">
<label
[attr.data-contained-checkbox-state]="item.selected"
class="cds--checkbox-label">
<input
class="cds--checkbox"
type="checkbox"
[checked]="item.selected"
[disabled]="item.disabled"
tabindex="-1">
<span class="cds--checkbox-appearance"></span>
<span class="cds--checkbox-label-text">{{item.content}}</span>
</label>
</div>
<ng-container *ngIf="!listTpl && type === 'single'">{{item.content}}</ng-container>
<svg
*ngIf="!listTpl && type === 'single'"
cdsIcon="checkmark"
size="16"
class="cds--list-box__menu-item__selected-icon">
</svg>
<ng-template
*ngIf="listTpl"
[ngTemplateOutletContext]="{item: item}"
[ngTemplateOutlet]="listTpl">
</ng-template>
</div>
</li>
</ul>`, isInline: true, dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DropdownList, decorators: [{
type: Component,
args: [{
selector: "cds-dropdown-list, ibm-dropdown-list",
template: `
<ul
#list
[id]="listId"
role="listbox"
class="cds--list-box__menu cds--multi-select"
(scroll)="emitScroll($event)"
(keydown)="navigateList($event)"
tabindex="-1"
[attr.aria-label]="ariaLabel"
[attr.aria-activedescendant]="highlightedItem">
<li
role="option"
*ngFor="let item of displayItems; let i = index"
(click)="doClick($event, item)"
class="cds--list-box__menu-item"
[attr.aria-selected]="item.selected"
[id]="getItemId(i)"
[attr.title]=" showTitles ? item.content : null"
[attr.disabled]="item.disabled ? true : null"
[ngClass]="{
'cds--list-box__menu-item--active': item.selected,
'cds--list-box__menu-item--highlighted': highlightedItem === getItemId(i)
}">
<div
#listItem
tabindex="-1"
class="cds--list-box__menu-item__option">
<div
*ngIf="!listTpl && type === 'multi'"
class="cds--form-item cds--checkbox-wrapper">
<label
[attr.data-contained-checkbox-state]="item.selected"
class="cds--checkbox-label">
<input
class="cds--checkbox"
type="checkbox"
[checked]="item.selected"
[disabled]="item.disabled"
tabindex="-1">
<span class="cds--checkbox-appearance"></span>
<span class="cds--checkbox-label-text">{{item.content}}</span>
</label>
</div>
<ng-container *ngIf="!listTpl && type === 'single'">{{item.content}}</ng-container>
<svg
*ngIf="!listTpl && type === 'single'"
cdsIcon="checkmark"
size="16"
class="cds--list-box__menu-item__selected-icon">
</svg>
<ng-template
*ngIf="listTpl"
[ngTemplateOutletContext]="{item: item}"
[ngTemplateOutlet]="listTpl">
</ng-template>
</div>
</li>
</ul>`,
providers: [
{
provide: AbstractDropdownView,
useExisting: DropdownList
}
]
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.I18n }, { type: i0.ApplicationRef }]; }, propDecorators: { ariaLabel: [{
type: Input
}], items: [{
type: Input
}], listTpl: [{
type: Input
}], select: [{
type: Output
}], scroll: [{
type: Output
}], blurIntent: [{
type: Output
}], list: [{
type: ViewChild,
args: ["list", { static: true }]
}], type: [{
type: Input
}], showTitles: [{
type: Input
}], listElementList: [{
type: ViewChildren,
args: ["listItem"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-list.component.js","sourceRoot":"","sources":["../../../../src/dropdown/list/dropdown-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tOutput,\n\tOnDestroy,\n\tEventEmitter,\n\tTemplateRef,\n\tAfterViewInit,\n\tViewChild,\n\tElementRef,\n\tViewChildren,\n\tQueryList,\n\tApplicationRef\n} from \"@angular/core\";\nimport { Observable, isObservable, Subscription, of } from \"rxjs\";\nimport { first } from \"rxjs/operators\";\n\nimport { I18n } from \"carbon-components-angular/i18n\";\nimport { AbstractDropdownView } from \"../abstract-dropdown-view.class\";\nimport { ListItem } from \"../list-item.interface\";\nimport { watchFocusJump } from \"../dropdowntools\";\nimport { ScrollCustomEvent } from \"./scroll-custom-event.interface\";\n\n\n/**\n * ```html\n * <cds-dropdown-list [items]=\"listItems\"></cds-dropdown-list>\n * ```\n * ```typescript\n * listItems = [\n * \t{\n * \t\tcontent: \"item one\",\n * \t\tselected: false\n * \t},\n * \t{\n * \t\tcontent: \"item two\",\n * \t\tselected: false,\n * \t},\n * \t{\n * \t\tcontent: \"item three\",\n * \t\tselected: false\n * \t},\n * \t{\n * \t\tcontent: \"item four\",\n * \t\tselected: false\n * \t}\n * ];\n * ```\n */\n@Component({\n\tselector: \"cds-dropdown-list, ibm-dropdown-list\",\n\ttemplate: `\n\t\t<ul\n\t\t\t#list\n\t\t\t[id]=\"listId\"\n\t\t\trole=\"listbox\"\n\t\t\tclass=\"cds--list-box__menu cds--multi-select\"\n\t\t\t(scroll)=\"emitScroll($event)\"\n\t\t\t(keydown)=\"navigateList($event)\"\n\t\t\ttabindex=\"-1\"\n\t\t\t[attr.aria-label]=\"ariaLabel\"\n\t\t\t[attr.aria-activedescendant]=\"highlightedItem\">\n\t\t\t<li\n\t\t\t\trole=\"option\"\n\t\t\t\t*ngFor=\"let item of displayItems; let i = index\"\n\t\t\t\t(click)=\"doClick($event, item)\"\n\t\t\t\tclass=\"cds--list-box__menu-item\"\n\t\t\t\t[attr.aria-selected]=\"item.selected\"\n\t\t\t\t[id]=\"getItemId(i)\"\n\t\t\t\t[attr.title]=\" showTitles ? item.content : null\"\n\t\t\t\t[attr.disabled]=\"item.disabled ? true : null\"\n\t\t\t\t[ngClass]=\"{\n\t\t\t\t\t'cds--list-box__menu-item--active': item.selected,\n\t\t\t\t\t'cds--list-box__menu-item--highlighted': highlightedItem === getItemId(i)\n\t\t\t\t}\">\n\t\t\t\t<div\n\t\t\t\t\t#listItem\n\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\tclass=\"cds--list-box__menu-item__option\">\n\t\t\t\t\t<div\n\t\t\t\t\t\t*ngIf=\"!listTpl && type === 'multi'\"\n\t\t\t\t\t\tclass=\"cds--form-item cds--checkbox-wrapper\">\n\t\t\t\t\t\t<label\n\t\t\t\t\t\t\t[attr.data-contained-checkbox-state]=\"item.selected\"\n\t\t\t\t\t\t\tclass=\"cds--checkbox-label\">\n\t\t\t\t\t\t\t<input\n\t\t\t\t\t\t\t\tclass=\"cds--checkbox\"\n\t\t\t\t\t\t\t\ttype=\"checkbox\"\n\t\t\t\t\t\t\t\t[checked]=\"item.selected\"\n\t\t\t\t\t\t\t\t[disabled]=\"item.disabled\"\n\t\t\t\t\t\t\t\ttabindex=\"-1\">\n\t\t\t\t\t\t\t<span class=\"cds--checkbox-appearance\"></span>\n\t\t\t\t\t\t\t<span class=\"cds--checkbox-label-text\">{{item.content}}</span>\n\t\t\t\t\t\t</label>\n\t\t\t\t\t</div>\n\t\t\t\t\t<ng-container *ngIf=\"!listTpl && type === 'single'\">{{item.content}}</ng-container>\n\t\t\t\t\t<svg\n\t\t\t\t\t\t*ngIf=\"!listTpl && type === 'single'\"\n\t\t\t\t\t\tcdsIcon=\"checkmark\"\n\t\t\t\t\t\tsize=\"16\"\n\t\t\t\t\t\tclass=\"cds--list-box__menu-item__selected-icon\">\n\t\t\t\t\t</svg>\n\t\t\t\t\t<ng-template\n\t\t\t\t\t\t*ngIf=\"listTpl\"\n\t\t\t\t\t\t[ngTemplateOutletContext]=\"{item: item}\"\n\t\t\t\t\t\t[ngTemplateOutlet]=\"listTpl\">\n\t\t\t\t\t</ng-template>\n\t\t\t\t</div>\n\t\t\t</li>\n\t\t</ul>`,\n\tproviders: [\n\t\t{\n\t\t\tprovide: AbstractDropdownView,\n\t\t\tuseExisting: DropdownList\n\t\t}\n\t]\n})\nexport class DropdownList implements AbstractDropdownView, AfterViewInit, OnDestroy {\n\tstatic listCount = 0;\n\t@Input() ariaLabel = this.i18n.get().DROPDOWN_LIST.LABEL;\n\t/**\n\t * The list items belonging to the `DropdownList`.\n\t */\n\t@Input() set items(value: Array<ListItem> | Observable<Array<ListItem>>) {\n\t\tif (isObservable(value)) {\n\t\t\tif (this._itemsSubscription) {\n\t\t\t\tthis._itemsSubscription.unsubscribe();\n\t\t\t}\n\t\t\tthis._itemsReady = new Observable<boolean>((observer) => {\n\t\t\t\tthis._itemsSubscription = value.subscribe(v => {\n\t\t\t\t\tthis.updateList(v);\n\t\t\t\t\tobserver.next(true);\n\t\t\t\t\tobserver.complete();\n\t\t\t\t});\n\t\t\t});\n\t\t\tthis.onItemsReady(null);\n\t\t} else {\n\t\t\tthis.updateList(value);\n\t\t}\n\t\tthis._originalItems = value;\n\t}\n\n\tget items(): Array<ListItem> | Observable<Array<ListItem>> {\n\t\treturn this._originalItems;\n\t}\n\t/**\n\t * Template to bind to items in the `DropdownList` (optional).\n\t */\n\t@Input() listTpl: string | TemplateRef<any> = null;\n\t/**\n\t * Event to emit selection of a list item within the `DropdownList`.\n\t */\n\t@Output() select: EventEmitter<{ item: ListItem, isUpdate?: boolean } | ListItem[]> = new EventEmitter();\n\t/**\n\t * Event to emit scroll event of a list within the `DropdownList`.\n\t */\n\t@Output() scroll: EventEmitter<ScrollCustomEvent> = new EventEmitter();\n\t/**\n\t * Event to suggest a blur on the view.\n\t * Emits _after_ the first/last item has been focused.\n\t * ex.\n\t * ArrowUp -> focus first item\n\t * ArrowUp -> emit event\n\t *\n\t * When this event fires focus should be placed on some element outside of the list - blurring the list as a result\n\t */\n\t@Output() blurIntent = new EventEmitter<\"top\" | \"bottom\">();\n\t/**\n\t * Maintains a reference to the view DOM element for the unordered list of items within the `DropdownList`.\n\t */\n\t@ViewChild(\"list\", { static: true }) list: ElementRef;\n\t/**\n\t * Defines whether or not the `DropdownList` supports selecting multiple items as opposed to single\n\t * item selection.\n\t */\n\t@Input() type: \"single\" | \"multi\" = \"single\";\n\n\t/**\n\t * Defines whether to show title attribute or not\n\t */\n\t@Input() showTitles = true;\n\n\t/**\n\t * Defines the rendering size of the `DropdownList` input component.\n\t */\n\tpublic size: \"sm\" | \"md\" | \"lg\" = \"md\";\n\tpublic listId = `listbox-${DropdownList.listCount++}`;\n\tpublic highlightedItem = null;\n\t/**\n\t * Holds the list of items that will be displayed in the `DropdownList`.\n\t * It differs from the the complete set of items when filtering is used (but\n\t * it is always a subset of the total items in `DropdownList`).\n\t */\n\tpublic displayItems: Array<ListItem> = [];\n\t/**\n\t * Maintains the index for the selected item within the `DropdownList`.\n\t */\n\tprotected index = -1;\n\t/**\n\t * An array holding the HTML list elements in the view.\n\t */\n\t@ViewChildren(\"listItem\") protected listElementList: QueryList<ElementRef>;\n\t/**\n\t * Observable bound to keydown events to control filtering.\n\t */\n\tprotected focusJump;\n\t/**\n\t * Tracks the current (if any) subscription to the items observable so we can clean up when the input is updated.\n\t */\n\tprotected _itemsSubscription: Subscription;\n\t/**\n\t * Used to retain the original items passed to the setter.\n\t */\n\tprotected _originalItems: Array<ListItem> | Observable<Array<ListItem>>;\n\t/**\n\t * Useful representation of the items, should be accessed via `getListItems`.\n\t */\n\tprotected _items: Array<ListItem> = [];\n\t/**\n\t * Used to wait for items in case they are passed through an observable.\n\t */\n\tprotected _itemsReady: Observable<boolean>;\n\n\t/**\n\t * Creates an instance of `DropdownList`.\n\t */\n\tconstructor(public elementRef: ElementRef, protected i18n: I18n, protected appRef: ApplicationRef) {}\n\n\t/**\n\t * Retrieves array of list items and index of the selected item after view has rendered.\n\t * Additionally, any Observables for the `DropdownList` are initialized.\n\t */\n\tngAfterViewInit() {\n\t\tthis.index = this.getListItems().findIndex(item => item.selected);\n\t\tthis.setupFocusObservable();\n\t\tsetTimeout(() 