@guajiritos/general-autocomplete 18.0.11 → 20.0.0

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.
@@ -1,456 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, EventEmitter, forwardRef, Input, NgZone, Output, signal, TemplateRef, ViewChild } from '@angular/core';
3
- import { NG_VALUE_ACCESSOR, ReactiveFormsModule, UntypedFormControl, Validators } from '@angular/forms';
4
- import { MatAutocompleteModule } from '@angular/material/autocomplete';
5
- import { MatButtonModule } from '@angular/material/button';
6
- import { MatFormFieldModule } from '@angular/material/form-field';
7
- import { MatIconModule } from '@angular/material/icon';
8
- import { MatInputModule } from '@angular/material/input';
9
- import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
10
- import { TranslateModule, TranslateService } from '@ngx-translate/core';
11
- import { debounceTime, finalize, Subject } from 'rxjs';
12
- import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
13
- import { AutocompleteService, DisplayOptionItemType, I18nPipe } from '@guajiritos/services';
14
- import { GENERAL_DISPLAY_OPTIONS } from '../utils/constants/constants';
15
- import { ResolvePropertyPath } from '../utils/pipes/resolve-property-path.pipe';
16
- import { UtilsService } from '../utils/services/utils.service';
17
- import * as i0 from "@angular/core";
18
- import * as i1 from "@guajiritos/services";
19
- import * as i2 from "@ngx-translate/core";
20
- import * as i3 from "@angular/common";
21
- import * as i4 from "@angular/material/form-field";
22
- import * as i5 from "@angular/material/icon";
23
- import * as i6 from "@angular/forms";
24
- import * as i7 from "@angular/material/input";
25
- import * as i8 from "@angular/material/button";
26
- import * as i9 from "@angular/material/progress-spinner";
27
- import * as i10 from "@angular/material/autocomplete";
28
- import * as i11 from "@angular/material/core";
29
- export class GuajiritosGeneralAutocomplete {
30
- constructor(_autocompleteService, _zone, _destroyRef, translateService) {
31
- this._autocompleteService = _autocompleteService;
32
- this._zone = _zone;
33
- this._destroyRef = _destroyRef;
34
- this.translateService = translateService;
35
- this.wasSelected = false;
36
- this.firstCall = true;
37
- this.selectedElement = null;
38
- this._url = null;
39
- this.restrictionsFilters = [];
40
- this.disabled = signal(false);
41
- this.loading = signal(false);
42
- this.required = signal(false);
43
- this.filteredOptions = signal([]);
44
- this.originalOptions = signal([]);
45
- this.notAllowedOption = signal(null);
46
- this.component = new UntypedFormControl({ value: null, disabled: false });
47
- /**
48
- * Possible values 'never', 'auto' or 'always'
49
- */
50
- this.floatLabel = 'auto';
51
- this.color = 'accent';
52
- this.appearance = 'outline';
53
- this.subscriptSizing = 'dynamic';
54
- this.debounceTimeValue = 300;
55
- this.label = 'Seleccione';
56
- this.showLabel = true;
57
- this.placeholder = 'Seleccione un elemento';
58
- this.field = ['name'];
59
- this.filterString = 'filter[$and][name][$like]';
60
- this.displayOptions = GENERAL_DISPLAY_OPTIONS;
61
- this.withoutPaddingBottom = true;
62
- this.valueId = false;
63
- this.showSuffix = false;
64
- this.requireSelection = false;
65
- this.suffixIcon = 'search';
66
- this.removeProperties = [];
67
- this.modifyResultFn = () => null;
68
- this.SelectElement = new EventEmitter();
69
- this.clearElement = new EventEmitter();
70
- this.propagateChange = (_) => {
71
- };
72
- /**
73
- * Función para mostrar los elementos a seleccionar
74
- *
75
- * @param value - Valor a mostrar
76
- */
77
- this.displayFn = (value) => {
78
- if (value) {
79
- if (typeof value === 'string') {
80
- return value;
81
- }
82
- let displayText = '';
83
- if (!this.displayOptions) {
84
- this.displayOptions = GENERAL_DISPLAY_OPTIONS;
85
- }
86
- this.displayOptions?.firthLabel?.forEach((field) => {
87
- if (field?.type === DisplayOptionItemType.PATH) {
88
- displayText += UtilsService.resolvePropertyByPath(value, field?.path);
89
- }
90
- else {
91
- displayText += field?.divider;
92
- }
93
- });
94
- return displayText;
95
- }
96
- };
97
- }
98
- set url(data) {
99
- if (data) {
100
- this._url = data;
101
- this.subscribeComponentChanges();
102
- }
103
- }
104
- set clearData(value) {
105
- this.clearData$ = value;
106
- if (this.clearData$) {
107
- this.clearData$
108
- .pipe(takeUntilDestroyed(this._destroyRef))
109
- .subscribe({
110
- next: () => {
111
- this.component.setValue(null, { emitEvent: false });
112
- this.selectedElement = null;
113
- this.SelectElement.emit(null);
114
- this.filteredOptions.set([]);
115
- this.propagateChange(null);
116
- }
117
- });
118
- }
119
- }
120
- set initialValue(value) {
121
- this.component.setValue(value);
122
- }
123
- /**
124
- * Añade o elimina restricciones para la búsqueda
125
- *
126
- * @param restrictions - Restricciones para la búsqueda
127
- */
128
- set restrictions(restrictions) {
129
- if (restrictions?.length) {
130
- this.restrictionsFilters = [...restrictions];
131
- }
132
- else {
133
- this.restrictionsFilters = [];
134
- }
135
- }
136
- /**
137
- * Añade o elimina la validación de que el campo sea requerido
138
- *
139
- * @param required - Define si es requerido o no
140
- */
141
- set isRequired(required) {
142
- this.required.set(required);
143
- if (required) {
144
- this.component.setValidators([Validators.required, autocompleteValidator]);
145
- }
146
- else {
147
- this.component.clearValidators();
148
- this.component.setValidators([autocompleteValidator]);
149
- }
150
- this.component.updateValueAndValidity();
151
- }
152
- /**
153
- * Define si vamos a realizar una búsqueda al elemento estar en el focus de la aplicación
154
- *
155
- * @param focusSubject - Observable para la subscripción al evento Focus
156
- */
157
- set doFocus(focusSubject) {
158
- this.doFocusSubject$ = focusSubject;
159
- if (this.doFocusSubject$) {
160
- this.doFocusSubject$
161
- .pipe(debounceTime(this.debounceTimeValue), takeUntilDestroyed(this._destroyRef))
162
- .subscribe({
163
- next: () => {
164
- this._zone.run(() => {
165
- setTimeout(() => {
166
- this.inputText?.nativeElement?.focus();
167
- }, 500);
168
- });
169
- }
170
- });
171
- }
172
- }
173
- set notAllowedElements(element) {
174
- if (element) {
175
- this.notAllowedOption.set(element);
176
- if (this.originalOptions()?.length) {
177
- this.filteredOptions.set(this.originalOptions()?.filter((option) => JSON.stringify(option) !== JSON.stringify(this.notAllowedOption())));
178
- }
179
- }
180
- }
181
- /**
182
- * Subscripción a los cambios del input de búsqueda
183
- */
184
- subscribeComponentChanges() {
185
- this.component.valueChanges
186
- .pipe(debounceTime(this.debounceTimeValue), takeUntilDestroyed(this._destroyRef))
187
- .subscribe({
188
- next: () => {
189
- console.log(this.component.value);
190
- if (!this.firstCall && !this.wasSelected) {
191
- this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());
192
- }
193
- this.firstCall = false;
194
- this.wasSelected = false;
195
- }
196
- });
197
- }
198
- /**
199
- * Búsqueda de los elementos a mostrar en el componente de auto-completamiento
200
- *
201
- * @param text - Texto a buscar
202
- */
203
- getAutocompleteByTextHandler(text) {
204
- this.loading.set(true);
205
- this.propagateChange(null);
206
- this.selectedElement = null;
207
- this.SelectElement.emit(null);
208
- if (!this.serviceConfig) {
209
- this._autocompleteService
210
- .getAutocompleteByText(this._url, text, this.filterString, this.restrictionsFilters, this.removeProperties, this.order, this.bodyRequest)
211
- .then((resp) => {
212
- resp?.pipe(finalize(() => this.loading.set(false))).subscribe({
213
- next: (result) => {
214
- this.originalOptions.set(result?.payload?.data ?? result?.data);
215
- // Modifica los options con una función que se le pase como parámetro
216
- const modifiedOptions = this.modifyResultFn(this.originalOptions());
217
- if (modifiedOptions)
218
- this.filteredOptions.set(modifiedOptions);
219
- if (this.notAllowedOption()) {
220
- this.filteredOptions.set(this.originalOptions()?.filter((option) => JSON.stringify(option) !== JSON.stringify(this.notAllowedOption())));
221
- }
222
- else {
223
- this.filteredOptions.set(this.originalOptions());
224
- }
225
- }
226
- });
227
- });
228
- }
229
- else {
230
- let body = this.serviceConfig;
231
- body[this.serviceConfig.searchProperty] = text;
232
- this.serviceConfig
233
- .service[this.serviceConfig.method](body)
234
- .pipe(takeUntilDestroyed(this._destroyRef), debounceTime(this.debounceTimeValue || 300), finalize(() => this.loading.set(false)))
235
- .subscribe({
236
- next: (result) => {
237
- this.originalOptions.set(result?.payload?.data ?? result?.data);
238
- // Modifica los options con una función que se le pase como parámetro
239
- const modifiedOptions = this.modifyResultFn(this.originalOptions());
240
- if (modifiedOptions)
241
- this.filteredOptions.set(modifiedOptions);
242
- if (this.notAllowedOption()) {
243
- this.filteredOptions.set(this.originalOptions()?.filter((option) => JSON.stringify(option) !== JSON.stringify(this.notAllowedOption())));
244
- }
245
- else {
246
- this.filteredOptions.set(this.originalOptions());
247
- }
248
- }
249
- });
250
- }
251
- }
252
- /**
253
- * Define el texto por el que se va a realizar la búsqueda
254
- *
255
- * @return {string} Texto de la búsqueda
256
- */
257
- getAutocompleteSearchText() {
258
- let text = '';
259
- if (this.component.value) {
260
- if (typeof this.component.value === 'object') {
261
- const componentValue = this.component.value?.[this.field?.[0]];
262
- if (typeof componentValue === 'object') {
263
- let lang = 'es';
264
- if (this.field?.[1]) {
265
- lang = this.field?.[1];
266
- }
267
- text = componentValue?.[lang];
268
- }
269
- }
270
- else if (typeof this.component.value === 'string') {
271
- text = this.component.value;
272
- }
273
- }
274
- return text;
275
- }
276
- registerOnChange(fn) {
277
- this.propagateChange = fn;
278
- }
279
- registerOnTouched() {
280
- }
281
- /**
282
- * Recibe el valor del FormControl
283
- *
284
- * @param value - Valor entrado por FormControl
285
- */
286
- writeValue(value) {
287
- if (value) {
288
- this.component.setValue(value, { emitEvent: false });
289
- if (typeof value === 'object' && this.valueId) {
290
- this.selectedElement = value?.id;
291
- }
292
- else {
293
- this.selectedElement = value;
294
- }
295
- }
296
- else {
297
- this.selectedElement = null;
298
- }
299
- }
300
- setDisabledState(isDisabled) {
301
- this.disabled.set(isDisabled);
302
- if (this.disabled()) {
303
- this.component.disable();
304
- }
305
- else {
306
- this.component.enable();
307
- }
308
- }
309
- /**
310
- * Acción al limpiar el valor del input
311
- *
312
- * @param trigger
313
- */
314
- clear(trigger) {
315
- this.clearElement.emit(this.component.value);
316
- this.component.setValue(null);
317
- this.selectedElement = null;
318
- this.SelectElement.emit(null);
319
- this.propagateChange(null);
320
- this._zone.run(() => {
321
- setTimeout(() => {
322
- trigger.openPanel();
323
- }, 100);
324
- });
325
- }
326
- /**
327
- * Acción en el Focus del elemento
328
- */
329
- onFocus() {
330
- if (!this.selectedElement) {
331
- this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());
332
- }
333
- }
334
- optionSelected($event) {
335
- if ($event?.option?.value) {
336
- this.wasSelected = true;
337
- this.selectedElement = $event.option.value;
338
- this.SelectElement.emit($event.option.value);
339
- if (this.valueId) {
340
- this.propagateChange(typeof $event.option.value === 'object' ? $event.option.value?.id : $event.option.value);
341
- }
342
- else {
343
- this.propagateChange($event.option.value);
344
- }
345
- }
346
- else {
347
- this.propagateChange($event.option.value);
348
- }
349
- }
350
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: GuajiritosGeneralAutocomplete, deps: [{ token: i1.AutocompleteService }, { token: i0.NgZone }, { token: i0.DestroyRef }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
351
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: GuajiritosGeneralAutocomplete, isStandalone: true, selector: "guajiritos-general-autocomplete", inputs: { floatLabel: "floatLabel", color: "color", appearance: "appearance", subscriptSizing: "subscriptSizing", bodyRequest: "bodyRequest", debounceTimeValue: "debounceTimeValue", detailsTemplate: "detailsTemplate", label: "label", showLabel: "showLabel", placeholder: "placeholder", field: "field", filterString: "filterString", displayOptions: "displayOptions", withoutPaddingBottom: "withoutPaddingBottom", valueId: "valueId", showSuffix: "showSuffix", requireSelection: "requireSelection", order: "order", serviceConfig: "serviceConfig", suffixIcon: "suffixIcon", removeProperties: "removeProperties", modifyResultFn: "modifyResultFn", url: "url", clearData: "clearData", initialValue: "initialValue", restrictions: "restrictions", isRequired: "isRequired", doFocus: "doFocus", notAllowedElements: "notAllowedElements" }, outputs: { SelectElement: "SelectElement", clearElement: "clearElement" }, providers: [
352
- {
353
- provide: NG_VALUE_ACCESSOR,
354
- useExisting: forwardRef(() => GuajiritosGeneralAutocomplete),
355
- multi: true
356
- }
357
- ], viewQueries: [{ propertyName: "inputText", first: true, predicate: ["inputText"], descendants: true, static: true }], ngImport: i0, template: "<mat-form-field [floatLabel]=\"floatLabel\" class=\"w-100\" [appearance]=\"appearance\" [color]=\"color\"\n [subscriptSizing]=\"subscriptSizing\">\n\n @if (showLabel) {\n <mat-label>{{ label | translate }}</mat-label>\n }\n @if (showSuffix) {\n <mat-icon matSuffix>{{ suffixIcon ?? \"search\" }}</mat-icon>\n }\n <input #inputText #trigger=\"matAutocompleteTrigger\" (focus)=\"onFocus()\" [formControl]=\"component\" type=\"text\"\n [matAutocomplete]=\"autocomplete\" [placeholder]=\"placeholder | translate\" aria-label=\"autocomplete\"\n autocomplete=\"off\" matInput [required]=\"required()\">\n @if (!loading() && component.value) {\n <button (click)=\"clear(trigger)\" [disabled]=\"disabled()\"\n aria-label=\"Clear\" mat-icon-button matSuffix>\n <mat-icon>close</mat-icon>\n </button>\n }\n @if (loading()) {\n <button aria-label=\"search\" mat-icon-button matSuffix>\n <mat-spinner [value]=\"90\" color=\"accent\" diameter=\"25\"></mat-spinner>\n </button>\n }\n <mat-autocomplete #autocomplete=\"matAutocomplete\" [displayWith]=\"displayFn\" [requireSelection]=\"requireSelection\"\n (optionSelected)=\"optionSelected($event)\">\n @for (option of filteredOptions(); track option) {\n <mat-option [value]=\"option\">\n @if (!displayOptions && !detailsTemplate) {\n {{ option?.name | i18n: translateService.currentLang }}\n }\n @if (!detailsTemplate) {\n <div class=\"display-options\">\n <span [ngStyle]=\"{'line-height': displayOptions?.secondLabel ? '16px' : ''}\">\n {{ option | resolvePropertyPath:displayOptions.firthLabel | i18n: translateService.currentLang }}\n </span>\n @if (displayOptions?.secondLabel) {\n <span class=\"mat-caption\">\n {{ option | resolvePropertyPath: displayOptions.secondLabel | i18n: translateService.currentLang }}\n </span>\n }\n </div>\n }\n @if (detailsTemplate) {\n <ng-container *ngTemplateOutlet=\"detailsTemplate;context:{$implicit: option }\"></ng-container>\n }\n </mat-option>\n }\n </mat-autocomplete>\n\n @if (component.invalid) {\n <mat-error>\n {{ 'Este campo es requerido.' | translate }}\n </mat-error>\n }\n</mat-form-field>\n", styles: [".w-100{width:100%}.display-options{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i7.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: "ngmodule", type: MatButtonModule }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i9.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i10.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i11.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i10.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "pipe", type: I18nPipe, name: "i18n" }, { kind: "pipe", type: ResolvePropertyPath, name: "resolvePropertyPath" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
358
- }
359
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: GuajiritosGeneralAutocomplete, decorators: [{
360
- type: Component,
361
- args: [{ selector: 'guajiritos-general-autocomplete', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
362
- CommonModule,
363
- MatFormFieldModule,
364
- TranslateModule,
365
- MatIconModule,
366
- ReactiveFormsModule,
367
- MatInputModule,
368
- MatButtonModule,
369
- MatProgressSpinnerModule,
370
- MatAutocompleteModule,
371
- I18nPipe,
372
- ResolvePropertyPath
373
- ], providers: [
374
- {
375
- provide: NG_VALUE_ACCESSOR,
376
- useExisting: forwardRef(() => GuajiritosGeneralAutocomplete),
377
- multi: true
378
- }
379
- ], template: "<mat-form-field [floatLabel]=\"floatLabel\" class=\"w-100\" [appearance]=\"appearance\" [color]=\"color\"\n [subscriptSizing]=\"subscriptSizing\">\n\n @if (showLabel) {\n <mat-label>{{ label | translate }}</mat-label>\n }\n @if (showSuffix) {\n <mat-icon matSuffix>{{ suffixIcon ?? \"search\" }}</mat-icon>\n }\n <input #inputText #trigger=\"matAutocompleteTrigger\" (focus)=\"onFocus()\" [formControl]=\"component\" type=\"text\"\n [matAutocomplete]=\"autocomplete\" [placeholder]=\"placeholder | translate\" aria-label=\"autocomplete\"\n autocomplete=\"off\" matInput [required]=\"required()\">\n @if (!loading() && component.value) {\n <button (click)=\"clear(trigger)\" [disabled]=\"disabled()\"\n aria-label=\"Clear\" mat-icon-button matSuffix>\n <mat-icon>close</mat-icon>\n </button>\n }\n @if (loading()) {\n <button aria-label=\"search\" mat-icon-button matSuffix>\n <mat-spinner [value]=\"90\" color=\"accent\" diameter=\"25\"></mat-spinner>\n </button>\n }\n <mat-autocomplete #autocomplete=\"matAutocomplete\" [displayWith]=\"displayFn\" [requireSelection]=\"requireSelection\"\n (optionSelected)=\"optionSelected($event)\">\n @for (option of filteredOptions(); track option) {\n <mat-option [value]=\"option\">\n @if (!displayOptions && !detailsTemplate) {\n {{ option?.name | i18n: translateService.currentLang }}\n }\n @if (!detailsTemplate) {\n <div class=\"display-options\">\n <span [ngStyle]=\"{'line-height': displayOptions?.secondLabel ? '16px' : ''}\">\n {{ option | resolvePropertyPath:displayOptions.firthLabel | i18n: translateService.currentLang }}\n </span>\n @if (displayOptions?.secondLabel) {\n <span class=\"mat-caption\">\n {{ option | resolvePropertyPath: displayOptions.secondLabel | i18n: translateService.currentLang }}\n </span>\n }\n </div>\n }\n @if (detailsTemplate) {\n <ng-container *ngTemplateOutlet=\"detailsTemplate;context:{$implicit: option }\"></ng-container>\n }\n </mat-option>\n }\n </mat-autocomplete>\n\n @if (component.invalid) {\n <mat-error>\n {{ 'Este campo es requerido.' | translate }}\n </mat-error>\n }\n</mat-form-field>\n", styles: [".w-100{width:100%}.display-options{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start}\n"] }]
380
- }], ctorParameters: () => [{ type: i1.AutocompleteService }, { type: i0.NgZone }, { type: i0.DestroyRef }, { type: i2.TranslateService }], propDecorators: { inputText: [{
381
- type: ViewChild,
382
- args: ['inputText', { static: true }]
383
- }], floatLabel: [{
384
- type: Input
385
- }], color: [{
386
- type: Input
387
- }], appearance: [{
388
- type: Input
389
- }], subscriptSizing: [{
390
- type: Input
391
- }], bodyRequest: [{
392
- type: Input
393
- }], debounceTimeValue: [{
394
- type: Input
395
- }], detailsTemplate: [{
396
- type: Input
397
- }], label: [{
398
- type: Input
399
- }], showLabel: [{
400
- type: Input
401
- }], placeholder: [{
402
- type: Input
403
- }], field: [{
404
- type: Input
405
- }], filterString: [{
406
- type: Input
407
- }], displayOptions: [{
408
- type: Input
409
- }], withoutPaddingBottom: [{
410
- type: Input
411
- }], valueId: [{
412
- type: Input
413
- }], showSuffix: [{
414
- type: Input
415
- }], requireSelection: [{
416
- type: Input
417
- }], order: [{
418
- type: Input
419
- }], serviceConfig: [{
420
- type: Input
421
- }], suffixIcon: [{
422
- type: Input
423
- }], removeProperties: [{
424
- type: Input
425
- }], modifyResultFn: [{
426
- type: Input
427
- }], SelectElement: [{
428
- type: Output
429
- }], clearElement: [{
430
- type: Output
431
- }], url: [{
432
- type: Input
433
- }], clearData: [{
434
- type: Input
435
- }], initialValue: [{
436
- type: Input
437
- }], restrictions: [{
438
- type: Input
439
- }], isRequired: [{
440
- type: Input
441
- }], doFocus: [{
442
- type: Input
443
- }], notAllowedElements: [{
444
- type: Input
445
- }] } });
446
- /**
447
- * Validación customizada para la selección de elementos
448
- */
449
- export function autocompleteValidator(control) {
450
- console.log(control?.value);
451
- if (control?.value?.constructor !== Object || !control?.value?.id) {
452
- return { invalidSelection: true };
453
- }
454
- return null;
455
- }
456
- //# 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 {CommonModule} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component, DestroyRef,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  NgZone,\n  Output,\n  signal,\n  TemplateRef,\n  ViewChild,\n  WritableSignal\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  UntypedFormControl, ValidationErrors,\n  ValidatorFn,\n  Validators\n} from '@angular/forms';\nimport {MatAutocompleteModule, MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {MatButtonModule} from '@angular/material/button';\nimport {ThemePalette} from '@angular/material/core';\nimport {\n  FloatLabelType,\n  MatFormFieldAppearance,\n  MatFormFieldModule,\n  SubscriptSizing\n} from '@angular/material/form-field';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatProgressSpinnerModule} from '@angular/material/progress-spinner';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {debounceTime, distinctUntilChanged, finalize, Observable, Subject} from 'rxjs';\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\n\nimport {\n  ApiFormData,\n  AutocompleteService,\n  DisplayOption,\n  DisplayOptionItemType,\n  I18nPipe,\n  RestrictionFilter\n} from '@guajiritos/services';\n\nimport {GENERAL_DISPLAY_OPTIONS, ServiceConfig} from '../utils/constants/constants';\nimport {ResolvePropertyPath} from '../utils/pipes/resolve-property-path.pipe';\nimport {UtilsService} from '../utils/services/utils.service';\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  standalone: true,\n  imports: [\n    CommonModule,\n    MatFormFieldModule,\n    TranslateModule,\n    MatIconModule,\n    ReactiveFormsModule,\n    MatInputModule,\n    MatButtonModule,\n    MatProgressSpinnerModule,\n    MatAutocompleteModule,\n    I18nPipe,\n    ResolvePropertyPath\n  ],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => GuajiritosGeneralAutocomplete),\n      multi: true\n    }\n  ]\n})\nexport class GuajiritosGeneralAutocomplete implements ControlValueAccessor {\n\n  constructor(\n    private _autocompleteService: AutocompleteService,\n    private _zone: NgZone,\n    private _destroyRef: DestroyRef,\n    public translateService: TranslateService\n  ) {\n  }\n\n  private wasSelected: boolean = false;\n  private firstCall: boolean = true;\n  private clearData$: Subject<void>;\n  private doFocusSubject$: Subject<void>;\n  private selectedElement: any = null;\n  private _url: string = null;\n  private restrictionsFilters: RestrictionFilter[] = [];\n\n  public disabled: WritableSignal<boolean> = signal(false);\n  public loading: WritableSignal<boolean> = signal(false);\n  public required: WritableSignal<boolean> = signal(false);\n  public filteredOptions: WritableSignal<any[]> = signal([]);\n  public originalOptions: WritableSignal<any[]> = signal([]);\n  public notAllowedOption: WritableSignal<any> = signal(null);\n  public component: UntypedFormControl = new UntypedFormControl({value: null, disabled: 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() color: ThemePalette = 'accent';\n  @Input() appearance: MatFormFieldAppearance = 'outline';\n  @Input() subscriptSizing: SubscriptSizing = 'dynamic';\n  @Input() bodyRequest: ApiFormData;\n  @Input() debounceTimeValue: number = 300;\n  @Input() detailsTemplate: TemplateRef<any>;\n  @Input() label: string = 'Seleccione';\n  @Input() showLabel: boolean = true;\n  @Input() placeholder: string = 'Seleccione un elemento';\n  @Input() field: string[] = ['name'];\n  @Input() filterString: string[] | string = 'filter[$and][name][$like]';\n  @Input() displayOptions: DisplayOption = GENERAL_DISPLAY_OPTIONS;\n  @Input() withoutPaddingBottom: boolean = true;\n  @Input() valueId: boolean = false;\n  @Input() showSuffix: boolean = false;\n  @Input() requireSelection: boolean = false;\n  @Input() order: string;\n  @Input() serviceConfig: ServiceConfig;\n  @Input() suffixIcon: string = 'search';\n  @Input() removeProperties: string[] = [];\n  @Input() modifyResultFn: (options: any) => any = () => null;\n\n  @Output() SelectElement: EventEmitter<any> = new EventEmitter<any>();\n  @Output() clearElement: EventEmitter<any> = new EventEmitter<any>();\n\n  @Input() set url(data: string) {\n    if (data) {\n      this._url = data;\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(takeUntilDestroyed(this._destroyRef))\n        .subscribe({\n          next: (): void => {\n            this.component.setValue(null, {emitEvent: false});\n            this.selectedElement = null;\n            this.SelectElement.emit(null);\n            this.filteredOptions.set([]);\n            this.propagateChange(null);\n          }\n        });\n    }\n  }\n\n  @Input() set initialValue(value: any) {\n    this.component.setValue(value);\n  }\n\n  /**\n   * Añade o elimina restricciones para la búsqueda\n   *\n   * @param restrictions - Restricciones para la búsqueda\n   */\n  @Input() set restrictions(restrictions: RestrictionFilter[]) {\n    if (restrictions?.length) {\n      this.restrictionsFilters = [...restrictions];\n    } else {\n      this.restrictionsFilters = [];\n    }\n  }\n\n  /**\n   * Añade o elimina la validación de que el campo sea requerido\n   *\n   * @param required - Define si es requerido o no\n   */\n  @Input() set isRequired(required: boolean) {\n    this.required.set(required);\n    if (required) {\n      this.component.setValidators([Validators.required, autocompleteValidator]);\n    } else {\n      this.component.clearValidators();\n      this.component.setValidators([autocompleteValidator]);\n    }\n\n    this.component.updateValueAndValidity();\n  }\n\n  /**\n   * Define si vamos a realizar una búsqueda al elemento estar en el focus de la aplicación\n   *\n   * @param focusSubject - Observable para la subscripción al evento Focus\n   */\n  @Input() set doFocus(focusSubject: Subject<void>) {\n    this.doFocusSubject$ = focusSubject;\n\n    if (this.doFocusSubject$) {\n      this.doFocusSubject$\n        .pipe(debounceTime(this.debounceTimeValue), takeUntilDestroyed(this._destroyRef))\n        .subscribe({\n          next: (): void => {\n            this._zone.run((): void => {\n              setTimeout((): void => {\n                this.inputText?.nativeElement?.focus();\n              }, 500);\n            });\n          }\n        });\n    }\n  }\n\n  @Input() set notAllowedElements(element: any) {\n    if (element) {\n      this.notAllowedOption.set(element);\n\n      if (this.originalOptions()?.length) {\n        this.filteredOptions.set(this.originalOptions()?.filter((option: any): any => JSON.stringify(option) !== JSON.stringify(this.notAllowedOption())));\n      }\n    }\n  }\n\n  /**\n   * Subscripción a los cambios del input de búsqueda\n   */\n  private subscribeComponentChanges(): void {\n    this.component.valueChanges\n      .pipe(debounceTime(this.debounceTimeValue), takeUntilDestroyed(this._destroyRef))\n      .subscribe({\n        next: (): void => {\n          console.log(this.component.value);\n          if (!this.firstCall && !this.wasSelected) {\n            this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());\n          }\n\n          this.firstCall = false;\n          this.wasSelected = false;\n        }\n      });\n  }\n\n  /**\n   * Búsqueda de los elementos a mostrar en el componente de auto-completamiento\n   *\n   * @param text - Texto a buscar\n   */\n  private getAutocompleteByTextHandler(text?: string): void {\n    this.loading.set(true);\n    this.propagateChange(null);\n    this.selectedElement = null;\n    this.SelectElement.emit(null);\n    if (!this.serviceConfig) {\n      this._autocompleteService\n        .getAutocompleteByText(this._url, text, this.filterString, this.restrictionsFilters, this.removeProperties, this.order, this.bodyRequest)\n        .then((resp: Observable<any>): void => {\n          resp?.pipe(finalize((): void => this.loading.set(false))).subscribe({\n            next: (result: any): void => {\n              this.originalOptions.set(result?.payload?.data ?? result?.data);\n\n              // Modifica los options con una función que se le pase como parámetro\n              const modifiedOptions = this.modifyResultFn(this.originalOptions());\n              if (modifiedOptions) this.filteredOptions.set(modifiedOptions);\n\n              if (this.notAllowedOption()) {\n                this.filteredOptions.set(this.originalOptions()?.filter((option: any): any => JSON.stringify(option) !== JSON.stringify(this.notAllowedOption())));\n              } else {\n                this.filteredOptions.set(this.originalOptions());\n              }\n            }\n          });\n        });\n    } else {\n      let body: any = this.serviceConfig;\n      body[this.serviceConfig.searchProperty] = text;\n      this.serviceConfig\n        .service[this.serviceConfig.method](body)\n        .pipe(takeUntilDestroyed(this._destroyRef), debounceTime(this.debounceTimeValue || 300), finalize((): void => this.loading.set(false)))\n        .subscribe({\n          next: (result: any): void => {\n            this.originalOptions.set(result?.payload?.data ?? result?.data);\n\n            // Modifica los options con una función que se le pase como parámetro\n            const modifiedOptions = this.modifyResultFn(this.originalOptions());\n            if (modifiedOptions) this.filteredOptions.set(modifiedOptions);\n\n            if (this.notAllowedOption()) {\n              this.filteredOptions.set(this.originalOptions()?.filter((option: any): any => JSON.stringify(option) !== JSON.stringify(this.notAllowedOption())));\n            } else {\n              this.filteredOptions.set(this.originalOptions());\n            }\n          }\n        });\n    }\n  }\n\n  /**\n   * Define el texto por el que se va a realizar la búsqueda\n   *\n   * @return {string} Texto de la búsqueda\n   */\n  private getAutocompleteSearchText(): string {\n    let text: string = '';\n\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  propagateChange = (_: any): void => {\n  };\n\n  registerOnChange(fn: (_: any) => void): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(): void {\n  }\n\n  /**\n   * Recibe el valor del FormControl\n   *\n   * @param value - Valor entrado por FormControl\n   */\n  writeValue(value: any): void {\n    if (value) {\n      this.component.setValue(value, {emitEvent: false});\n\n      if (typeof value === 'object' && this.valueId) {\n        this.selectedElement = value?.id;\n      } else {\n        this.selectedElement = value;\n      }\n    } else {\n      this.selectedElement = null;\n    }\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled.set(isDisabled);\n\n    if (this.disabled()) {\n      this.component.disable();\n    } else {\n      this.component.enable();\n    }\n  }\n\n  /**\n   * Función para mostrar los elementos a seleccionar\n   *\n   * @param value - Valor a mostrar\n   */\n  public displayFn = (value: any): string => {\n    if (value) {\n      if (typeof value === 'string') {\n        return value;\n      }\n\n      let displayText: string = '';\n      if (!this.displayOptions) {\n        this.displayOptions = GENERAL_DISPLAY_OPTIONS;\n      }\n\n      this.displayOptions?.firthLabel?.forEach((field: any): void => {\n        if (field?.type === DisplayOptionItemType.PATH) {\n          displayText += UtilsService.resolvePropertyByPath(value, field?.path);\n        } else {\n          displayText += field?.divider;\n        }\n      });\n\n      return displayText;\n    }\n  };\n\n  /**\n   * Acción al limpiar el valor del input\n   *\n   * @param trigger\n   */\n  public clear(trigger: MatAutocompleteTrigger): void {\n    this.clearElement.emit(this.component.value);\n    this.component.setValue(null);\n    this.selectedElement = null;\n    this.SelectElement.emit(null);\n    this.propagateChange(null);\n\n    this._zone.run((): void => {\n      setTimeout((): void => {\n        trigger.openPanel();\n      }, 100);\n    });\n  }\n\n  /**\n   * Acción en el Focus del elemento\n   */\n  public onFocus(): void {\n    if (!this.selectedElement) {\n      this.getAutocompleteByTextHandler(this.getAutocompleteSearchText());\n    }\n  }\n\n  public optionSelected($event: any): void {\n    if ($event?.option?.value) {\n      this.wasSelected = true;\n      this.selectedElement = $event.option.value;\n      this.SelectElement.emit($event.option.value);\n\n      if (this.valueId) {\n        this.propagateChange(typeof $event.option.value === 'object' ? $event.option.value?.id : $event.option.value);\n      } else {\n        this.propagateChange($event.option.value);\n      }\n    } else {\n      this.propagateChange($event.option.value);\n    }\n  }\n}\n\n/**\n * Validación customizada para la selección de elementos\n */\nexport function autocompleteValidator(control: AbstractControl): ValidationErrors | null {\n  console.log(control?.value);\n    if (control?.value?.constructor !== Object || !control?.value?.id) {\n      return {invalidSelection: true};\n    }\n    return null;\n}\n","<mat-form-field [floatLabel]=\"floatLabel\" class=\"w-100\" [appearance]=\"appearance\" [color]=\"color\"\n                [subscriptSizing]=\"subscriptSizing\">\n\n  @if (showLabel) {\n    <mat-label>{{ label | translate }}</mat-label>\n  }\n  @if (showSuffix) {\n    <mat-icon matSuffix>{{ suffixIcon ?? \"search\" }}</mat-icon>\n  }\n  <input #inputText #trigger=\"matAutocompleteTrigger\" (focus)=\"onFocus()\" [formControl]=\"component\" type=\"text\"\n         [matAutocomplete]=\"autocomplete\" [placeholder]=\"placeholder | translate\" aria-label=\"autocomplete\"\n         autocomplete=\"off\" matInput [required]=\"required()\">\n  @if (!loading() && component.value) {\n    <button (click)=\"clear(trigger)\" [disabled]=\"disabled()\"\n            aria-label=\"Clear\" mat-icon-button matSuffix>\n      <mat-icon>close</mat-icon>\n    </button>\n  }\n  @if (loading()) {\n    <button aria-label=\"search\" mat-icon-button matSuffix>\n      <mat-spinner [value]=\"90\" color=\"accent\" diameter=\"25\"></mat-spinner>\n    </button>\n  }\n  <mat-autocomplete #autocomplete=\"matAutocomplete\" [displayWith]=\"displayFn\" [requireSelection]=\"requireSelection\"\n                    (optionSelected)=\"optionSelected($event)\">\n    @for (option of filteredOptions(); track option) {\n      <mat-option [value]=\"option\">\n        @if (!displayOptions && !detailsTemplate) {\n          {{ option?.name | i18n: translateService.currentLang }}\n        }\n        @if (!detailsTemplate) {\n          <div class=\"display-options\">\n              <span [ngStyle]=\"{'line-height': displayOptions?.secondLabel ? '16px' : ''}\">\n                {{ option | resolvePropertyPath:displayOptions.firthLabel | i18n: translateService.currentLang }}\n              </span>\n            @if (displayOptions?.secondLabel) {\n              <span class=\"mat-caption\">\n                  {{ option | resolvePropertyPath: displayOptions.secondLabel | i18n: translateService.currentLang }}\n                </span>\n            }\n          </div>\n        }\n        @if (detailsTemplate) {\n          <ng-container *ngTemplateOutlet=\"detailsTemplate;context:{$implicit: option }\"></ng-container>\n        }\n      </mat-option>\n    }\n  </mat-autocomplete>\n\n  @if (component.invalid) {\n    <mat-error>\n      {{ 'Este campo es requerido.' | translate }}\n    </mat-error>\n  }\n</mat-form-field>\n"]}
@@ -1,6 +0,0 @@
1
- /*
2
- * Public API Surface of guachos-general-autocomplete
3
- */
4
- export * from './utils/constants/constants';
5
- export * from './lib/guachos-general-autocomplete.component';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2d1YWNob3MtZ2VuZXJhbC1hdXRvY29tcGxldGUvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsOENBQThDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGd1YWNob3MtZ2VuZXJhbC1hdXRvY29tcGxldGVcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL2NvbnN0YW50cy9jb25zdGFudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZ3VhY2hvcy1nZW5lcmFsLWF1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xuIl19
@@ -1,11 +0,0 @@
1
- import { DisplayOptionItemType } from '@guajiritos/services';
2
- export const GENERAL_DISPLAY_OPTIONS = {
3
- firthLabel: [
4
- {
5
- type: DisplayOptionItemType.PATH,
6
- path: ['name']
7
- }
8
- ],
9
- applyTranslate: true
10
- };
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZ3VhY2hvcy1nZW5lcmFsLWF1dG9jb21wbGV0ZS9zcmMvdXRpbHMvY29uc3RhbnRzL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlCLHFCQUFxQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFJNUUsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQWtCO0lBQ2xELFVBQVUsRUFBRTtRQUNSO1lBQ0ksSUFBSSxFQUFFLHFCQUFxQixDQUFDLElBQUk7WUFDaEMsSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDO1NBQ2pCO0tBQ0o7SUFDRCxjQUFjLEVBQUUsSUFBSTtDQUN2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlzcGxheU9wdGlvbiwgRGlzcGxheU9wdGlvbkl0ZW1UeXBlIH0gZnJvbSAnQGd1YWppcml0b3Mvc2VydmljZXMnO1xuaW1wb3J0IHtEaXNwbGF5T3B0aW9uSXRlbX0gZnJvbSBcIkBndWFqaXJpdG9zL3NlcnZpY2VzL2xpYi9pbnRlcmZhY2VzL2ludGVyZmFjZXNcIjtcblxuXG5leHBvcnQgY29uc3QgR0VORVJBTF9ESVNQTEFZX09QVElPTlM6IERpc3BsYXlPcHRpb24gPSB7XG4gICAgZmlydGhMYWJlbDogW1xuICAgICAgICB7XG4gICAgICAgICAgICB0eXBlOiBEaXNwbGF5T3B0aW9uSXRlbVR5cGUuUEFUSCxcbiAgICAgICAgICAgIHBhdGg6IFsnbmFtZSddXG4gICAgICAgIH1cbiAgICBdLFxuICAgIGFwcGx5VHJhbnNsYXRlOiB0cnVlXG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIFNlcnZpY2VDb25maWcge1xuICAgIHNlcnZpY2U6IGFueTtcbiAgICBtZXRob2Q6IHN0cmluZztcbiAgICBwb3N0Qm9keTogYW55O1xuICAgIHNlYXJjaFByb3BlcnR5OiBzdHJpbmc7XG59XG4iXX0=
@@ -1,37 +0,0 @@
1
- import { Pipe } from '@angular/core';
2
- import { DisplayOptionItemType } from '@guajiritos/services';
3
- import { UtilsService } from '../services/utils.service';
4
- import * as i0 from "@angular/core";
5
- export class ResolvePropertyPath {
6
- /**
7
- * Transforms the given object based on the provided path and returns the transformed string.
8
- *
9
- * @param {any} obj - The object to be transformed.
10
- * @param {DisplayOptionItem[]} path - The array of display option items used for transformation.
11
- * @return {string} The transformed string.
12
- */
13
- transform(obj, path) {
14
- let result = '';
15
- path?.forEach((item) => {
16
- if (item?.type === DisplayOptionItemType.DIVIDER) {
17
- result += item?.divider;
18
- }
19
- else {
20
- if (item?.path) {
21
- result += UtilsService.resolvePropertyByPath(obj, item.path);
22
- }
23
- }
24
- });
25
- return result;
26
- }
27
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ResolvePropertyPath, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
28
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.2", ngImport: i0, type: ResolvePropertyPath, isStandalone: true, name: "resolvePropertyPath" }); }
29
- }
30
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ResolvePropertyPath, decorators: [{
31
- type: Pipe,
32
- args: [{
33
- name: 'resolvePropertyPath',
34
- standalone: true
35
- }]
36
- }] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb2x2ZS1wcm9wZXJ0eS1wYXRoLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ndWFjaG9zLWdlbmVyYWwtYXV0b2NvbXBsZXRlL3NyYy91dGlscy9waXBlcy9yZXNvbHZlLXByb3BlcnR5LXBhdGgucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUVwRCxPQUFPLEVBQXFCLHFCQUFxQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFaEYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDJCQUEyQixDQUFDOztBQU16RCxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCOzs7Ozs7T0FNRztJQUNILFNBQVMsQ0FBQyxHQUFRLEVBQUUsSUFBeUI7UUFDM0MsSUFBSSxNQUFNLEdBQVcsRUFBRSxDQUFDO1FBRXhCLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQyxJQUF1QixFQUFRLEVBQUU7WUFDOUMsSUFBSSxJQUFJLEVBQUUsSUFBSSxLQUFLLHFCQUFxQixDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUNqRCxNQUFNLElBQUksSUFBSSxFQUFFLE9BQU8sQ0FBQztZQUMxQixDQUFDO2lCQUFNLENBQUM7Z0JBQ04sSUFBSSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUM7b0JBQ2YsTUFBTSxJQUFJLFlBQVksQ0FBQyxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUMvRCxDQUFDO1lBQ0gsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQzs4R0F0QlUsbUJBQW1COzRHQUFuQixtQkFBbUI7OzJGQUFuQixtQkFBbUI7a0JBSi9CLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLHFCQUFxQjtvQkFDM0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEaXNwbGF5T3B0aW9uSXRlbSwgRGlzcGxheU9wdGlvbkl0ZW1UeXBlIH0gZnJvbSAnQGd1YWppcml0b3Mvc2VydmljZXMnO1xuXG5pbXBvcnQgeyBVdGlsc1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy91dGlscy5zZXJ2aWNlJztcblxuQFBpcGUoe1xuICBuYW1lOiAncmVzb2x2ZVByb3BlcnR5UGF0aCcsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgUmVzb2x2ZVByb3BlcnR5UGF0aCBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICAvKipcbiAgICogVHJhbnNmb3JtcyB0aGUgZ2l2ZW4gb2JqZWN0IGJhc2VkIG9uIHRoZSBwcm92aWRlZCBwYXRoIGFuZCByZXR1cm5zIHRoZSB0cmFuc2Zvcm1lZCBzdHJpbmcuXG4gICAqXG4gICAqIEBwYXJhbSB7YW55fSBvYmogLSBUaGUgb2JqZWN0IHRvIGJlIHRyYW5zZm9ybWVkLlxuICAgKiBAcGFyYW0ge0Rpc3BsYXlPcHRpb25JdGVtW119IHBhdGggLSBUaGUgYXJyYXkgb2YgZGlzcGxheSBvcHRpb24gaXRlbXMgdXNlZCBmb3IgdHJhbnNmb3JtYXRpb24uXG4gICAqIEByZXR1cm4ge3N0cmluZ30gVGhlIHRyYW5zZm9ybWVkIHN0cmluZy5cbiAgICovXG4gIHRyYW5zZm9ybShvYmo6IGFueSwgcGF0aDogRGlzcGxheU9wdGlvbkl0ZW1bXSk6IHN0cmluZyB7XG4gICAgbGV0IHJlc3VsdDogc3RyaW5nID0gJyc7XG5cbiAgICBwYXRoPy5mb3JFYWNoKChpdGVtOiBEaXNwbGF5T3B0aW9uSXRlbSk6IHZvaWQgPT4ge1xuICAgICAgaWYgKGl0ZW0/LnR5cGUgPT09IERpc3BsYXlPcHRpb25JdGVtVHlwZS5ESVZJREVSKSB7XG4gICAgICAgIHJlc3VsdCArPSBpdGVtPy5kaXZpZGVyO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKGl0ZW0/LnBhdGgpIHtcbiAgICAgICAgICByZXN1bHQgKz0gVXRpbHNTZXJ2aWNlLnJlc29sdmVQcm9wZXJ0eUJ5UGF0aChvYmosIGl0ZW0ucGF0aCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHJldHVybiByZXN1bHQ7XG4gIH1cbn1cbiJdfQ==
@@ -1,25 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class UtilsService {
4
- /**
5
- * Resolves the value of a property in an object by providing a path.
6
- *
7
- * @param {any} obj - The object to traverse.
8
- * @param {string[]} path - An array of strings representing the path to the desired property.
9
- * @return {any} The value of the property at the given path, or null if the path is invalid.
10
- */
11
- static resolvePropertyByPath(obj, path) {
12
- return path.reduce((prev, curr) => {
13
- return prev ? prev[curr] : null;
14
- }, obj || self);
15
- }
16
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: UtilsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
17
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: UtilsService, providedIn: 'root' }); }
18
- }
19
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: UtilsService, decorators: [{
20
- type: Injectable,
21
- args: [{
22
- providedIn: 'root'
23
- }]
24
- }] });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2d1YWNob3MtZ2VuZXJhbC1hdXRvY29tcGxldGUvc3JjL3V0aWxzL3NlcnZpY2VzL3V0aWxzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFLekMsTUFBTSxPQUFPLFlBQVk7SUFDckI7Ozs7OztPQU1HO0lBQ0ksTUFBTSxDQUFDLHFCQUFxQixDQUFDLEdBQVEsRUFBRSxJQUFjO1FBQ3hELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksRUFBRSxJQUFZLEVBQUUsRUFBRTtZQUN0QyxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFDcEMsQ0FBQyxFQUFFLEdBQUcsSUFBSSxJQUFJLENBQUMsQ0FBQztJQUNwQixDQUFDOzhHQVpRLFlBQVk7a0hBQVosWUFBWSxjQUZULE1BQU07OzJGQUVULFlBQVk7a0JBSHhCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBVdGlsc1NlcnZpY2Uge1xuICAgIC8qKlxuICAgICAqIFJlc29sdmVzIHRoZSB2YWx1ZSBvZiBhIHByb3BlcnR5IGluIGFuIG9iamVjdCBieSBwcm92aWRpbmcgYSBwYXRoLlxuICAgICAqXG4gICAgICogQHBhcmFtIHthbnl9IG9iaiAtIFRoZSBvYmplY3QgdG8gdHJhdmVyc2UuXG4gICAgICogQHBhcmFtIHtzdHJpbmdbXX0gcGF0aCAtIEFuIGFycmF5IG9mIHN0cmluZ3MgcmVwcmVzZW50aW5nIHRoZSBwYXRoIHRvIHRoZSBkZXNpcmVkIHByb3BlcnR5LlxuICAgICAqIEByZXR1cm4ge2FueX0gVGhlIHZhbHVlIG9mIHRoZSBwcm9wZXJ0eSBhdCB0aGUgZ2l2ZW4gcGF0aCwgb3IgbnVsbCBpZiB0aGUgcGF0aCBpcyBpbnZhbGlkLlxuICAgICAqL1xuICAgIHB1YmxpYyBzdGF0aWMgcmVzb2x2ZVByb3BlcnR5QnlQYXRoKG9iajogYW55LCBwYXRoOiBzdHJpbmdbXSk6IGFueSB7XG4gICAgICAgIHJldHVybiBwYXRoLnJlZHVjZSgocHJldiwgY3Vycjogc3RyaW5nKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gcHJldiA/IHByZXZbY3Vycl0gOiBudWxsO1xuICAgICAgICB9LCBvYmogfHwgc2VsZik7XG4gICAgfVxufVxuIl19