mdc-autocomplete-list
Version:
MdcAutocomplete in conjunction with MdcAutocompleteList and MdcAutocompleteListItem are a pack of angular components to provide an autocomplete functionality to Angular MDC web.
312 lines (302 loc) • 27.6 kB
JavaScript
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('mdc-autocomplete-list-item'), require('rxjs'), require('@angular/common'), require('@angular-mdc/web')) :
typeof define === 'function' && define.amd ? define('mdc-autocomplete-list', ['exports', '@angular/core', 'mdc-autocomplete-list-item', 'rxjs', '@angular/common', '@angular-mdc/web'], factory) :
(factory((global['mdc-autocomplete-list'] = {}),global.ng.core,null,global.rxjs,global.ng.common,null));
}(this, (function (exports,i0,mdcAutocompleteListItem,rxjs,common,web) { 'use strict';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var MdcAutocompleteListService = (function () {
function MdcAutocompleteListService() {
}
MdcAutocompleteListService.decorators = [
{ type: i0.Injectable, args: [{
providedIn: 'root'
},] },
];
/** @nocollapse */
MdcAutocompleteListService.ctorParameters = function () { return []; };
/** @nocollapse */ MdcAutocompleteListService.ngInjectableDef = i0.defineInjectable({ factory: function MdcAutocompleteListService_Factory() { return new MdcAutocompleteListService(); }, token: MdcAutocompleteListService, providedIn: "root" });
return MdcAutocompleteListService;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var MdcAutocompleteListComponent = (function () {
function MdcAutocompleteListComponent() {
}
/**
* @return {?}
*/
MdcAutocompleteListComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
};
MdcAutocompleteListComponent.decorators = [
{ type: i0.Component, args: [{
selector: 'mdc-mdc-autocomplete-list',
template: "\n <p>\n mdc-autocomplete-list works!\n </p>\n ",
styles: []
},] },
];
/** @nocollapse */
MdcAutocompleteListComponent.ctorParameters = function () { return []; };
return MdcAutocompleteListComponent;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var MdcAutocompleteList = (function () {
function MdcAutocompleteList() {
this.itemSelected = new rxjs.Subject();
this.maxVisibleItems = Number.POSITIVE_INFINITY;
this._visible = false;
this._filter = '';
}
Object.defineProperty(MdcAutocompleteList.prototype, "visible", {
get: /**
* @return {?}
*/ function () {
return this._visible;
},
set: /**
* @param {?} v
* @return {?}
*/ function (v) {
this._visible = v;
if (v) {
this.filterItems();
this.focusFirstItem();
}
else {
this.unfocusAllItems();
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(MdcAutocompleteList.prototype, "filter", {
get: /**
* @return {?}
*/ function () {
return this._filter;
},
set: /**
* @param {?} f
* @return {?}
*/ function (f) {
this._filter = f;
this.filterItems();
this.focusFirstItem();
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
MdcAutocompleteList.prototype.ngOnInit = /**
* @return {?}
*/
function () {
};
/**
* @return {?}
*/
MdcAutocompleteList.prototype.ngAfterContentChecked = /**
* @return {?}
*/
function () {
var _this = this;
this.autocompleteListItems.toArray().forEach(function (item) {
if (item.itemClicked.observers.length === 0) {
// Only allow one subscription
item.itemClicked.subscribe(function (itemValue) {
_this.itemSelected.next(itemValue);
});
}
if (item.itemHovered.observers.length === 0) {
// Only allow one subscription
item.itemHovered.subscribe(function (itemValue) {
_this.unfocusAllItems();
item.focused = true;
});
}
});
};
/**
* @return {?}
*/
MdcAutocompleteList.prototype.unfocusAllItems = /**
* @return {?}
*/
function () {
this.autocompleteListItems.toArray().forEach(function (item) {
item.focused = false;
});
};
/**
* @return {?}
*/
MdcAutocompleteList.prototype.focusNextItem = /**
* @return {?}
*/
function () {
/** @type {?} */
var focusedItems = this.autocompleteListItems.filter(function (item, index, list) { return item.focused; });
/** @type {?} */
var focusedItem = focusedItems.length > 0 ? focusedItems[0] : null;
/** @type {?} */
var visibleItems = this.autocompleteListItems.filter(function (item, index, list) { return item.visible; });
if (focusedItem) {
/** @type {?} */
var focusedItemIndex = visibleItems.indexOf(focusedItem);
/** @type {?} */
var nextFocusedItem = (visibleItems.length >= focusedItemIndex + 1) ? visibleItems[focusedItemIndex + 1] : null;
if (nextFocusedItem) {
focusedItem.focused = false;
nextFocusedItem.focused = true;
nextFocusedItem.scrollIntoView();
}
}
else {
if (visibleItems.length > 0) {
visibleItems[0].focused = true;
}
}
};
/**
* @return {?}
*/
MdcAutocompleteList.prototype.focusPreviousItem = /**
* @return {?}
*/
function () {
/** @type {?} */
var focusedItems = this.autocompleteListItems.filter(function (item, index, list) { return item.focused; });
/** @type {?} */
var focusedItem = focusedItems.length > 0 ? focusedItems[0] : null;
/** @type {?} */
var visibleItems = this.autocompleteListItems.filter(function (item, index, list) { return item.visible; });
if (focusedItem) {
/** @type {?} */
var focusedItemIndex = visibleItems.indexOf(focusedItem);
/** @type {?} */
var previousFocusedItem = (focusedItemIndex > 0) ? visibleItems[focusedItemIndex - 1] : null;
if (previousFocusedItem) {
focusedItem.focused = false;
previousFocusedItem.focused = true;
previousFocusedItem.scrollIntoView();
}
}
else {
if (visibleItems.length > 0) {
visibleItems[0].focused = true;
}
}
};
/**
* @return {?}
*/
MdcAutocompleteList.prototype.focusFirstItem = /**
* @return {?}
*/
function () {
this.unfocusAllItems();
/** @type {?} */
var visibleItems = this.autocompleteListItems.filter(function (item, index, list) { return item.visible; });
if (visibleItems.length > 0) {
visibleItems[0].focused = true;
}
};
/**
* @return {?}
*/
MdcAutocompleteList.prototype.selectFocusedItem = /**
* @return {?}
*/
function () {
/** @type {?} */
var focusedItems = this.autocompleteListItems.filter(function (item, index, list) { return item.focused; });
/** @type {?} */
var focusedItem = focusedItems.length > 0 ? focusedItems[0] : null;
if (focusedItem) {
this.itemSelected.next(focusedItem.value);
}
};
/**
* @return {?}
*/
MdcAutocompleteList.prototype.filterItems = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var showing = 0;
this.autocompleteListItems.forEach(function (item, index, list) {
if (showing < _this.maxVisibleItems && item.filterString.toUpperCase().includes(_this._filter.toUpperCase())) {
item.visible = true;
showing++;
}
else {
item.visible = false;
item.focused = false;
}
});
};
MdcAutocompleteList.decorators = [
{ type: i0.Component, args: [{
selector: 'mdc-autocomplete-list',
template: "<ul *ngIf=\"visible\" class=\"mdc-elevation--z2\">\n <ng-content></ng-content>\n</ul>\n",
styles: ["ul{position:absolute;min-width:200px;max-height:400px;padding:0;margin:0;background-color:#fff;overflow-y:scroll;list-style:none}"]
},] },
];
/** @nocollapse */
MdcAutocompleteList.ctorParameters = function () { return []; };
MdcAutocompleteList.propDecorators = {
maxVisibleItems: [{ type: i0.Input }],
itemSelected: [{ type: i0.Output }],
autocompleteListItems: [{ type: i0.ContentChildren, args: [mdcAutocompleteListItem.MdcAutocompleteListItem,] }]
};
return MdcAutocompleteList;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var MdcAutocompleteListModule = (function () {
function MdcAutocompleteListModule() {
}
MdcAutocompleteListModule.decorators = [
{ type: i0.NgModule, args: [{
imports: [
common.CommonModule,
mdcAutocompleteListItem.MdcAutocompleteListItemModule,
web.MdcElevationModule
],
declarations: [MdcAutocompleteListComponent, MdcAutocompleteList],
exports: [MdcAutocompleteList]
},] },
];
return MdcAutocompleteListModule;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
exports.MdcAutocompleteListService = MdcAutocompleteListService;
exports.MdcAutocompleteListModule = MdcAutocompleteListModule;
exports.MdcAutocompleteList = MdcAutocompleteList;
exports.ɵa = MdcAutocompleteListComponent;
Object.defineProperty(exports, '__esModule', { value: true });
})));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mdc-autocomplete-list.umd.js.map","sources":["ng://mdc-autocomplete-list/lib/mdc-autocomplete-list.service.ts","ng://mdc-autocomplete-list/lib/mdc-autocomplete-list.component.ts","ng://mdc-autocomplete-list/lib/autocomplete-list/autocomplete-list.component.ts","ng://mdc-autocomplete-list/lib/mdc-autocomplete-list.module.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class MdcAutocompleteListService {\r\n\r\n  constructor() { }\r\n}\r\n","import { Component, OnInit } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'mdc-mdc-autocomplete-list',\r\n  template: `\r\n    <p>\r\n      mdc-autocomplete-list works!\r\n    </p>\r\n  `,\r\n  styles: []\r\n})\r\nexport class MdcAutocompleteListComponent implements OnInit {\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n}\r\n","import { Component, OnInit, ContentChildren, QueryList, Input, Output, AfterContentChecked } from '@angular/core';\r\nimport { MdcAutocompleteListItem } from 'mdc-autocomplete-list-item';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'mdc-autocomplete-list',\r\n  template: `<ul *ngIf=\"visible\" class=\"mdc-elevation--z2\">\r\n  <ng-content></ng-content>\r\n</ul>\r\n`,\r\n  styles: [`ul{position:absolute;min-width:200px;max-height:400px;padding:0;margin:0;background-color:#fff;overflow-y:scroll;list-style:none}`]\r\n})\r\n// tslint:disable-next-line:component-class-suffix\r\nexport class MdcAutocompleteList implements OnInit, AfterContentChecked {\r\n\r\n  @Input() maxVisibleItems: number;\r\n  @Output() public itemSelected: Subject<any> = new Subject();\r\n\r\n  @ContentChildren(MdcAutocompleteListItem) autocompleteListItems:  QueryList<MdcAutocompleteListItem>;\r\n  _visible: boolean;\r\n  _filter: string;\r\n\r\n  public get visible(): boolean {\r\n    return this._visible;\r\n  }\r\n\r\n  public set visible(v: boolean) {\r\n    this._visible = v;\r\n    if (v) {\r\n      this.filterItems();\r\n      this.focusFirstItem();\r\n    } else {\r\n      this.unfocusAllItems();\r\n    }\r\n  }\r\n\r\n  public get filter(): string {\r\n    return this._filter;\r\n  }\r\n\r\n  public set filter(f: string) {\r\n    this._filter = f;\r\n    this.filterItems();\r\n    this.focusFirstItem();\r\n  }\r\n\r\n  constructor() {\r\n    this.maxVisibleItems = Number.POSITIVE_INFINITY;\r\n    this._visible = false;\r\n    this._filter = '';\r\n  }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  ngAfterContentChecked() {\r\n    this.autocompleteListItems.toArray().forEach((item) => {\r\n      if (item.itemClicked.observers.length === 0) { // Only allow one subscription\r\n        item.itemClicked.subscribe((itemValue) => {\r\n          this.itemSelected.next(itemValue);\r\n        });\r\n      }\r\n\r\n      if (item.itemHovered.observers.length === 0) { // Only allow one subscription\r\n        item.itemHovered.subscribe((itemValue) => {\r\n          this.unfocusAllItems();\r\n          item.focused = true;\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  public unfocusAllItems() {\r\n    this.autocompleteListItems.toArray().forEach((item) => {\r\n      item.focused = false;\r\n    });\r\n  }\r\n\r\n  public focusNextItem() {\r\n    const focusedItems = this.autocompleteListItems.filter((item, index, list) => item.focused);\r\n    const focusedItem = focusedItems.length > 0 ? focusedItems[0] : null;\r\n    const visibleItems = this.autocompleteListItems.filter((item, index, list) => item.visible);\r\n\r\n    if (focusedItem) {\r\n      const focusedItemIndex = visibleItems.indexOf(focusedItem);\r\n      const nextFocusedItem = (visibleItems.length >= focusedItemIndex + 1) ? visibleItems[focusedItemIndex + 1] : null;\r\n      if (nextFocusedItem) {\r\n        focusedItem.focused = false;\r\n        nextFocusedItem.focused = true;\r\n        nextFocusedItem.scrollIntoView();\r\n      }\r\n    } else {\r\n      if (visibleItems.length > 0) {\r\n        visibleItems[0].focused = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  public focusPreviousItem() {\r\n    const focusedItems = this.autocompleteListItems.filter((item, index, list) => item.focused);\r\n    const focusedItem = focusedItems.length > 0 ? focusedItems[0] : null;\r\n    const visibleItems = this.autocompleteListItems.filter((item, index, list) => item.visible);\r\n\r\n    if (focusedItem) {\r\n      const focusedItemIndex = visibleItems.indexOf(focusedItem);\r\n      const previousFocusedItem = (focusedItemIndex > 0) ? visibleItems[focusedItemIndex - 1] : null;\r\n      if (previousFocusedItem) {\r\n        focusedItem.focused = false;\r\n        previousFocusedItem.focused = true;\r\n        previousFocusedItem.scrollIntoView();\r\n      }\r\n    } else {\r\n      if (visibleItems.length > 0) {\r\n        visibleItems[0].focused = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  public focusFirstItem() {\r\n    this.unfocusAllItems();\r\n    const visibleItems = this.autocompleteListItems.filter((item, index, list) => item.visible);\r\n    if (visibleItems.length > 0) {\r\n      visibleItems[0].focused = true;\r\n    }\r\n  }\r\n\r\n  public selectFocusedItem() {\r\n    const focusedItems = this.autocompleteListItems.filter((item, index, list) => item.focused);\r\n    const focusedItem = focusedItems.length > 0 ? focusedItems[0] : null;\r\n\r\n    if (focusedItem) {\r\n      this.itemSelected.next(focusedItem.value);\r\n    }\r\n  }\r\n\r\n  private filterItems() {\r\n    let showing = 0;\r\n    this.autocompleteListItems.forEach((item, index, list) => {\r\n      if (showing < this.maxVisibleItems && item.filterString.toUpperCase().includes(this._filter.toUpperCase())) {\r\n        item.visible = true;\r\n        showing++;\r\n      } else {\r\n        item.visible = false;\r\n        item.focused = false;\r\n      }\r\n    });\r\n  }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MdcAutocompleteListComponent } from './mdc-autocomplete-list.component';\r\nimport { MdcAutocompleteList } from './autocomplete-list/autocomplete-list.component';\r\nimport { MdcAutocompleteListItemModule } from 'mdc-autocomplete-list-item';\r\nimport { MdcElevationModule } from '@angular-mdc/web';\r\n\r\n@NgModule({\r\n  imports: [\r\n    CommonModule,\r\n    MdcAutocompleteListItemModule,\r\n    MdcElevationModule\r\n  ],\r\n  declarations: [MdcAutocompleteListComponent, MdcAutocompleteList],\r\n  exports: [MdcAutocompleteList]\r\n})\r\nexport class MdcAutocompleteListModule { }\r\n"],"names":["Injectable","Component","Subject","Input","Output","ContentChildren","MdcAutocompleteListItem","NgModule","CommonModule","MdcAutocompleteListItemModule","MdcElevationModule"],"mappings":"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"}