UNPKG

ngx-mat-dropdown

Version:
293 lines (291 loc) 24.4 kB
/** * @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"]}