autocomplete-entry
Advanced tools
Comparing version 3.3.1 to 3.3.2
@@ -129,4 +129,13 @@ (function (global, factory) { | ||
AutocompleteEntryComponent.prototype.writeValue = function (value) { | ||
this.selectedItem.patchValue(value, { emitEvent: false }); | ||
this.selectedItemDropDown.patchValue(value, { emitEvent: false }); | ||
var _this = this; | ||
if (this.returnKey) { | ||
this.findReturnKeySelection(value).subscribe(function (value) { | ||
_this.selectedItem.patchValue(value, { emitEvent: false }); | ||
_this.selectedItemDropDown.patchValue(value, { emitEvent: false }); | ||
}); | ||
} | ||
else { | ||
this.selectedItem.patchValue(value, { emitEvent: false }); | ||
this.selectedItemDropDown.patchValue(value, { emitEvent: false }); | ||
} | ||
}; | ||
@@ -176,3 +185,3 @@ AutocompleteEntryComponent.prototype.registerOnChange = function (fn) { | ||
if (_this.key && _this.hasObjects) { | ||
var found = obj.find(function (obj) { return (obj[_this.key]).toLocaleLowerCase() === value.toLocaleLowerCase(); }); | ||
var found = obj.find(function (obj) { return (obj[_this.key]).toLocaleLowerCase() === (value).toString().toLocaleLowerCase(); }); | ||
return (found) ? (_this.returnKey) ? found[_this.returnKey] : value : (_this.acceptInput) ? value : null; | ||
@@ -211,2 +220,17 @@ } | ||
}; | ||
AutocompleteEntryComponent.prototype.findReturnKeySelection = function (value) { | ||
var _this = this; | ||
return this._data.pipe(operators.take(1), operators.map(function (obj) { | ||
if (!value) | ||
value = ''; | ||
var key = (_this.returnKey) ? _this.returnKey : _this.key; | ||
if (key && _this.hasObjects) { | ||
var found = obj.find(function (obj) { return (obj[key]).toString().toLocaleLowerCase() === (value).toString().toLocaleLowerCase(); }); | ||
return (found) ? (_this.returnKey) ? found[_this.key] : value : (_this.acceptInput) ? value : null; | ||
} | ||
else { | ||
return obj.find(function (obj) { return obj.toLocaleLowerCase() === value.toLocaleLowerCase(); }); | ||
} | ||
})); | ||
}; | ||
return AutocompleteEntryComponent; | ||
@@ -213,0 +237,0 @@ }()); |
@@ -97,4 +97,12 @@ import { Component, forwardRef, Input } from '@angular/core'; | ||
writeValue(value) { | ||
this.selectedItem.patchValue(value, { emitEvent: false }); | ||
this.selectedItemDropDown.patchValue(value, { emitEvent: false }); | ||
if (this.returnKey) { | ||
this.findReturnKeySelection(value).subscribe(value => { | ||
this.selectedItem.patchValue(value, { emitEvent: false }); | ||
this.selectedItemDropDown.patchValue(value, { emitEvent: false }); | ||
}); | ||
} | ||
else { | ||
this.selectedItem.patchValue(value, { emitEvent: false }); | ||
this.selectedItemDropDown.patchValue(value, { emitEvent: false }); | ||
} | ||
} | ||
@@ -142,3 +150,3 @@ registerOnChange(fn) { | ||
if (this.key && this.hasObjects) { | ||
const found = obj.find(obj => (obj[this.key]).toLocaleLowerCase() === value.toLocaleLowerCase()); | ||
const found = obj.find(obj => (obj[this.key]).toLocaleLowerCase() === (value).toString().toLocaleLowerCase()); | ||
return (found) ? (this.returnKey) ? found[this.returnKey] : value : (this.acceptInput) ? value : null; | ||
@@ -175,2 +183,16 @@ } | ||
} | ||
findReturnKeySelection(value) { | ||
return this._data.pipe(take(1), map(obj => { | ||
if (!value) | ||
value = ''; | ||
const key = (this.returnKey) ? this.returnKey : this.key; | ||
if (key && this.hasObjects) { | ||
const found = obj.find(obj => (obj[key]).toString().toLocaleLowerCase() === (value).toString().toLocaleLowerCase()); | ||
return (found) ? (this.returnKey) ? found[this.key] : value : (this.acceptInput) ? value : null; | ||
} | ||
else { | ||
return obj.find(obj => obj.toLocaleLowerCase() === value.toLocaleLowerCase()); | ||
} | ||
})); | ||
} | ||
} | ||
@@ -222,2 +244,2 @@ AutocompleteEntryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: AutocompleteEntryComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-entry.component.js","sourceRoot":"","sources":["../../../../projects/autocomplete-entry/src/lib/autocomplete-entry.component.ts","../../../../projects/autocomplete-entry/src/lib/autocomplete-entry.component.html"],"names":[],"mappings":"AAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACrE,OAAO,EAAe,iBAAiB,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAG5E,OAAO,EAAE,YAAY,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AACpD,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;AAEhE,MAAM,CAAC,MAAM,oBAAoB,GAAQ;IACvC,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,0BAA0B,CAAC;IACzD,KAAK,EAAE,IAAI;CACZ,CAAA;AAQD,MAAM,OAAO,0BAA0B;IAgFvC,YACU,EAAe;QAAf,OAAE,GAAF,EAAE,CAAa;QA/EzB,UAAK,GAAsB,EAAE,CAAC,EAAE,CAAC,CAAA;QA8BjC,cAAS,GAAG,KAAK,CAAA;QAmBjB,oBAAe,GAAyB,EAAE,CAAC,EAAE,CAAC,CAAA;QAErC,YAAO,GAAG,EAAE,CAAA;QACZ,iBAAY,GAAG,KAAK,CAAA;QACpB,aAAQ,GAAG,KAAK,CAAA;QAEhB,WAAM,GAAG,EAAE,CAAA;QACX,gBAAW,GAAG,EAAE,CAAA;QAChB,UAAK,GAAG,EAAE,CAAA;QACV,WAAM,GAAG,EAAE,CAAA;QAEX,WAAM,GAAG,CAAC,CAAA;QACV,WAAM,GAAG,MAAM,CAAA;QAEf,cAAS,GAAG,IAAI,CAAA;QAKhB,gBAAW,GAAG,KAAK,CAAA;QAE5B,iBAAY,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;QACtC,yBAAoB,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;QAKtC,eAAU,GAAG,IAAI,CAAA;QAKvB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAA;QAC9B,IAAI,CAAC,SAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAA;IAC3B,CAAC;IAlFD,IAAa,IAAI,CAAC,KAAU;QAC1B,IAAI,CAAC,KAAK,GAAG,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAA;QACtD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC;IAED,IAAI,IAAI;QAEN,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CACpB,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,CAAC,QAAa,EAAE,EAAE;YAEpB,IAAI,QAAQ,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,GAAG,EAAE;gBAE3C,IAAG,IAAI,CAAC,SAAS,EAAE;oBACjB,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;iBACxH;gBAED,OAAO,QAAQ,CAAA;aAEhB;iBAAM;gBACL,IAAG,CAAC,QAAQ;oBAAE,QAAQ,GAAG,EAAE,CAAA;gBAC3B,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAA;aACrD;QAEH,CAAC,CAAC,CACH,CAAA;IAEH,CAAC;IAGD,IAAa,QAAQ,CAAC,KAAc;QAElC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;QAEtB,IAAG,KAAK,EAAE;YACR,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAA;YAC3B,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,CAAA;SACpC;aAAM;YACL,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAA;YAC1B,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAA;SACnC;IAEH,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAA;IACvB,CAAC;IAsCD,QAAQ;QAEN,IAAG,IAAI,CAAC,QAAQ,EAAE;YAChB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAA;YACpD,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAA;SAC7D;QAED,IAAI,CAAC,WAAW,EAAE,CAAA;QAElB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CACxD,SAAS,CAAC,EAAE,CAAC,EACb,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CACjC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAQ,EAAE,EAAE;YACrC,OAAO,CAAC,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,WAAW,GAAG,UAAU,CAAC,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,WAAW,EAAE,CAAC,CAAC,CAAA;QAClE,CAAC,CAAC,CAAC,CACJ,CAAC,CACH,CAAA;QAED,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YACvD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QACtB,CAAC,CAAC,CAAA;IAEJ,CAAC;IAED,eAAe;QAEb,IAAG,IAAI,CAAC,OAAO,EAAE;YAChB,UAAU,CAAC,GAAG,EAAE;gBACf,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;gBAC9D,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;YACvE,CAAC,EACE,CAAC,CAAC,CAAA;SACL;IAEH,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;QACzD,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;IACnE,CAAC;IAED,gBAAgB,CAAC,EAAoB;QACnC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;IACpB,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAA;IACrB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAA;IAC5B,CAAC;IAED,OAAO,CAAC,KAAa;QACnB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QACpB,IAAI,CAAC,SAAS,EAAE,CAAA;IAClB,CAAC;IAED,MAAM,CAAC,KAAa;QAClB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QACpB,IAAI,CAAC,SAAS,EAAE,CAAA;IAClB,CAAC;IAED,UAAU,CAAC,KAAmC;QAC5C,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;IACnC,CAAC;IAEO,QAAQ,CAAC,GAAQ;QACvB,OAAO,CAAC,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAE,CAAC,OAAO,GAAG,KAAK,UAAU,CAAC,IAAI,CAAC,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAE,CAAA;IAC5G,CAAC;IAEO,WAAW;QAEjB,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,GAAG,CAAC,IAAI,CAAC,EAAE;YACT,IAAG,CAAC,IAAI;gBAAE,OAAM;YAChB,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;YACvF,IAAG,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,MAAK,CAAC,qDAAqD,CAAC,CAAA;YAC7F,IAAG,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,IAAI,CAAC,SAAS,EAAE,CAAA;QACpD,CAAC,CAAC,CACH,CAAC,SAAS,EAAE,CAAA;IAEf,CAAC;IAEO,aAAa,CAAC,KAAa;QAEjC,IAAG,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,WAAW;YAAE,OAAO,EAAE,CAAC,KAAK,CAAC,CAAA;QAEvE,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CACpB,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,GAAG,CAAC,EAAE;YAER,IAAG,CAAC,KAAK;gBAAE,KAAK,GAAG,EAAE,CAAA;YAErB,IAAG,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,UAAU,EAAE;gBAC9B,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,iBAAiB,EAAE,KAAK,KAAK,CAAC,iBAAiB,EAAE,CAAC,CAAA;gBAChG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAA;aACtG;iBAAM;gBACL,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,iBAAiB,EAAE,KAAK,KAAK,CAAC,iBAAiB,EAAE,CAAC,CAAA;aAC9E;QACH,CAAC,CAAC,CACH,CAAA;IAEH,CAAC;IAEO,QAAQ,CAAC,KAAa;QAE5B,IAAG,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK;YAAE,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAC9C,IAAG,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC;YAAE,OAAM;QAEzF,IAAG,IAAI,CAAC,WAAW,EAAE;YACnB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;SACrB;aAAM;YACL,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAA;SAC/D;QAED,IAAG,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY;YAAE,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;IAEtE,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,UAAU,GAAG,KAAK,CAAA;IACzB,CAAC;IAEO,aAAa,CAAC,KAAa;QAEjC,IAAI,CAAC,KAAK,CAAC,IAAI,CACX,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,GAAG,CAAC,EAAE;YAER,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,CAAC,CAAA;YACxD,IAAG,KAAK;gBAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;QAEtF,CAAC,CAAC,CACH,CAAC,SAAS,EAAE,CAAA;IAEf,CAAC;;wHA/NU,0BAA0B;4GAA1B,0BAA0B,6aAF1B,CAAC,oBAAoB,CAAC,0BCjBrC,gxCAkDA;4FD/Be,0BAA0B;kBANtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,WAAW,EAAE,qCAAqC;oBAClD,SAAS,EAAE,CAAC,qCAAqC,CAAC;oBAClD,SAAS,EAAE,CAAC,oBAAoB,CAAC;iBAClC;kGAIY,IAAI;sBAAhB,KAAK;gBA8BO,QAAQ;sBAApB,KAAK;gBAoBG,OAAO;sBAAf,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,GAAG;sBAAX,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,WAAW;sBAAnB,KAAK","sourcesContent":["  import { Component, forwardRef, Input, OnInit } from '@angular/core';\n  import { FormBuilder, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';\n  import { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\n  import { isObservable, Observable, of } from 'rxjs';\n  import { map, mergeMap, startWith, take } from 'rxjs/operators';\n\n  export const INPUT_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => AutocompleteEntryComponent),\n    multi: true\n  }\n\n  @Component({\n    selector: 'wav-autocomplete-entry',\n    templateUrl: './autocomplete-entry.component.html',\n    styleUrls: ['./autocomplete-entry.component.scss'],\n    providers: [INPUT_VALUE_ACCESSOR]\n  })\n  export class AutocompleteEntryComponent implements OnInit {\n\n  _data: Observable<any[]> = of([])\n  @Input() set data(value: any) {\n    this._data = (isObservable(value)) ? value : of(value)\n    this.selectedItem.setValue('')\n  }\n\n  get data(): Observable<any[]> {\n\n    return this._data.pipe(\n      take(1),\n      map((response: any) => {\n\n        if (response && this.hasObjects && this.key) {\n\n          if(this.sortAlpha) {\n            response = response.sort((a: any, b: any) => a[this.key].localeCompare(b[this.key])).map((item: any) => item[this.key])\n          }\n\n          return response\n\n        } else {\n          if(!response) response = []\n          return (this.sortAlpha) ? response.sort() : response\n        }\n\n      }),\n    )\n\n  }\n\n  _disabled = false\n  @Input() set disabled(value: boolean) {\n\n    this._disabled = value\n\n    if(value) {\n      this.selectedItem.disable()\n      this.selectedItemDropDown.disable()\n    } else {\n      this.selectedItem.enable()\n      this.selectedItemDropDown.enable()\n    }\n\n  }\n\n  get disabled() {\n    return this._disabled\n  }\n\n  filteredOptions: Observable<string[]> = of([])\n\n  @Input() default = ''\n  @Input() autocomplete = false\n  @Input() required = false\n  @Input() appearance: MatFormFieldAppearance\n  @Input() styles = ''\n  @Input() placeholder = ''\n  @Input() label = ''\n  @Input() prefix = ''\n\n  @Input() minlen = 0\n  @Input() maxlen = 524288\n\n  @Input() sortAlpha = true\n\n  @Input() key: string\n  @Input() returnKey: string\n  @Input() displayInput: string\n  @Input() acceptInput = false\n\n  selectedItem = this.fb.control([null])\n  selectedItemDropDown = this.fb.control([null])\n\n  private onChange: Function\n  private onTouched: Function\n\n  private hasObjects = true\n\n  constructor(\n    private fb: FormBuilder,\n  ) {\n    this.onChange = (_: any) => {}\n    this.onTouched = () => {}\n  }\n\n  ngOnInit() {\n\n    if(this.required) {\n      this.selectedItem.setValidators(Validators.required)\n      this.selectedItemDropDown.setValidators(Validators.required)\n    }\n\n    this.isDataValid()\n\n    this.filteredOptions = this.selectedItem.valueChanges.pipe(\n      startWith(''),\n      mergeMap(findItem => this.data.pipe(\n        map(items => items.filter((item:any) => {\n          return (item?.toLowerCase().startsWith(findItem?.toLowerCase()))\n        }))\n      )),\n    )\n\n    this.selectedItemDropDown.valueChanges.subscribe(value => {\n      this.selected(value)\n    })\n\n  }\n\n  ngAfterViewInit() {\n\n    if(this.default) {\n     setTimeout(() => {\n      this.selectedItem.setValue(this.default, { emitEvent: false })\n      this.selectedItemDropDown.setValue(this.default, { emitEvent: false })\n     }\n       ,0)\n    }\n\n  }\n\n  writeValue(value: any) {\n    this.selectedItem.patchValue(value, { emitEvent: false })\n    this.selectedItemDropDown.patchValue(value, { emitEvent: false })\n  }\n\n  registerOnChange(fn: (_: any) => void) {\n    this.onChange = fn\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled\n  }\n\n  onEnter(value: string) {\n    this.selected(value)\n    this.onTouched()\n  }\n\n  onBlur(value: string) {\n    this.selected(value)\n    this.onTouched()\n  }\n\n  onSelected(value: MatAutocompleteSelectedEvent) {\n    this.selected(value.option.value)\n  }\n\n  private isObject(val: any): boolean {\n    return (val === null || val === []) ? false : ( (typeof val === 'function') || (typeof val === 'object') )\n  }\n\n  private isDataValid() {\n\n    this._data.pipe(\n      map(data => {\n        if(!data) return\n        this.hasObjects = (data.length > 0) ? data.every(value => this.isObject(value)) : false\n        if(this.hasObjects && !this.key) throw('This array contains Objects. Please specify the key')\n        if(!this.hasObjects && !this.key) this.clearKeys()\n      })\n    ).subscribe()\n\n  }\n\n  private findSelection(value: string) {\n\n    if((!this.returnKey || !this.key) && this.acceptInput) return of(value)\n\n    return this._data.pipe(\n      take(1),\n      map(obj => {\n\n        if(!value) value = ''\n\n        if(this.key && this.hasObjects) {\n          const found = obj.find(obj => (obj[this.key]).toLocaleLowerCase() === value.toLocaleLowerCase())\n          return (found) ? (this.returnKey) ? found[this.returnKey] : value : (this.acceptInput) ? value : null\n        } else {\n          return obj.find(obj => obj.toLocaleLowerCase() === value.toLocaleLowerCase())\n        }\n      })\n    )\n\n  }\n\n  private selected(value: string) {\n\n    if(!this.selectedItem.valid) this.onChange('')\n    if(this.required && !(this.selectedItem.valid || this.selectedItemDropDown.valid)) return\n\n    if(this.acceptInput) {\n      this.onChange(value)\n    } else {\n      this.findSelection(value).subscribe(val => this.onChange(val))\n    }\n\n    if(this.displayInput && this.autocomplete) this.updateDisplay(value)\n\n  }\n\n  private clearKeys() {\n    this.hasObjects = false\n  }\n\n  private updateDisplay(value: string) {\n\n    this._data.pipe(\n        take(1),\n        map(obj => {\n\n          const found = obj.find(obj => (obj[this.key]) === value)\n          if(found) this.selectedItem.setValue(found[this.displayInput], { emitEvent: false })\n\n        })\n      ).subscribe()\n\n    }\n\n}\n","<div *ngIf=\"autocomplete\">\n  <mat-form-field [appearance]=\"appearance\" fxFlex [style]=\"styles\">\n\n    <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n    <span *ngIf=\"prefix !==''\" matPrefix>{{ prefix }}&nbsp;</span>\n    <input type=\"text\"\n      matInput\n      #inputData\n      [maxlength]=\"maxlen\"\n      [placeholder]=\"placeholder\"\n      [formControl]=\"selectedItem\"\n      [matAutocomplete]=\"auto\"\n      (keyup.enter)=\"onEnter(inputData.value)\"\n      (blur)=\"onBlur(inputData.value)\"\n    >\n    <mat-autocomplete\n      autoActiveFirstOption\n      #auto=\"matAutocomplete\"\n      (optionSelected)='onSelected($event)'\n    >\n      <mat-option\n        *ngFor=\"let item of (filteredOptions | async)\"\n        [value]=\"item\"\n      >\n        {{item}}\n      </mat-option>\n\n    </mat-autocomplete>\n\n  </mat-form-field>\n</div>\n\n<div *ngIf=\"!autocomplete\">\n\n  <mat-form-field [appearance]=\"appearance\" fxFlex [style]=\"styles\">\n\n    <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n    <mat-select [formControl]=\"selectedItemDropDown\">\n      <mat-option\n        *ngFor=\"let item of (data | async)\"\n        [value]=\"item\"\n      >\n        {{item}}\n      </mat-option>\n    </mat-select>\n\n  </mat-form-field>\n\n</div>\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-entry.component.js","sourceRoot":"","sources":["../../../../projects/autocomplete-entry/src/lib/autocomplete-entry.component.ts","../../../../projects/autocomplete-entry/src/lib/autocomplete-entry.component.html"],"names":[],"mappings":"AAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACrE,OAAO,EAAe,iBAAiB,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAG5E,OAAO,EAAE,YAAY,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AACpD,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;AAEhE,MAAM,CAAC,MAAM,oBAAoB,GAAQ;IACvC,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,0BAA0B,CAAC;IACzD,KAAK,EAAE,IAAI;CACZ,CAAA;AAQD,MAAM,OAAO,0BAA0B;IAgFvC,YACU,EAAe;QAAf,OAAE,GAAF,EAAE,CAAa;QA/EzB,UAAK,GAAsB,EAAE,CAAC,EAAE,CAAC,CAAA;QA8BjC,cAAS,GAAG,KAAK,CAAA;QAmBjB,oBAAe,GAAyB,EAAE,CAAC,EAAE,CAAC,CAAA;QAErC,YAAO,GAAG,EAAE,CAAA;QACZ,iBAAY,GAAG,KAAK,CAAA;QACpB,aAAQ,GAAG,KAAK,CAAA;QAEhB,WAAM,GAAG,EAAE,CAAA;QACX,gBAAW,GAAG,EAAE,CAAA;QAChB,UAAK,GAAG,EAAE,CAAA;QACV,WAAM,GAAG,EAAE,CAAA;QAEX,WAAM,GAAG,CAAC,CAAA;QACV,WAAM,GAAG,MAAM,CAAA;QAEf,cAAS,GAAG,IAAI,CAAA;QAKhB,gBAAW,GAAG,KAAK,CAAA;QAE5B,iBAAY,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;QACtC,yBAAoB,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;QAKtC,eAAU,GAAG,IAAI,CAAA;QAKvB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAA;QAC9B,IAAI,CAAC,SAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAA;IAC3B,CAAC;IAlFD,IAAa,IAAI,CAAC,KAAU;QAC1B,IAAI,CAAC,KAAK,GAAG,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAA;QACtD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC;IAED,IAAI,IAAI;QAEN,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CACpB,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,CAAC,QAAa,EAAE,EAAE;YAEpB,IAAI,QAAQ,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,GAAG,EAAE;gBAE3C,IAAG,IAAI,CAAC,SAAS,EAAE;oBACjB,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;iBACxH;gBAED,OAAO,QAAQ,CAAA;aAEhB;iBAAM;gBACL,IAAG,CAAC,QAAQ;oBAAE,QAAQ,GAAG,EAAE,CAAA;gBAC3B,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAA;aACrD;QAEH,CAAC,CAAC,CACH,CAAA;IAEH,CAAC;IAGD,IAAa,QAAQ,CAAC,KAAc;QAElC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;QAEtB,IAAG,KAAK,EAAE;YACR,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAA;YAC3B,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,CAAA;SACpC;aAAM;YACL,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAA;YAC1B,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAA;SACnC;IAEH,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAA;IACvB,CAAC;IAsCD,QAAQ;QAEN,IAAG,IAAI,CAAC,QAAQ,EAAE;YAChB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAA;YACpD,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAA;SAC7D;QAED,IAAI,CAAC,WAAW,EAAE,CAAA;QAElB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CACxD,SAAS,CAAC,EAAE,CAAC,EACb,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CACjC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAQ,EAAE,EAAE;YACrC,OAAO,CAAC,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,WAAW,GAAG,UAAU,CAAC,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,WAAW,EAAE,CAAC,CAAC,CAAA;QAClE,CAAC,CAAC,CAAC,CACJ,CAAC,CACH,CAAA;QAED,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YACvD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QACtB,CAAC,CAAC,CAAA;IAEJ,CAAC;IAED,eAAe;QAEb,IAAG,IAAI,CAAC,OAAO,EAAE;YAChB,UAAU,CAAC,GAAG,EAAE;gBACf,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;gBAC9D,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;YACvE,CAAC,EACE,CAAC,CAAC,CAAA;SACL;IAEH,CAAC;IAED,UAAU,CAAC,KAAU;QAEnB,IAAG,IAAI,CAAC,SAAS,EAAE;YAEjB,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;gBAEnD,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;gBACzD,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;YAEnE,CAAC,CAAC,CAAA;SAEH;aAAM;YAEL,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;YACzD,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;SAElE;IACH,CAAC;IAED,gBAAgB,CAAC,EAAoB;QACnC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;IACpB,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAA;IACrB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAA;IAC5B,CAAC;IAED,OAAO,CAAC,KAAa;QACnB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QACpB,IAAI,CAAC,SAAS,EAAE,CAAA;IAClB,CAAC;IAED,MAAM,CAAC,KAAa;QAClB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QACpB,IAAI,CAAC,SAAS,EAAE,CAAA;IAClB,CAAC;IAED,UAAU,CAAC,KAAmC;QAC5C,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;IACnC,CAAC;IAEO,QAAQ,CAAC,GAAQ;QACvB,OAAO,CAAC,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAE,CAAC,OAAO,GAAG,KAAK,UAAU,CAAC,IAAI,CAAC,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAE,CAAA;IAC5G,CAAC;IAEO,WAAW;QAEjB,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,GAAG,CAAC,IAAI,CAAC,EAAE;YACT,IAAG,CAAC,IAAI;gBAAE,OAAM;YAChB,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;YACvF,IAAG,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,MAAK,CAAC,qDAAqD,CAAC,CAAA;YAC7F,IAAG,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,IAAI,CAAC,SAAS,EAAE,CAAA;QACpD,CAAC,CAAC,CACH,CAAC,SAAS,EAAE,CAAA;IAEf,CAAC;IAEO,aAAa,CAAC,KAAa;QAEjC,IAAG,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,WAAW;YAAE,OAAO,EAAE,CAAC,KAAK,CAAC,CAAA;QAEvE,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CACpB,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,GAAG,CAAC,EAAE;YAER,IAAG,CAAC,KAAK;gBAAE,KAAK,GAAG,EAAE,CAAA;YAErB,IAAG,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,UAAU,EAAE;gBAC9B,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,iBAAiB,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC,iBAAiB,EAAE,CAAC,CAAA;gBAC7G,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAA;aACtG;iBAAM;gBACL,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,iBAAiB,EAAE,KAAK,KAAK,CAAC,iBAAiB,EAAE,CAAC,CAAA;aAC9E;QACH,CAAC,CAAC,CACH,CAAA;IAEH,CAAC;IAEO,QAAQ,CAAC,KAAa;QAE5B,IAAG,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK;YAAE,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAC9C,IAAG,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC;YAAE,OAAM;QAEzF,IAAG,IAAI,CAAC,WAAW,EAAE;YACnB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;SACrB;aAAM;YACL,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAA;SAC/D;QAED,IAAG,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY;YAAE,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;IAEtE,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,UAAU,GAAG,KAAK,CAAA;IACzB,CAAC;IAEO,aAAa,CAAC,KAAa;QAEjC,IAAI,CAAC,KAAK,CAAC,IAAI,CACX,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,GAAG,CAAC,EAAE;YAER,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,CAAC,CAAA;YACxD,IAAG,KAAK;gBAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;QAEtF,CAAC,CAAC,CACH,CAAC,SAAS,EAAE,CAAA;IAEjB,CAAC;IAEO,sBAAsB,CAAC,KAAa;QAE1C,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CACpB,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,GAAG,CAAC,EAAE;YAER,IAAG,CAAC,KAAK;gBAAE,KAAK,GAAG,EAAE,CAAA;YAErB,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAA;YAExD,IAAG,GAAG,IAAI,IAAI,CAAC,UAAU,EAAE;gBACzB,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,iBAAiB,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC,iBAAiB,EAAE,CAAC,CAAA;gBACnH,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAA;aAChG;iBAAM;gBACL,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,iBAAiB,EAAE,KAAK,KAAK,CAAC,iBAAiB,EAAE,CAAC,CAAA;aAC9E;QACH,CAAC,CAAC,CACH,CAAA;IAEH,CAAC;;wHAlQY,0BAA0B;4GAA1B,0BAA0B,6aAF1B,CAAC,oBAAoB,CAAC,0BCjBrC,gxCAkDA;4FD/Be,0BAA0B;kBANtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,WAAW,EAAE,qCAAqC;oBAClD,SAAS,EAAE,CAAC,qCAAqC,CAAC;oBAClD,SAAS,EAAE,CAAC,oBAAoB,CAAC;iBAClC;kGAIY,IAAI;sBAAhB,KAAK;gBA8BO,QAAQ;sBAApB,KAAK;gBAoBG,OAAO;sBAAf,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,GAAG;sBAAX,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,WAAW;sBAAnB,KAAK","sourcesContent":["  import { Component, forwardRef, Input, OnInit } from '@angular/core';\n  import { FormBuilder, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';\n  import { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\n  import { isObservable, Observable, of } from 'rxjs';\n  import { map, mergeMap, startWith, take } from 'rxjs/operators';\n\n  export const INPUT_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => AutocompleteEntryComponent),\n    multi: true\n  }\n\n  @Component({\n    selector: 'wav-autocomplete-entry',\n    templateUrl: './autocomplete-entry.component.html',\n    styleUrls: ['./autocomplete-entry.component.scss'],\n    providers: [INPUT_VALUE_ACCESSOR]\n  })\n  export class AutocompleteEntryComponent implements OnInit {\n\n  _data: Observable<any[]> = of([])\n  @Input() set data(value: any) {\n    this._data = (isObservable(value)) ? value : of(value)\n    this.selectedItem.setValue('')\n  }\n\n  get data(): Observable<any[]> {\n\n    return this._data.pipe(\n      take(1),\n      map((response: any) => {\n\n        if (response && this.hasObjects && this.key) {\n\n          if(this.sortAlpha) {\n            response = response.sort((a: any, b: any) => a[this.key].localeCompare(b[this.key])).map((item: any) => item[this.key])\n          }\n\n          return response\n\n        } else {\n          if(!response) response = []\n          return (this.sortAlpha) ? response.sort() : response\n        }\n\n      }),\n    )\n\n  }\n\n  _disabled = false\n  @Input() set disabled(value: boolean) {\n\n    this._disabled = value\n\n    if(value) {\n      this.selectedItem.disable()\n      this.selectedItemDropDown.disable()\n    } else {\n      this.selectedItem.enable()\n      this.selectedItemDropDown.enable()\n    }\n\n  }\n\n  get disabled() {\n    return this._disabled\n  }\n\n  filteredOptions: Observable<string[]> = of([])\n\n  @Input() default = ''\n  @Input() autocomplete = false\n  @Input() required = false\n  @Input() appearance: MatFormFieldAppearance\n  @Input() styles = ''\n  @Input() placeholder = ''\n  @Input() label = ''\n  @Input() prefix = ''\n\n  @Input() minlen = 0\n  @Input() maxlen = 524288\n\n  @Input() sortAlpha = true\n\n  @Input() key: string\n  @Input() returnKey: string\n  @Input() displayInput: string\n  @Input() acceptInput = false\n\n  selectedItem = this.fb.control([null])\n  selectedItemDropDown = this.fb.control([null])\n\n  private onChange: Function\n  private onTouched: Function\n\n  private hasObjects = true\n\n  constructor(\n    private fb: FormBuilder,\n  ) {\n    this.onChange = (_: any) => {}\n    this.onTouched = () => {}\n  }\n\n  ngOnInit() {\n\n    if(this.required) {\n      this.selectedItem.setValidators(Validators.required)\n      this.selectedItemDropDown.setValidators(Validators.required)\n    }\n\n    this.isDataValid()\n\n    this.filteredOptions = this.selectedItem.valueChanges.pipe(\n      startWith(''),\n      mergeMap(findItem => this.data.pipe(\n        map(items => items.filter((item:any) => {\n          return (item?.toLowerCase().startsWith(findItem?.toLowerCase()))\n        }))\n      )),\n    )\n\n    this.selectedItemDropDown.valueChanges.subscribe(value => {\n      this.selected(value)\n    })\n\n  }\n\n  ngAfterViewInit() {\n\n    if(this.default) {\n     setTimeout(() => {\n      this.selectedItem.setValue(this.default, { emitEvent: false })\n      this.selectedItemDropDown.setValue(this.default, { emitEvent: false })\n     }\n       ,0)\n    }\n\n  }\n\n  writeValue(value: any) {\n\n    if(this.returnKey) {\n\n      this.findReturnKeySelection(value).subscribe(value => {\n\n        this.selectedItem.patchValue(value, { emitEvent: false })\n        this.selectedItemDropDown.patchValue(value, { emitEvent: false })\n\n      })\n\n    } else {\n\n      this.selectedItem.patchValue(value, { emitEvent: false })\n      this.selectedItemDropDown.patchValue(value, { emitEvent: false })\n\n    }\n  }\n\n  registerOnChange(fn: (_: any) => void) {\n    this.onChange = fn\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled\n  }\n\n  onEnter(value: string) {\n    this.selected(value)\n    this.onTouched()\n  }\n\n  onBlur(value: string) {\n    this.selected(value)\n    this.onTouched()\n  }\n\n  onSelected(value: MatAutocompleteSelectedEvent) {\n    this.selected(value.option.value)\n  }\n\n  private isObject(val: any): boolean {\n    return (val === null || val === []) ? false : ( (typeof val === 'function') || (typeof val === 'object') )\n  }\n\n  private isDataValid() {\n\n    this._data.pipe(\n      map(data => {\n        if(!data) return\n        this.hasObjects = (data.length > 0) ? data.every(value => this.isObject(value)) : false\n        if(this.hasObjects && !this.key) throw('This array contains Objects. Please specify the key')\n        if(!this.hasObjects && !this.key) this.clearKeys()\n      })\n    ).subscribe()\n\n  }\n\n  private findSelection(value: string) {\n\n    if((!this.returnKey || !this.key) && this.acceptInput) return of(value)\n\n    return this._data.pipe(\n      take(1),\n      map(obj => {\n\n        if(!value) value = ''\n\n        if(this.key && this.hasObjects) {\n          const found = obj.find(obj => (obj[this.key]).toLocaleLowerCase() === (value).toString().toLocaleLowerCase())\n          return (found) ? (this.returnKey) ? found[this.returnKey] : value : (this.acceptInput) ? value : null\n        } else {\n          return obj.find(obj => obj.toLocaleLowerCase() === value.toLocaleLowerCase())\n        }\n      })\n    )\n\n  }\n\n  private selected(value: string) {\n\n    if(!this.selectedItem.valid) this.onChange('')\n    if(this.required && !(this.selectedItem.valid || this.selectedItemDropDown.valid)) return\n\n    if(this.acceptInput) {\n      this.onChange(value)\n    } else {\n      this.findSelection(value).subscribe(val => this.onChange(val))\n    }\n\n    if(this.displayInput && this.autocomplete) this.updateDisplay(value)\n\n  }\n\n  private clearKeys() {\n    this.hasObjects = false\n  }\n\n  private updateDisplay(value: string) {\n\n    this._data.pipe(\n        take(1),\n        map(obj => {\n\n          const found = obj.find(obj => (obj[this.key]) === value)\n          if(found) this.selectedItem.setValue(found[this.displayInput], { emitEvent: false })\n\n        })\n      ).subscribe()\n\n  }\n\n  private findReturnKeySelection(value: string) {\n\n    return this._data.pipe(\n      take(1),\n      map(obj => {\n\n        if(!value) value = ''\n\n        const key = (this.returnKey) ? this.returnKey : this.key\n\n        if(key && this.hasObjects) {\n          const found = obj.find(obj => (obj[key]).toString().toLocaleLowerCase() === (value).toString().toLocaleLowerCase())\n          return (found) ? (this.returnKey) ? found[this.key] : value : (this.acceptInput) ? value : null\n        } else {\n          return obj.find(obj => obj.toLocaleLowerCase() === value.toLocaleLowerCase())\n        }\n      })\n    )\n\n  }\n\n}\n","<div *ngIf=\"autocomplete\">\n  <mat-form-field [appearance]=\"appearance\" fxFlex [style]=\"styles\">\n\n    <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n    <span *ngIf=\"prefix !==''\" matPrefix>{{ prefix }}&nbsp;</span>\n    <input type=\"text\"\n      matInput\n      #inputData\n      [maxlength]=\"maxlen\"\n      [placeholder]=\"placeholder\"\n      [formControl]=\"selectedItem\"\n      [matAutocomplete]=\"auto\"\n      (keyup.enter)=\"onEnter(inputData.value)\"\n      (blur)=\"onBlur(inputData.value)\"\n    >\n    <mat-autocomplete\n      autoActiveFirstOption\n      #auto=\"matAutocomplete\"\n      (optionSelected)='onSelected($event)'\n    >\n      <mat-option\n        *ngFor=\"let item of (filteredOptions | async)\"\n        [value]=\"item\"\n      >\n        {{item}}\n      </mat-option>\n\n    </mat-autocomplete>\n\n  </mat-form-field>\n</div>\n\n<div *ngIf=\"!autocomplete\">\n\n  <mat-form-field [appearance]=\"appearance\" fxFlex [style]=\"styles\">\n\n    <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n    <mat-select [formControl]=\"selectedItemDropDown\">\n      <mat-option\n        *ngFor=\"let item of (data | async)\"\n        [value]=\"item\"\n      >\n        {{item}}\n      </mat-option>\n    </mat-select>\n\n  </mat-form-field>\n\n</div>\n"]} |
@@ -104,4 +104,12 @@ import * as i0 from '@angular/core'; | ||
writeValue(value) { | ||
this.selectedItem.patchValue(value, { emitEvent: false }); | ||
this.selectedItemDropDown.patchValue(value, { emitEvent: false }); | ||
if (this.returnKey) { | ||
this.findReturnKeySelection(value).subscribe(value => { | ||
this.selectedItem.patchValue(value, { emitEvent: false }); | ||
this.selectedItemDropDown.patchValue(value, { emitEvent: false }); | ||
}); | ||
} | ||
else { | ||
this.selectedItem.patchValue(value, { emitEvent: false }); | ||
this.selectedItemDropDown.patchValue(value, { emitEvent: false }); | ||
} | ||
} | ||
@@ -149,3 +157,3 @@ registerOnChange(fn) { | ||
if (this.key && this.hasObjects) { | ||
const found = obj.find(obj => (obj[this.key]).toLocaleLowerCase() === value.toLocaleLowerCase()); | ||
const found = obj.find(obj => (obj[this.key]).toLocaleLowerCase() === (value).toString().toLocaleLowerCase()); | ||
return (found) ? (this.returnKey) ? found[this.returnKey] : value : (this.acceptInput) ? value : null; | ||
@@ -182,2 +190,16 @@ } | ||
} | ||
findReturnKeySelection(value) { | ||
return this._data.pipe(take(1), map(obj => { | ||
if (!value) | ||
value = ''; | ||
const key = (this.returnKey) ? this.returnKey : this.key; | ||
if (key && this.hasObjects) { | ||
const found = obj.find(obj => (obj[key]).toString().toLocaleLowerCase() === (value).toString().toLocaleLowerCase()); | ||
return (found) ? (this.returnKey) ? found[this.key] : value : (this.acceptInput) ? value : null; | ||
} | ||
else { | ||
return obj.find(obj => obj.toLocaleLowerCase() === value.toLocaleLowerCase()); | ||
} | ||
})); | ||
} | ||
} | ||
@@ -184,0 +206,0 @@ AutocompleteEntryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: AutocompleteEntryComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); |
@@ -53,4 +53,5 @@ import { OnInit } from '@angular/core'; | ||
private updateDisplay; | ||
private findReturnKeySelection; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<AutocompleteEntryComponent, never>; | ||
static ɵcmp: i0.ɵɵComponentDeclaration<AutocompleteEntryComponent, "wav-autocomplete-entry", never, { "data": "data"; "disabled": "disabled"; "default": "default"; "autocomplete": "autocomplete"; "required": "required"; "appearance": "appearance"; "styles": "styles"; "placeholder": "placeholder"; "label": "label"; "prefix": "prefix"; "minlen": "minlen"; "maxlen": "maxlen"; "sortAlpha": "sortAlpha"; "key": "key"; "returnKey": "returnKey"; "displayInput": "displayInput"; "acceptInput": "acceptInput"; }, {}, never, never>; | ||
} |
{ | ||
"name": "autocomplete-entry", | ||
"version": "3.3.1", | ||
"version": "3.3.2", | ||
"description": "This Angular Material Component (Module) allows you to have an autocomplete or dropdown menu. You can provide an array of objects or an Observable array of objects", | ||
@@ -5,0 +5,0 @@ "author": "Mike Boni <wavecoders@gmail.com> (http://wavecoders.ca)", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
123958
1046