ets-fe-ng-sdk 18.0.0 → 18.0.2
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.
- package/esm2022/lib/Shared/components/autocomplete/autocomplete-td-rf/autocomplete-td-rf.component.mjs +3 -3
- package/esm2022/lib/Shared/components/autocomplete/autocomplete.component.mjs +3 -3
- package/esm2022/lib/Shared/components/autocomplete/autocomplete.service.mjs +7 -4
- package/esm2022/lib/Shared/components/input/input-basic.component.mjs +3 -3
- package/esm2022/lib/Shared/components/input/input-control.component.mjs +3 -3
- package/esm2022/lib/Shared/components/input/input-td-rf.component.mjs +3 -3
- package/esm2022/lib/Shared/components/input/input.component.mjs +3 -3
- package/esm2022/lib/Shared/components/input/input.service.mjs +10 -7
- package/esm2022/lib/Shared/components/input-NgModel/input-ngmodel.component.mjs +3 -3
- package/fesm2022/ets-fe-ng-sdk.mjs +27 -23
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Services/api.service.d.ts +1 -1
- package/lib/Services/utility.service.d.ts +1 -1
- package/lib/Shared/components/autocomplete/autocomplete-td-rf/autocomplete-td-rf.component.d.ts +1 -2
- package/lib/Shared/components/autocomplete/autocomplete.component.d.ts +2 -2
- package/lib/Shared/components/autocomplete/autocomplete.service.d.ts +6 -2
- package/lib/Shared/components/btn/btn.component.d.ts +3 -3
- package/lib/Shared/components/form-generator/form-generated-value/form-generated-value.component.d.ts +2 -2
- package/lib/Shared/components/index-comp-layout/index-comp-layout.component.d.ts +1 -1
- package/lib/Shared/components/input/input.service.d.ts +4 -2
- package/lib/Shared/components/page-template/page-template.component.d.ts +1 -1
- package/lib/Shared/components/table-https/table-https.component.d.ts +3 -3
- package/lib/Shared/components/text-case-2/text-case-2.component.d.ts +1 -1
- package/package.json +23 -23
|
@@ -94,7 +94,7 @@ export class AutocompleteTdRfComponent extends InputTD_RFComponent {
|
|
|
94
94
|
// }, 600);
|
|
95
95
|
}
|
|
96
96
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AutocompleteTdRfComponent, deps: [{ token: i1.AutocompleteService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
97
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: AutocompleteTdRfComponent, isStandalone: true, selector: "autocomplete-td-rf,app-autocomplete-td-rf", inputs: { validate: "validate", _options: ["options", "_options"] }, viewQueries: [{ propertyName: "autoCompleteRef", first: true, predicate: MatAutocomplete, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"row align-items-center\">\n <!-- {{options()|json}} -->\n @if (verbose()) {\n <div>disabledSignal: {{ disabledSignal() }}</div>\n <div>validSignal: {{ validSignal() }}</div>\n <div>invalidSignal: {{ invalidSignal() }}</div>\n <div>valueSignal: {{ valueSignal()|json }}</div>\n <div>hasValue: {{ hasValue() }}</div>\n <div>dirtySignal: {{ dirtySignal() }}</div>\n <div>touchedSignal: {{ touchedSignal() }}</div>\n <div>errorsSignal: {{ errorsSignaljson() }}</div>\n <div>pendingSignal: {{ pendingSignal() }}</div>\n <div>pristineSignal: {{ pristineSignal() }}</div>\n <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n }\n @if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()|toAny\"\n [hint]=\"hint\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl\"\n [light]=\"light\"\n [mini]=\"miniSignal()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme\"\n [xsmall]=\"xsmall\" />\n }\n <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n <form [formGroup]=\"form()|toAny\" class=\"position-relative\">\n <input\n type=\"text\"\n data-noformat=\"true\"\n [formControlName]=\"nameStrSignal()\"\n placeholder=\"{{ placeholder() }}\"\n [id]=\"idSignal()\"\n (keyup)=\"fetchOptions($event)\"\n [class]=\"inputClassSignal()\"\n [required]=\"requiredSignal()\"\n [readonly]=\"readonlySignal()\"\n #trigger=\"matAutocompleteTrigger\"\n [matAutocomplete]=\"auto\"\n #inp />\n @if (!disabledSignal()) {\n <i
|
|
97
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: AutocompleteTdRfComponent, isStandalone: true, selector: "autocomplete-td-rf,app-autocomplete-td-rf", inputs: { validate: "validate", _options: ["options", "_options"] }, viewQueries: [{ propertyName: "autoCompleteRef", first: true, predicate: MatAutocomplete, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"row align-items-center\">\n <!-- {{options()|json}} -->\n @if (verbose()) {\n <div>disabledSignal: {{ disabledSignal() }}</div>\n <div>validSignal: {{ validSignal() }}</div>\n <div>invalidSignal: {{ invalidSignal() }}</div>\n <div>valueSignal: {{ valueSignal() | json }}</div>\n <div>hasValue: {{ hasValue() }}</div>\n <div>dirtySignal: {{ dirtySignal() }}</div>\n <div>touchedSignal: {{ touchedSignal() }}</div>\n <div>errorsSignal: {{ errorsSignaljson() }}</div>\n <div>pendingSignal: {{ pendingSignal() }}</div>\n <div>pristineSignal: {{ pristineSignal() }}</div>\n <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n }\n @if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form() | toAny\"\n [hint]=\"hint\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl\"\n [light]=\"light\"\n [mini]=\"miniSignal()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme\"\n [xsmall]=\"xsmall\" />\n }\n <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n <form [formGroup]=\"form() | toAny\" class=\"position-relative\">\n <input\n type=\"text\"\n data-noformat=\"true\"\n [formControlName]=\"nameStrSignal()\"\n placeholder=\"{{ placeholder() }}\"\n [id]=\"idSignal()\"\n (keyup)=\"fetchOptions($event)\"\n [class]=\"inputClassSignal()\"\n [required]=\"requiredSignal()\"\n [readonly]=\"readonlySignal()\"\n #trigger=\"matAutocompleteTrigger\"\n [matAutocomplete]=\"auto\"\n #inp />\n @if (!disabledSignal()) {\n <i\n class=\"input-icon fa fa-search\"\n (click)=\"$event.stopPropagation(); trigger.openPanel()\"></i>\n }\n <mat-autocomplete\n #auto=\"matAutocomplete\"\n [displayWith]=\"displayWith\"\n class=\"options-w-auto\"\n (optionSelected)=\"selected($event)\">\n <!-- <ng-container *ngIf=\"duplicateCheck; else elseNoDulicateTemplate\">\n <mat-option\n *ngFor=\"let item of filteredOptions|removeUsedOptionsReactive:(form.parent|toAny):(form.value):'value':name;trackBy:iS.trackByValue\"\n [value]=\"item.value\">\n <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions | async }}\n </div>\n </mat-option>\n </ng-container>\n <ng-template #elseNoDulicateTemplate>\n <mat-option\n *ngFor=\"let item of filteredOptions;trackBy:iS.trackByValue\"\n [value]=\"item.value\">\n <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions | async }}\n </div>\n </mat-option>\n </ng-template> -->\n\n @if (showEmptyOptionSignal()) {\n <mat-option selected [value]=\"null\" class=\"empty-option\">\n {{ optionsFunc ? 'Type to search' : placeholder() }}\n </mat-option>\n }\n @for (item of filteredOptions(); track item._id) {\n <mat-option [value]=\"item.value\" (onSelectionChange)=\"selectedOption(item)\">\n <div\n class=\"option\"\n [matTooltip]=\"ele.innerText\"\n [matTooltipShowDelay]=\"1000\"\n [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions() | async }}\n </div>\n </mat-option>\n }\n </mat-autocomplete>\n @if (dirtySignal() && showValidationSignal() && showValidationIconSignal()) {\n <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-check\"></i>\n </div>\n <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-times\"></i>\n </div>\n }\n @if (loading) {\n <div class=\"d-flex text-primary me-1 validity-icon\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n }\n </form>\n </div>\n</div>\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: ["i.input-icon{position:absolute;top:15px;right:7px;opacity:.4;font-size:10px}.option{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"], dependencies: [{ kind: "component", type: InputLabelComponent, selector: "app-input-label", inputs: ["colored", "form", "hint", "inlineHint", "id", "invalidCheckbox", "isRequired", "label", "labelLink", "lblCl", "light", "mini", "showLabel", "showRequiredTag", "small", "stacked", "theme", "xsmall"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "pipe", type: JsonPipe, name: "json" }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i3.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: i4.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i3.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ValidationMessageComponent, selector: "app-validation-message", inputs: ["debug", "label", "hideOverflow", "minLength", "maxLength", "ignoreDirtiness", "customMessage", "control", "input"], outputs: ["labelChange"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
|
|
98
98
|
}
|
|
99
99
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AutocompleteTdRfComponent, decorators: [{
|
|
100
100
|
type: Component,
|
|
@@ -114,7 +114,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
114
114
|
ToAnyPipe,
|
|
115
115
|
SDKTranslatePipe,
|
|
116
116
|
InputClassPipe,
|
|
117
|
-
], template: "<div class=\"row align-items-center\">\n <!-- {{options()|json}} -->\n @if (verbose()) {\n <div>disabledSignal: {{ disabledSignal() }}</div>\n <div>validSignal: {{ validSignal() }}</div>\n <div>invalidSignal: {{ invalidSignal() }}</div>\n <div>valueSignal: {{ valueSignal()|json }}</div>\n <div>hasValue: {{ hasValue() }}</div>\n <div>dirtySignal: {{ dirtySignal() }}</div>\n <div>touchedSignal: {{ touchedSignal() }}</div>\n <div>errorsSignal: {{ errorsSignaljson() }}</div>\n <div>pendingSignal: {{ pendingSignal() }}</div>\n <div>pristineSignal: {{ pristineSignal() }}</div>\n <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n }\n @if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()|toAny\"\n [hint]=\"hint\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl\"\n [light]=\"light\"\n [mini]=\"miniSignal()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme\"\n [xsmall]=\"xsmall\" />\n }\n <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n <form [formGroup]=\"form()|toAny\" class=\"position-relative\">\n <input\n type=\"text\"\n data-noformat=\"true\"\n [formControlName]=\"nameStrSignal()\"\n placeholder=\"{{ placeholder() }}\"\n [id]=\"idSignal()\"\n (keyup)=\"fetchOptions($event)\"\n [class]=\"inputClassSignal()\"\n [required]=\"requiredSignal()\"\n [readonly]=\"readonlySignal()\"\n #trigger=\"matAutocompleteTrigger\"\n [matAutocomplete]=\"auto\"\n #inp />\n @if (!disabledSignal()) {\n <i
|
|
117
|
+
], template: "<div class=\"row align-items-center\">\n <!-- {{options()|json}} -->\n @if (verbose()) {\n <div>disabledSignal: {{ disabledSignal() }}</div>\n <div>validSignal: {{ validSignal() }}</div>\n <div>invalidSignal: {{ invalidSignal() }}</div>\n <div>valueSignal: {{ valueSignal() | json }}</div>\n <div>hasValue: {{ hasValue() }}</div>\n <div>dirtySignal: {{ dirtySignal() }}</div>\n <div>touchedSignal: {{ touchedSignal() }}</div>\n <div>errorsSignal: {{ errorsSignaljson() }}</div>\n <div>pendingSignal: {{ pendingSignal() }}</div>\n <div>pristineSignal: {{ pristineSignal() }}</div>\n <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n }\n @if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form() | toAny\"\n [hint]=\"hint\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl\"\n [light]=\"light\"\n [mini]=\"miniSignal()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme\"\n [xsmall]=\"xsmall\" />\n }\n <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n <form [formGroup]=\"form() | toAny\" class=\"position-relative\">\n <input\n type=\"text\"\n data-noformat=\"true\"\n [formControlName]=\"nameStrSignal()\"\n placeholder=\"{{ placeholder() }}\"\n [id]=\"idSignal()\"\n (keyup)=\"fetchOptions($event)\"\n [class]=\"inputClassSignal()\"\n [required]=\"requiredSignal()\"\n [readonly]=\"readonlySignal()\"\n #trigger=\"matAutocompleteTrigger\"\n [matAutocomplete]=\"auto\"\n #inp />\n @if (!disabledSignal()) {\n <i\n class=\"input-icon fa fa-search\"\n (click)=\"$event.stopPropagation(); trigger.openPanel()\"></i>\n }\n <mat-autocomplete\n #auto=\"matAutocomplete\"\n [displayWith]=\"displayWith\"\n class=\"options-w-auto\"\n (optionSelected)=\"selected($event)\">\n <!-- <ng-container *ngIf=\"duplicateCheck; else elseNoDulicateTemplate\">\n <mat-option\n *ngFor=\"let item of filteredOptions|removeUsedOptionsReactive:(form.parent|toAny):(form.value):'value':name;trackBy:iS.trackByValue\"\n [value]=\"item.value\">\n <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions | async }}\n </div>\n </mat-option>\n </ng-container>\n <ng-template #elseNoDulicateTemplate>\n <mat-option\n *ngFor=\"let item of filteredOptions;trackBy:iS.trackByValue\"\n [value]=\"item.value\">\n <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions | async }}\n </div>\n </mat-option>\n </ng-template> -->\n\n @if (showEmptyOptionSignal()) {\n <mat-option selected [value]=\"null\" class=\"empty-option\">\n {{ optionsFunc ? 'Type to search' : placeholder() }}\n </mat-option>\n }\n @for (item of filteredOptions(); track item._id) {\n <mat-option [value]=\"item.value\" (onSelectionChange)=\"selectedOption(item)\">\n <div\n class=\"option\"\n [matTooltip]=\"ele.innerText\"\n [matTooltipShowDelay]=\"1000\"\n [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions() | async }}\n </div>\n </mat-option>\n }\n </mat-autocomplete>\n @if (dirtySignal() && showValidationSignal() && showValidationIconSignal()) {\n <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-check\"></i>\n </div>\n <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-times\"></i>\n </div>\n }\n @if (loading) {\n <div class=\"d-flex text-primary me-1 validity-icon\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n }\n </form>\n </div>\n</div>\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: ["i.input-icon{position:absolute;top:15px;right:7px;opacity:.4;font-size:10px}.option{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"] }]
|
|
118
118
|
}], ctorParameters: () => [{ type: i1.AutocompleteService }], propDecorators: { validate: [{
|
|
119
119
|
type: Input
|
|
120
120
|
}], _options: [{
|
|
@@ -124,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
124
124
|
type: ViewChild,
|
|
125
125
|
args: [MatAutocomplete]
|
|
126
126
|
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-td-rf.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/autocomplete/autocomplete-td-rf/autocomplete-td-rf.component.ts","../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, computed } from '@angular/core';\nimport { AbstractControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport {\n  MatAutocomplete,\n  MatAutocompleteSelectedEvent,\n  MatAutocompleteModule,\n} from '@angular/material/autocomplete';\nimport { ReplaySubject, Subscription } from 'rxjs';\nimport { debounceTime, filter, switchMap, tap } from 'rxjs/operators';\nimport { IOption } from '../../input/input-basic.component';\nimport { InputTD_RFComponent } from '../../input/input-td-rf.component';\nimport { AutocompleteService } from '../autocomplete.service';\nimport { InputClassPipe } from '../../input/inputs-pipes.pipe';\nimport { ToAnyPipe } from '../../../pipes/utility.pipe';\nimport { SDKTranslatePipe } from '../../../pipes/translate.pipe';\nimport { ValidationMessageComponent } from '../../input/validation-message/validation-message.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatOption, MatOptionModule } from '@angular/material/core';\nimport { InputLabelComponent } from '../../input/input-label/input-label.component';\nimport { NgIf, NgFor, NgClass, AsyncPipe, JsonPipe } from '@angular/common';\n\n@Component({\n  selector: 'autocomplete-td-rf,app-autocomplete-td-rf',\n  templateUrl: '../autocomplete.component.html',\n  styleUrls: ['../autocomplete.component.scss'],\n  standalone: true,\n  imports: [\n    NgIf,\n    InputLabelComponent,\n    FormsModule,\n    ReactiveFormsModule,\n    JsonPipe,\n    MatAutocompleteModule,\n    NgFor,\n    MatOptionModule,\n    MatTooltipModule,\n    NgClass,\n    ValidationMessageComponent,\n    AsyncPipe,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    InputClassPipe,\n  ],\n})\nexport class AutocompleteTdRfComponent<TOption> extends InputTD_RFComponent<TOption> {\n  readonly cOptions = computed(() => this.autoS.normalizeOptions(this.options()));\n  filteredOptions = computed<IOption[]>(() => {\n    return this.autoS.filterOptions(this.valueSignal(), this.cOptions());\n  });\n  @Input() validate = true;\n  @Input('options') override set _options(v: TOption[]) {\n    super._options = v;\n    if (this.autoCompleteRef && this.control()?.getRawValue())\n      this.control().setValue(this.control()?.getRawValue(), { emitEvent: false });\n  }\n  @ViewChild(MatAutocomplete) autoCompleteRef: MatAutocomplete;\n\n  protected valueChanged = new ReplaySubject<string>();\n\n  constructor(public autoS: AutocompleteService) {\n    super();\n  }\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n    let vS: Subscription;\n    this.addOnControlObtainedHook('includesOption', (control) => {\n      if (!control?.hasValidator(this.includesOption)) control?.addValidators(this.includesOption);\n      else debugger;\n      vS?.unsubscribe();\n      vS = control?.valueChanges.subscribe((r) => {\n        // debugger\n        super.change({ target: { value: r } });\n      });\n    });\n    if (this.optionsFunc)\n      this.valueChanged\n        .pipe(\n          tap(() => (this.loading = true)),\n          debounceTime(600),\n          filter((v) => v != null && v != ''),\n          switchMap((v) => this.optionsFunc(v)),\n        )\n        .subscribe((r) => {\n          // debugger\n          this._options = r;\n          this.loading = false;\n        });\n  }\n\n  fetchOptions($event: Event) {\n    if (this.optionsFunc) {\n      this.loading = true;\n      this.valueChanged.next(this.control()?.getRawValue());\n    }\n  }\n\n  override ngAfterViewInit(): void {\n    super.ngAfterViewInit();\n  }\n\n  selected($event: MatAutocompleteSelectedEvent) {\n    this.mSelectedOptionLabel.emit(this.displayWith(this.control()?.getRawValue()));\n    // setTimeout(() => {\n    //   this.filteredOptions.set(this.options());\n    // }, 600);\n  }\n\n  displayWith = (val: any) =>\n    // {\n    // if (this.debug()) debugger;\n    val instanceof MatOption\n      ? this.displayWith(val.value)\n      : this.doesOptionExist(val)?.label || val;\n  // };\n\n  includesOption = (control: AbstractControl) => {\n    if (this.debug()) debugger;\n    const val = control?.value;\n    if (!val) return null;\n    if (!this.options() || this.options().length === 0) return null;\n    // debugger\n    if (this.doesOptionExist(val)) return null;\n    else return this.autoS.invalidSelectionError;\n  };\n}\n","<div class=\"row align-items-center\">\n  <!-- {{options()|json}} -->\n  @if (verbose()) {\n    <div>disabledSignal: {{ disabledSignal() }}</div>\n    <div>validSignal: {{ validSignal() }}</div>\n    <div>invalidSignal: {{ invalidSignal() }}</div>\n    <div>valueSignal: {{ valueSignal()|json }}</div>\n    <div>hasValue: {{ hasValue() }}</div>\n    <div>dirtySignal: {{ dirtySignal() }}</div>\n    <div>touchedSignal: {{ touchedSignal() }}</div>\n    <div>errorsSignal: {{ errorsSignaljson() }}</div>\n    <div>pendingSignal: {{ pendingSignal() }}</div>\n    <div>pristineSignal: {{ pristineSignal() }}</div>\n    <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n    <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n    <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n  }\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"form()|toAny\"\n      [hint]=\"hint\"\n      [id]=\"idSignal()\"\n      [invalidCheckbox]=\"invalidCheckboxSignal()\"\n      [isRequired]=\"isRequiredSignal()\"\n      [label]=\"labelSignal()\"\n      [lblCl]=\"lblCl\"\n      [light]=\"light\"\n      [mini]=\"miniSignal()\"\n      [showRequiredTag]=\"showRequiredTagSignal()\"\n      [showLabel]=\"showLabelSignal()\"\n      [small]=\"smallSignal()\"\n      [stacked]=\"stackedSignal()\"\n      [theme]=\"theme\"\n      [xsmall]=\"xsmall\" />\n  }\n  <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n    <form [formGroup]=\"form()|toAny\" class=\"position-relative\">\n      <input\n        type=\"text\"\n        data-noformat=\"true\"\n        [formControlName]=\"nameStrSignal()\"\n        placeholder=\"{{ placeholder() }}\"\n        [id]=\"idSignal()\"\n        (keyup)=\"fetchOptions($event)\"\n        [class]=\"inputClassSignal()\"\n        [required]=\"requiredSignal()\"\n        [readonly]=\"readonlySignal()\"\n        #trigger=\"matAutocompleteTrigger\"\n        [matAutocomplete]=\"auto\"\n        #inp />\n      @if (!disabledSignal()) {\n        <i class=\"input-icon fa fa-search\" (click)=\"$event.stopPropagation(); trigger.openPanel()\"></i>\n      }\n      <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayWith\" class=\"options-w-auto\" (optionSelected)=\"selected($event)\">\n        <!-- <ng-container *ngIf=\"duplicateCheck; else elseNoDulicateTemplate\">\n          <mat-option\n            *ngFor=\"let item of filteredOptions|removeUsedOptionsReactive:(form.parent|toAny):(form.value):'value':name;trackBy:iS.trackByValue\"\n            [value]=\"item.value\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions | async }}\n            </div>\n          </mat-option>\n        </ng-container>\n        <ng-template #elseNoDulicateTemplate>\n          <mat-option\n            *ngFor=\"let item of filteredOptions;trackBy:iS.trackByValue\"\n            [value]=\"item.value\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions | async }}\n            </div>\n          </mat-option>\n        </ng-template> -->\n\n        @if (showEmptyOptionSignal()) {\n          <mat-option selected [value]=\"null\" class=\"empty-option\">\n            {{ optionsFunc ? 'Type to search' : placeholder() }}\n          </mat-option>\n        }\n        @for (item of filteredOptions(); track iS.trackByValue) {\n          <mat-option [value]=\"item.value\" (onSelectionChange)=\"selectedOption(item)\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipShowDelay]=\"1000\" [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\" #ele>\n              {{ item.label | appTranslate: translateOptions() | async }} \n            </div>\n          </mat-option>\n        }\n      </mat-autocomplete>\n      @if (dirtySignal() && showValidationSignal() && showValidationIconSignal()) {\n        <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\"><i class=\"fa fa-check\"></i></div>\n        <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n        <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\"><i class=\"fa fa-times\"></i></div>\n      }\n      @if (loading) {\n        <div class=\"d-flex text-primary me-1 validity-icon\"><i class=\"fa fa-spinner fa-spin\"></i></div>\n      }\n    </form>\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-td-rf.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/autocomplete/autocomplete-td-rf/autocomplete-td-rf.component.ts","../../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, computed } from '@angular/core';\nimport { AbstractControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport {\n  MatAutocomplete,\n  MatAutocompleteSelectedEvent,\n  MatAutocompleteModule,\n} from '@angular/material/autocomplete';\nimport { ReplaySubject, Subscription } from 'rxjs';\nimport { debounceTime, filter, switchMap, tap } from 'rxjs/operators';\nimport { IOption } from '../../input/input-basic.component';\nimport { InputTD_RFComponent } from '../../input/input-td-rf.component';\nimport { AutocompleteService } from '../autocomplete.service';\nimport { InputClassPipe } from '../../input/inputs-pipes.pipe';\nimport { ToAnyPipe } from '../../../pipes/utility.pipe';\nimport { SDKTranslatePipe } from '../../../pipes/translate.pipe';\nimport { ValidationMessageComponent } from '../../input/validation-message/validation-message.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatOption, MatOptionModule } from '@angular/material/core';\nimport { InputLabelComponent } from '../../input/input-label/input-label.component';\nimport { NgIf, NgFor, NgClass, AsyncPipe, JsonPipe } from '@angular/common';\n\n@Component({\n  selector: 'autocomplete-td-rf,app-autocomplete-td-rf',\n  templateUrl: '../autocomplete.component.html',\n  styleUrls: ['../autocomplete.component.scss'],\n  standalone: true,\n  imports: [\n    NgIf,\n    InputLabelComponent,\n    FormsModule,\n    ReactiveFormsModule,\n    JsonPipe,\n    MatAutocompleteModule,\n    NgFor,\n    MatOptionModule,\n    MatTooltipModule,\n    NgClass,\n    ValidationMessageComponent,\n    AsyncPipe,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    InputClassPipe,\n  ],\n})\nexport class AutocompleteTdRfComponent<TOption> extends InputTD_RFComponent<TOption> {\n  readonly cOptions = computed(() => this.autoS.normalizeOptions(this.options()));\n  readonly filteredOptions = computed(() => {\n    return this.autoS.filterOptions(this.valueSignal(), this.cOptions());\n  });\n  @Input() validate = true;\n  @Input('options') override set _options(v: TOption[]) {\n    super._options = v;\n    if (this.autoCompleteRef && this.control()?.getRawValue())\n      this.control().setValue(this.control()?.getRawValue(), { emitEvent: false });\n  }\n  @ViewChild(MatAutocomplete) autoCompleteRef: MatAutocomplete;\n\n  protected valueChanged = new ReplaySubject<string>();\n\n  constructor(public autoS: AutocompleteService) {\n    super();\n  }\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n    let vS: Subscription;\n    this.addOnControlObtainedHook('includesOption', (control) => {\n      if (!control?.hasValidator(this.includesOption)) control?.addValidators(this.includesOption);\n      else debugger;\n      vS?.unsubscribe();\n      vS = control?.valueChanges.subscribe((r) => {\n        // debugger\n        super.change({ target: { value: r } });\n      });\n    });\n    if (this.optionsFunc)\n      this.valueChanged\n        .pipe(\n          tap(() => (this.loading = true)),\n          debounceTime(600),\n          filter((v) => v != null && v != ''),\n          switchMap((v) => this.optionsFunc(v)),\n        )\n        .subscribe((r) => {\n          // debugger\n          this._options = r;\n          this.loading = false;\n        });\n  }\n\n  fetchOptions($event: Event) {\n    if (this.optionsFunc) {\n      this.loading = true;\n      this.valueChanged.next(this.control()?.getRawValue());\n    }\n  }\n\n  override ngAfterViewInit(): void {\n    super.ngAfterViewInit();\n  }\n\n  selected($event: MatAutocompleteSelectedEvent) {\n    this.mSelectedOptionLabel.emit(this.displayWith(this.control()?.getRawValue()));\n    // setTimeout(() => {\n    //   this.filteredOptions.set(this.options());\n    // }, 600);\n  }\n\n  displayWith = (val: any) =>\n    // {\n    // if (this.debug()) debugger;\n    val instanceof MatOption\n      ? this.displayWith(val.value)\n      : this.doesOptionExist(val)?.label || val;\n  // };\n\n  includesOption = (control: AbstractControl) => {\n    if (this.debug()) debugger;\n    const val = control?.value;\n    if (!val) return null;\n    if (!this.options() || this.options().length === 0) return null;\n    // debugger\n    if (this.doesOptionExist(val)) return null;\n    else return this.autoS.invalidSelectionError;\n  };\n}\n","<div class=\"row align-items-center\">\n  <!-- {{options()|json}} -->\n  @if (verbose()) {\n    <div>disabledSignal: {{ disabledSignal() }}</div>\n    <div>validSignal: {{ validSignal() }}</div>\n    <div>invalidSignal: {{ invalidSignal() }}</div>\n    <div>valueSignal: {{ valueSignal() | json }}</div>\n    <div>hasValue: {{ hasValue() }}</div>\n    <div>dirtySignal: {{ dirtySignal() }}</div>\n    <div>touchedSignal: {{ touchedSignal() }}</div>\n    <div>errorsSignal: {{ errorsSignaljson() }}</div>\n    <div>pendingSignal: {{ pendingSignal() }}</div>\n    <div>pristineSignal: {{ pristineSignal() }}</div>\n    <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n    <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n    <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n  }\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"form() | toAny\"\n      [hint]=\"hint\"\n      [id]=\"idSignal()\"\n      [invalidCheckbox]=\"invalidCheckboxSignal()\"\n      [isRequired]=\"isRequiredSignal()\"\n      [label]=\"labelSignal()\"\n      [lblCl]=\"lblCl\"\n      [light]=\"light\"\n      [mini]=\"miniSignal()\"\n      [showRequiredTag]=\"showRequiredTagSignal()\"\n      [showLabel]=\"showLabelSignal()\"\n      [small]=\"smallSignal()\"\n      [stacked]=\"stackedSignal()\"\n      [theme]=\"theme\"\n      [xsmall]=\"xsmall\" />\n  }\n  <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n    <form [formGroup]=\"form() | toAny\" class=\"position-relative\">\n      <input\n        type=\"text\"\n        data-noformat=\"true\"\n        [formControlName]=\"nameStrSignal()\"\n        placeholder=\"{{ placeholder() }}\"\n        [id]=\"idSignal()\"\n        (keyup)=\"fetchOptions($event)\"\n        [class]=\"inputClassSignal()\"\n        [required]=\"requiredSignal()\"\n        [readonly]=\"readonlySignal()\"\n        #trigger=\"matAutocompleteTrigger\"\n        [matAutocomplete]=\"auto\"\n        #inp />\n      @if (!disabledSignal()) {\n        <i\n          class=\"input-icon fa fa-search\"\n          (click)=\"$event.stopPropagation(); trigger.openPanel()\"></i>\n      }\n      <mat-autocomplete\n        #auto=\"matAutocomplete\"\n        [displayWith]=\"displayWith\"\n        class=\"options-w-auto\"\n        (optionSelected)=\"selected($event)\">\n        <!-- <ng-container *ngIf=\"duplicateCheck; else elseNoDulicateTemplate\">\n          <mat-option\n            *ngFor=\"let item of filteredOptions|removeUsedOptionsReactive:(form.parent|toAny):(form.value):'value':name;trackBy:iS.trackByValue\"\n            [value]=\"item.value\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions | async }}\n            </div>\n          </mat-option>\n        </ng-container>\n        <ng-template #elseNoDulicateTemplate>\n          <mat-option\n            *ngFor=\"let item of filteredOptions;trackBy:iS.trackByValue\"\n            [value]=\"item.value\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions | async }}\n            </div>\n          </mat-option>\n        </ng-template> -->\n\n        @if (showEmptyOptionSignal()) {\n          <mat-option selected [value]=\"null\" class=\"empty-option\">\n            {{ optionsFunc ? 'Type to search' : placeholder() }}\n          </mat-option>\n        }\n        @for (item of filteredOptions(); track item._id) {\n          <mat-option [value]=\"item.value\" (onSelectionChange)=\"selectedOption(item)\">\n            <div\n              class=\"option\"\n              [matTooltip]=\"ele.innerText\"\n              [matTooltipShowDelay]=\"1000\"\n              [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions() | async }}\n            </div>\n          </mat-option>\n        }\n      </mat-autocomplete>\n      @if (dirtySignal() && showValidationSignal() && showValidationIconSignal()) {\n        <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-check\"></i>\n        </div>\n        <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n        <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-times\"></i>\n        </div>\n      }\n      @if (loading) {\n        <div class=\"d-flex text-primary me-1 validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n      }\n    </form>\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n"]}
|
|
@@ -90,7 +90,7 @@ export class AutocompleteComponent extends InputBasicComponent {
|
|
|
90
90
|
// }, 600);
|
|
91
91
|
}
|
|
92
92
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AutocompleteComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
93
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: AutocompleteComponent, isStandalone: true, selector: "app-autocomplete,autocomplete", inputs: { showRequiredTag: "showRequiredTag", validate: "validate", _options: ["options", "_options"] }, viewQueries: [{ propertyName: "autoCompleteRef", first: true, predicate: MatAutocomplete, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"row align-items-center\">\n <!-- {{options()|json}} -->\n @if (verbose()) {\n <div>disabledSignal: {{ disabledSignal() }}</div>\n <div>validSignal: {{ validSignal() }}</div>\n <div>invalidSignal: {{ invalidSignal() }}</div>\n <div>valueSignal: {{ valueSignal()|json }}</div>\n <div>hasValue: {{ hasValue() }}</div>\n <div>dirtySignal: {{ dirtySignal() }}</div>\n <div>touchedSignal: {{ touchedSignal() }}</div>\n <div>errorsSignal: {{ errorsSignaljson() }}</div>\n <div>pendingSignal: {{ pendingSignal() }}</div>\n <div>pristineSignal: {{ pristineSignal() }}</div>\n <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n }\n @if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()|toAny\"\n [hint]=\"hint\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl\"\n [light]=\"light\"\n [mini]=\"miniSignal()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme\"\n [xsmall]=\"xsmall\" />\n }\n <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n <form [formGroup]=\"form()|toAny\" class=\"position-relative\">\n <input\n type=\"text\"\n data-noformat=\"true\"\n [formControlName]=\"nameStrSignal()\"\n placeholder=\"{{ placeholder() }}\"\n [id]=\"idSignal()\"\n (keyup)=\"fetchOptions($event)\"\n [class]=\"inputClassSignal()\"\n [required]=\"requiredSignal()\"\n [readonly]=\"readonlySignal()\"\n #trigger=\"matAutocompleteTrigger\"\n [matAutocomplete]=\"auto\"\n #inp />\n @if (!disabledSignal()) {\n <i
|
|
93
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: AutocompleteComponent, isStandalone: true, selector: "app-autocomplete,autocomplete", inputs: { showRequiredTag: "showRequiredTag", validate: "validate", _options: ["options", "_options"] }, viewQueries: [{ propertyName: "autoCompleteRef", first: true, predicate: MatAutocomplete, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"row align-items-center\">\n <!-- {{options()|json}} -->\n @if (verbose()) {\n <div>disabledSignal: {{ disabledSignal() }}</div>\n <div>validSignal: {{ validSignal() }}</div>\n <div>invalidSignal: {{ invalidSignal() }}</div>\n <div>valueSignal: {{ valueSignal() | json }}</div>\n <div>hasValue: {{ hasValue() }}</div>\n <div>dirtySignal: {{ dirtySignal() }}</div>\n <div>touchedSignal: {{ touchedSignal() }}</div>\n <div>errorsSignal: {{ errorsSignaljson() }}</div>\n <div>pendingSignal: {{ pendingSignal() }}</div>\n <div>pristineSignal: {{ pristineSignal() }}</div>\n <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n }\n @if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form() | toAny\"\n [hint]=\"hint\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl\"\n [light]=\"light\"\n [mini]=\"miniSignal()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme\"\n [xsmall]=\"xsmall\" />\n }\n <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n <form [formGroup]=\"form() | toAny\" class=\"position-relative\">\n <input\n type=\"text\"\n data-noformat=\"true\"\n [formControlName]=\"nameStrSignal()\"\n placeholder=\"{{ placeholder() }}\"\n [id]=\"idSignal()\"\n (keyup)=\"fetchOptions($event)\"\n [class]=\"inputClassSignal()\"\n [required]=\"requiredSignal()\"\n [readonly]=\"readonlySignal()\"\n #trigger=\"matAutocompleteTrigger\"\n [matAutocomplete]=\"auto\"\n #inp />\n @if (!disabledSignal()) {\n <i\n class=\"input-icon fa fa-search\"\n (click)=\"$event.stopPropagation(); trigger.openPanel()\"></i>\n }\n <mat-autocomplete\n #auto=\"matAutocomplete\"\n [displayWith]=\"displayWith\"\n class=\"options-w-auto\"\n (optionSelected)=\"selected($event)\">\n <!-- <ng-container *ngIf=\"duplicateCheck; else elseNoDulicateTemplate\">\n <mat-option\n *ngFor=\"let item of filteredOptions|removeUsedOptionsReactive:(form.parent|toAny):(form.value):'value':name;trackBy:iS.trackByValue\"\n [value]=\"item.value\">\n <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions | async }}\n </div>\n </mat-option>\n </ng-container>\n <ng-template #elseNoDulicateTemplate>\n <mat-option\n *ngFor=\"let item of filteredOptions;trackBy:iS.trackByValue\"\n [value]=\"item.value\">\n <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions | async }}\n </div>\n </mat-option>\n </ng-template> -->\n\n @if (showEmptyOptionSignal()) {\n <mat-option selected [value]=\"null\" class=\"empty-option\">\n {{ optionsFunc ? 'Type to search' : placeholder() }}\n </mat-option>\n }\n @for (item of filteredOptions(); track item._id) {\n <mat-option [value]=\"item.value\" (onSelectionChange)=\"selectedOption(item)\">\n <div\n class=\"option\"\n [matTooltip]=\"ele.innerText\"\n [matTooltipShowDelay]=\"1000\"\n [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions() | async }}\n </div>\n </mat-option>\n }\n </mat-autocomplete>\n @if (dirtySignal() && showValidationSignal() && showValidationIconSignal()) {\n <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-check\"></i>\n </div>\n <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-times\"></i>\n </div>\n }\n @if (loading) {\n <div class=\"d-flex text-primary me-1 validity-icon\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n }\n </form>\n </div>\n</div>\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [".bordercheck{border:1px solid #4ef580!important;outline:0}.borderuncheck{border:1px solid red!important;outline:0}.light{font-weight:500}.validity-icon{display:none;position:absolute;top:0;left:unset;right:20px;height:100%;align-items:center}.select .validity-icon{right:30px}.valid{display:flex!important;color:#4ef580}.pending{display:flex!important;color:#ff4500}.invalid{display:flex!important;color:red}.inputform{height:41px}.invalid-label{color:red!important}input[type=checkbox]:checked{position:relative}.showValidationIcon .form-control:not(input[type=checkbox].form-control),.showValidationIcon select.form-control:not(input[type=checkbox].form-control){padding:10px 36px 10px 12px}.password-icons{position:absolute;right:20px;top:17%}[disabled]{cursor:default}.link{cursor:pointer}.option{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n", "i.input-icon{position:absolute;top:15px;right:7px;opacity:.4;font-size:10px}.option{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"], dependencies: [{ kind: "component", type: InputLabelComponent, selector: "app-input-label", inputs: ["colored", "form", "hint", "inlineHint", "id", "invalidCheckbox", "isRequired", "label", "labelLink", "lblCl", "light", "mini", "showLabel", "showRequiredTag", "small", "stacked", "theme", "xsmall"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "pipe", type: JsonPipe, name: "json" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i2.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: i3.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i2.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ValidationMessageComponent, selector: "app-validation-message", inputs: ["debug", "label", "hideOverflow", "minLength", "maxLength", "ignoreDirtiness", "customMessage", "control", "input"], outputs: ["labelChange"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
|
|
94
94
|
}
|
|
95
95
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AutocompleteComponent, decorators: [{
|
|
96
96
|
type: Component,
|
|
@@ -110,7 +110,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
110
110
|
ToAnyPipe,
|
|
111
111
|
SDKTranslatePipe,
|
|
112
112
|
InputClassPipe,
|
|
113
|
-
], template: "<div class=\"row align-items-center\">\n <!-- {{options()|json}} -->\n @if (verbose()) {\n <div>disabledSignal: {{ disabledSignal() }}</div>\n <div>validSignal: {{ validSignal() }}</div>\n <div>invalidSignal: {{ invalidSignal() }}</div>\n <div>valueSignal: {{ valueSignal()|json }}</div>\n <div>hasValue: {{ hasValue() }}</div>\n <div>dirtySignal: {{ dirtySignal() }}</div>\n <div>touchedSignal: {{ touchedSignal() }}</div>\n <div>errorsSignal: {{ errorsSignaljson() }}</div>\n <div>pendingSignal: {{ pendingSignal() }}</div>\n <div>pristineSignal: {{ pristineSignal() }}</div>\n <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n }\n @if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()|toAny\"\n [hint]=\"hint\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl\"\n [light]=\"light\"\n [mini]=\"miniSignal()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme\"\n [xsmall]=\"xsmall\" />\n }\n <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n <form [formGroup]=\"form()|toAny\" class=\"position-relative\">\n <input\n type=\"text\"\n data-noformat=\"true\"\n [formControlName]=\"nameStrSignal()\"\n placeholder=\"{{ placeholder() }}\"\n [id]=\"idSignal()\"\n (keyup)=\"fetchOptions($event)\"\n [class]=\"inputClassSignal()\"\n [required]=\"requiredSignal()\"\n [readonly]=\"readonlySignal()\"\n #trigger=\"matAutocompleteTrigger\"\n [matAutocomplete]=\"auto\"\n #inp />\n @if (!disabledSignal()) {\n <i
|
|
113
|
+
], template: "<div class=\"row align-items-center\">\n <!-- {{options()|json}} -->\n @if (verbose()) {\n <div>disabledSignal: {{ disabledSignal() }}</div>\n <div>validSignal: {{ validSignal() }}</div>\n <div>invalidSignal: {{ invalidSignal() }}</div>\n <div>valueSignal: {{ valueSignal() | json }}</div>\n <div>hasValue: {{ hasValue() }}</div>\n <div>dirtySignal: {{ dirtySignal() }}</div>\n <div>touchedSignal: {{ touchedSignal() }}</div>\n <div>errorsSignal: {{ errorsSignaljson() }}</div>\n <div>pendingSignal: {{ pendingSignal() }}</div>\n <div>pristineSignal: {{ pristineSignal() }}</div>\n <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n }\n @if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form() | toAny\"\n [hint]=\"hint\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl\"\n [light]=\"light\"\n [mini]=\"miniSignal()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme\"\n [xsmall]=\"xsmall\" />\n }\n <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n <form [formGroup]=\"form() | toAny\" class=\"position-relative\">\n <input\n type=\"text\"\n data-noformat=\"true\"\n [formControlName]=\"nameStrSignal()\"\n placeholder=\"{{ placeholder() }}\"\n [id]=\"idSignal()\"\n (keyup)=\"fetchOptions($event)\"\n [class]=\"inputClassSignal()\"\n [required]=\"requiredSignal()\"\n [readonly]=\"readonlySignal()\"\n #trigger=\"matAutocompleteTrigger\"\n [matAutocomplete]=\"auto\"\n #inp />\n @if (!disabledSignal()) {\n <i\n class=\"input-icon fa fa-search\"\n (click)=\"$event.stopPropagation(); trigger.openPanel()\"></i>\n }\n <mat-autocomplete\n #auto=\"matAutocomplete\"\n [displayWith]=\"displayWith\"\n class=\"options-w-auto\"\n (optionSelected)=\"selected($event)\">\n <!-- <ng-container *ngIf=\"duplicateCheck; else elseNoDulicateTemplate\">\n <mat-option\n *ngFor=\"let item of filteredOptions|removeUsedOptionsReactive:(form.parent|toAny):(form.value):'value':name;trackBy:iS.trackByValue\"\n [value]=\"item.value\">\n <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions | async }}\n </div>\n </mat-option>\n </ng-container>\n <ng-template #elseNoDulicateTemplate>\n <mat-option\n *ngFor=\"let item of filteredOptions;trackBy:iS.trackByValue\"\n [value]=\"item.value\">\n <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions | async }}\n </div>\n </mat-option>\n </ng-template> -->\n\n @if (showEmptyOptionSignal()) {\n <mat-option selected [value]=\"null\" class=\"empty-option\">\n {{ optionsFunc ? 'Type to search' : placeholder() }}\n </mat-option>\n }\n @for (item of filteredOptions(); track item._id) {\n <mat-option [value]=\"item.value\" (onSelectionChange)=\"selectedOption(item)\">\n <div\n class=\"option\"\n [matTooltip]=\"ele.innerText\"\n [matTooltipShowDelay]=\"1000\"\n [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n #ele>\n {{ item.label | appTranslate: translateOptions() | async }}\n </div>\n </mat-option>\n }\n </mat-autocomplete>\n @if (dirtySignal() && showValidationSignal() && showValidationIconSignal()) {\n <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-check\"></i>\n </div>\n <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n <i class=\"fa fa-times\"></i>\n </div>\n }\n @if (loading) {\n <div class=\"d-flex text-primary me-1 validity-icon\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n }\n </form>\n </div>\n</div>\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [".bordercheck{border:1px solid #4ef580!important;outline:0}.borderuncheck{border:1px solid red!important;outline:0}.light{font-weight:500}.validity-icon{display:none;position:absolute;top:0;left:unset;right:20px;height:100%;align-items:center}.select .validity-icon{right:30px}.valid{display:flex!important;color:#4ef580}.pending{display:flex!important;color:#ff4500}.invalid{display:flex!important;color:red}.inputform{height:41px}.invalid-label{color:red!important}input[type=checkbox]:checked{position:relative}.showValidationIcon .form-control:not(input[type=checkbox].form-control),.showValidationIcon select.form-control:not(input[type=checkbox].form-control){padding:10px 36px 10px 12px}.password-icons{position:absolute;right:20px;top:17%}[disabled]{cursor:default}.link{cursor:pointer}.option{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n", "i.input-icon{position:absolute;top:15px;right:7px;opacity:.4;font-size:10px}.option{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"] }]
|
|
114
114
|
}], propDecorators: { showRequiredTag: [{
|
|
115
115
|
type: Input
|
|
116
116
|
}], validate: [{
|
|
@@ -122,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
122
122
|
type: ViewChild,
|
|
123
123
|
args: [MatAutocomplete]
|
|
124
124
|
}] } });
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/autocomplete/autocomplete.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, computed, inject, signal } from '@angular/core';\nimport { AbstractControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport {\n  MatAutocomplete,\n  MatAutocompleteSelectedEvent,\n  MatAutocompleteModule,\n} from '@angular/material/autocomplete';\nimport { merge, ReplaySubject } from 'rxjs';\nimport { debounceTime, filter, startWith, switchMap, tap } from 'rxjs/operators';\nimport { InputBasicComponent, IOption } from '../input/input-basic.component';\nimport { AutocompleteService } from './autocomplete.service';\nimport { InputClassPipe } from '../input/inputs-pipes.pipe';\nimport { ToAnyPipe } from '../../pipes/utility.pipe';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatOption, MatOptionModule } from '@angular/material/core';\nimport { InputLabelComponent } from '../input/input-label/input-label.component';\nimport { NgIf, NgFor, NgClass, AsyncPipe, JsonPipe } from '@angular/common';\n\n@Component({\n  selector: 'app-autocomplete,autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['../input/input.component.scss', './autocomplete.component.scss'],\n  standalone: true,\n  imports: [\n    NgIf,\n    InputLabelComponent,\n    FormsModule,\n    JsonPipe,\n    ReactiveFormsModule,\n    MatAutocompleteModule,\n    NgFor,\n    MatOptionModule,\n    MatTooltipModule,\n    NgClass,\n    ValidationMessageComponent,\n    AsyncPipe,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    InputClassPipe,\n  ],\n})\nexport class AutocompleteComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n  TControl = any,\n  TOption = any,\n> extends InputBasicComponent<TFormGroup, TControl, TOption> {\n  readonly cOptions = computed(() => this.autoS.normalizeOptions(this.options()));\n  readonly filteredOptions = computed<IOption[]>(() => {\n    return this.autoS.filterOptions(this.valueSignal(), this.cOptions());\n  });\n\n  @Input() showRequiredTag: boolean = true;\n  @Input() validate = true;\n\n  @Input('options') override set _options(v: TOption[] | null) {\n    // debugger;\n    super._options = v;\n    if (this.autoCompleteRef && this.control()?.getRawValue())\n      this.control()?.setValue(this.control()?.getRawValue(), { emitEvent: false });\n  }\n\n  @ViewChild(MatAutocomplete) autoCompleteRef: MatAutocomplete;\n\n  protected valueChanged = new ReplaySubject<string>();\n\n  override loading: boolean;\n  public autoS = inject(AutocompleteService);\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n    this.addOnControlObtainedHook('includesOption', (control) => {\n      if (!control?.hasValidator(this.includesOption)) control?.addValidators(this.includesOption);\n      else debugger;\n    });\n\n    if (this.optionsFunc)\n      this.valueChanged\n        .pipe(\n          tap(() => (this.loading = true)),\n          debounceTime(600),\n          filter((v) => v != null && v != ''),\n          switchMap((v) => this.optionsFunc(v)),\n        )\n        .subscribe((r) => {\n          // debugger\n          this._options = r;\n          this.loading = false;\n        });\n  }\n\n  ngOnDestroy(): void {\n    // debugger;\n    if (this.control()?.hasValidator(this.includesOption))\n      this.control()?.removeValidators(this.includesOption);\n  }\n\n  fetchOptions($event: Event) {\n    if (this.optionsFunc) {\n      this.loading = true;\n      this.valueChanged.next(this.control()?.getRawValue());\n    }\n  }\n\n  selected($event: MatAutocompleteSelectedEvent) {\n    // debugger;\n    this.mSelectedOptionLabel.emit(this.displayWith(this.control()?.getRawValue()));\n    this.control().formattedValue = this.displayWith(this.control()?.getRawValue());\n    super.change({ target: { value: $event.option.value } });\n\n    // setTimeout(() => {\n    //   this.filteredOptions.set(this.options());\n    // }, 600);\n  }\n\n  displayWith = (val: any) =>\n    val instanceof MatOption\n      ? this.displayWith(val.value)\n      : this.doesOptionExist(val)?.label || val;\n\n  includesOption = (control: AbstractControl) => {\n    const val = control?.value;\n    // debugger;\n    if (!val) return null;\n    if (!this.options() || this.options().length === 0) return null;\n    // debugger\n    if (this.doesOptionExist(val)) return null;\n    else return this.autoS.invalidSelectionError;\n  };\n}\n","<div class=\"row align-items-center\">\n  <!-- {{options()|json}} -->\n  @if (verbose()) {\n    <div>disabledSignal: {{ disabledSignal() }}</div>\n    <div>validSignal: {{ validSignal() }}</div>\n    <div>invalidSignal: {{ invalidSignal() }}</div>\n    <div>valueSignal: {{ valueSignal()|json }}</div>\n    <div>hasValue: {{ hasValue() }}</div>\n    <div>dirtySignal: {{ dirtySignal() }}</div>\n    <div>touchedSignal: {{ touchedSignal() }}</div>\n    <div>errorsSignal: {{ errorsSignaljson() }}</div>\n    <div>pendingSignal: {{ pendingSignal() }}</div>\n    <div>pristineSignal: {{ pristineSignal() }}</div>\n    <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n    <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n    <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n  }\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"form()|toAny\"\n      [hint]=\"hint\"\n      [id]=\"idSignal()\"\n      [invalidCheckbox]=\"invalidCheckboxSignal()\"\n      [isRequired]=\"isRequiredSignal()\"\n      [label]=\"labelSignal()\"\n      [lblCl]=\"lblCl\"\n      [light]=\"light\"\n      [mini]=\"miniSignal()\"\n      [showRequiredTag]=\"showRequiredTagSignal()\"\n      [showLabel]=\"showLabelSignal()\"\n      [small]=\"smallSignal()\"\n      [stacked]=\"stackedSignal()\"\n      [theme]=\"theme\"\n      [xsmall]=\"xsmall\" />\n  }\n  <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n    <form [formGroup]=\"form()|toAny\" class=\"position-relative\">\n      <input\n        type=\"text\"\n        data-noformat=\"true\"\n        [formControlName]=\"nameStrSignal()\"\n        placeholder=\"{{ placeholder() }}\"\n        [id]=\"idSignal()\"\n        (keyup)=\"fetchOptions($event)\"\n        [class]=\"inputClassSignal()\"\n        [required]=\"requiredSignal()\"\n        [readonly]=\"readonlySignal()\"\n        #trigger=\"matAutocompleteTrigger\"\n        [matAutocomplete]=\"auto\"\n        #inp />\n      @if (!disabledSignal()) {\n        <i class=\"input-icon fa fa-search\" (click)=\"$event.stopPropagation(); trigger.openPanel()\"></i>\n      }\n      <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayWith\" class=\"options-w-auto\" (optionSelected)=\"selected($event)\">\n        <!-- <ng-container *ngIf=\"duplicateCheck; else elseNoDulicateTemplate\">\n          <mat-option\n            *ngFor=\"let item of filteredOptions|removeUsedOptionsReactive:(form.parent|toAny):(form.value):'value':name;trackBy:iS.trackByValue\"\n            [value]=\"item.value\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions | async }}\n            </div>\n          </mat-option>\n        </ng-container>\n        <ng-template #elseNoDulicateTemplate>\n          <mat-option\n            *ngFor=\"let item of filteredOptions;trackBy:iS.trackByValue\"\n            [value]=\"item.value\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions | async }}\n            </div>\n          </mat-option>\n        </ng-template> -->\n\n        @if (showEmptyOptionSignal()) {\n          <mat-option selected [value]=\"null\" class=\"empty-option\">\n            {{ optionsFunc ? 'Type to search' : placeholder() }}\n          </mat-option>\n        }\n        @for (item of filteredOptions(); track iS.trackByValue) {\n          <mat-option [value]=\"item.value\" (onSelectionChange)=\"selectedOption(item)\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipShowDelay]=\"1000\" [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\" #ele>\n              {{ item.label | appTranslate: translateOptions() | async }} \n            </div>\n          </mat-option>\n        }\n      </mat-autocomplete>\n      @if (dirtySignal() && showValidationSignal() && showValidationIconSignal()) {\n        <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\"><i class=\"fa fa-check\"></i></div>\n        <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n        <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\"><i class=\"fa fa-times\"></i></div>\n      }\n      @if (loading) {\n        <div class=\"d-flex text-primary me-1 validity-icon\"><i class=\"fa fa-spinner fa-spin\"></i></div>\n      }\n    </form>\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/autocomplete/autocomplete.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, computed, inject, signal } from '@angular/core';\nimport { AbstractControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport {\n  MatAutocomplete,\n  MatAutocompleteSelectedEvent,\n  MatAutocompleteModule,\n} from '@angular/material/autocomplete';\nimport { merge, ReplaySubject } from 'rxjs';\nimport { debounceTime, filter, startWith, switchMap, tap } from 'rxjs/operators';\nimport { InputBasicComponent, IOption } from '../input/input-basic.component';\nimport { AutocompleteService } from './autocomplete.service';\nimport { InputClassPipe } from '../input/inputs-pipes.pipe';\nimport { ToAnyPipe } from '../../pipes/utility.pipe';\nimport { SDKTranslatePipe } from '../../pipes/translate.pipe';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatOption, MatOptionModule } from '@angular/material/core';\nimport { InputLabelComponent } from '../input/input-label/input-label.component';\nimport { NgIf, NgFor, NgClass, AsyncPipe, JsonPipe } from '@angular/common';\n\n@Component({\n  selector: 'app-autocomplete,autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['../input/input.component.scss', './autocomplete.component.scss'],\n  standalone: true,\n  imports: [\n    NgIf,\n    InputLabelComponent,\n    FormsModule,\n    JsonPipe,\n    ReactiveFormsModule,\n    MatAutocompleteModule,\n    NgFor,\n    MatOptionModule,\n    MatTooltipModule,\n    NgClass,\n    ValidationMessageComponent,\n    AsyncPipe,\n    ToAnyPipe,\n    SDKTranslatePipe,\n    InputClassPipe,\n  ],\n})\nexport class AutocompleteComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n  TControl = any,\n  TOption = any,\n> extends InputBasicComponent<TFormGroup, TControl, TOption> {\n  readonly cOptions = computed(() => this.autoS.normalizeOptions(this.options()));\n  readonly filteredOptions = computed(() => {\n    return this.autoS.filterOptions(this.valueSignal(), this.cOptions());\n  });\n\n  @Input() showRequiredTag: boolean = true;\n  @Input() validate = true;\n\n  @Input('options') override set _options(v: TOption[] | null) {\n    // debugger;\n    super._options = v;\n    if (this.autoCompleteRef && this.control()?.getRawValue())\n      this.control()?.setValue(this.control()?.getRawValue(), { emitEvent: false });\n  }\n\n  @ViewChild(MatAutocomplete) autoCompleteRef: MatAutocomplete;\n\n  protected valueChanged = new ReplaySubject<string>();\n\n  override loading: boolean;\n  public autoS = inject(AutocompleteService);\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n    this.addOnControlObtainedHook('includesOption', (control) => {\n      if (!control?.hasValidator(this.includesOption)) control?.addValidators(this.includesOption);\n      else debugger;\n    });\n\n    if (this.optionsFunc)\n      this.valueChanged\n        .pipe(\n          tap(() => (this.loading = true)),\n          debounceTime(600),\n          filter((v) => v != null && v != ''),\n          switchMap((v) => this.optionsFunc(v)),\n        )\n        .subscribe((r) => {\n          // debugger\n          this._options = r;\n          this.loading = false;\n        });\n  }\n\n  ngOnDestroy(): void {\n    // debugger;\n    if (this.control()?.hasValidator(this.includesOption))\n      this.control()?.removeValidators(this.includesOption);\n  }\n\n  fetchOptions($event: Event) {\n    if (this.optionsFunc) {\n      this.loading = true;\n      this.valueChanged.next(this.control()?.getRawValue());\n    }\n  }\n\n  selected($event: MatAutocompleteSelectedEvent) {\n    // debugger;\n    this.mSelectedOptionLabel.emit(this.displayWith(this.control()?.getRawValue()));\n    this.control().formattedValue = this.displayWith(this.control()?.getRawValue());\n    super.change({ target: { value: $event.option.value } });\n\n    // setTimeout(() => {\n    //   this.filteredOptions.set(this.options());\n    // }, 600);\n  }\n\n  displayWith = (val: any) =>\n    val instanceof MatOption\n      ? this.displayWith(val.value)\n      : this.doesOptionExist(val)?.label || val;\n\n  includesOption = (control: AbstractControl) => {\n    const val = control?.value;\n    // debugger;\n    if (!val) return null;\n    if (!this.options() || this.options().length === 0) return null;\n    // debugger\n    if (this.doesOptionExist(val)) return null;\n    else return this.autoS.invalidSelectionError;\n  };\n}\n","<div class=\"row align-items-center\">\n  <!-- {{options()|json}} -->\n  @if (verbose()) {\n    <div>disabledSignal: {{ disabledSignal() }}</div>\n    <div>validSignal: {{ validSignal() }}</div>\n    <div>invalidSignal: {{ invalidSignal() }}</div>\n    <div>valueSignal: {{ valueSignal() | json }}</div>\n    <div>hasValue: {{ hasValue() }}</div>\n    <div>dirtySignal: {{ dirtySignal() }}</div>\n    <div>touchedSignal: {{ touchedSignal() }}</div>\n    <div>errorsSignal: {{ errorsSignaljson() }}</div>\n    <div>pendingSignal: {{ pendingSignal() }}</div>\n    <div>pristineSignal: {{ pristineSignal() }}</div>\n    <div>controlRequiredSignal: {{ controlRequiredSignal() }}</div>\n    <div>isRequiredSignal: {{ isRequiredSignal() }}</div>\n    <div class=\"\">onControlObtainedList Length: {{ onControlObtainedList().length }}</div>\n  }\n  @if (computedShowLabel()) {\n    <app-input-label\n      [colored]=\"coloredSignal()\"\n      [form]=\"form() | toAny\"\n      [hint]=\"hint\"\n      [id]=\"idSignal()\"\n      [invalidCheckbox]=\"invalidCheckboxSignal()\"\n      [isRequired]=\"isRequiredSignal()\"\n      [label]=\"labelSignal()\"\n      [lblCl]=\"lblCl\"\n      [light]=\"light\"\n      [mini]=\"miniSignal()\"\n      [showRequiredTag]=\"showRequiredTagSignal()\"\n      [showLabel]=\"showLabelSignal()\"\n      [small]=\"smallSignal()\"\n      [stacked]=\"stackedSignal()\"\n      [theme]=\"theme\"\n      [xsmall]=\"xsmall\" />\n  }\n  <div class=\"{{ stackedSignal() ? 'col-12' : 'col-md' }} position-relative\">\n    <form [formGroup]=\"form() | toAny\" class=\"position-relative\">\n      <input\n        type=\"text\"\n        data-noformat=\"true\"\n        [formControlName]=\"nameStrSignal()\"\n        placeholder=\"{{ placeholder() }}\"\n        [id]=\"idSignal()\"\n        (keyup)=\"fetchOptions($event)\"\n        [class]=\"inputClassSignal()\"\n        [required]=\"requiredSignal()\"\n        [readonly]=\"readonlySignal()\"\n        #trigger=\"matAutocompleteTrigger\"\n        [matAutocomplete]=\"auto\"\n        #inp />\n      @if (!disabledSignal()) {\n        <i\n          class=\"input-icon fa fa-search\"\n          (click)=\"$event.stopPropagation(); trigger.openPanel()\"></i>\n      }\n      <mat-autocomplete\n        #auto=\"matAutocomplete\"\n        [displayWith]=\"displayWith\"\n        class=\"options-w-auto\"\n        (optionSelected)=\"selected($event)\">\n        <!-- <ng-container *ngIf=\"duplicateCheck; else elseNoDulicateTemplate\">\n          <mat-option\n            *ngFor=\"let item of filteredOptions|removeUsedOptionsReactive:(form.parent|toAny):(form.value):'value':name;trackBy:iS.trackByValue\"\n            [value]=\"item.value\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions | async }}\n            </div>\n          </mat-option>\n        </ng-container>\n        <ng-template #elseNoDulicateTemplate>\n          <mat-option\n            *ngFor=\"let item of filteredOptions;trackBy:iS.trackByValue\"\n            [value]=\"item.value\">\n            <div class=\"option\" [matTooltip]=\"ele.innerText\" [matTooltipDisabled]=\"ele.scrollWidth<=ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions | async }}\n            </div>\n          </mat-option>\n        </ng-template> -->\n\n        @if (showEmptyOptionSignal()) {\n          <mat-option selected [value]=\"null\" class=\"empty-option\">\n            {{ optionsFunc ? 'Type to search' : placeholder() }}\n          </mat-option>\n        }\n        @for (item of filteredOptions(); track item._id) {\n          <mat-option [value]=\"item.value\" (onSelectionChange)=\"selectedOption(item)\">\n            <div\n              class=\"option\"\n              [matTooltip]=\"ele.innerText\"\n              [matTooltipShowDelay]=\"1000\"\n              [matTooltipDisabled]=\"ele.scrollWidth <= ele.offsetWidth\"\n              #ele>\n              {{ item.label | appTranslate: translateOptions() | async }}\n            </div>\n          </mat-option>\n        }\n      </mat-autocomplete>\n      @if (dirtySignal() && showValidationSignal() && showValidationIconSignal()) {\n        <div [ngClass]=\"{ valid: validSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-check\"></i>\n        </div>\n        <div [ngClass]=\"{ pending: pendingSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n        <div [ngClass]=\"{ invalid: invalidSignal() }\" class=\"validity-icon\">\n          <i class=\"fa fa-times\"></i>\n        </div>\n      }\n      @if (loading) {\n        <div class=\"d-flex text-primary me-1 validity-icon\">\n          <i class=\"fa fa-spinner fa-spin\"></i>\n        </div>\n      }\n    </form>\n  </div>\n</div>\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n"]}
|
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../../Services/utility.service";
|
|
3
4
|
export class AutocompleteService {
|
|
4
|
-
constructor() {
|
|
5
|
+
constructor(uS) {
|
|
6
|
+
this.uS = uS;
|
|
5
7
|
this.invalidSelectionError = { invalid: true };
|
|
6
8
|
this.normalizeOptions = (options) => options?.map((x) => ({
|
|
7
9
|
...x,
|
|
8
10
|
_normalizedLabel: this.normalizeValue(x.label),
|
|
11
|
+
// _id: this.uS.generateUUID(),
|
|
9
12
|
}));
|
|
10
13
|
this.displayWith = (options) => (val) => {
|
|
11
14
|
console.log('this.options', options);
|
|
@@ -29,7 +32,7 @@ export class AutocompleteService {
|
|
|
29
32
|
normalizeValue(value) {
|
|
30
33
|
return value?.toString()?.toLowerCase().replace(/\s/g, '');
|
|
31
34
|
}
|
|
32
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AutocompleteService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
35
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AutocompleteService, deps: [{ token: i1.UtilityService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
33
36
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AutocompleteService, providedIn: 'root' }); }
|
|
34
37
|
}
|
|
35
38
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: AutocompleteService, decorators: [{
|
|
@@ -37,5 +40,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
37
40
|
args: [{
|
|
38
41
|
providedIn: 'root',
|
|
39
42
|
}]
|
|
40
|
-
}], ctorParameters: () => [] });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
}], ctorParameters: () => [{ type: i1.UtilityService }] });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvU2hhcmVkL2NvbXBvbmVudHMvYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVEzQyxNQUFNLE9BQU8sbUJBQW1CO0lBRzlCLFlBQW1CLEVBQWtCO1FBQWxCLE9BQUUsR0FBRixFQUFFLENBQWdCO1FBRjVCLDBCQUFxQixHQUEwQixFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQztRQW1CMUUscUJBQWdCLEdBQUcsQ0FBQyxPQUFrQixFQUFFLEVBQUUsQ0FDeEMsT0FBTyxFQUFFLEdBQUcsQ0FBc0IsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDeEMsR0FBRyxDQUFDO1lBQ0osZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO1lBQzlDLCtCQUErQjtTQUNoQyxDQUFDLENBQUMsQ0FBQztRQUNOLGdCQUFXLEdBQUcsQ0FBQyxPQUFjLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDeEMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFDckMsT0FBTyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxJQUFJLEdBQUcsQ0FBQyxFQUFFLEtBQUssSUFBSSxHQUFHLENBQUM7UUFDNUQsQ0FBQyxDQUFDO0lBMUJzQyxDQUFDO0lBRXpDLGFBQWEsQ0FBeUMsS0FBYSxFQUFFLE9BQVk7UUFDL0UsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQyxJQUFJLFdBQVcsRUFBRSxDQUFDO1lBQ2hCLE1BQU0sR0FBRyxHQUFRLEVBQUUsRUFDakIsV0FBVyxHQUFRLEVBQUUsQ0FBQztZQUN4QixLQUFLLE1BQU0sTUFBTSxJQUFJLE9BQU87Z0JBQzFCLElBQUksTUFBTSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUM7b0JBQUUsR0FBRyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztxQkFDakUsSUFBSSxNQUFNLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQztvQkFBRSxXQUFXLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ25GLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNqQyxDQUFDOztZQUFNLE9BQU8sT0FBTyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBYTtRQUMxQixPQUFPLEtBQUssRUFBRSxRQUFRLEVBQUUsRUFBRSxXQUFXLEVBQUUsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzdELENBQUM7OEdBbkJVLG1CQUFtQjtrSEFBbkIsbUJBQW1CLGNBRmxCLE1BQU07OzJGQUVQLG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJT3B0aW9uIH0gZnJvbSAnLi4vaW5wdXQvaW5wdXQuc2VydmljZSc7XG5pbXBvcnQgeyBDdXN0b21WYWxpZGF0aW9uRXJyb3IgfSBmcm9tICcuLi8uLi9tb2RlbHMvaW5kZXgubW9kZWwnO1xuaW1wb3J0IHsgVXRpbGl0eVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9TZXJ2aWNlcy91dGlsaXR5LnNlcnZpY2UnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgQXV0b2NvbXBsZXRlU2VydmljZSB7XG4gIHJlYWRvbmx5IGludmFsaWRTZWxlY3Rpb25FcnJvcjogQ3VzdG9tVmFsaWRhdGlvbkVycm9yID0geyBpbnZhbGlkOiB0cnVlIH07XG5cbiAgY29uc3RydWN0b3IocHVibGljIHVTOiBVdGlsaXR5U2VydmljZSkge31cblxuICBmaWx0ZXJPcHRpb25zPFQgZXh0ZW5kcyB7IF9ub3JtYWxpemVkTGFiZWw6IHN0cmluZyB9PihxdWVyeTogc3RyaW5nLCBvcHRpb25zOiBUW10pOiBUW10ge1xuICAgIGNvbnN0IGZpbHRlclZhbHVlID0gdGhpcy5ub3JtYWxpemVWYWx1ZShxdWVyeSk7XG4gICAgaWYgKGZpbHRlclZhbHVlKSB7XG4gICAgICBjb25zdCByZXM6IFRbXSA9IFtdLFxuICAgICAgICByZXNJbmNsdWRlczogVFtdID0gW107XG4gICAgICBmb3IgKGNvbnN0IG9wdGlvbiBvZiBvcHRpb25zKVxuICAgICAgICBpZiAob3B0aW9uLl9ub3JtYWxpemVkTGFiZWwuc3RhcnRzV2l0aChmaWx0ZXJWYWx1ZSkpIHJlcy5wdXNoKG9wdGlvbik7XG4gICAgICAgIGVsc2UgaWYgKG9wdGlvbi5fbm9ybWFsaXplZExhYmVsLmluY2x1ZGVzKGZpbHRlclZhbHVlKSkgcmVzSW5jbHVkZXMucHVzaChvcHRpb24pO1xuICAgICAgcmV0dXJuIHJlcy5jb25jYXQocmVzSW5jbHVkZXMpO1xuICAgIH0gZWxzZSByZXR1cm4gb3B0aW9ucztcbiAgfVxuXG4gIG5vcm1hbGl6ZVZhbHVlKHZhbHVlOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiB2YWx1ZT8udG9TdHJpbmcoKT8udG9Mb3dlckNhc2UoKS5yZXBsYWNlKC9cXHMvZywgJycpO1xuICB9XG4gIG5vcm1hbGl6ZU9wdGlvbnMgPSAob3B0aW9uczogSU9wdGlvbltdKSA9PlxuICAgIG9wdGlvbnM/Lm1hcDxJQXV0b0NvbXBsZXRlT3B0aW9uPigoeCkgPT4gKHtcbiAgICAgIC4uLngsXG4gICAgICBfbm9ybWFsaXplZExhYmVsOiB0aGlzLm5vcm1hbGl6ZVZhbHVlKHgubGFiZWwpLFxuICAgICAgLy8gX2lkOiB0aGlzLnVTLmdlbmVyYXRlVVVJRCgpLFxuICAgIH0pKTtcbiAgZGlzcGxheVdpdGggPSAob3B0aW9uczogYW55W10pID0+ICh2YWwpID0+IHtcbiAgICBjb25zb2xlLmxvZygndGhpcy5vcHRpb25zJywgb3B0aW9ucyk7XG4gICAgcmV0dXJuIG9wdGlvbnM/LmZpbmQoKHgpID0+IHgudmFsdWUgPT0gdmFsKT8ubGFiZWwgfHwgdmFsO1xuICB9O1xufVxuZXhwb3J0IGludGVyZmFjZSBJQXV0b0NvbXBsZXRlT3B0aW9uIGV4dGVuZHMgSU9wdGlvbiB7XG4gIF9ub3JtYWxpemVkTGFiZWw6IHN0cmluZztcbn1cbiJdfQ==
|