ngx-mat-dropdown
Version:
Angular Dropdown with search/filter option
293 lines (291 loc) • 24.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/mat-dropdown.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, ViewChild, ElementRef, } from "@angular/core";
import { FormControl } from "@angular/forms";
import { MatSelect } from "@angular/material/select";
import { ReplaySubject, Subject } from "rxjs";
import { take, takeUntil } from "rxjs/operators";
import { DropdownSettingsModel } from "./dropdown-settings.model";
export class MatDropdownComponent {
constructor() {
this.dropdownCtrl = new FormControl();
this.appearance = "outline";
/**
* control for the MatSelect filter keyword
*/
this.FilterCtrl = new FormControl();
this.dropdownList = [];
this.onselectItems = new EventEmitter();
this.filteredBanks = new ReplaySubject(1);
/**
* Subject that emits when the component has been destroyed.
*/
this._onDestroy = new Subject();
}
/**
* @param {?} isTrue
* @return {?}
*/
set dropdownDisabled(isTrue) {
if (isTrue) {
this.dropdownCtrl.disable();
}
else {
this.dropdownCtrl.enable();
}
}
/**
* @param {?} list
* @return {?}
*/
set getdropdownList(list) {
if (list) {
this.dropdownList = list;
this.filteredBanks.next(list.slice());
}
else {
}
}
/**
* @param {?} evt
* @return {?}
*/
set onselect(evt) {
if (evt) {
this.selectedItems = evt;
// console.log(evt, this.preBind);
this.dropdownCtrl.setValue(evt);
}
else {
if (this.dropdownSettings.multiple) {
this.selectedItems = [];
}
else
this.selectedItems = null;
this.dropdownCtrl.setValue(evt);
}
}
/**
* @return {?}
*/
ngOnInit() {
// set intial value
// listen for search field value changes
this.FilterCtrl.valueChanges
.pipe(takeUntil(this._onDestroy))
.subscribe((/**
* @return {?}
*/
() => {
/** @type {?} */
let evt = this.FilterCtrl.value;
this._filter(evt);
}));
}
/**
* @private
* @param {?} evt
* @return {?}
*/
_filter(evt) {
if (evt)
this.filteredBanks.next(this.dropdownList.filter((/**
* @param {?} x
* @return {?}
*/
(x) => x[this.dropdownSettings.labelKey]
.toLowerCase()
.includes(evt.val.toLowerCase()))));
else
this.filteredBanks.next(this.dropdownList.slice());
}
/**
* @return {?}
*/
ngAfterViewInit() {
//this.dropdownCtrl.setValue(this.selectedItems);
if (!this.dropdownSettings.multiple)
this.setInitialValue();
}
/**
* @return {?}
*/
ngOnDestroy() {
this._onDestroy.next();
this._onDestroy.complete();
}
/**
* @private
* @return {?}
*/
setInitialValue() {
this.filteredBanks
.pipe(take(1), takeUntil(this._onDestroy))
.subscribe((/**
* @return {?}
*/
() => {
this.singleSelect.compareWith = (/**
* @param {?} a
* @param {?} b
* @return {?}
*/
(a, b) => {
if (a && b)
return (a[this.dropdownSettings.keyValue] ===
b[this.dropdownSettings.keyValue]);
});
}));
}
/**
* @param {?} evt
* @return {?}
*/
OnSelectedEvent(evt) {
this.onselectItems.emit(evt.source);
//if (evt.isUserInput) {
// this.onselectItems.emit(evt.source);
//} else {
// this.onselectItems.emit({ value: null });
//}
}
// multi
/**
* @param {?} checked
* @return {?}
*/
AllClicked(checked) {
//console.log(checked, this.multidropdownCtrl)
if (checked.checked) {
// this.multidropdownCtrl.patchValue([...this.dropdownList.map(item => item.key), 0]);
/** @type {?} */
let items = this.dropdownList.map((/**
* @param {?} item
* @return {?}
*/
(item) => item));
this.dropdownCtrl.setValue(items);
}
else {
// this.multidropdownCtrl.patchValue([]);
this.dropdownCtrl.setValue([]);
}
this.onselectItems.emit(this.dropdownCtrl);
}
/**
* @param {?} check
* @return {?}
*/
ischecked(check) {
/** @type {?} */
let selected = this.dropdownCtrl.value;
return (this.dropdownList &&
selected &&
selected.length > 0 &&
this.dropdownList.length == selected.length);
}
/**
* @return {?}
*/
isIndeterminate() {
/** @type {?} */
let selected = this.dropdownCtrl.value;
return (this.dropdownList &&
selected &&
selected.length > 0 &&
selected.length < this.dropdownList.length);
}
/**
* @return {?}
*/
openedChange() {
if (!this.innerSelectAll || !this.innerSelectAll.nativeElement) {
return;
}
/** @type {?} */
let SelectAllElement = this.innerSelectAll.nativeElement;
/** @type {?} */
let SelectAllPanelElement;
while ((SelectAllElement = SelectAllElement.parentElement)) {
if (SelectAllElement.classList.contains("mat-select-panel")) {
SelectAllPanelElement = SelectAllElement;
break;
}
}
if (SelectAllPanelElement) {
this.innerSelectAll.nativeElement.style.width =
SelectAllPanelElement.clientWidth + "px";
/** @type {?} */
let children = this.innerSelectAll.nativeElement.childNodes;
//if (children)
// children[0].childNodes[0].style.width = SelectallpanelElement.clientWidth + 'px';
}
}
}
MatDropdownComponent.decorators = [
{ type: Component, args: [{
selector: "ngx-mat-dropdown",
template: "<mat-form-field appearance=\"{{appearance}}\">\r\n <mat-label>{{dropdownSettings?.placeholder}}</mat-label>\r\n <mat-select disableOptionCentering [formControl]=\"dropdownCtrl\" [attr.id]=\"dropdownSettings?.id\" \r\n (selectionChange)=\"OnSelectedEvent($event)\"\r\n [placeholder]=\"dropdownSettings.placeholder \" \r\n #singleSelect [multiple]=\"dropdownSettings?.multiple\" \r\n matTooltip=\"{{selectedItems ? selectedItems[dropdownSettings.labelKey] : ''}}\"\r\n [multiple]=\"dropdownSettings?.multiple\">\r\n <mat-select-search [formControl]=\"FilterCtrl\" [multiple]=\"dropdownSettings?.multiple\" *ngIf=\"dropdownList.length > 5\"></mat-select-search>\r\n <div #innerSelectall [style.top.px]=\"dropdownList?.length <= 5 ? 0 : 44\" class=\"mat-select-all-inner\" *ngIf=\"dropdownList?.length !== 0 && dropdownSettings.multiple\" >\r\n <mat-checkbox class=\"mat-option mat-select-checkbox\" [disableRipple]=\"true\" [indeterminate]=\"isIndeterminate()\" [checked]=\"ischecked(check)\" (change)=\"AllClicked($event)\" #check>\r\n {{ check.checked ? ('Unselect All' ) : ('Select All' ) }}\r\n </mat-checkbox>\r\n </div>\r\n <mat-option *ngIf=\"dropdownList.length && !dropdownSettings.multiple\">None</mat-option>\r\n <mat-option *ngFor=\"let item of filteredBanks | async\" [value]=\"item\" \r\n matTooltip=\"{{item[dropdownSettings.labelKey]}}\">\r\n {{ item[dropdownSettings.labelKey] }}\r\n </mat-option>\r\n </mat-select>\r\n</mat-form-field>",
styles: [`
.mat-select-all-inner {
position: absolute;
top: 52px;
width: calc(100% + 3px);
background: white;
z-index: 100;
font-size: inherit;
box-shadow: none;
border-radius: 0;
-webkit-transform: translate3d(0,0,0);
}
`]
}] }
];
/** @nocollapse */
MatDropdownComponent.ctorParameters = () => [];
MatDropdownComponent.propDecorators = {
dropdownCtrl: [{ type: Input, args: ["ctrl",] }],
appearance: [{ type: Input }],
dropdownSettings: [{ type: Input, args: ["dropdownSettings",] }],
dropdownDisabled: [{ type: Input, args: ["disabled",] }],
getdropdownList: [{ type: Input, args: ["dropdownList",] }],
onselect: [{ type: Input, args: ["selectedItems",] }],
onselectItems: [{ type: Output, args: ["onselectItems",] }],
singleSelect: [{ type: ViewChild, args: ["singleSelect", { read: ElementRef },] }],
innerSelectAll: [{ type: ViewChild, args: ["innerSelectall", { read: ElementRef, static: true },] }]
};
if (false) {
/** @type {?} */
MatDropdownComponent.prototype.dropdownCtrl;
/** @type {?} */
MatDropdownComponent.prototype.appearance;
/**
* control for the MatSelect filter keyword
* @type {?}
*/
MatDropdownComponent.prototype.FilterCtrl;
/** @type {?} */
MatDropdownComponent.prototype.dropdownSettings;
/** @type {?} */
MatDropdownComponent.prototype.dropdownList;
/** @type {?} */
MatDropdownComponent.prototype.selectedItems;
/** @type {?} */
MatDropdownComponent.prototype.onselectItems;
/** @type {?} */
MatDropdownComponent.prototype.filteredBanks;
/** @type {?} */
MatDropdownComponent.prototype.singleSelect;
/** @type {?} */
MatDropdownComponent.prototype.innerSelectAll;
/**
* Subject that emits when the component has been destroyed.
* @type {?}
* @private
*/
MatDropdownComponent.prototype._onDestroy;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mat-dropdown.component.js","sourceRoot":"ng://ngx-mat-dropdown/","sources":["lib/mat-dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild,\n  ElementRef,\n} from \"@angular/core\";\nimport { FormControl } from \"@angular/forms\";\nimport { MatSelect } from \"@angular/material/select\";\nimport { ReplaySubject, Subject } from \"rxjs\";\nimport { take, takeUntil } from \"rxjs/operators\";\nimport { DropdownSettingsModel } from \"./dropdown-settings.model\";\n\n@Component({\n  selector: \"ngx-mat-dropdown\",\n  templateUrl: \"./mat-dropdown.component.html\",\n  styles: [`\n  .mat-select-all-inner {\n    position: absolute;\n    top: 52px;\n    width: calc(100% + 3px);\n    \n    background: white;\n    z-index: 100;\n    font-size: inherit;\n    box-shadow: none;\n    border-radius: 0;\n    -webkit-transform: translate3d(0,0,0);\n}\n\n  `],\n})\nexport class MatDropdownComponent implements OnInit {\n  @Input(\"ctrl\")\n  public dropdownCtrl: FormControl = new FormControl();\n  @Input() appearance: string = \"outline\";\n  /** control for the MatSelect filter keyword */\n  public FilterCtrl: FormControl = new FormControl();\n\n  @Input(\"dropdownSettings\")\n  dropdownSettings: DropdownSettingsModel;\n\n  @Input(\"disabled\")\n  set dropdownDisabled(isTrue: boolean) {\n    if (isTrue) {\n      this.dropdownCtrl.disable();\n    } else {\n      this.dropdownCtrl.enable();\n    }\n  }\n\n  dropdownList: Array<any> = [];\n  @Input(\"dropdownList\")\n  set getdropdownList(list: any) {\n    if (list) {\n      this.dropdownList = list;\n      this.filteredBanks.next(list.slice());\n    } else {\n    }\n  }\n\n  selectedItems: any;\n  @Input(\"selectedItems\")\n  set onselect(evt) {\n    if (evt) {\n      this.selectedItems = evt;\n      // console.log(evt, this.preBind);\n      this.dropdownCtrl.setValue(evt);\n    } else {\n      if (this.dropdownSettings.multiple) {\n        this.selectedItems = [];\n      } else this.selectedItems = null;\n      this.dropdownCtrl.setValue(evt);\n    }\n  }\n  @Output(\"onselectItems\") onselectItems: EventEmitter<\n    Object\n  > = new EventEmitter<Object>();\n\n  public filteredBanks: ReplaySubject<any[]> = new ReplaySubject<any[]>(1);\n  @ViewChild(\"singleSelect\", { read: ElementRef }) singleSelect: MatSelect;\n  @ViewChild(\"innerSelectall\", { read: ElementRef, static: true })\n  innerSelectAll: ElementRef;\n  /** Subject that emits when the component has been destroyed. */\n  private _onDestroy = new Subject<void>();\n\n  constructor() {}\n  ngOnInit() {\n    // set intial value\n    // listen for search field value changes\n    this.FilterCtrl.valueChanges\n      .pipe(takeUntil(this._onDestroy))\n      .subscribe(() => {\n        let evt = this.FilterCtrl.value;\n        this._filter(evt);\n      });\n  }\n\n  private _filter(evt) {\n    if (evt)\n      this.filteredBanks.next(\n        this.dropdownList.filter((x) =>\n          x[this.dropdownSettings.labelKey]\n            .toLowerCase()\n            .includes(evt.val.toLowerCase())\n        )\n      );\n    else this.filteredBanks.next(this.dropdownList.slice());\n  }\n\n  ngAfterViewInit() {\n    //this.dropdownCtrl.setValue(this.selectedItems);\n\n    if (!this.dropdownSettings.multiple) this.setInitialValue();\n  }\n\n  ngOnDestroy() {\n    this._onDestroy.next();\n    this._onDestroy.complete();\n  }\n  private setInitialValue() {\n    this.filteredBanks\n      .pipe(take(1), takeUntil(this._onDestroy))\n      .subscribe(() => {\n        this.singleSelect.compareWith = (a: any, b: any) => {\n          if (a && b)\n            return (\n              a[this.dropdownSettings.keyValue] ===\n              b[this.dropdownSettings.keyValue]\n            );\n        };\n      });\n  }\n\n  OnSelectedEvent(evt) {\n    this.onselectItems.emit(evt.source);\n    //if (evt.isUserInput) {\n    //    this.onselectItems.emit(evt.source);\n    //} else {\n    //    this.onselectItems.emit({ value: null });\n    //}\n  }\n\n  // multi\n  AllClicked(checked) {\n    //console.log(checked, this.multidropdownCtrl)\n    if (checked.checked) {\n      // this.multidropdownCtrl.patchValue([...this.dropdownList.map(item => item.key), 0]);\n      let items = this.dropdownList.map((item) => item);\n      this.dropdownCtrl.setValue(items);\n    } else {\n      // this.multidropdownCtrl.patchValue([]);\n      this.dropdownCtrl.setValue([]);\n    }\n    this.onselectItems.emit(this.dropdownCtrl);\n  }\n  ischecked(check): boolean {\n    let selected: any = this.dropdownCtrl.value;\n    return (\n      this.dropdownList &&\n      selected &&\n      selected.length > 0 &&\n      this.dropdownList.length == selected.length\n    );\n  }\n  isIndeterminate(): boolean {\n    let selected: any = this.dropdownCtrl.value;\n    return (\n      this.dropdownList &&\n      selected &&\n      selected.length > 0 &&\n      selected.length < this.dropdownList.length\n    );\n  }\n\n  openedChange() {\n    \n    if (!this.innerSelectAll || !this.innerSelectAll.nativeElement) {\n      return;\n    }\n    let SelectAllElement: HTMLElement = this.innerSelectAll.nativeElement;\n    let SelectAllPanelElement: HTMLElement;\n    while ((SelectAllElement = SelectAllElement.parentElement)) {\n      if (SelectAllElement.classList.contains(\"mat-select-panel\")) {\n        SelectAllPanelElement = SelectAllElement;\n        break;\n      }\n    }\n    if (SelectAllPanelElement) {\n      this.innerSelectAll.nativeElement.style.width =\n        SelectAllPanelElement.clientWidth + \"px\";\n      let children = this.innerSelectAll.nativeElement.childNodes;\n      //if (children)\n      //    children[0].childNodes[0].style.width = SelectallpanelElement.clientWidth + 'px';\n    }\n  }\n}\n"]}