@guajiritos/general-autocomplete 0.0.6 → 0.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. package/esm2020/guajiritos-general-autocomplete.mjs +4 -4
  2. package/esm2020/lib/guachos-general-autocomplete.component.mjs +327 -309
  3. package/esm2020/lib/guachos-general-autocomplete.module.mjs +108 -108
  4. package/esm2020/public-api.mjs +7 -7
  5. package/esm2020/utils/constants/contacts.mjs +9 -9
  6. package/esm2020/utils/interfaces/interfaces.mjs +11 -11
  7. package/esm2020/utils/pipes/duration.pipe.mjs +17 -17
  8. package/esm2020/utils/pipes/humanize-duration.pipe.mjs +16 -16
  9. package/esm2020/utils/pipes/i18n-field.pipe.mjs +27 -27
  10. package/esm2020/utils/pipes/ida-return.pipe.mjs +22 -22
  11. package/esm2020/utils/pipes/resolve-property-path.pipe.mjs +79 -79
  12. package/esm2020/utils/pipes/show-roles.pipe.mjs +23 -23
  13. package/esm2020/utils/pipes/show-segments.pipe.mjs +23 -23
  14. package/esm2020/utils/pipes/show-transport-types.pipe.mjs +23 -23
  15. package/esm2020/utils/services/autocomplete.service.mjs +161 -161
  16. package/esm2020/utils/services/utils.service.mjs +47 -47
  17. package/fesm2015/guajiritos-general-autocomplete.mjs +802 -784
  18. package/fesm2015/guajiritos-general-autocomplete.mjs.map +1 -1
  19. package/fesm2020/guajiritos-general-autocomplete.mjs +798 -780
  20. package/fesm2020/guajiritos-general-autocomplete.mjs.map +1 -1
  21. package/index.d.ts +5 -5
  22. package/lib/guachos-general-autocomplete.component.d.ts +72 -72
  23. package/lib/guachos-general-autocomplete.module.d.ts +24 -24
  24. package/package.json +3 -2
  25. package/public-api.d.ts +4 -4
  26. package/utils/constants/contacts.d.ts +2 -2
  27. package/utils/interfaces/interfaces.d.ts +33 -33
  28. package/utils/pipes/duration.pipe.d.ts +8 -8
  29. package/utils/pipes/humanize-duration.pipe.d.ts +7 -7
  30. package/utils/pipes/i18n-field.pipe.d.ts +7 -7
  31. package/utils/pipes/ida-return.pipe.d.ts +8 -8
  32. package/utils/pipes/resolve-property-path.pipe.d.ts +24 -24
  33. package/utils/pipes/show-roles.pipe.d.ts +8 -8
  34. package/utils/pipes/show-segments.pipe.d.ts +8 -8
  35. package/utils/pipes/show-transport-types.pipe.d.ts +8 -8
  36. package/utils/services/autocomplete.service.d.ts +15 -15
  37. package/utils/services/utils.service.d.ts +25 -25
