UNPKG

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
(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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"}