ngx-ui-hero
Version:
Simple, fast and reliable utilities for Angular.
232 lines • 42.4 kB
JavaScript
import { Component, EventEmitter, Inject, Input, IterableDiffers, Optional, Output, ViewChild } from '@angular/core';
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel } from '@angular/forms';
import { ElementBase } from '../../base/element-base';
import { INPUT_FORMS_CONFIG } from '../../input-forms-config.constants';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@angular/forms";
import * as i3 from "../../../ui/directives/debounce.directive";
import * as i4 from "../../../ui/directives/click-outside.directive";
import * as i5 from "../../../ui/directives/auto-focus.directive";
import * as i6 from "ngx-bootstrap/tooltip";
import * as i7 from "../../../data-grid/data-grid.component";
import * as i8 from "../../../data-grid/directives/data-grid-templates.directive";
import * as i9 from "../input-validations/input-validations.component";
let identifier = 0;
export class InputDropdownGridComponent extends ElementBase {
constructor(validators, asyncValidators, config, iterableDiffers) {
super(validators, asyncValidators, config);
this.config = config;
this.iterableDiffers = iterableDiffers;
this.clickOutsideEnabled = true;
this.placeholder = 'Select...';
this.searchPlaceholder = 'Search...';
this.itemsPerPage = 5;
this.maxSize = 5;
this.showInfos = true;
this.onChange = new EventEmitter();
this.onSearch = new EventEmitter();
this.identifier = `input-dropdown-grid-${identifier++}`;
if (config.dropDown) {
Object.assign(this, config.dropDown);
}
this._differData = this.iterableDiffers.find([]).create(null);
}
get data() {
return this._data;
}
set data(value) {
this._data = value;
this.Init();
}
ngOnInit() {
this.Init();
}
ngDoCheck() {
let changesInData = this._differData.diff(this._data);
if (changesInData || !this.modelInitialized || this.value != this._lastModelInitialized) {
this.Init();
}
}
Init() {
this.clearSearch();
if (!this.internalData || this.internalData.length == 0) {
return;
}
if (this.value) {
this.setSelectedItemByTheCurrentModelValue();
this._lastModelInitialized = this.value;
}
else {
this.selectedDisplayText = '';
this._lastModelInitialized = undefined;
}
this.modelInitialized = true;
}
ToggleDropDown(event, value) {
if (this.clickOutsideEnabled) {
if ((value == false && !this.showDropdown) || (value == undefined && this.disabled))
return;
if (value == undefined) {
if (this.showDropdown) {
this.setComboTouched();
}
this.showDropdown = !this.showDropdown;
}
else {
if (!value && this.showDropdown) {
this.setComboTouched();
}
this.showDropdown = value;
}
this.clearSearch();
}
else {
this.clickOutsideEnabled = true;
}
}
Select(row) {
if (this.disabled) {
this.ToggleDropDown(null, false);
return;
}
this.value = this.renderPropertyValue(this.valueProperty, row);
this.onChange.emit(this.value);
this.ToggleDropDown(null, false);
}
OnSearch() {
if (this.lazyLoadedData) {
this.onSearch.emit(this.search);
return;
}
if (!this.search || this.search.length < 3) {
this.clearSearchResults();
return;
}
this.filterData();
}
OnPaginate() {
this.clickOutsideEnabled = false;
}
ClearSelection(e) {
this.value = null;
this.selectedDisplayText = null;
this.comboTouched = true;
this.showDropdown = false;
this.onChange.emit(this.value);
if (e)
e.stopPropagation();
}
OnComboPressed(event) {
if (event.keyCode == 13) {
this.ToggleDropDown(null);
event.preventDefault();
}
}
setSelectedItemByTheCurrentModelValue() {
if (!this.value)
return;
let row = this.data.find(x => this.value == this.renderPropertyValue(this.valueProperty, x));
if (row) {
this.selectedDisplayText = this.renderPropertyValue(this.displayTextProperty, row);
}
}
filterData() {
this.internalData = this.data.filter(x => {
for (let i = 0; i < this.columns.length; i++) {
let columnData = '';
let value = '';
if (this.columns[i].data) {
columnData = this.renderPropertyValue(this.columns[i].data, x);
}
if (this.columns[i].render != undefined) {
value = this.columns[i].render(x, columnData, i);
}
else {
value = columnData;
}
if (value && value.toString().toUpperCase().indexOf(this.search.toUpperCase()) >= 0) {
return true;
}
}
return false;
});
}
clearSearch() {
this.search = '';
this.clearSearchResults();
}
clearSearchResults() {
this.internalData = Object.assign([], this.data);
}
setComboTouched() {
this.comboTouched = true;
}
renderPropertyValue(propertyPath, object) {
let parts = propertyPath.split(".");
let property = object || {};
for (let i = 0; i < parts.length; i++) {
if (!property) {
return null;
}
property = property[parts[i]];
}
return property;
}
}
InputDropdownGridComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: InputDropdownGridComponent, deps: [{ token: NG_VALIDATORS, optional: true }, { token: NG_ASYNC_VALIDATORS, optional: true }, { token: INPUT_FORMS_CONFIG }, { token: i0.IterableDiffers }], target: i0.ɵɵFactoryTarget.Component });
InputDropdownGridComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: InputDropdownGridComponent, selector: "input-dropdown-grid", inputs: { placeholder: "placeholder", searchPlaceholder: "searchPlaceholder", displayTextProperty: "displayTextProperty", valueProperty: "valueProperty", columns: "columns", lazyLoadedData: "lazyLoadedData", itemsPerPage: "itemsPerPage", maxSize: "maxSize", showInfos: "showInfos", data: "data" }, outputs: { onChange: "onChange", onSearch: "onSearch" }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputDropdownGridComponent,
multi: true
}], viewQueries: [{ propertyName: "model", first: true, predicate: NgModel, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div [id]=\"identifier\" class=\"ui-dropdown-grid\">\n <label *ngIf=\"label\">\n {{label}}\n <span class=\"required-symbol\" *ngIf=\"isRequired\"> *</span>\n <i class=\"fa fa-question-circle ml-2\" tooltip=\"{{help}}\" container=\"body\" *ngIf=\"help\"></i>\n </label>\n\n <input type=\"hidden\" [(ngModel)]=\"value\" />\n <div class=\"combobox d-flex align-items-center\" \n [ngClass]=\"{\n 'has-validations': showValidations,\n 'open': showDropdown, \n 'disabled': disabled,\n 'is-valid': !showDropdown && !disabled && comboTouched && (!isRequired || value),\n 'is-invalid': !showDropdown && !disabled && comboTouched && isRequired && !value\n }\"\n (click)=\"ToggleDropDown($event)\" (keyup)=\"OnComboPressed($event)\" tabindex=\"0\">\n\n <span class=\"mr-auto text-truncate\">{{selectedDisplayText || placeholder}}</span>\n <i class=\"fa fa-times btn-clear-selection\" *ngIf=\"value && !disabled\" (click)=\"ClearSelection($event)\"></i>\n <i class=\"fa\" [ngClass]=\"{'fa-caret-down': !showDropdown, 'fa-caret-up': showDropdown}\"></i>\n </div>\n\n <div class=\"dropdown-options shadow fadeInDown\" *ngIf=\"showDropdown\" (clickOutside)=\"ToggleDropDown($event, false)\">\n <div class=\"options-container\">\n <div class=\"toolbar d-flex align-items-center\">\n <input type=\"text\" auto-focus\n class=\"form-control\" \n name=\"{{identifier}}-search\" \n [(ngModel)]=\"search\" \n placeholder=\"{{searchPlaceholder}}\"\n debounce (callback)=\"OnSearch()\" />\n </div>\n\n <div class=\"p-2\">\n <datagrid \n [data]=\"internalData\" \n [columns]=\"columns\" \n [showActionsColumn]=\"true\"\n [initialColumnToSort]=\"0\" \n [itemsPerPage]=\"itemsPerPage\"\n [maxSize]=\"maxSize\"\n [showInfos]=\"showInfos\" \n actionsColumnWidth=\"60px\"\n (OnPaginate)=\"OnPaginate()\">\n <ng-template actions-column let-row=\"row\" let-rowIndex=\"rowIndex\">\n <button class=\"btn btn-outline-primary btn-sm\" (click)=\"Select(row)\"><i class=\"fa fa-external-link\"></i></button>\n </ng-template>\n </datagrid>\n </div>\n </div>\n </div>\n</div>\n\n<input-validations\n *ngIf=\"showValidations && !disabled && comboTouched && (invalid | async)\"\n [messages]=\"failures | async\">\n</input-validations>\n\n<small class=\"text-muted\" *ngIf=\"description\">{{description}}</small>\n", styles: ["@keyframes fadeInDown{0%{opacity:0;transform:translate3d(0,-5%,0)}to{opacity:1;transform:translateZ(0)}}.fadeInDown{animation-name:fadeInDown;animation-duration:.35s;animation-fill-mode:both}.ui-dropdown-grid{position:relative}.ui-dropdown-grid *{-webkit-user-select:none;user-select:none}.ui-dropdown-grid>.combobox{outline:none;background-color:#fff;padding:.375rem .4rem .375rem .75rem;border:1px solid #ced4da;border-radius:.25rem}.ui-dropdown-grid>.combobox>span{color:#6c757d;font-size:1rem;line-height:1.5}.ui-dropdown-grid>.combobox>i{color:#495057;font-size:14px;margin-left:10px}.ui-dropdown-grid>.combobox.open{border-radius:.25rem .25rem 0 0}.ui-dropdown-grid>.combobox.disabled{background-color:#e9ecef;border-color:#ced4da}.ui-dropdown-grid>.combobox.has-validations.is-invalid{border-color:#dc3545}.ui-dropdown-grid>.combobox.has-validations.is-invalid.open{box-shadow:0 0 0 .2rem #dc354540}.ui-dropdown-grid>.combobox.has-validations.is-valid{border-color:#28a745}.ui-dropdown-grid>.combobox.has-validations.is-valid.open{box-shadow:0 0 0 .2rem #28a74540}.ui-dropdown-grid>.dropdown-options{background-color:#fff;border:1px solid #ced4da;border-radius:0 0 .25rem .25rem;position:absolute;top:100%;left:0;width:100%;z-index:20;margin-top:-1px;min-width:300px}.ui-dropdown-grid>.dropdown-options>.options-container{display:inherit;position:initial;font-family:inherit;background-color:inherit;box-shadow:none;height:auto;width:auto;color:inherit;font-size:inherit;letter-spacing:inherit;line-height:inherit;padding:inherit;border-radius:inherit}.ui-dropdown-grid>.dropdown-options .toolbar{padding:3px;border-bottom:1px solid #ced4da;background-color:#f8f9fa}.ui-dropdown-grid>.dropdown-options .toolbar input[type=text]{background-color:transparent;border:0;padding:.375rem .55rem;box-shadow:none!important}.ui-dropdown-grid>.dropdown-options .empty-results{font-style:italic;padding:12px;display:block;color:#6b6b6b}.btn-clear-selection{cursor:pointer;padding:8px 10px;margin:-5px 0 -5px -5px!important;border-radius:3px}.btn-clear-selection:hover{background-color:#e7e7e7}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.DebounceDirective, selector: "[debounce]", inputs: ["delay"], outputs: ["callback", "arrowsCallback"] }, { kind: "directive", type: i4.ClickOutsideDirective, selector: "[clickOutside]", inputs: ["clickOutsideEnabled", "attachOutsideOnClick", "delayClickOutsideInit", "emitOnBlur", "exclude", "excludeBeforeClick", "clickOutsideEvents"], outputs: ["clickOutside"] }, { kind: "directive", type: i5.AutoFocusDirective, selector: "[auto-focus]" }, { kind: "directive", type: i6.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["containerClass", "tooltipAnimation", "tooltipFadeDuration", "isOpen", "tooltipHtml", "tooltip", "tooltipPlacement", "placement", "tooltipIsOpen", "tooltipEnable", "isDisabled", "tooltipAppendToBody", "container", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "delay", "tooltipTrigger", "triggers", "adaptivePosition"], outputs: ["tooltipChange", "tooltipStateChanged", "onShown", "onHidden"], exportAs: ["bs-tooltip"] }, { kind: "component", type: i7.DataGridComponent, selector: "datagrid", inputs: ["debugMode", "tableId", "columns", "emptyResultsMessage", "infoMessage", "animated", "striped", "bordered", "hoverEffect", "responsive", "showCheckboxColumn", "showSelectAllCheckbox", "selectAllPages", "checkBoxMode", "showSummaries", "allowExports", "exportButtonLabel", "exportedFileName", "exportedExcelSheetName", "initialColumnToSort", "initialSortDirection", "mode", "totalItems", "itemsPerPage", "maxSize", "boundaryLinks", "directionLinks", "rotate", "showActionsColumn", "showInfos", "actionsColumnCaption", "actionsColumnWidth", "firstText", "previousText", "nextText", "lastText", "autoFitMode", "allowColumnResize", "allowColumnFilters", "allowColumnReorder", "fixedHeader", "minHeight", "maxHeight", "userPreferencesKey", "filterPlaceholder", "filterPlacement", "boundedExportCallback", "data"], outputs: ["OnSelectionChanged", "OnRowSelected", "OnRowRendered", "OnPaginate", "OnSort", "OnColumnFiltered"] }, { kind: "directive", type: i8.ActionsColumnDirective, selector: "[actions-column]" }, { kind: "component", type: i9.InputValidationsComponent, selector: "input-validations", inputs: ["messages"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: InputDropdownGridComponent, decorators: [{
type: Component,
args: [{ selector: 'input-dropdown-grid', providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputDropdownGridComponent,
multi: true
}], template: "<div [id]=\"identifier\" class=\"ui-dropdown-grid\">\n <label *ngIf=\"label\">\n {{label}}\n <span class=\"required-symbol\" *ngIf=\"isRequired\"> *</span>\n <i class=\"fa fa-question-circle ml-2\" tooltip=\"{{help}}\" container=\"body\" *ngIf=\"help\"></i>\n </label>\n\n <input type=\"hidden\" [(ngModel)]=\"value\" />\n <div class=\"combobox d-flex align-items-center\" \n [ngClass]=\"{\n 'has-validations': showValidations,\n 'open': showDropdown, \n 'disabled': disabled,\n 'is-valid': !showDropdown && !disabled && comboTouched && (!isRequired || value),\n 'is-invalid': !showDropdown && !disabled && comboTouched && isRequired && !value\n }\"\n (click)=\"ToggleDropDown($event)\" (keyup)=\"OnComboPressed($event)\" tabindex=\"0\">\n\n <span class=\"mr-auto text-truncate\">{{selectedDisplayText || placeholder}}</span>\n <i class=\"fa fa-times btn-clear-selection\" *ngIf=\"value && !disabled\" (click)=\"ClearSelection($event)\"></i>\n <i class=\"fa\" [ngClass]=\"{'fa-caret-down': !showDropdown, 'fa-caret-up': showDropdown}\"></i>\n </div>\n\n <div class=\"dropdown-options shadow fadeInDown\" *ngIf=\"showDropdown\" (clickOutside)=\"ToggleDropDown($event, false)\">\n <div class=\"options-container\">\n <div class=\"toolbar d-flex align-items-center\">\n <input type=\"text\" auto-focus\n class=\"form-control\" \n name=\"{{identifier}}-search\" \n [(ngModel)]=\"search\" \n placeholder=\"{{searchPlaceholder}}\"\n debounce (callback)=\"OnSearch()\" />\n </div>\n\n <div class=\"p-2\">\n <datagrid \n [data]=\"internalData\" \n [columns]=\"columns\" \n [showActionsColumn]=\"true\"\n [initialColumnToSort]=\"0\" \n [itemsPerPage]=\"itemsPerPage\"\n [maxSize]=\"maxSize\"\n [showInfos]=\"showInfos\" \n actionsColumnWidth=\"60px\"\n (OnPaginate)=\"OnPaginate()\">\n <ng-template actions-column let-row=\"row\" let-rowIndex=\"rowIndex\">\n <button class=\"btn btn-outline-primary btn-sm\" (click)=\"Select(row)\"><i class=\"fa fa-external-link\"></i></button>\n </ng-template>\n </datagrid>\n </div>\n </div>\n </div>\n</div>\n\n<input-validations\n *ngIf=\"showValidations && !disabled && comboTouched && (invalid | async)\"\n [messages]=\"failures | async\">\n</input-validations>\n\n<small class=\"text-muted\" *ngIf=\"description\">{{description}}</small>\n", styles: ["@keyframes fadeInDown{0%{opacity:0;transform:translate3d(0,-5%,0)}to{opacity:1;transform:translateZ(0)}}.fadeInDown{animation-name:fadeInDown;animation-duration:.35s;animation-fill-mode:both}.ui-dropdown-grid{position:relative}.ui-dropdown-grid *{-webkit-user-select:none;user-select:none}.ui-dropdown-grid>.combobox{outline:none;background-color:#fff;padding:.375rem .4rem .375rem .75rem;border:1px solid #ced4da;border-radius:.25rem}.ui-dropdown-grid>.combobox>span{color:#6c757d;font-size:1rem;line-height:1.5}.ui-dropdown-grid>.combobox>i{color:#495057;font-size:14px;margin-left:10px}.ui-dropdown-grid>.combobox.open{border-radius:.25rem .25rem 0 0}.ui-dropdown-grid>.combobox.disabled{background-color:#e9ecef;border-color:#ced4da}.ui-dropdown-grid>.combobox.has-validations.is-invalid{border-color:#dc3545}.ui-dropdown-grid>.combobox.has-validations.is-invalid.open{box-shadow:0 0 0 .2rem #dc354540}.ui-dropdown-grid>.combobox.has-validations.is-valid{border-color:#28a745}.ui-dropdown-grid>.combobox.has-validations.is-valid.open{box-shadow:0 0 0 .2rem #28a74540}.ui-dropdown-grid>.dropdown-options{background-color:#fff;border:1px solid #ced4da;border-radius:0 0 .25rem .25rem;position:absolute;top:100%;left:0;width:100%;z-index:20;margin-top:-1px;min-width:300px}.ui-dropdown-grid>.dropdown-options>.options-container{display:inherit;position:initial;font-family:inherit;background-color:inherit;box-shadow:none;height:auto;width:auto;color:inherit;font-size:inherit;letter-spacing:inherit;line-height:inherit;padding:inherit;border-radius:inherit}.ui-dropdown-grid>.dropdown-options .toolbar{padding:3px;border-bottom:1px solid #ced4da;background-color:#f8f9fa}.ui-dropdown-grid>.dropdown-options .toolbar input[type=text]{background-color:transparent;border:0;padding:.375rem .55rem;box-shadow:none!important}.ui-dropdown-grid>.dropdown-options .empty-results{font-style:italic;padding:12px;display:block;color:#6b6b6b}.btn-clear-selection{cursor:pointer;padding:8px 10px;margin:-5px 0 -5px -5px!important;border-radius:3px}.btn-clear-selection:hover{background-color:#e7e7e7}\n"] }]
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [NG_VALIDATORS]
}] }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [NG_ASYNC_VALIDATORS]
}] }, { type: undefined, decorators: [{
type: Inject,
args: [INPUT_FORMS_CONFIG]
}] }, { type: i0.IterableDiffers }]; }, propDecorators: { model: [{
type: ViewChild,
args: [NgModel, { static: true }]
}], placeholder: [{
type: Input
}], searchPlaceholder: [{
type: Input
}], displayTextProperty: [{
type: Input
}], valueProperty: [{
type: Input
}], columns: [{
type: Input
}], lazyLoadedData: [{
type: Input
}], itemsPerPage: [{
type: Input
}], maxSize: [{
type: Input
}], showInfos: [{
type: Input
}], onChange: [{
type: Output
}], onSearch: [{
type: Output
}], data: [{
type: Input,
args: ['data']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-dropdown-grid.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-ui-hero/src/lib/input-forms/components/input-dropdown-grid/input-dropdown-grid.component.ts","../../../../../../../projects/ngx-ui-hero/src/lib/input-forms/components/input-dropdown-grid/input-dropdown-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, IterableDiffers, OnInit, Optional, Output, ViewChild } from '@angular/core';\nimport { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel } from '@angular/forms';\n\nimport { DataGridColumnModel } from '../../../data-grid/models/data-grid-column.model';\nimport { ElementBase } from '../../base/element-base';\nimport { AsyncValidatorArray, ValidatorArray } from '../../base/validate';\nimport { InputFormsConfig } from '../../input-forms-config';\nimport { INPUT_FORMS_CONFIG } from '../../input-forms-config.constants';\n\nlet identifier = 0;\n\n@Component({\n  selector: 'input-dropdown-grid',\n  templateUrl: './input-dropdown-grid.component.html',\n  styleUrls: ['./input-dropdown-grid.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: InputDropdownGridComponent,\n    multi: true\n  }]\n})\nexport class InputDropdownGridComponent extends ElementBase<any> implements OnInit { \n  private _lastModelInitialized: any;\n  private _differData: any;\n  private _data: Array<any>;\n  showDropdown: boolean;\n  comboTouched: boolean;\n  modelInitialized: boolean;\n  clickOutsideEnabled: boolean = true;\n  search: string;\n  selectedDisplayText: string;\n  internalData: Array<any>;\n  \n  @ViewChild(NgModel, {static: true}) model: NgModel;\n  @Input() public placeholder = 'Select...';\n  @Input() public searchPlaceholder = 'Search...';\n  @Input() public displayTextProperty: string;\n  @Input() public valueProperty: string;\n  @Input() public columns: Array<DataGridColumnModel>; \n  @Input() public lazyLoadedData: boolean;\n  @Input() itemsPerPage?: number = 5;  \n  @Input() maxSize?: number = 5;  \n  @Input() showInfos?: boolean = true;  \n  @Output() public onChange = new EventEmitter<any>();\n  @Output() public onSearch = new EventEmitter<string>();\n\n  get data(): Array<any> {\n    return this._data;\n  }    \n  @Input('data')\n  set data(value: Array<any>) {\n    this._data = value;\n    this.Init();\n  }\n  \n  public identifier = `input-dropdown-grid-${identifier++}`;  \n \n  constructor(\n    @Optional() @Inject(NG_VALIDATORS) validators: ValidatorArray,\n    @Optional() @Inject(NG_ASYNC_VALIDATORS) asyncValidators: AsyncValidatorArray,\n    @Inject( INPUT_FORMS_CONFIG ) public config: InputFormsConfig,\n    private iterableDiffers: IterableDiffers,\n  ) {\n    super(validators, asyncValidators, config);\n\n    if (config.dropDown) {\n      Object.assign(this, config.dropDown);\n    }\n\n    this._differData = this.iterableDiffers.find([]).create(null);\n  }\n\n  ngOnInit(): void {\n    this.Init();\n  }\n  ngDoCheck(): void {\n    let changesInData = this._differData.diff(this._data);\n\n    if (changesInData || !this.modelInitialized || this.value != this._lastModelInitialized) {\n      this.Init();\n    }\n  }\n\n  Init(): void {\n    this.clearSearch();\n\n    if (!this.internalData || this.internalData.length == 0) {\n      return;\n    }\n\n    if (this.value) {\n      this.setSelectedItemByTheCurrentModelValue();\n      this._lastModelInitialized = this.value;\n    } else {\n      this.selectedDisplayText = '';\n      this._lastModelInitialized = undefined;\n    }\n    \n    this.modelInitialized = true;\n  }\n\n  ToggleDropDown(event: MouseEvent, value?: boolean): void {\n    if (this.clickOutsideEnabled) {\n      if ((value == false && !this.showDropdown) || (value == undefined && this.disabled)) return;\n    \n      if (value == undefined) {\n        if (this.showDropdown) {\n          this.setComboTouched();\n        }\n  \n        this.showDropdown = !this.showDropdown;      \n      } else {\n        if (!value && this.showDropdown) {\n          this.setComboTouched();\n        }\n        \n        this.showDropdown = value;\n      }\n      \n      this.clearSearch();\n    } else {\n      this.clickOutsideEnabled = true;\n    }\n  }\n  Select(row: any): void {\n    if (this.disabled) {\n      this.ToggleDropDown(null, false);\n      return;\n    }\n\n    this.value = this.renderPropertyValue(this.valueProperty, row);\n    this.onChange.emit(this.value);    \n    this.ToggleDropDown(null, false);\n  }\n  OnSearch(): void {\n    if(this.lazyLoadedData) {\n      this.onSearch.emit(this.search);\n      return;\n    }\n\n    if (!this.search || this.search.length < 3) {\n      this.clearSearchResults();\n      return;\n    }\n\n    this.filterData();\n  }\n  OnPaginate(): void {\n    this.clickOutsideEnabled = false;\n  }\n  ClearSelection(e?: any): void {\n    this.value = null;\n    this.selectedDisplayText = null;\n    this.comboTouched = true;\n    this.showDropdown = false;\n    this.onChange.emit(this.value);\n\n    if (e) e.stopPropagation();\n  }\n  OnComboPressed(event: KeyboardEvent): void {\n    if (event.keyCode == 13) {\n      this.ToggleDropDown(null);\n      event.preventDefault();\n    }\n  }\n\n  private setSelectedItemByTheCurrentModelValue(): void {\n    if (!this.value) return;\n\n    let row = this.data.find(x => this.value == this.renderPropertyValue(this.valueProperty, x));\n    if (row) {\n      this.selectedDisplayText = this.renderPropertyValue(this.displayTextProperty, row);\n    }\n  }\n  private filterData(): void {\n    this.internalData = this.data.filter(x => {\n      \n      for (let i = 0; i < this.columns.length; i++) {\n        let columnData = '';\n        let value = '';\n\n        if (this.columns[i].data) {\n          columnData = this.renderPropertyValue(this.columns[i].data, x);\n        }\n\n        if (this.columns[i].render != undefined) {\n          value = this.columns[i].render(x, columnData, i);\n        } else {\n          value = columnData;\n        }\n\n        if (value && value.toString().toUpperCase().indexOf(this.search.toUpperCase()) >= 0) {\n          return true;\n        }\n      }\n\n      return false;\n    });\n  }\n  private clearSearch(): void {\n    this.search = '';\n    this.clearSearchResults();\n  }\n  private clearSearchResults(): void {\n    this.internalData = Object.assign([], this.data);\n  }\n  private setComboTouched(): void {\n    this.comboTouched = true;\n  }\n  private renderPropertyValue(propertyPath: string, object: any): any {\n    let parts: string[] = propertyPath.split( \".\" );\n    let property: any = object || {};\n  \n    for (let i = 0; i < parts.length; i++) {\n      if (!property) {\n        return null;\n      }\n\n      property = property[parts[i]];\n    }\n\n    return property;\n  }\n \n}\n","<div [id]=\"identifier\" class=\"ui-dropdown-grid\">\n  <label *ngIf=\"label\">\n    {{label}}\n    <span class=\"required-symbol\" *ngIf=\"isRequired\"> *</span>\n    <i class=\"fa fa-question-circle ml-2\" tooltip=\"{{help}}\" container=\"body\" *ngIf=\"help\"></i>\n  </label>\n\n  <input type=\"hidden\" [(ngModel)]=\"value\" />\n  <div class=\"combobox d-flex align-items-center\" \n    [ngClass]=\"{\n      'has-validations': showValidations,\n      'open': showDropdown, \n      'disabled': disabled,\n      'is-valid': !showDropdown && !disabled && comboTouched && (!isRequired || value),\n      'is-invalid': !showDropdown && !disabled && comboTouched && isRequired && !value\n    }\"\n    (click)=\"ToggleDropDown($event)\" (keyup)=\"OnComboPressed($event)\" tabindex=\"0\">\n\n    <span class=\"mr-auto text-truncate\">{{selectedDisplayText || placeholder}}</span>\n    <i class=\"fa fa-times btn-clear-selection\" *ngIf=\"value && !disabled\" (click)=\"ClearSelection($event)\"></i>\n    <i class=\"fa\" [ngClass]=\"{'fa-caret-down': !showDropdown, 'fa-caret-up': showDropdown}\"></i>\n  </div>\n\n  <div class=\"dropdown-options shadow fadeInDown\" *ngIf=\"showDropdown\" (clickOutside)=\"ToggleDropDown($event, false)\">\n    <div class=\"options-container\">\n      <div class=\"toolbar d-flex align-items-center\">\n        <input type=\"text\" auto-focus\n          class=\"form-control\" \n          name=\"{{identifier}}-search\" \n          [(ngModel)]=\"search\" \n          placeholder=\"{{searchPlaceholder}}\"\n          debounce (callback)=\"OnSearch()\" />\n      </div>\n\n      <div class=\"p-2\">\n        <datagrid \n          [data]=\"internalData\" \n          [columns]=\"columns\" \n          [showActionsColumn]=\"true\"\n          [initialColumnToSort]=\"0\"          \n          [itemsPerPage]=\"itemsPerPage\"\n          [maxSize]=\"maxSize\"\n          [showInfos]=\"showInfos\"          \n          actionsColumnWidth=\"60px\"\n          (OnPaginate)=\"OnPaginate()\">\n          <ng-template actions-column let-row=\"row\" let-rowIndex=\"rowIndex\">\n            <button class=\"btn btn-outline-primary btn-sm\" (click)=\"Select(row)\"><i class=\"fa fa-external-link\"></i></button>\n          </ng-template>\n        </datagrid>\n      </div>\n    </div>\n  </div>\n</div>\n\n<input-validations\n  *ngIf=\"showValidations && !disabled && comboTouched && (invalid | async)\"\n  [messages]=\"failures | async\">\n</input-validations>\n\n<small class=\"text-muted\" *ngIf=\"description\">{{description}}</small>\n"]}