@@ -1,309 +1,327 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Input, Output, TemplateRef, ViewChild } from '@angular/core';
2
- import { FormControl, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';
3
- import { TranslateService } from '@ngx-translate/core';
4
- import { debounceTime, Subject, takeUntil } from 'rxjs';
5
- import { GENERAL_DISPLAY_OPTIONS } from '../utils/constants/contacts';
6
- import { AutocompleteService } from '../utils/services/autocomplete.service';
7
- import { UtilsService } from '../utils/services/utils.service';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "../utils/services/autocomplete.service";
10
- import * as i2 from "@ngx-translate/core";
11
- import * as i3 from "@angular/common";
12
- import * as i4 from "@angular/forms";
13
- import * as i5 from "@angular/material/form-field";
14
- import * as i6 from "@angular/material/icon";
15
- import * as i7 from "@angular/material/progress-spinner";
16
- import * as i8 from "@angular/material/button";
17
- import * as i9 from "@angular/material/input";
18
- import * as i10 from "@angular/material/autocomplete";
19
- import * as i11 from "@angular/material/core";
20
- import * as i12 from "../utils/pipes/i18n-field.pipe";
21
- import * as i13 from "../utils/pipes/resolve-property-path.pipe";
22
- export class GuajiritosGeneralAutocompleteComponent {
23
- constructor(_autocompleteService, _cdRef, translateService) {
24
- this._autocompleteService = _autocompleteService;
25
- this._cdRef = _cdRef;
26
- this.translateService = translateService;
27
- this.unsubscribeAll$ = new Subject();
28
- this.firstCall = true;
29
- this.restrictionsFilters = [];
30
- this.required = true;
31
- this.component = new FormControl({
32
- value: null, disabled: false
33
- });
34
- this.disabled = false;
35
- this.loading = false;
36
- /**
37
- * Possible values 'never', 'auto' or 'always'
38
- */
39
- this.floatLabel = 'auto';
40
- this.debounceTimeValue = 250;
41
- this.label = 'Seleccione';
42
- this.placeholder = 'Seleccione un elemento';
43
- this.field = ['name'];
44
- this.filterString = 'filter[$and][name][$like]';
45
- this.displayOptions = GENERAL_DISPLAY_OPTIONS;
46
- this.withoutPaddingBottom = true;
47
- this.valueId = false;
48
- this.disable = false;
49
- this.order = null;
50
- this.removeProperties = [];
51
- this.SelectElement = new EventEmitter();
52
- this.onChanged = () => {
53
- };
54
- this.onTouched = () => {
55
- };
56
- this.displayFn = (value) => {
57
- if (value) {
58
- if (typeof value === 'string') {
59
- return value;
60
- }
61
- let displayText = '';
62
- if (!this.displayOptions) {
63
- this.displayOptions = GENERAL_DISPLAY_OPTIONS;
64
- }
65
- this.displayOptions?.firthLabel?.forEach((field) => {
66
- if (field?.type === 'path') {
67
- displayText += UtilsService.resolvePropertyByPath(value, field?.path);
68
- }
69
- else {
70
- displayText += field?.divider;
71
- }
72
- });
73
- return displayText;
74
- }
75
- };
76
- }
77
- set url(data) {
78
- if (data) {
79
- this._url = data;
80
- this.subscribeComponentChanges();
81
- }
82
- }
83
- set clearData(value) {
84
- this.clearData$ = value;
85
- if (this.clearData$) {
86
- this.clearData$
87
- .pipe(takeUntil(this.unsubscribeAll$))
88
- .subscribe(() => {
89
- this.component.setValue(null);
90
- this.selectedElement = null;
91
- this.SelectElement.emit(null);
92
- this.filteredOptions = [];
93
- this.onChanged(null);
94
- });
95
- }
96
- }
97
- set initialValue(value) {
98
- this.component.setValue(value);
99
- }
100
- set restrictions(value) {
101
- if (value) {
102
- this.restrictionsFilters = value;
103
- }
104
- else {
105
- this.restrictionsFilters = [];
106
- }
107
- }
108
- set isRequired(value) {
109
- this.required = value;
110
- if (this.required) {
111
- this.component.setValidators([Validators.required, GuajiritosGeneralAutocompleteComponent.ValidateAutocomplete]);
112
- }
113
- else {
114
- this.component.clearValidators();
115
- }
116
- this.component.updateValueAndValidity();
117
- }
118
- get doFocus() {
119
- return this.doFocusSubject;
120
- }
121
- set doFocus(value) {
122
- this.doFocusSubject = value;
123
- if (value) {
124
- this.doFocusSubject
125
- .pipe(takeUntil(this.unsubscribeAll$))
126
- .subscribe(() => {
127
- setTimeout(() => {
128
- this.inputText.nativeElement.focus();
129
- }, 500);
130
- });
131
- }
132
- }
133
- static ValidateAutocomplete(control) {
134
- if (control?.value?.constructor !== Object || !control?.value?.id) {
135
- return { invalidSelection: true };
136
- }
137
- return null;
138
- }
139
- subscribeComponentChanges() {
140
- this.component?.valueChanges
141
- ?.pipe(debounceTime(this.debounceTimeValue), takeUntil(this.unsubscribeAll$))
142
- ?.subscribe(() => {
143
- if (!this.firstCall) {
144
- this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());
145
- }
146
- else {
147
- this.firstCall = false;
148
- }
149
- });
150
- }
151
- getAutocompleteByTextHandler(text) {
152
- this._autocompleteService
153
- .getAutocompleteByText(this._url, text, this.filterString, this.restrictionsFilters, this.removeProperties, this.order, this.bodyRequest)
154
- .then((resp) => {
155
- resp?.subscribe((result) => {
156
- this.filteredOptions = result?.payload?.data;
157
- this.loading = false;
158
- this._cdRef.detectChanges();
159
- });
160
- });
161
- }
162
- getAutocompleteSearchText() {
163
- this.loading = true;
164
- let text = null;
165
- if (this.component?.value) {
166
- if (typeof this.component.value === 'object') {
167
- const componentValue = this.component?.value[this.field[0]];
168
- if (typeof componentValue === 'object') {
169
- let lang = 'es';
170
- if (this.field[1]) {
171
- lang = this.field[1];
172
- }
173
- text = componentValue[lang];
174
- }
175
- }
176
- else if (typeof this.component?.value === 'string') {
177
- text = this.component.value;
178
- }
179
- }
180
- return text;
181
- }
182
- clear(trigger) {
183
- this.component.setValue(null);
184
- this.selectedElement = null;
185
- this.SelectElement.emit(null);
186
- this._cdRef.detectChanges();
187
- this.onChanged(null);
188
- setTimeout(() => {
189
- trigger.openPanel();
190
- this._cdRef.detectChanges();
191
- }, 200);
192
- }
193
- onFocus() {
194
- this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());
195
- }
196
- onSelectElement(item) {
197
- this.selectedElement = item;
198
- this.SelectElement.emit(item);
199
- this.value = item;
200
- if (this.valueId) {
201
- this.onChanged(item?.id);
202
- }
203
- else {
204
- this.onChanged(item);
205
- }
206
- this._cdRef.detectChanges();
207
- }
208
- writeValue(value) {
209
- if (value) {
210
- if (typeof value === 'number') {
211
- this.value = value;
212
- }
213
- else if (typeof value === 'object') {
214
- this.component.setValue(value);
215
- this.value = value.id;
216
- }
217
- else {
218
- this.value = value;
219
- }
220
- }
221
- else {
222
- this.value = null;
223
- }
224
- this._cdRef.detectChanges();
225
- }
226
- registerOnChange(fn) {
227
- this.onChanged = fn;
228
- this._cdRef.detectChanges();
229
- }
230
- registerOnTouched(fn) {
231
- this.onTouched = fn;
232
- this._cdRef.detectChanges();
233
- }
234
- setDisabledState(isDisabled) {
235
- this.disabled = isDisabled;
236
- this._cdRef.detectChanges();
237
- }
238
- ngOnInit() {
239
- this.component.markAllAsTouched();
240
- }
241
- ngOnDestroy() {
242
- this.unsubscribeAll$.next();
243
- this.unsubscribeAll$.complete();
244
- }
245
- }
246
- GuajiritosGeneralAutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: GuajiritosGeneralAutocompleteComponent, deps: [{ token: i1.AutocompleteService }, { token: i0.ChangeDetectorRef }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
247
- GuajiritosGeneralAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.4", type: GuajiritosGeneralAutocompleteComponent, selector: "guajiritos-general-autocomplete", inputs: { floatLabel: "floatLabel", bodyRequest: "bodyRequest", debounceTimeValue: "debounceTimeValue", detailsTemplate: "detailsTemplate", label: "label", placeholder: "placeholder", field: "field", filterString: "filterString", displayOptions: "displayOptions", withoutPaddingBottom: "withoutPaddingBottom", valueId: "valueId", disable: "disable", order: "order", removeProperties: "removeProperties", url: "url", clearData: "clearData", initialValue: "initialValue", restrictions: "restrictions", isRequired: "isRequired", doFocus: "doFocus" }, outputs: { SelectElement: "SelectElement" }, providers: [
248
- {
249
- provide: NG_VALUE_ACCESSOR,
250
- useExisting: forwardRef(() => GuajiritosGeneralAutocompleteComponent),
251
- multi: true
252
- }
253
- ], viewQueries: [{ propertyName: "inputText", first: true, predicate: ["inputText"], descendants: true, static: true }], ngImport: i0, template: "<mat-form-field [floatLabel]=\"floatLabel\" [ngClass]=\"{'without-padding-bottom': withoutPaddingBottom}\"\r\n appearance=\"outline\" class=\"w-100\" color=\"accent\">\r\n\r\n <mat-label>{{label | translate}}</mat-label>\r\n <input #inputText #trigger=\"matAutocompleteTrigger\" (blur)=\"onTouched()\" (focus)=\"onFocus()\" [disabled]=\"disable\"\r\n [formControl]=\"component\" [matAutocomplete]=\"autocomplete\" [placeholder]=\"placeholder | translate\"\r\n aria-label=\"Number\" autocomplete=\"off\" matInput type=\"text\">\r\n <button (click)=\"clear(trigger)\" *ngIf=\"!loading && component?.value\" [disabled]=\"disable\" aria-label=\"Clear\"\r\n mat-icon-button matSuffix>\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n <button *ngIf=\"loading\" aria-label=\"Clear\" mat-icon-button matSuffix>\r\n <mat-spinner [value]=\"90\" color=\"accent\" diameter=\"25\"></mat-spinner>\r\n </button>\r\n <mat-autocomplete #autocomplete=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\"\r\n (onSelectionChange)=\"onSelectElement(option)\">\r\n\r\n <ng-container *ngIf=\"!displayOptions && !detailsTemplate\">\r\n {{ option?.name | i18nField: translateService.currentLang }}\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!detailsTemplate\">\r\n <div class=\"display-options\">\r\n <span [ngStyle]=\"{'line-height': displayOptions?.secondLabel ? '16px' : ''}\">\r\n {{option | resolvePropertyPath:displayOptions?.firthLabel | i18nField: translateService.currentLang}}\r\n </span>\r\n <span *ngIf=\"displayOptions?.secondLabel\" class=\"mat-caption\">\r\n {{option | resolvePropertyPath: displayOptions?.secondLabel | i18nField: translateService.currentLang}}\r\n </span>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"detailsTemplate\">\r\n <ng-container *ngTemplateOutlet=\"detailsTemplate;context:{$implicit: option }\"></ng-container>\r\n </ng-container>\r\n\r\n </mat-option>\r\n </mat-autocomplete>\r\n</mat-form-field>\r\n", styles: ["::ng-deep .without-padding-bottom .mat-form-field-wrapper{padding-bottom:0!important}.w-100{width:100%}.display-options{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i11.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i10.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i12.I18nFieldPipe, name: "i18nField" }, { kind: "pipe", type: i13.ResolvePropertyPath, name: "resolvePropertyPath" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
254
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: GuajiritosGeneralAutocompleteComponent, decorators: [{
255
- type: Component,
256
- args: [{ selector: 'guajiritos-general-autocomplete', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
257
- {
258
- provide: NG_VALUE_ACCESSOR,
259
- useExisting: forwardRef(() => GuajiritosGeneralAutocompleteComponent),
260
- multi: true
261
- }
262
- ], template: "<mat-form-field [floatLabel]=\"floatLabel\" [ngClass]=\"{'without-padding-bottom': withoutPaddingBottom}\"\r\n appearance=\"outline\" class=\"w-100\" color=\"accent\">\r\n\r\n <mat-label>{{label | translate}}</mat-label>\r\n <input #inputText #trigger=\"matAutocompleteTrigger\" (blur)=\"onTouched()\" (focus)=\"onFocus()\" [disabled]=\"disable\"\r\n [formControl]=\"component\" [matAutocomplete]=\"autocomplete\" [placeholder]=\"placeholder | translate\"\r\n aria-label=\"Number\" autocomplete=\"off\" matInput type=\"text\">\r\n <button (click)=\"clear(trigger)\" *ngIf=\"!loading && component?.value\" [disabled]=\"disable\" aria-label=\"Clear\"\r\n mat-icon-button matSuffix>\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n <button *ngIf=\"loading\" aria-label=\"Clear\" mat-icon-button matSuffix>\r\n <mat-spinner [value]=\"90\" color=\"accent\" diameter=\"25\"></mat-spinner>\r\n </button>\r\n <mat-autocomplete #autocomplete=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\"\r\n (onSelectionChange)=\"onSelectElement(option)\">\r\n\r\n <ng-container *ngIf=\"!displayOptions && !detailsTemplate\">\r\n {{ option?.name | i18nField: translateService.currentLang }}\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!detailsTemplate\">\r\n <div class=\"display-options\">\r\n <span [ngStyle]=\"{'line-height': displayOptions?.secondLabel ? '16px' : ''}\">\r\n {{option | resolvePropertyPath:displayOptions?.firthLabel | i18nField: translateService.currentLang}}\r\n </span>\r\n <span *ngIf=\"displayOptions?.secondLabel\" class=\"mat-caption\">\r\n {{option | resolvePropertyPath: displayOptions?.secondLabel | i18nField: translateService.currentLang}}\r\n </span>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"detailsTemplate\">\r\n <ng-container *ngTemplateOutlet=\"detailsTemplate;context:{$implicit: option }\"></ng-container>\r\n </ng-container>\r\n\r\n </mat-option>\r\n </mat-autocomplete>\r\n</mat-form-field>\r\n", styles: ["::ng-deep .without-padding-bottom .mat-form-field-wrapper{padding-bottom:0!important}.w-100{width:100%}.display-options{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}\n"] }]
263
- }], ctorParameters: function () { return [{ type: i1.AutocompleteService }, { type: i0.ChangeDetectorRef }, { type: i2.TranslateService }]; }, propDecorators: { inputText: [{
264
- type: ViewChild,
265
- args: ['inputText', { static: true }]
266
- }], floatLabel: [{
267
- type: Input
268
- }], bodyRequest: [{
269
- type: Input
270
- }], debounceTimeValue: [{
271
- type: Input
272
- }], detailsTemplate: [{
273
- type: Input
274
- }], label: [{
275
- type: Input
276
- }], placeholder: [{
277
- type: Input
278
- }], field: [{
279
- type: Input
280
- }], filterString: [{
281
- type: Input
282
- }], displayOptions: [{
283
- type: Input
284
- }], withoutPaddingBottom: [{
285
- type: Input
286
- }], valueId: [{
287
- type: Input
288
- }], disable: [{
289
- type: Input
290
- }], order: [{
291
- type: Input
292
- }], removeProperties: [{
293
- type: Input
294
- }], SelectElement: [{
295
- type: Output
296
- }], url: [{
297
- type: Input
298
- }], clearData: [{
299
- type: Input
300
- }], initialValue: [{
301
- type: Input
302
- }], restrictions: [{
303
- type: Input
304
- }], isRequired: [{
305
- type: Input
306
- }], doFocus: [{
307
- type: Input
308
- }] } });
309
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guachos-general-autocomplete.component.js","sourceRoot":"","sources":["../../../../projects/guachos-general-autocomplete/src/lib/guachos-general-autocomplete.component.ts","../../../../projects/guachos-general-autocomplete/src/lib/guachos-general-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport {\n    ControlValueAccessor,\n    FormControl,\n    NG_VALUE_ACCESSOR,\n    Validators\n} from '@angular/forms';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {FloatLabelType} from '@angular/material/form-field';\nimport {TranslateService} from '@ngx-translate/core';\nimport {debounceTime, Observable, Subject, takeUntil} from 'rxjs';\n\nimport {GENERAL_DISPLAY_OPTIONS} from '../utils/constants/contacts';\nimport {AutocompleteService} from '../utils/services/autocomplete.service';\nimport {UtilsService} from '../utils/services/utils.service';\nimport {ApiFormData, DisplayOption, RestrictionFilter} from \"../utils/interfaces/interfaces\";\n\ndeclare interface PayloadResponse {\n    data: any;\n    meta: any;\n}\n\ndeclare interface GenericResponse {\n    payload: PayloadResponse;\n    error: any;\n    requestId: string;\n}\n\n@Component({\n    selector: 'guajiritos-general-autocomplete',\n    templateUrl: './guachos-general-autocomplete.component.html',\n    styleUrls: ['./guachos-general-autocomplete.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => GuajiritosGeneralAutocompleteComponent),\n            multi: true\n        }\n    ]\n})\nexport class GuajiritosGeneralAutocompleteComponent implements OnInit, OnDestroy, ControlValueAccessor {\n\n    constructor(\n        private _autocompleteService: AutocompleteService,\n        private _cdRef: ChangeDetectorRef,\n        public translateService: TranslateService,\n    ) {\n    }\n\n    private unsubscribeAll$: Subject<void> = new Subject<void>();\n    private firstCall: boolean = true;\n    private restrictionsFilters: RestrictionFilter[] = [];\n    private selectedElement: any;\n    private doFocusSubject: Subject<any>;\n    private clearData$: Subject<any>;\n    private _url: string;\n\n    public required: boolean = true;\n    public component: FormControl = new FormControl({\n        value: null, disabled: false\n    });\n    public value: any;\n    public disabled: boolean = false;\n    public filteredOptions: any[];\n    public loading: boolean = false;\n\n    @ViewChild('inputText', {static: true}) inputText: ElementRef;\n    /**\n     * Possible values 'never', 'auto' or 'always'\n     */\n    @Input() floatLabel: FloatLabelType = 'auto';\n    @Input() bodyRequest: ApiFormData;\n    @Input() debounceTimeValue: number = 250;\n    @Input() detailsTemplate: TemplateRef<any>;\n    @Input() label: string = 'Seleccione';\n    @Input() placeholder: string = 'Seleccione un elemento';\n    @Input() field: string[] = ['name'];\n    @Input() filterString: string = 'filter[$and][name][$like]';\n    @Input() displayOptions: DisplayOption = GENERAL_DISPLAY_OPTIONS;\n    @Input() withoutPaddingBottom: boolean = true;\n    @Input() valueId: boolean = false;\n    @Input() disable: boolean = false;\n    @Input() order: string = null;\n    @Input() removeProperties: string[] = [];\n    @Output() SelectElement: EventEmitter<any> = new EventEmitter<any>();\n\n    @Input() set url(data: string) {\n        if (data) {\n            this._url = data;\n\n            this.subscribeComponentChanges();\n        }\n    }\n\n    @Input() set clearData(value: any) {\n        this.clearData$ = value;\n        if (this.clearData$) {\n            this.clearData$\n                .pipe(takeUntil(this.unsubscribeAll$))\n                .subscribe(() => {\n                    this.component.setValue(null);\n                    this.selectedElement = null;\n                    this.SelectElement.emit(null);\n                    this.filteredOptions = [];\n                    this.onChanged(null);\n                });\n        }\n    }\n\n    @Input() set initialValue(value: any) {\n        this.component.setValue(value);\n    }\n\n    @Input() set restrictions(value: any) {\n        if (value) {\n            this.restrictionsFilters = value;\n        } else {\n            this.restrictionsFilters = [];\n        }\n    }\n\n    @Input() set isRequired(value: boolean) {\n        this.required = value;\n\n        if (this.required) {\n            this.component.setValidators([Validators.required, GuajiritosGeneralAutocompleteComponent.ValidateAutocomplete]);\n        } else {\n            this.component.clearValidators();\n        }\n\n        this.component.updateValueAndValidity();\n    }\n\n    get doFocus(): Subject<any> {\n        return this.doFocusSubject;\n    }\n\n    @Input() set doFocus(value: Subject<any>) {\n        this.doFocusSubject = value;\n\n        if (value) {\n            this.doFocusSubject\n                .pipe(takeUntil(this.unsubscribeAll$))\n                .subscribe(() => {\n                    setTimeout(() => {\n                        this.inputText.nativeElement.focus();\n                    }, 500);\n                });\n        }\n    }\n\n    private static ValidateAutocomplete(control: FormControl) {\n        if (control?.value?.constructor !== Object || !control?.value?.id) {\n            return {invalidSelection: true};\n        }\n\n        return null;\n    }\n\n    private subscribeComponentChanges(): void {\n        this.component?.valueChanges\n            ?.pipe(debounceTime(this.debounceTimeValue), takeUntil(this.unsubscribeAll$))\n            ?.subscribe(() => {\n                if (!this.firstCall) {\n                    this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());\n                } else {\n                    this.firstCall = false;\n                }\n            });\n    }\n\n    private getAutocompleteByTextHandler(text?: string): void {\n        this._autocompleteService\n            .getAutocompleteByText(this._url, text, this.filterString, this.restrictionsFilters,\n                this.removeProperties, this.order, this.bodyRequest)\n            .then((resp: Observable<any>) => {\n                resp?.subscribe((result: GenericResponse) => {\n                    this.filteredOptions = result?.payload?.data;\n                    this.loading = false;\n                    this._cdRef.detectChanges();\n                });\n            });\n    }\n\n    private getAutocompleteSearchText(): string {\n        this.loading = true;\n\n        let text: string = null;\n        if (this.component?.value) {\n            if (typeof this.component.value === 'object') {\n                const componentValue = this.component?.value[this.field[0]]\n                if (typeof componentValue === 'object') {\n                    let lang: string = 'es';\n                    if (this.field[1]) {\n                        lang = this.field[1];\n                    }\n\n                    text = componentValue[lang];\n                }\n            } else if (typeof this.component?.value === 'string') {\n                text = this.component.value;\n            }\n        }\n\n        return text;\n    }\n\n    onChanged: any = () => {\n    };\n\n    onTouched: any = () => {\n    };\n\n    public clear(trigger: MatAutocompleteTrigger): void {\n        this.component.setValue(null);\n        this.selectedElement = null;\n        this.SelectElement.emit(null);\n        this._cdRef.detectChanges();\n        this.onChanged(null);\n\n        setTimeout(() => {\n            trigger.openPanel();\n            this._cdRef.detectChanges();\n        }, 200);\n    }\n\n    public onFocus(): void {\n        this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());\n    }\n\n    public onSelectElement(item: any): void {\n        this.selectedElement = item;\n        this.SelectElement.emit(item);\n        this.value = item;\n\n        if (this.valueId) {\n            this.onChanged(item?.id);\n        } else {\n            this.onChanged(item);\n        }\n\n        this._cdRef.detectChanges();\n    }\n\n    displayFn = (value: any) => {\n        if (value) {\n            if (typeof value === 'string') {\n                return value;\n            }\n\n            let displayText = '';\n            if (!this.displayOptions) {\n                this.displayOptions = GENERAL_DISPLAY_OPTIONS;\n            }\n            this.displayOptions?.firthLabel?.forEach((field: any) => {\n                if (field?.type === 'path') {\n                    displayText += UtilsService.resolvePropertyByPath(value, field?.path);\n                } else {\n                    displayText += field?.divider;\n                }\n            });\n            return displayText;\n        }\n    };\n\n    writeValue(value: any): void {\n        if (value) {\n            if (typeof value === 'number') {\n                this.value = value;\n            } else if (typeof value === 'object') {\n                this.component.setValue(value);\n                this.value = value.id;\n            } else {\n                this.value = value;\n            }\n        } else {\n            this.value = null;\n        }\n\n        this._cdRef.detectChanges();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChanged = fn;\n        this._cdRef.detectChanges();\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n        this._cdRef.detectChanges();\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n        this._cdRef.detectChanges();\n    }\n\n    ngOnInit(): void {\n        this.component.markAllAsTouched();\n    }\n\n    ngOnDestroy(): void {\n        this.unsubscribeAll$.next();\n        this.unsubscribeAll$.complete();\n    }\n}\n","<mat-form-field [floatLabel]=\"floatLabel\" [ngClass]=\"{'without-padding-bottom': withoutPaddingBottom}\"\r\n                appearance=\"outline\" class=\"w-100\" color=\"accent\">\r\n\r\n    <mat-label>{{label | translate}}</mat-label>\r\n    <input #inputText #trigger=\"matAutocompleteTrigger\" (blur)=\"onTouched()\" (focus)=\"onFocus()\" [disabled]=\"disable\"\r\n           [formControl]=\"component\" [matAutocomplete]=\"autocomplete\" [placeholder]=\"placeholder | translate\"\r\n           aria-label=\"Number\" autocomplete=\"off\" matInput type=\"text\">\r\n    <button (click)=\"clear(trigger)\" *ngIf=\"!loading && component?.value\" [disabled]=\"disable\" aria-label=\"Clear\"\r\n            mat-icon-button matSuffix>\r\n        <mat-icon>close</mat-icon>\r\n    </button>\r\n    <button *ngIf=\"loading\" aria-label=\"Clear\" mat-icon-button matSuffix>\r\n        <mat-spinner [value]=\"90\" color=\"accent\" diameter=\"25\"></mat-spinner>\r\n    </button>\r\n    <mat-autocomplete #autocomplete=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n        <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\"\r\n                    (onSelectionChange)=\"onSelectElement(option)\">\r\n\r\n            <ng-container *ngIf=\"!displayOptions && !detailsTemplate\">\r\n                {{ option?.name | i18nField: translateService.currentLang }}\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"!detailsTemplate\">\r\n                <div class=\"display-options\">\r\n                  <span [ngStyle]=\"{'line-height': displayOptions?.secondLabel ? '16px' : ''}\">\r\n                    {{option | resolvePropertyPath:displayOptions?.firthLabel | i18nField: translateService.currentLang}}\r\n                  </span>\r\n                    <span *ngIf=\"displayOptions?.secondLabel\" class=\"mat-caption\">\r\n                    {{option | resolvePropertyPath: displayOptions?.secondLabel | i18nField: translateService.currentLang}}\r\n                  </span>\r\n                </div>\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"detailsTemplate\">\r\n                <ng-container *ngTemplateOutlet=\"detailsTemplate;context:{$implicit: option }\"></ng-container>\r\n            </ng-container>\r\n\r\n        </mat-option>\r\n    </mat-autocomplete>\r\n</mat-form-field>\r\n"]}
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Input, NgZone, Output, TemplateRef, ViewChild } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR, UntypedFormControl, Validators } from '@angular/forms';
3
+ import { TranslateService } from '@ngx-translate/core';
4
+ import { debounceTime, Subject, takeUntil } from 'rxjs';
5
+ import { GENERAL_DISPLAY_OPTIONS } from '../utils/constants/contacts';
6
+ import { AutocompleteService } from '../utils/services/autocomplete.service';
7
+ import { UtilsService } from '../utils/services/utils.service';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "../utils/services/autocomplete.service";
10
+ import * as i2 from "@ngx-translate/core";
11
+ import * as i3 from "@angular/common";
12
+ import * as i4 from "@angular/forms";
13
+ import * as i5 from "@angular/material/form-field";
14
+ import * as i6 from "@angular/material/icon";
15
+ import * as i7 from "@angular/material/progress-spinner";
16
+ import * as i8 from "@angular/material/button";
17
+ import * as i9 from "@angular/material/input";
18
+ import * as i10 from "@angular/material/autocomplete";
19
+ import * as i11 from "@angular/material/core";
20
+ import * as i12 from "../utils/pipes/i18n-field.pipe";
21
+ import * as i13 from "../utils/pipes/resolve-property-path.pipe";
22
+ export class GuajiritosGeneralAutocompleteComponent {
23
+ constructor(_autocompleteService, _cdRef, _zone, translateService) {
24
+ this._autocompleteService = _autocompleteService;
25
+ this._cdRef = _cdRef;
26
+ this._zone = _zone;
27
+ this.translateService = translateService;
28
+ this.unsubscribeAll$ = new Subject();
29
+ this.firstCall = true;
30
+ this.restrictionsFilters = [];
31
+ this.required = true;
32
+ this.component = new UntypedFormControl({
33
+ value: null, disabled: false
34
+ });
35
+ this.disabledButton = false;
36
+ this.loading = false;
37
+ /**
38
+ * Possible values 'never', 'auto' or 'always'
39
+ */
40
+ this.floatLabel = 'auto';
41
+ this.debounceTimeValue = 250;
42
+ this.label = 'Seleccione';
43
+ this.placeholder = 'Seleccione un elemento';
44
+ this.field = ['name'];
45
+ this.filterString = 'filter[$and][name][$like]';
46
+ this.displayOptions = GENERAL_DISPLAY_OPTIONS;
47
+ this.withoutPaddingBottom = true;
48
+ this.valueId = false;
49
+ this.order = null;
50
+ this.removeProperties = [];
51
+ this.SelectElement = new EventEmitter();
52
+ this.onChanged = () => {
53
+ };
54
+ this.onTouched = () => {
55
+ };
56
+ this.displayFn = (value) => {
57
+ if (value) {
58
+ if (typeof value === 'string') {
59
+ return value;
60
+ }
61
+ let displayText = '';
62
+ if (!this.displayOptions) {
63
+ this.displayOptions = GENERAL_DISPLAY_OPTIONS;
64
+ }
65
+ this.displayOptions?.firthLabel?.forEach((field) => {
66
+ if (field?.type === 'path') {
67
+ displayText += UtilsService.resolvePropertyByPath(value, field?.path);
68
+ }
69
+ else {
70
+ displayText += field?.divider;
71
+ }
72
+ });
73
+ return displayText;
74
+ }
75
+ };
76
+ }
77
+ set disable(flag) {
78
+ this.disabledButton = flag;
79
+ if (flag) {
80
+ this.component.disable();
81
+ }
82
+ else {
83
+ this.component.enable();
84
+ }
85
+ this._cdRef.detectChanges();
86
+ }
87
+ set url(data) {
88
+ if (data) {
89
+ this._url = data;
90
+ this.subscribeComponentChanges();
91
+ }
92
+ }
93
+ set clearData(value) {
94
+ this.clearData$ = value;
95
+ if (this.clearData$) {
96
+ this.clearData$
97
+ .pipe(takeUntil(this.unsubscribeAll$))
98
+ .subscribe({
99
+ next: () => {
100
+ this.component.setValue(null);
101
+ this.selectedElement = null;
102
+ this.SelectElement.emit(null);
103
+ this.filteredOptions = [];
104
+ this.onChanged(null);
105
+ }
106
+ });
107
+ }
108
+ }
109
+ set initialValue(value) {
110
+ this.component.setValue(value);
111
+ }
112
+ set restrictions(value) {
113
+ if (value) {
114
+ this.restrictionsFilters = value;
115
+ }
116
+ else {
117
+ this.restrictionsFilters = [];
118
+ }
119
+ }
120
+ set isRequired(value) {
121
+ this.required = value;
122
+ if (this.required) {
123
+ this.component.setValidators([Validators.required, GuajiritosGeneralAutocompleteComponent.ValidateAutocomplete]);
124
+ }
125
+ else {
126
+ this.component.clearValidators();
127
+ }
128
+ this.component.updateValueAndValidity();
129
+ }
130
+ get doFocus() {
131
+ return this.doFocusSubject$;
132
+ }
133
+ set doFocus(value) {
134
+ this.doFocusSubject$ = value;
135
+ if (value) {
136
+ this.doFocusSubject$
137
+ .pipe(takeUntil(this.unsubscribeAll$))
138
+ .subscribe({
139
+ next: () => {
140
+ this._zone.run(() => {
141
+ setTimeout(() => {
142
+ this.inputText.nativeElement.focus();
143
+ }, 500);
144
+ });
145
+ }
146
+ });
147
+ }
148
+ }
149
+ static ValidateAutocomplete(control) {
150
+ if (control?.value?.constructor !== Object || !control?.value?.id) {
151
+ return { invalidSelection: true };
152
+ }
153
+ return null;
154
+ }
155
+ subscribeComponentChanges() {
156
+ this.component?.valueChanges
157
+ ?.pipe(debounceTime(this.debounceTimeValue), takeUntil(this.unsubscribeAll$))
158
+ ?.subscribe({
159
+ next: () => {
160
+ if (!this.firstCall) {
161
+ this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());
162
+ }
163
+ else {
164
+ this.firstCall = false;
165
+ }
166
+ }
167
+ });
168
+ }
169
+ getAutocompleteByTextHandler(text) {
170
+ this._autocompleteService
171
+ .getAutocompleteByText(this._url, text, this.filterString, this.restrictionsFilters, this.removeProperties, this.order, this.bodyRequest)
172
+ .then((resp) => {
173
+ resp?.subscribe({
174
+ next: (result) => {
175
+ this.filteredOptions = result?.payload?.data || result?.data;
176
+ this.loading = false;
177
+ this._cdRef.detectChanges();
178
+ }
179
+ });
180
+ });
181
+ }
182
+ getAutocompleteSearchText() {
183
+ this.loading = true;
184
+ let text = null;
185
+ if (this.component?.value) {
186
+ if (typeof this.component.value === 'object') {
187
+ const componentValue = this.component?.value[this.field[0]];
188
+ if (typeof componentValue === 'object') {
189
+ let lang = 'es';
190
+ if (this.field[1]) {
191
+ lang = this.field[1];
192
+ }
193
+ text = componentValue[lang];
194
+ }
195
+ }
196
+ else if (typeof this.component?.value === 'string') {
197
+ text = this.component.value;
198
+ }
199
+ }
200
+ return text;
201
+ }
202
+ writeValue(value) {
203
+ if (value) {
204
+ if (typeof value === 'number') {
205
+ this.value = value;
206
+ }
207
+ else if (typeof value === 'object') {
208
+ this.component.setValue(value);
209
+ this.value = value.id;
210
+ }
211
+ else {
212
+ this.value = value;
213
+ }
214
+ }
215
+ else {
216
+ this.value = null;
217
+ }
218
+ this._cdRef.detectChanges();
219
+ }
220
+ registerOnChange(fn) {
221
+ this.onChanged = fn;
222
+ this._cdRef.detectChanges();
223
+ }
224
+ registerOnTouched(fn) {
225
+ this.onTouched = fn;
226
+ this._cdRef.detectChanges();
227
+ }
228
+ clear(trigger) {
229
+ this.component.setValue(null);
230
+ this.selectedElement = null;
231
+ this.SelectElement.emit(null);
232
+ this._cdRef.detectChanges();
233
+ this.onChanged(null);
234
+ this._zone.run(() => {
235
+ setTimeout(() => {
236
+ trigger.openPanel();
237
+ this._cdRef.detectChanges();
238
+ }, 200);
239
+ });
240
+ }
241
+ onFocus() {
242
+ this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());
243
+ }
244
+ onSelectElement(item) {
245
+ this.selectedElement = item;
246
+ this.SelectElement.emit(item);
247
+ this.value = item;
248
+ if (this.valueId) {
249
+ this.onChanged(item?.id);
250
+ }
251
+ else {
252
+ this.onChanged(item);
253
+ }
254
+ this._cdRef.detectChanges();
255
+ }
256
+ ngOnInit() {
257
+ this.component.markAllAsTouched();
258
+ }
259
+ ngOnDestroy() {
260
+ this.unsubscribeAll$.next();
261
+ this.unsubscribeAll$.complete();
262
+ }
263
+ }
264
+ GuajiritosGeneralAutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.5", ngImport: i0, type: GuajiritosGeneralAutocompleteComponent, deps: [{ token: i1.AutocompleteService }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
265
+ GuajiritosGeneralAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.5", type: GuajiritosGeneralAutocompleteComponent, selector: "guajiritos-general-autocomplete", inputs: { floatLabel: "floatLabel", bodyRequest: "bodyRequest", debounceTimeValue: "debounceTimeValue", detailsTemplate: "detailsTemplate", label: "label", placeholder: "placeholder", field: "field", filterString: "filterString", displayOptions: "displayOptions", withoutPaddingBottom: "withoutPaddingBottom", valueId: "valueId", order: "order", removeProperties: "removeProperties", disable: "disable", url: "url", clearData: "clearData", initialValue: "initialValue", restrictions: "restrictions", isRequired: "isRequired", doFocus: "doFocus" }, outputs: { SelectElement: "SelectElement" }, providers: [
266
+ {
267
+ provide: NG_VALUE_ACCESSOR,
268
+ useExisting: forwardRef(() => GuajiritosGeneralAutocompleteComponent),
269
+ multi: true
270
+ }
271
+ ], viewQueries: [{ propertyName: "inputText", first: true, predicate: ["inputText"], descendants: true, static: true }], ngImport: i0, template: "<mat-form-field [floatLabel]=\"floatLabel\" [ngClass]=\"{'without-padding-bottom': withoutPaddingBottom}\"\r\n appearance=\"outline\" class=\"w-100\" color=\"accent\">\r\n\r\n <mat-label>{{label | translate}}</mat-label>\r\n <input #inputText #trigger=\"matAutocompleteTrigger\" (blur)=\"onTouched()\" (focus)=\"onFocus()\"\r\n [formControl]=\"component\" [matAutocomplete]=\"autocomplete\" [placeholder]=\"placeholder | translate\"\r\n aria-label=\"Number\" autocomplete=\"off\" matInput type=\"text\">\r\n <button (click)=\"clear(trigger)\" *ngIf=\"!loading && component?.value\" [disabled]=\"disabledButton\" aria-label=\"Clear\"\r\n mat-icon-button matSuffix>\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n <button *ngIf=\"loading\" aria-label=\"Clear\" mat-icon-button matSuffix>\r\n <mat-spinner [value]=\"90\" color=\"accent\" diameter=\"25\"></mat-spinner>\r\n </button>\r\n <mat-autocomplete #autocomplete=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\"\r\n (onSelectionChange)=\"onSelectElement(option)\">\r\n\r\n <ng-container *ngIf=\"!displayOptions && !detailsTemplate\">\r\n {{ option?.name | i18nField: translateService.currentLang }}\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!detailsTemplate\">\r\n <div class=\"display-options\">\r\n <span [ngStyle]=\"{'line-height': displayOptions?.secondLabel ? '16px' : ''}\">\r\n {{option | resolvePropertyPath:displayOptions?.firthLabel | i18nField: translateService.currentLang}}\r\n </span>\r\n <span *ngIf=\"displayOptions?.secondLabel\" class=\"mat-caption\">\r\n {{option | resolvePropertyPath: displayOptions?.secondLabel | i18nField: translateService.currentLang}}\r\n </span>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"detailsTemplate\">\r\n <ng-container *ngTemplateOutlet=\"detailsTemplate;context:{$implicit: option }\"></ng-container>\r\n </ng-container>\r\n\r\n </mat-option>\r\n </mat-autocomplete>\r\n</mat-form-field>\r\n", styles: ["::ng-deep .without-padding-bottom .mat-form-field-wrapper{padding-bottom:0!important}.w-100{width:100%}.display-options{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i11.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i10.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i12.I18nFieldPipe, name: "i18nField" }, { kind: "pipe", type: i13.ResolvePropertyPath, name: "resolvePropertyPath" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
272
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.5", ngImport: i0, type: GuajiritosGeneralAutocompleteComponent, decorators: [{
273
+ type: Component,
274
+ args: [{ selector: 'guajiritos-general-autocomplete', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
275
+ {
276
+ provide: NG_VALUE_ACCESSOR,
277
+ useExisting: forwardRef(() => GuajiritosGeneralAutocompleteComponent),
278
+ multi: true
279
+ }
280
+ ], template: "<mat-form-field [floatLabel]=\"floatLabel\" [ngClass]=\"{'without-padding-bottom': withoutPaddingBottom}\"\r\n appearance=\"outline\" class=\"w-100\" color=\"accent\">\r\n\r\n <mat-label>{{label | translate}}</mat-label>\r\n <input #inputText #trigger=\"matAutocompleteTrigger\" (blur)=\"onTouched()\" (focus)=\"onFocus()\"\r\n [formControl]=\"component\" [matAutocomplete]=\"autocomplete\" [placeholder]=\"placeholder | translate\"\r\n aria-label=\"Number\" autocomplete=\"off\" matInput type=\"text\">\r\n <button (click)=\"clear(trigger)\" *ngIf=\"!loading && component?.value\" [disabled]=\"disabledButton\" aria-label=\"Clear\"\r\n mat-icon-button matSuffix>\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n <button *ngIf=\"loading\" aria-label=\"Clear\" mat-icon-button matSuffix>\r\n <mat-spinner [value]=\"90\" color=\"accent\" diameter=\"25\"></mat-spinner>\r\n </button>\r\n <mat-autocomplete #autocomplete=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\"\r\n (onSelectionChange)=\"onSelectElement(option)\">\r\n\r\n <ng-container *ngIf=\"!displayOptions && !detailsTemplate\">\r\n {{ option?.name | i18nField: translateService.currentLang }}\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!detailsTemplate\">\r\n <div class=\"display-options\">\r\n <span [ngStyle]=\"{'line-height': displayOptions?.secondLabel ? '16px' : ''}\">\r\n {{option | resolvePropertyPath:displayOptions?.firthLabel | i18nField: translateService.currentLang}}\r\n </span>\r\n <span *ngIf=\"displayOptions?.secondLabel\" class=\"mat-caption\">\r\n {{option | resolvePropertyPath: displayOptions?.secondLabel | i18nField: translateService.currentLang}}\r\n </span>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"detailsTemplate\">\r\n <ng-container *ngTemplateOutlet=\"detailsTemplate;context:{$implicit: option }\"></ng-container>\r\n </ng-container>\r\n\r\n </mat-option>\r\n </mat-autocomplete>\r\n</mat-form-field>\r\n", styles: ["::ng-deep .without-padding-bottom .mat-form-field-wrapper{padding-bottom:0!important}.w-100{width:100%}.display-options{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}\n"] }]
281
+ }], ctorParameters: function () { return [{ type: i1.AutocompleteService }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i2.TranslateService }]; }, propDecorators: { inputText: [{
282
+ type: ViewChild,
283
+ args: ['inputText', { static: true }]
284
+ }], floatLabel: [{
285
+ type: Input
286
+ }], bodyRequest: [{
287
+ type: Input
288
+ }], debounceTimeValue: [{
289
+ type: Input
290
+ }], detailsTemplate: [{
291
+ type: Input
292
+ }], label: [{
293
+ type: Input
294
+ }], placeholder: [{
295
+ type: Input
296
+ }], field: [{
297
+ type: Input
298
+ }], filterString: [{
299
+ type: Input
300
+ }], displayOptions: [{
301
+ type: Input
302
+ }], withoutPaddingBottom: [{
303
+ type: Input
304
+ }], valueId: [{
305
+ type: Input
306
+ }], order: [{
307
+ type: Input
308
+ }], removeProperties: [{
309
+ type: Input
310
+ }], SelectElement: [{
311
+ type: Output
312
+ }], disable: [{
313
+ type: Input
314
+ }], url: [{
315
+ type: Input
316
+ }], clearData: [{
317
+ type: Input
318
+ }], initialValue: [{
319
+ type: Input
320
+ }], restrictions: [{
321
+ type: Input
322
+ }], isRequired: [{
323
+ type: Input
324
+ }], doFocus: [{
325
+ type: Input
326
+ }] } });
327
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guachos-general-autocomplete.component.js","sourceRoot":"","sources":["../../../../projects/guachos-general-autocomplete/src/lib/guachos-general-autocomplete.component.ts","../../../../projects/guachos-general-autocomplete/src/lib/guachos-general-autocomplete.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,KAAK,EACL,MAAM,EAGN,MAAM,EACN,WAAW,EACX,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAuB,iBAAiB,EAAE,kBAAkB,EAAE,UAAU,EAAC,MAAM,gBAAgB,CAAC;AAGvG,OAAO,EAAC,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAC,YAAY,EAAc,OAAO,EAAE,SAAS,EAAC,MAAM,MAAM,CAAC;AAElE,OAAO,EAAC,uBAAuB,EAAC,MAAM,6BAA6B,CAAC;AACpE,OAAO,EAAC,mBAAmB,EAAC,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAC,YAAY,EAAC,MAAM,iCAAiC,CAAC;;;;;;;;;;;;;;;AAgB7D,MAAM,OAAO,sCAAsC;IAEjD,YACU,oBAAyC,EACzC,MAAyB,EACzB,KAAa,EACd,gBAAkC;QAHjC,yBAAoB,GAApB,oBAAoB,CAAqB;QACzC,WAAM,GAAN,MAAM,CAAmB;QACzB,UAAK,GAAL,KAAK,CAAQ;QACd,qBAAgB,GAAhB,gBAAgB,CAAkB;QAInC,oBAAe,GAAkB,IAAI,OAAO,EAAQ,CAAC;QACrD,cAAS,GAAY,IAAI,CAAC;QAC1B,wBAAmB,GAAwB,EAAE,CAAC;QAM/C,aAAQ,GAAY,IAAI,CAAC;QACzB,cAAS,GAAuB,IAAI,kBAAkB,CAAC;YAC5D,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK;SAC7B,CAAC,CAAC;QAEI,mBAAc,GAAY,KAAK,CAAC;QAEhC,YAAO,GAAY,KAAK,CAAC;QAGhC;;WAEG;QACM,eAAU,GAAmB,MAAM,CAAC;QAEpC,sBAAiB,GAAW,GAAG,CAAC;QAEhC,UAAK,GAAW,YAAY,CAAC;QAC7B,gBAAW,GAAW,wBAAwB,CAAC;QAC/C,UAAK,GAAa,CAAC,MAAM,CAAC,CAAC;QAC3B,iBAAY,GAAW,2BAA2B,CAAC;QACnD,mBAAc,GAAkB,uBAAuB,CAAC;QACxD,yBAAoB,GAAY,IAAI,CAAC;QACrC,YAAO,GAAY,KAAK,CAAC;QACzB,UAAK,GAAW,IAAI,CAAC;QACrB,qBAAgB,GAAa,EAAE,CAAC;QAC/B,kBAAa,GAAsB,IAAI,YAAY,EAAO,CAAC;QA+IrE,cAAS,GAAQ,GAAG,EAAE;QACtB,CAAC,CAAC;QAEF,cAAS,GAAQ,GAAG,EAAE;QACtB,CAAC,CAAC;QAEF,cAAS,GAAG,CAAC,KAAU,EAAE,EAAE;YACzB,IAAI,KAAK,EAAE;gBACT,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;oBAC7B,OAAO,KAAK,CAAC;iBACd;gBAED,IAAI,WAAW,GAAG,EAAE,CAAC;gBACrB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;oBACxB,IAAI,CAAC,cAAc,GAAG,uBAAuB,CAAC;iBAC/C;gBACD,IAAI,CAAC,cAAc,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;oBACtD,IAAI,KAAK,EAAE,IAAI,KAAK,MAAM,EAAE;wBAC1B,WAAW,IAAI,YAAY,CAAC,qBAAqB,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;qBACvE;yBAAM;wBACL,WAAW,IAAI,KAAK,EAAE,OAAO,CAAC;qBAC/B;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,WAAW,CAAC;aACpB;QACH,CAAC,CAAC;IA5MF,CAAC;IAsCD,IAAa,OAAO,CAAC,IAAa;QAChC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;SAC1B;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;SACzB;QACD,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED,IAAa,GAAG,CAAC,IAAY;QAC3B,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YAEjB,IAAI,CAAC,yBAAyB,EAAE,CAAC;SAClC;IACH,CAAC;IAED,IAAa,SAAS,CAAC,KAAoB;QACzC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,UAAU;iBACZ,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;iBACrC,SAAS,CAAC;gBACT,IAAI,EAAE,GAAG,EAAE;oBACT,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;oBAC9B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;oBAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC9B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;oBAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;gBACvB,CAAC;aACF,CAAC,CAAC;SACN;IACH,CAAC;IAED,IAAa,YAAY,CAAC,KAAU;QAClC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,IAAa,YAAY,CAAC,KAAU;QAClC,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;SAClC;aAAM;YACL,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;SAC/B;IACH,CAAC;IAED,IAAa,UAAU,CAAC,KAAc;QACpC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QAEtB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC,QAAQ,EAAE,sCAAsC,CAAC,oBAAoB,CAAC,CAAC,CAAC;SAClH;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,eAAe,EAAE,CAAC;SAClC;QAED,IAAI,CAAC,SAAS,CAAC,sBAAsB,EAAE,CAAC;IAC1C,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED,IAAa,OAAO,CAAC,KAAoB;QACvC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAE7B,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,eAAe;iBACjB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;iBACrC,SAAS,CAAC;gBACT,IAAI,EAAE,GAAG,EAAE;oBACT,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;wBAClB,UAAU,CAAC,GAAG,EAAE;4BACd,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;wBACvC,CAAC,EAAE,GAAG,CAAC,CAAC;oBACV,CAAC,CAAC,CAAC;gBACL,CAAC;aACF,CAAC,CAAC;SACN;IACH,CAAC;IAEO,MAAM,CAAC,oBAAoB,CAAC,OAA2B;QAC7D,IAAI,OAAO,EAAE,KAAK,EAAE,WAAW,KAAK,MAAM,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE;YACjE,OAAO,EAAC,gBAAgB,EAAE,IAAI,EAAC,CAAC;SACjC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,yBAAyB;QAC/B,IAAI,CAAC,SAAS,EAAE,YAAY;YAC1B,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC7E,EAAE,SAAS,CAAC;YACV,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;oBACnB,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,yBAAyB,EAAE,CAAC,CAAC;iBACrE;qBAAM;oBACL,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;iBACxB;YACH,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAEO,4BAA4B,CAAC,IAAa;QAChD,IAAI,CAAC,oBAAoB;aACtB,qBAAqB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,mBAAmB,EACjF,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC;aACrD,IAAI,CAAC,CAAC,IAAqB,EAAE,EAAE;YAC9B,IAAI,EAAE,SAAS,CAAC;gBACd,IAAI,EAAE,CAAC,MAAW,EAAE,EAAE;oBACpB,IAAI,CAAC,eAAe,GAAG,MAAM,EAAE,OAAO,EAAE,IAAI,IAAI,MAAM,EAAE,IAAI,CAAC;oBAC7D,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;gBAC9B,CAAC;aACF,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,yBAAyB;QAC/B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QAEpB,IAAI,IAAI,GAAW,IAAI,CAAC;QACxB,IAAI,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE;YACzB,IAAI,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,QAAQ,EAAE;gBAC5C,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAA;gBAC3D,IAAI,OAAO,cAAc,KAAK,QAAQ,EAAE;oBACtC,IAAI,IAAI,GAAW,IAAI,CAAC;oBACxB,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;wBACjB,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;qBACtB;oBAED,IAAI,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;iBAC7B;aACF;iBAAM,IAAI,OAAO,IAAI,CAAC,SAAS,EAAE,KAAK,KAAK,QAAQ,EAAE;gBACpD,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;aAC7B;SACF;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IA6BD,UAAU,CAAC,KAAU;QACnB,IAAI,KAAK,EAAE;YACT,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;aACpB;iBAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBACpC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBAC/B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,EAAE,CAAC;aACvB;iBAAM;gBACL,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;aACpB;SACF;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACnB;QAED,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAEM,KAAK,CAAC,OAA+B;QAC1C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;QAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAErB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,UAAU,CAAC,GAAG,EAAE;gBACd,OAAO,CAAC,SAAS,EAAE,CAAC;gBACpB,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;YAC9B,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,yBAAyB,EAAE,CAAC,CAAC;IACtE,CAAC;IAEM,eAAe,CAAC,IAAS;QAC9B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAElB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;SAC1B;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;SACtB;QAED,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE,CAAC;IACpC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;;mIAzRU,sCAAsC;uHAAtC,sCAAsC,2oBARtC;QACT;YACE,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sCAAsC,CAAC;YACrE,KAAK,EAAE,IAAI;SACZ;KACF,gJCrCH,gzEAwCA;2FDDa,sCAAsC;kBAblD,SAAS;+BACE,iCAAiC,mBAG1B,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uCAAuC,CAAC;4BACrE,KAAK,EAAE,IAAI;yBACZ;qBACF;8LA6BuC,SAAS;sBAAhD,SAAS;uBAAC,WAAW,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAI7B,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACI,aAAa;sBAAtB,MAAM;gBAEM,OAAO;sBAAnB,KAAK;gBAUO,GAAG;sBAAf,KAAK;gBAQO,SAAS;sBAArB,KAAK;gBAiBO,YAAY;sBAAxB,KAAK;gBAIO,YAAY;sBAAxB,KAAK;gBAQO,UAAU;sBAAtB,KAAK;gBAgBO,OAAO;sBAAnB,KAAK","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR, UntypedFormControl, Validators} from '@angular/forms';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {FloatLabelType} from '@angular/material/form-field';\nimport {TranslateService} from '@ngx-translate/core';\nimport {debounceTime, Observable, Subject, takeUntil} from 'rxjs';\n\nimport {GENERAL_DISPLAY_OPTIONS} from '../utils/constants/contacts';\nimport {AutocompleteService} from '../utils/services/autocomplete.service';\nimport {UtilsService} from '../utils/services/utils.service';\nimport {ApiFormData, DisplayOption, RestrictionFilter} from \"../utils/interfaces/interfaces\";\n\n@Component({\n  selector: 'guajiritos-general-autocomplete',\n  templateUrl: './guachos-general-autocomplete.component.html',\n  styleUrls: ['./guachos-general-autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => GuajiritosGeneralAutocompleteComponent),\n      multi: true\n    }\n  ]\n})\nexport class GuajiritosGeneralAutocompleteComponent implements OnInit, OnDestroy, ControlValueAccessor {\n\n  constructor(\n    private _autocompleteService: AutocompleteService,\n    private _cdRef: ChangeDetectorRef,\n    private _zone: NgZone,\n    public translateService: TranslateService,\n  ) {\n  }\n\n  private unsubscribeAll$: Subject<void> = new Subject<void>();\n  private firstCall: boolean = true;\n  private restrictionsFilters: RestrictionFilter[] = [];\n  private selectedElement: any;\n  private doFocusSubject$: Subject<void>;\n  private clearData$: Subject<void>;\n  private _url: string;\n\n  public required: boolean = true;\n  public component: UntypedFormControl = new UntypedFormControl({\n    value: null, disabled: false\n  });\n  public value: any;\n  public disabledButton: boolean = false;\n  public filteredOptions: any[];\n  public loading: boolean = false;\n\n  @ViewChild('inputText', {static: true}) inputText: ElementRef;\n  /**\n   * Possible values 'never', 'auto' or 'always'\n   */\n  @Input() floatLabel: FloatLabelType = 'auto';\n  @Input() bodyRequest: ApiFormData;\n  @Input() debounceTimeValue: number = 250;\n  @Input() detailsTemplate: TemplateRef<any>;\n  @Input() label: string = 'Seleccione';\n  @Input() placeholder: string = 'Seleccione un elemento';\n  @Input() field: string[] = ['name'];\n  @Input() filterString: string = 'filter[$and][name][$like]';\n  @Input() displayOptions: DisplayOption = GENERAL_DISPLAY_OPTIONS;\n  @Input() withoutPaddingBottom: boolean = true;\n  @Input() valueId: boolean = false;\n  @Input() order: string = null;\n  @Input() removeProperties: string[] = [];\n  @Output() SelectElement: EventEmitter<any> = new EventEmitter<any>();\n\n  @Input() set disable(flag: boolean) {\n    this.disabledButton = flag;\n    if (flag) {\n      this.component.disable();\n    } else {\n      this.component.enable();\n    }\n    this._cdRef.detectChanges();\n  }\n\n  @Input() set url(data: string) {\n    if (data) {\n      this._url = data;\n\n      this.subscribeComponentChanges();\n    }\n  }\n\n  @Input() set clearData(value: Subject<void>) {\n    this.clearData$ = value;\n    if (this.clearData$) {\n      this.clearData$\n        .pipe(takeUntil(this.unsubscribeAll$))\n        .subscribe({\n          next: () => {\n            this.component.setValue(null);\n            this.selectedElement = null;\n            this.SelectElement.emit(null);\n            this.filteredOptions = [];\n            this.onChanged(null);\n          }\n        });\n    }\n  }\n\n  @Input() set initialValue(value: any) {\n    this.component.setValue(value);\n  }\n\n  @Input() set restrictions(value: any) {\n    if (value) {\n      this.restrictionsFilters = value;\n    } else {\n      this.restrictionsFilters = [];\n    }\n  }\n\n  @Input() set isRequired(value: boolean) {\n    this.required = value;\n\n    if (this.required) {\n      this.component.setValidators([Validators.required, GuajiritosGeneralAutocompleteComponent.ValidateAutocomplete]);\n    } else {\n      this.component.clearValidators();\n    }\n\n    this.component.updateValueAndValidity();\n  }\n\n  get doFocus(): Subject<any> {\n    return this.doFocusSubject$;\n  }\n\n  @Input() set doFocus(value: Subject<void>) {\n    this.doFocusSubject$ = value;\n\n    if (value) {\n      this.doFocusSubject$\n        .pipe(takeUntil(this.unsubscribeAll$))\n        .subscribe({\n          next: () => {\n            this._zone.run(() => {\n              setTimeout(() => {\n                this.inputText.nativeElement.focus();\n              }, 500);\n            });\n          }\n        });\n    }\n  }\n\n  private static ValidateAutocomplete(control: UntypedFormControl) {\n    if (control?.value?.constructor !== Object || !control?.value?.id) {\n      return {invalidSelection: true};\n    }\n\n    return null;\n  }\n\n  private subscribeComponentChanges(): void {\n    this.component?.valueChanges\n      ?.pipe(debounceTime(this.debounceTimeValue), takeUntil(this.unsubscribeAll$))\n      ?.subscribe({\n        next: () => {\n          if (!this.firstCall) {\n            this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());\n          } else {\n            this.firstCall = false;\n          }\n        }\n      });\n  }\n\n  private getAutocompleteByTextHandler(text?: string): void {\n    this._autocompleteService\n      .getAutocompleteByText(this._url, text, this.filterString, this.restrictionsFilters,\n        this.removeProperties, this.order, this.bodyRequest)\n      .then((resp: Observable<any>) => {\n        resp?.subscribe({\n          next: (result: any) => {\n            this.filteredOptions = result?.payload?.data || result?.data;\n            this.loading = false;\n            this._cdRef.detectChanges();\n          }\n        });\n      });\n  }\n\n  private getAutocompleteSearchText(): string {\n    this.loading = true;\n\n    let text: string = null;\n    if (this.component?.value) {\n      if (typeof this.component.value === 'object') {\n        const componentValue = this.component?.value[this.field[0]]\n        if (typeof componentValue === 'object') {\n          let lang: string = 'es';\n          if (this.field[1]) {\n            lang = this.field[1];\n          }\n\n          text = componentValue[lang];\n        }\n      } else if (typeof this.component?.value === 'string') {\n        text = this.component.value;\n      }\n    }\n\n    return text;\n  }\n\n  onChanged: any = () => {\n  };\n\n  onTouched: any = () => {\n  };\n\n  displayFn = (value: any) => {\n    if (value) {\n      if (typeof value === 'string') {\n        return value;\n      }\n\n      let displayText = '';\n      if (!this.displayOptions) {\n        this.displayOptions = GENERAL_DISPLAY_OPTIONS;\n      }\n      this.displayOptions?.firthLabel?.forEach((field: any) => {\n        if (field?.type === 'path') {\n          displayText += UtilsService.resolvePropertyByPath(value, field?.path);\n        } else {\n          displayText += field?.divider;\n        }\n      });\n      return displayText;\n    }\n  };\n\n  writeValue(value: any): void {\n    if (value) {\n      if (typeof value === 'number') {\n        this.value = value;\n      } else if (typeof value === 'object') {\n        this.component.setValue(value);\n        this.value = value.id;\n      } else {\n        this.value = value;\n      }\n    } else {\n      this.value = null;\n    }\n\n    this._cdRef.detectChanges();\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChanged = fn;\n    this._cdRef.detectChanges();\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n    this._cdRef.detectChanges();\n  }\n\n  public clear(trigger: MatAutocompleteTrigger): void {\n    this.component.setValue(null);\n    this.selectedElement = null;\n    this.SelectElement.emit(null);\n    this._cdRef.detectChanges();\n    this.onChanged(null);\n\n    this._zone.run(() => {\n      setTimeout(() => {\n        trigger.openPanel();\n        this._cdRef.detectChanges();\n      }, 200);\n    });\n  }\n\n  public onFocus(): void {\n    this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());\n  }\n\n  public onSelectElement(item: any): void {\n    this.selectedElement = item;\n    this.SelectElement.emit(item);\n    this.value = item;\n\n    if (this.valueId) {\n      this.onChanged(item?.id);\n    } else {\n      this.onChanged(item);\n    }\n\n    this._cdRef.detectChanges();\n  }\n\n  ngOnInit(): void {\n    this.component.markAllAsTouched();\n  }\n\n  ngOnDestroy(): void {\n    this.unsubscribeAll$.next();\n    this.unsubscribeAll$.complete();\n  }\n}\n","<mat-form-field [floatLabel]=\"floatLabel\" [ngClass]=\"{'without-padding-bottom': withoutPaddingBottom}\"\r\n                appearance=\"outline\" class=\"w-100\" color=\"accent\">\r\n\r\n    <mat-label>{{label | translate}}</mat-label>\r\n    <input #inputText #trigger=\"matAutocompleteTrigger\" (blur)=\"onTouched()\" (focus)=\"onFocus()\"\r\n           [formControl]=\"component\" [matAutocomplete]=\"autocomplete\" [placeholder]=\"placeholder | translate\"\r\n           aria-label=\"Number\" autocomplete=\"off\" matInput type=\"text\">\r\n    <button (click)=\"clear(trigger)\" *ngIf=\"!loading && component?.value\" [disabled]=\"disabledButton\" aria-label=\"Clear\"\r\n            mat-icon-button matSuffix>\r\n        <mat-icon>close</mat-icon>\r\n    </button>\r\n    <button *ngIf=\"loading\" aria-label=\"Clear\" mat-icon-button matSuffix>\r\n        <mat-spinner [value]=\"90\" color=\"accent\" diameter=\"25\"></mat-spinner>\r\n    </button>\r\n    <mat-autocomplete #autocomplete=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n        <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\"\r\n                    (onSelectionChange)=\"onSelectElement(option)\">\r\n\r\n            <ng-container *ngIf=\"!displayOptions && !detailsTemplate\">\r\n                {{ option?.name | i18nField: translateService.currentLang }}\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"!detailsTemplate\">\r\n                <div class=\"display-options\">\r\n                  <span [ngStyle]=\"{'line-height': displayOptions?.secondLabel ? '16px' : ''}\">\r\n                    {{option | resolvePropertyPath:displayOptions?.firthLabel | i18nField: translateService.currentLang}}\r\n                  </span>\r\n                    <span *ngIf=\"displayOptions?.secondLabel\" class=\"mat-caption\">\r\n                    {{option | resolvePropertyPath: displayOptions?.secondLabel | i18nField: translateService.currentLang}}\r\n                  </span>\r\n                </div>\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"detailsTemplate\">\r\n                <ng-container *ngTemplateOutlet=\"detailsTemplate;context:{$implicit: option }\"></ng-container>\r\n            </ng-container>\r\n\r\n        </mat-option>\r\n    </mat-autocomplete>\r\n</mat-form-field>\r\n"]}