ngx-sp-infra 2.0.21 → 2.1.1

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.
@@ -42,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
42
42
  }], maximo: [{
43
43
  type: Input
44
44
  }] } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtY29udGFkb3ItbWVzc2FnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3AtaW5mcmEvc3JjL2xpYi93aWRnZXRzL2ZpZWxkLWNvbnRhZG9yLW1lc3NhZ2UvZmllbGQtY29udGFkb3ItbWVzc2FnZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3AtaW5mcmEvc3JjL2xpYi93aWRnZXRzL2ZpZWxkLWNvbnRhZG9yLW1lc3NhZ2UvZmllbGQtY29udGFkb3ItbWVzc2FnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFVekQsTUFBTSxPQUFPLDZCQUE2QjtJQU4xQztRQVFXLFlBQU8sR0FBMkIsSUFBSSxDQUFDO1FBRWhELFNBQUksR0FBVyxDQUFDLENBQUM7UUFDakIsYUFBUSxHQUFXLEVBQUUsQ0FBQztRQUN0QixxQkFBZ0IsR0FBWSxLQUFLLENBQUM7S0E0Qm5DO0lBekJDLFFBQVE7UUFDTixJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQzFDLElBQUksQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3JDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN2QixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7SUFDSCxDQUFDO0lBRUQsYUFBYTtRQUNYLElBQUksSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDNUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxtQ0FBbUMsSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUM7WUFDL0UsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQztZQUM3QixJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDakIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsRUFBRSxpQkFBaUIsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1lBQ3RELENBQUM7UUFDSCxDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxRQUFRLEdBQUcseUJBQXlCLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ3BFLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxLQUFLLENBQUM7WUFDOUIsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7Z0JBQ2pCLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQy9CLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQzsrR0FoQ1UsNkJBQTZCO21HQUE3Qiw2QkFBNkIsb0hDVjFDLGlKQU1BOzs0RkRJYSw2QkFBNkI7a0JBTnpDLFNBQVM7K0JBQ0UsNEJBQTRCLGNBQzFCLEtBQUs7OEJBTVIsT0FBTztzQkFBZixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2xpYi1maWVsZC1jb250YWRvci1tZXNzYWdlJyxcbiAgc3RhbmRhbG9uZTogZmFsc2UsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWVsZC1jb250YWRvci1tZXNzYWdlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmllbGQtY29udGFkb3ItbWVzc2FnZS5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgRmllbGRDb250YWRvck1lc3NhZ2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIEBJbnB1dCgpIGNvbnRyb2w6IEFic3RyYWN0Q29udHJvbCB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKSBtYXhpbW8hOiBudW1iZXI7XG4gIGNvbnQ6IG51bWJlciA9IDA7XG4gIG1lbnNhZ2VtOiBzdHJpbmcgPSAnJztcbiAgbWVuc2FnZW1FeGNlZGlkYTogYm9vbGVhbiA9IGZhbHNlO1xuXG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuY29udHJvbCkge1xuICAgICAgdGhpcy5jb250cm9sLnZhbHVlQ2hhbmdlcy5zdWJzY3JpYmUodmFsdWUgPT4ge1xuICAgICAgICB0aGlzLmNvbnQgPSB2YWx1ZSA/IHZhbHVlLmxlbmd0aCA6IDA7XG4gICAgICAgIHRoaXMudXBkYXRlTWVzc2FnZSgpO1xuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgdXBkYXRlTWVzc2FnZSgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5jb250ID4gdGhpcy5tYXhpbW8pIHtcbiAgICAgIHRoaXMubWVuc2FnZW0gPSBgTGltaXRlIGRlIGNhcmFjdGVyZXMgZXhjZWRpZG8uICgke3RoaXMuY29udH0vJHt0aGlzLm1heGltb30pYDtcbiAgICAgIHRoaXMubWVuc2FnZW1FeGNlZGlkYSA9IHRydWU7XG4gICAgICBpZiAodGhpcy5jb250cm9sKSB7XG4gICAgICAgIHRoaXMuY29udHJvbC5zZXRFcnJvcnMoeyBtYXhMZW5ndGhFeGNlZWRlZDogdHJ1ZSB9KTtcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5tZW5zYWdlbSA9IGBMaW1pdGUgZGUgY2FyYWN0ZXJlczogJHt0aGlzLmNvbnR9LyR7dGhpcy5tYXhpbW99YDtcbiAgICAgIHRoaXMubWVuc2FnZW1FeGNlZGlkYSA9IGZhbHNlO1xuICAgICAgaWYgKHRoaXMuY29udHJvbCkge1xuICAgICAgICB0aGlzLmNvbnRyb2wuc2V0RXJyb3JzKG51bGwpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG59XG4iLCI8ZGl2XG4gIFtjbGFzcy50ZXh0LWRhbmdlcl09XCJtZW5zYWdlbUV4Y2VkaWRhXCJcbiAgW2NsYXNzLnRleHQtbXV0ZWRdPVwiIW1lbnNhZ2VtRXhjZWRpZGFcIlxuICBjbGFzcz1cInRleHQtZW5kXCI+XG4gIHt7IG1lbnNhZ2VtIH19XG48L2Rpdj5cbiJdfQ==
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtY29udGFkb3ItbWVzc2FnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3AtaW5mcmEvc3JjL2xpYi93aWRnZXRzL2ZpZWxkLWNvbnRhZG9yLW1lc3NhZ2UvZmllbGQtY29udGFkb3ItbWVzc2FnZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3AtaW5mcmEvc3JjL2xpYi93aWRnZXRzL2ZpZWxkLWNvbnRhZG9yLW1lc3NhZ2UvZmllbGQtY29udGFkb3ItbWVzc2FnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFTekQsTUFBTSxPQUFPLDZCQUE2QjtJQU4xQztRQVFXLFlBQU8sR0FBMkIsSUFBSSxDQUFDO1FBRWhELFNBQUksR0FBVyxDQUFDLENBQUM7UUFDakIsYUFBUSxHQUFXLEVBQUUsQ0FBQztRQUN0QixxQkFBZ0IsR0FBWSxLQUFLLENBQUM7S0E0Qm5DO0lBekJDLFFBQVE7UUFDTixJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQzFDLElBQUksQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3JDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN2QixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7SUFDSCxDQUFDO0lBRUQsYUFBYTtRQUNYLElBQUksSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDNUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxtQ0FBbUMsSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUM7WUFDL0UsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQztZQUM3QixJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDakIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsRUFBRSxpQkFBaUIsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1lBQ3RELENBQUM7UUFDSCxDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxRQUFRLEdBQUcseUJBQXlCLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ3BFLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxLQUFLLENBQUM7WUFDOUIsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7Z0JBQ2pCLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQy9CLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQzsrR0FoQ1UsNkJBQTZCO21HQUE3Qiw2QkFBNkIsb0hDVDFDLGlKQU1BOzs0RkRHYSw2QkFBNkI7a0JBTnpDLFNBQVM7K0JBQ0UsNEJBQTRCLGNBQzFCLEtBQUs7OEJBTVIsT0FBTztzQkFBZixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsaWItZmllbGQtY29udGFkb3ItbWVzc2FnZScsXG4gIHN0YW5kYWxvbmU6IGZhbHNlLFxuICB0ZW1wbGF0ZVVybDogJy4vZmllbGQtY29udGFkb3ItbWVzc2FnZS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2ZpZWxkLWNvbnRhZG9yLW1lc3NhZ2UuY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIEZpZWxkQ29udGFkb3JNZXNzYWdlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBASW5wdXQoKSBjb250cm9sOiBBYnN0cmFjdENvbnRyb2wgfCBudWxsID0gbnVsbDtcbiAgQElucHV0KCkgbWF4aW1vITogbnVtYmVyO1xuICBjb250OiBudW1iZXIgPSAwO1xuICBtZW5zYWdlbTogc3RyaW5nID0gJyc7XG4gIG1lbnNhZ2VtRXhjZWRpZGE6IGJvb2xlYW4gPSBmYWxzZTtcblxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmNvbnRyb2wpIHtcbiAgICAgIHRoaXMuY29udHJvbC52YWx1ZUNoYW5nZXMuc3Vic2NyaWJlKHZhbHVlID0+IHtcbiAgICAgICAgdGhpcy5jb250ID0gdmFsdWUgPyB2YWx1ZS5sZW5ndGggOiAwO1xuICAgICAgICB0aGlzLnVwZGF0ZU1lc3NhZ2UoKTtcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIHVwZGF0ZU1lc3NhZ2UoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuY29udCA+IHRoaXMubWF4aW1vKSB7XG4gICAgICB0aGlzLm1lbnNhZ2VtID0gYExpbWl0ZSBkZSBjYXJhY3RlcmVzIGV4Y2VkaWRvLiAoJHt0aGlzLmNvbnR9LyR7dGhpcy5tYXhpbW99KWA7XG4gICAgICB0aGlzLm1lbnNhZ2VtRXhjZWRpZGEgPSB0cnVlO1xuICAgICAgaWYgKHRoaXMuY29udHJvbCkge1xuICAgICAgICB0aGlzLmNvbnRyb2wuc2V0RXJyb3JzKHsgbWF4TGVuZ3RoRXhjZWVkZWQ6IHRydWUgfSk7XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMubWVuc2FnZW0gPSBgTGltaXRlIGRlIGNhcmFjdGVyZXM6ICR7dGhpcy5jb250fS8ke3RoaXMubWF4aW1vfWA7XG4gICAgICB0aGlzLm1lbnNhZ2VtRXhjZWRpZGEgPSBmYWxzZTtcbiAgICAgIGlmICh0aGlzLmNvbnRyb2wpIHtcbiAgICAgICAgdGhpcy5jb250cm9sLnNldEVycm9ycyhudWxsKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxufVxuIiwiPGRpdlxuICBbY2xhc3MudGV4dC1kYW5nZXJdPVwibWVuc2FnZW1FeGNlZGlkYVwiXG4gIFtjbGFzcy50ZXh0LW11dGVkXT1cIiFtZW5zYWdlbUV4Y2VkaWRhXCJcbiAgY2xhc3M9XCJ0ZXh0LWVuZFwiPlxuICB7eyBtZW5zYWdlbSB9fVxuPC9kaXY+XG4iXX0=
@@ -0,0 +1,34 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import { FormControl } from '@angular/forms';
3
+ import { debounceTime, distinctUntilChanged } from 'rxjs';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "@angular/forms";
7
+ export class InputTrimComponent {
8
+ constructor() {
9
+ this.formControl = new FormControl();
10
+ this.placeholder = '';
11
+ this.uppercase = false;
12
+ }
13
+ ngOnInit() {
14
+ if (this.formControl) {
15
+ this.formControl.valueChanges.pipe(debounceTime(2000), distinctUntilChanged()).subscribe(value => {
16
+ this.formControl?.setValue(value.trim(), { emitEvent: false });
17
+ });
18
+ }
19
+ }
20
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTrimComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
21
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: InputTrimComponent, selector: "lib-input-trim", inputs: { formControl: ["control", "formControl"], placeholder: "placeholder", uppercase: "uppercase" }, ngImport: i0, template: "<input\r\n type=\"text\"\r\n [formControl]=\"formControl\"\r\n [placeholder]=\"placeholder\"\r\n class=\"form-control\"\r\n [class.is-invalid]=\"formControl.invalid && formControl.touched\"\r\n [ngClass]=\"{'text-uppercase': uppercase}\"\r\n>\r\n", styles: [".text-uppercase{text-transform:uppercase}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] }); }
22
+ }
23
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputTrimComponent, decorators: [{
24
+ type: Component,
25
+ args: [{ selector: 'lib-input-trim', standalone: false, template: "<input\r\n type=\"text\"\r\n [formControl]=\"formControl\"\r\n [placeholder]=\"placeholder\"\r\n class=\"form-control\"\r\n [class.is-invalid]=\"formControl.invalid && formControl.touched\"\r\n [ngClass]=\"{'text-uppercase': uppercase}\"\r\n>\r\n", styles: [".text-uppercase{text-transform:uppercase}\n"] }]
26
+ }], propDecorators: { formControl: [{
27
+ type: Input,
28
+ args: ['control']
29
+ }], placeholder: [{
30
+ type: Input
31
+ }], uppercase: [{
32
+ type: Input
33
+ }] } });
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdHJpbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3AtaW5mcmEvc3JjL2xpYi93aWRnZXRzL2lucHV0LXRyaW0vaW5wdXQtdHJpbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3AtaW5mcmEvc3JjL2xpYi93aWRnZXRzL2lucHV0LXRyaW0vaW5wdXQtdHJpbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQW1CLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7QUFRMUQsTUFBTSxPQUFPLGtCQUFrQjtJQU4vQjtRQVFvQixnQkFBVyxHQUFnQixJQUFJLFdBQVcsRUFBRSxDQUFDO1FBQ3RELGdCQUFXLEdBQVcsRUFBRSxDQUFDO1FBQ3pCLGNBQVMsR0FBWSxLQUFLLENBQUM7S0FZckM7SUFWQyxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDckIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUNoQyxZQUFZLENBQUMsSUFBSSxDQUFDLEVBQ2xCLG9CQUFvQixFQUFFLENBQ3ZCLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUNsQixJQUFJLENBQUMsV0FBVyxFQUFFLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUNqRSxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7SUFDSCxDQUFDOytHQWZVLGtCQUFrQjttR0FBbEIsa0JBQWtCLCtKQ1YvQiw4UEFRQTs7NEZERWEsa0JBQWtCO2tCQU45QixTQUFTOytCQUNFLGdCQUFnQixjQUNkLEtBQUs7OEJBTUMsV0FBVztzQkFBNUIsS0FBSzt1QkFBQyxTQUFTO2dCQUNQLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wsIEZvcm1Db250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBkZWJvdW5jZVRpbWUsIGRpc3RpbmN0VW50aWxDaGFuZ2VkIH0gZnJvbSAncnhqcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi1pbnB1dC10cmltJyxcclxuICBzdGFuZGFsb25lOiBmYWxzZSxcclxuICB0ZW1wbGF0ZVVybDogJy4vaW5wdXQtdHJpbS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vaW5wdXQtdHJpbS5jb21wb25lbnQuY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIElucHV0VHJpbUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIEBJbnB1dCgnY29udHJvbCcpIGZvcm1Db250cm9sOiBGb3JtQ29udHJvbCA9IG5ldyBGb3JtQ29udHJvbCgpO1xyXG4gIEBJbnB1dCgpIHBsYWNlaG9sZGVyOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKSB1cHBlcmNhc2U6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICBpZiAodGhpcy5mb3JtQ29udHJvbCkge1xyXG4gICAgICB0aGlzLmZvcm1Db250cm9sLnZhbHVlQ2hhbmdlcy5waXBlKFxyXG4gICAgICAgIGRlYm91bmNlVGltZSgyMDAwKSxcclxuICAgICAgICBkaXN0aW5jdFVudGlsQ2hhbmdlZCgpXHJcbiAgICAgICkuc3Vic2NyaWJlKHZhbHVlID0+IHtcclxuICAgICAgICB0aGlzLmZvcm1Db250cm9sPy5zZXRWYWx1ZSh2YWx1ZS50cmltKCksIHsgZW1pdEV2ZW50OiBmYWxzZSB9KTtcclxuICAgICAgfSk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjxpbnB1dFxyXG4gIHR5cGU9XCJ0ZXh0XCJcclxuICBbZm9ybUNvbnRyb2xdPVwiZm9ybUNvbnRyb2xcIlxyXG4gIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXHJcbiAgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIlxyXG4gIFtjbGFzcy5pcy1pbnZhbGlkXT1cImZvcm1Db250cm9sLmludmFsaWQgJiYgZm9ybUNvbnRyb2wudG91Y2hlZFwiXHJcbiAgW25nQ2xhc3NdPVwieyd0ZXh0LXVwcGVyY2FzZSc6IHVwcGVyY2FzZX1cIlxyXG4+XHJcbiJdfQ==
@@ -256,4 +256,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
256
256
  type: HostListener,
257
257
  args: ['window:resize', ['$event']]
258
258
  }] } });
259
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-combobox.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { AbstractControl, FormControl, FormControlStatus, Validators } from '@angular/forms';\n\nimport { Subscription } from 'rxjs';\n\nimport { RecordCombobox } from '../../models/combobox/record-combobox';\n\n/**\n * @component LibComboboxComponent\n * @selector lib-combobox\n * \n * @description\n * O componente LibComboboxComponent é projetado para fornecer aos usuários uma interface para pesquisar e selecionar itens de uma lista.\n * Ele suporta a filtragem de itens com base na entrada do usuário, permitindo uma seleção mais fácil em listas extensas.\n * \n * ## Funcionalidades:\n * - Pesquisa e filtragem de itens na lista do combobox.\n * - Seleção de itens com feedback visual.\n * - Emissão de eventos personalizados para interações do usuário, como recarregar a lista ou selecionar um item.\n * - Ajuste dinâmico da largura do dropdown para corresponder ao input principal.\n * - Inicialização de um valor selecionado, se fornecido.\n * \n * ## Inputs:\n * - `outerControl` (FormControl | AbstractControl): Control para seleção dos valores, atualizará automaticamente o control do componente pai também\n * - `comboboxList` (RecordCombobox[]): Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\n * - `labelText` (string): Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\n * - `disabled` (boolean): Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\n * - `libRequired` (boolean): Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\n * - `mainInputPlaceholder` (string): Placeholder do campo principal do combo\n * - `searchInputPlaceholder` (string): Placeholder do campo de pesquisa dentro do combo\n * - `colorTheme` (\"primary\" | \"secondary\" | \"success\" | \"danger\" | \"warning\" | \"info\" | \"light\" | \"dark\"): Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\n * - `returnRecord` (boolean): Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID\n * \n * ## Outputs:\n * - `onReloadList` (EventEmitter<string>): Evento emitido quando a lista precisa ser recarregada.\n */\n@Component({\n  selector: 'lib-combobox',\n  templateUrl: './lib-combobox.component.html',\n  styleUrl: './lib-combobox.component.scss'\n})\nexport class LibComboboxComponent implements OnInit, AfterViewInit, OnDestroy {\n\n  // #region ==========> PROPERTIES <==========\n\n  // #region PROTECTED\n  protected textoPesquisa: string = \"\";\n\n  protected get ariaExpanded(): boolean { return this._ariaExpanded; }\n  protected set ariaExpanded(value: boolean) {\n    this._ariaExpanded = value;\n    this.adjustDropdownWidth();\n  }\n\n  protected innerControl: FormControl = new FormControl<string | number | null>(null);\n  protected invalidControl: boolean = false;\n  protected isRequired: boolean = false;\n\n  protected invalid: boolean = false;\n  protected dirty: boolean = false;\n  protected touched: boolean = false;\n  // #endregion PROTECTED\n\n  // #region PRIVATE\n  private _disabled?: boolean = false;\n  private _ariaExpanded: boolean = false;\n  private _subscription: Subscription = new Subscription();\n\n  private _outerControl: FormControl = new FormControl<string | number | null>(null);\n  // #endregion PRIVATE\n\n  // #region PUBLIC\n\n  /** (obrigatório) Control para seleção dos valores, atualizará automaticamente o control do componente pai também\n   * @alias 'control'\n   * @type {FormControl<any> | AbstractControl<any>} */\n  @Input({ alias: 'control', required: true })\n  public get outerControl(): FormControl<any> { return this._outerControl }\n  public set outerControl(value: FormControl<any> | AbstractControl<any>) {\n    this._outerControl = value as FormControl;\n\n    // Cancela a subscrição anterior (se houver) para evitar múltiplas subscrições\n    if (this._subscription) this._subscription.unsubscribe();\n\n    // Subscrição ao observável valueChanges para reagir a mudanças no valor\n    this._subscription = this._outerControl.valueChanges.subscribe(value => { this.updateSelectedValue(value) });\n    this._subscription = this._outerControl.statusChanges.subscribe(status => { this.setControlStatus(status) });\n  }\n\n  /** (obrigatório) Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\n   * @alias 'list'\n   * @type {RecordCombobox[]} */\n  @Input({ alias: 'list', required: true }) public comboboxList?: RecordCombobox[];\n\n  /** (opcional) Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\n   * @type {string} */\n  @Input() public labelText?: string;\n\n  /** (opcional) Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\n   * ! SERÁ DEPRECIADO EM BREVE\n   * @type {boolean}\n   * @default false */\n  @Input() public libRequired?: boolean = false;\n\n  /** (opcional) Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\n   * @type {boolean}\n   * @default false */\n  @Input()\n  public get disabled(): boolean { return this._disabled ?? false; }\n  public set disabled(value: boolean | undefined) {\n    if (value && value === true) this.innerControl.disable();\n    else this.innerControl.enable();\n\n    //this.setControlStatus();\n  }\n\n  /** (opcional) Placeholder do campo principal do combo\n   * @alias 'mainPlaceholder'\n   * @type {string}\n   * @default \"Selecione uma opção...\" */\n  @Input('mainPlaceholder') public mainInputPlaceholder?: string = \"Selecione uma opção...\";\n\n  /** (opcional) Placeholder do campo de pesquisa dentro do combo\n   * @alias 'searchPlaceholder'\n   * @type {string}\n   * @default \"Pesquisa...\" */\n  @Input('searchPlaceholder') public searchInputPlaceholder?: string = \"Pesquisa...\";\n\n  /** (opcional) Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\n   * @alias 'theme'\n   * @type {string}\n   * @default \"primary\"\n  */\n  @Input('theme') public colorTheme?: string = \"primary\";\n\n  /** (opcional) Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID.\n   * @type {boolean}\n   * @default false\n  */\n  @Input() public returnRecord?: boolean = false;\n\n  /** Evento emitido ao recarregar a lista de registros\n   * @example Ao ser emitido, o componente pai pode refazer o GET da lista, por exemplo.\n   * @emits EventEmitter<string> que leva o valor string da pesquisa feita para ser enviada para o GET\n   * @type {EventEmitter<string>} */\n  @Output() public onReloadList: EventEmitter<string> = new EventEmitter<string>();\n\n\n  /** Evento emitido ao selecionar um registro da lista do combobox\n   * @example Ao ser emitido, o componente pai pode realizar uma validação com o valor selecionado.\n   * @emits EventEmitter<string|number|null> que leva o valor string da pesquisa feita para ser enviada para o GET\n   * @type {EventEmitter<string | number | null>} */\n  @Output() public onChange: EventEmitter<RecordCombobox | string | number | null> = new EventEmitter<RecordCombobox | string | number | null>();\n  \n\n  @ViewChild('mainInput') private _mainInput!: ElementRef;\n  @ViewChild('dropdownMenu') private _dropdownMenu!: ElementRef;\n  // #endregion PUBLIC\n\n  // #endregion ==========> PROPERTIES <==========\n\n\n  // #region ==========> INITIALIZATION <==========\n  constructor() { }\n\n  ngOnInit(): void {\n    this.adjustDropdownWidth();\n\n    this.setValidator();\n    this.updateSelectedValue();\n  }\n\n  ngAfterViewInit(): void {\n    this.adjustDropdownWidth();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes[\"comboboxList\"]?.currentValue) this.updateSelectedValue();\n    if (changes[\"outerControl\"]?.currentValue) this.updateSelectedValue((changes[\"outerControl\"].currentValue as FormControl).value);\n  }\n\n  ngOnDestroy(): void {\n    this._subscription.unsubscribe();\n  }\n\n  // O que fazer quando o evento de redimensionamento ocorrer\n  @HostListener('window:resize', ['$event'])\n  onResize(event: Event): void { this.adjustDropdownWidth() }\n  // #endregion ==========> INITIALIZATION <==========\n\n\n  // #region ==========> UTILS <==========\n  public setValue(item: RecordCombobox): void {\n    this.textoPesquisa = \"\";\n    this.innerControl.markAsDirty();\n    this._outerControl.markAsDirty();\n    \n    this._outerControl.setValue(item.ID);\n    this.innerControl.setValue(item.LABEL);\n\n    this.ariaExpanded = false;\n    this.setControlStatus(this.innerControl.status);\n    \n    this.onChange.emit(this.returnRecord ? item as RecordCombobox : item.ID);\n  }\n\n  public clearValue(): void {\n    this.textoPesquisa = \"\";\n    this.innerControl.markAsDirty();\n    this._outerControl.markAsDirty();\n\n    this._outerControl.setValue(null);\n    this.innerControl.setValue(null);\n\n    this.ariaExpanded = false;\n    this.setControlStatus(this.innerControl.status);\n\n    this.onChange.emit(null);\n  }\n\n  private updateSelectedValue(value?: string | number | null): void {\n    this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa\n    const selectedValue: string | number | null = value ?? this._outerControl.value;\n\n    if (!this.comboboxList || (selectedValue === null && selectedValue === '')) return;\n\n    const initializedValue = this.comboboxList.find(item => item.ID === selectedValue)\n    if (initializedValue) this.innerControl.setValue(initializedValue.LABEL);\n\n    // this.setControlStatus(this._outerControl.status);\n  }\n\n  private adjustDropdownWidth(): void {\n    if (this._mainInput && this._dropdownMenu) {\n      const inputWidth = this._mainInput.nativeElement.offsetWidth;\n      this._dropdownMenu.nativeElement.style.width = `${inputWidth}px`;\n    }\n  }\n\n  private setValidator(): void {\n    if (this._outerControl.hasValidator(Validators.required)) {\n      this.innerControl.addValidators(Validators.required);\n      this.isRequired = true;\n    }\n    else {\n      this.innerControl.removeValidators(Validators.required);\n      this.isRequired = false;\n    }\n  }\n\n  private setControlStatus(formStatus: FormControlStatus): void {\n    switch(formStatus) {\n      case 'VALID':\n        this.invalidControl = false;\n        this.innerControl.enable();\n        break;\n\n      case 'INVALID':\n        this.invalidControl = true;\n        this.innerControl.enable();\n        break;\n\n      case 'PENDING':\n        this.invalidControl = false;\n        this.innerControl.enable();\n        break;\n\n      case 'DISABLED':\n        this.invalidControl = false;\n        this.innerControl.disable();\n        break;\n\n    }\n  }\n\n  public reloadList(): void { this.onReloadList.emit(this.textoPesquisa) }\n  // #endregion ==========> UTILS <==========\n\n}\n","<label *ngIf=\"labelText && labelText != ''\" [libRequired]=\"isRequired\" class=\"form-label fw-bold\">{{ labelText }}</label>\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\n\n   <!-- Este elemento ng-content com o atributo [btnLeft] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\n   Ao usar o atributo [btnLeft], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\n   <ng-content select=\"[btnLeft]\"></ng-content>\n\n   <input  #mainInput class=\"form-select text-start rounded-end\" type=\"text\" data-bs-toggle=\"dropdown\" [placeholder]=\"mainInputPlaceholder\"\n            [formControl]=\"innerControl\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly [class.is-invalid]=\"invalidControl\"\n            (click)=\"ariaExpanded = !ariaExpanded; searchInput.focus()\" (focus)=\"searchInput.focus()\">\n\n   <ul  #dropdownMenu  class=\"dropdown-menu p-2 glb-max-height-350px overflow-y-scroll z-index-1020\" [class.show]=\"ariaExpanded\">\n      <div class=\"input-group mb-2\">\n         <input #searchInput (input)=\"textoPesquisa = searchInput.value\" type=\"text\" id=\"searchInput\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchInputPlaceholder\" (keyup.enter)=\"reloadList()\">\n         <button class=\"btn btn-{{colorTheme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\n      </div>\n\n      @if (comboboxList) {\n         <li *ngIf=\"innerControl.value != '' && innerControl.value != null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar opção selecionada</span> </li>\n         @for (item of comboboxList | textFilter:textoPesquisa; track $index) {\n            <li class=\"dropdown-item\" (click)=\"setValue(item)\">\n               <span *ngIf=\"item.AdditionalStringProperty1 || item.AdditionalStringProperty1 != ''\" class=\"glb-fs-12 fw-bold d-inline-block w-125\">{{ item.AdditionalStringProperty1 }}</span> {{ item.LABEL }}\n            </li>\n         }\n         @empty { <li class=\"dropdown-item fst-italic\">Nenhum registro encontrado com esta pesquisa...</li> }\n      }\n      @else { <li class=\"dropdown-item text-center\"> <div class=\"spinner-border\" role=\"status\"><span class=\"visually-hidden\">Carregando dados...</span></div> </li> }\n   </ul>\n\n   <!-- Este elemento ng-content com o atributo [btnRight] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado direito do combobox de pesquisa.\n   Ao usar o atributo [btnRight], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\n   <ng-content select=\"[btnRight]\"></ng-content>\n\n</div>\n\n<!-- #region MENSAGEM DE ERRO DE VALIDAÇÃO -->\n<app-field-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo é obrigatório.\" />\n<!-- #endregion MENSAGEM DE ERRO DE VALIDAÇÃO -->\n"]}
259
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-combobox.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAc,YAAY,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAiB,SAAS,EAAE,MAAM,eAAe,CAAC;AAC7J,OAAO,EAAmB,WAAW,EAAqB,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE7F,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;;;;;;;;AAIpC;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AAMH,MAAM,OAAO,oBAAoB;IAO/B,IAAc,YAAY,KAAc,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;IACpE,IAAc,YAAY,CAAC,KAAc;QACvC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAiBD,qBAAqB;IAErB,iBAAiB;IAEjB;;yDAEqD;IACrD,IACW,YAAY,KAAuB,OAAO,IAAI,CAAC,aAAa,CAAA,CAAC,CAAC;IACzE,IAAW,YAAY,CAAC,KAA8C;QACpE,IAAI,CAAC,aAAa,GAAG,KAAoB,CAAC;QAE1C,8EAA8E;QAC9E,IAAI,IAAI,CAAC,aAAa;YAAE,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;QAEzD,wEAAwE;QACxE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAA,CAAC,CAAC,CAAC,CAAC;QAC7G,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAA,CAAC,CAAC,CAAC,CAAC;IAC/G,CAAC;IAiBD;;wBAEoB;IACpB,IACW,QAAQ,KAAc,OAAO,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,CAAC,CAAC;IAClE,IAAW,QAAQ,CAAC,KAA0B;QAC5C,IAAI,KAAK,IAAI,KAAK,KAAK,IAAI;YAAE,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;;YACpD,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;QAEhC,0BAA0B;IAC5B,CAAC;IA2CD,oBAAoB;IAEpB,gDAAgD;IAGhD,iDAAiD;IACjD;QAxHA,6CAA6C;QAE7C,oBAAoB;QACV,kBAAa,GAAW,EAAE,CAAC;QAQ3B,iBAAY,GAAgB,IAAI,WAAW,CAAyB,IAAI,CAAC,CAAC;QAC1E,mBAAc,GAAY,KAAK,CAAC;QAChC,eAAU,GAAY,KAAK,CAAC;QAE5B,YAAO,GAAY,KAAK,CAAC;QACzB,UAAK,GAAY,KAAK,CAAC;QACvB,YAAO,GAAY,KAAK,CAAC;QACnC,uBAAuB;QAEvB,kBAAkB;QACV,cAAS,GAAa,KAAK,CAAC;QAC5B,kBAAa,GAAY,KAAK,CAAC;QAC/B,kBAAa,GAAiB,IAAI,YAAY,EAAE,CAAC;QAEjD,kBAAa,GAAgB,IAAI,WAAW,CAAyB,IAAI,CAAC,CAAC;QA8BnF;;;4BAGoB;QACJ,gBAAW,GAAa,KAAK,CAAC;QAc9C;;;+CAGuC;QACN,yBAAoB,GAAY,wBAAwB,CAAC;QAE1F;;;oCAG4B;QACO,2BAAsB,GAAY,aAAa,CAAC;QAEnF;;;;UAIE;QACqB,eAAU,GAAY,SAAS,CAAC;QAEvD;;;UAGE;QACc,iBAAY,GAAa,KAAK,CAAC;QAE/C;;;0CAGkC;QACjB,iBAAY,GAAyB,IAAI,YAAY,EAAU,CAAC;QAGjF;;;0DAGkD;QACjC,aAAQ,GAA0D,IAAI,YAAY,EAA2C,CAAC;IAW/H,CAAC;IAEjB,QAAQ;QACN,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,eAAe;QACb,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,cAAc,CAAC,EAAE,YAAY;YAAE,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACtE,IAAI,OAAO,CAAC,cAAc,CAAC,EAAE,YAAY;YAAE,IAAI,CAAC,mBAAmB,CAAE,OAAO,CAAC,cAAc,CAAC,CAAC,YAA4B,CAAC,KAAK,CAAC,CAAC;IACnI,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IACnC,CAAC;IAED,2DAA2D;IAE3D,QAAQ,CAAC,KAAY,IAAU,IAAI,CAAC,mBAAmB,EAAE,CAAA,CAAC,CAAC;IAC3D,oDAAoD;IAGpD,wCAAwC;IACjC,QAAQ,CAAC,IAAoB;QAClC,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;QAEjC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEvC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAEhD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAsB,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC3E,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;QAEjC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAEjC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAEhD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;IAEO,mBAAmB,CAAC,KAA8B;QACxD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,wCAAwC;QAC1E,MAAM,aAAa,GAA2B,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;QAEhF,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,aAAa,KAAK,IAAI,IAAI,aAAa,KAAK,EAAE,CAAC;YAAE,OAAO;QAEnF,MAAM,gBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,aAAa,CAAC,CAAA;QAClF,IAAI,gBAAgB;YAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAEzE,oDAAoD;IACtD,CAAC;IAEO,mBAAmB;QACzB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YAC1C,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC;YAC7D,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,UAAU,IAAI,CAAC;QACnE,CAAC;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YACzD,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACrD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACzB,CAAC;aACI,CAAC;YACJ,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACxD,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAC1B,CAAC;IACH,CAAC;IAEO,gBAAgB,CAAC,UAA6B;QACpD,QAAO,UAAU,EAAE,CAAC;YAClB,KAAK,OAAO;gBACV,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;gBAC5B,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;gBAC3B,MAAM;YAER,KAAK,SAAS;gBACZ,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;gBAC3B,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;gBAC3B,MAAM;YAER,KAAK,SAAS;gBACZ,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;gBAC5B,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;gBAC3B,MAAM;YAER,KAAK,UAAU;gBACb,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;gBAC5B,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;gBAC5B,MAAM;QAEV,CAAC;IACH,CAAC;IAEM,UAAU,KAAW,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA,CAAC,CAAC;+GA1O7D,oBAAoB;mGAApB,oBAAoB,ywBCzCjC,ioGAsCA;;4FDGa,oBAAoB;kBALhC,SAAS;+BACE,cAAc;wDAwCb,YAAY;sBADtB,KAAK;uBAAC,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAgBM,YAAY;sBAA5D,KAAK;uBAAC,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAIxB,SAAS;sBAAxB,KAAK;gBAMU,WAAW;sBAA1B,KAAK;gBAMK,QAAQ;sBADlB,KAAK;gBAa2B,oBAAoB;sBAApD,KAAK;uBAAC,iBAAiB;gBAMW,sBAAsB;sBAAxD,KAAK;uBAAC,mBAAmB;gBAOH,UAAU;sBAAhC,KAAK;uBAAC,OAAO;gBAME,YAAY;sBAA3B,KAAK;gBAMW,YAAY;sBAA5B,MAAM;gBAOU,QAAQ;sBAAxB,MAAM;gBAGyB,UAAU;sBAAzC,SAAS;uBAAC,WAAW;gBACa,aAAa;sBAA/C,SAAS;uBAAC,cAAc;gBA+BzB,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { AbstractControl, FormControl, FormControlStatus, Validators } from '@angular/forms';\r\n\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { RecordCombobox } from '../../models/combobox/record-combobox';\r\n\r\n/**\r\n * @component LibComboboxComponent\r\n * @selector lib-combobox\r\n * \r\n * @description\r\n * O componente LibComboboxComponent é projetado para fornecer aos usuários uma interface para pesquisar e selecionar itens de uma lista.\r\n * Ele suporta a filtragem de itens com base na entrada do usuário, permitindo uma seleção mais fácil em listas extensas.\r\n * \r\n * ## Funcionalidades:\r\n * - Pesquisa e filtragem de itens na lista do combobox.\r\n * - Seleção de itens com feedback visual.\r\n * - Emissão de eventos personalizados para interações do usuário, como recarregar a lista ou selecionar um item.\r\n * - Ajuste dinâmico da largura do dropdown para corresponder ao input principal.\r\n * - Inicialização de um valor selecionado, se fornecido.\r\n * \r\n * ## Inputs:\r\n * - `outerControl` (FormControl | AbstractControl): Control para seleção dos valores, atualizará automaticamente o control do componente pai também\r\n * - `comboboxList` (RecordCombobox[]): Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\r\n * - `labelText` (string): Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\r\n * - `disabled` (boolean): Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\r\n * - `libRequired` (boolean): Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\r\n * - `mainInputPlaceholder` (string): Placeholder do campo principal do combo\r\n * - `searchInputPlaceholder` (string): Placeholder do campo de pesquisa dentro do combo\r\n * - `colorTheme` (\"primary\" | \"secondary\" | \"success\" | \"danger\" | \"warning\" | \"info\" | \"light\" | \"dark\"): Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\r\n * - `returnRecord` (boolean): Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID\r\n * \r\n * ## Outputs:\r\n * - `onReloadList` (EventEmitter<string>): Evento emitido quando a lista precisa ser recarregada.\r\n */\r\n@Component({\r\n  selector: 'lib-combobox',\r\n  templateUrl: './lib-combobox.component.html',\r\n  styleUrl: './lib-combobox.component.scss'\r\n})\r\nexport class LibComboboxComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  // #region ==========> PROPERTIES <==========\r\n\r\n  // #region PROTECTED\r\n  protected textoPesquisa: string = \"\";\r\n\r\n  protected get ariaExpanded(): boolean { return this._ariaExpanded; }\r\n  protected set ariaExpanded(value: boolean) {\r\n    this._ariaExpanded = value;\r\n    this.adjustDropdownWidth();\r\n  }\r\n\r\n  protected innerControl: FormControl = new FormControl<string | number | null>(null);\r\n  protected invalidControl: boolean = false;\r\n  protected isRequired: boolean = false;\r\n\r\n  protected invalid: boolean = false;\r\n  protected dirty: boolean = false;\r\n  protected touched: boolean = false;\r\n  // #endregion PROTECTED\r\n\r\n  // #region PRIVATE\r\n  private _disabled?: boolean = false;\r\n  private _ariaExpanded: boolean = false;\r\n  private _subscription: Subscription = new Subscription();\r\n\r\n  private _outerControl: FormControl = new FormControl<string | number | null>(null);\r\n  // #endregion PRIVATE\r\n\r\n  // #region PUBLIC\r\n\r\n  /** (obrigatório) Control para seleção dos valores, atualizará automaticamente o control do componente pai também\r\n   * @alias 'control'\r\n   * @type {FormControl<any> | AbstractControl<any>} */\r\n  @Input({ alias: 'control', required: true })\r\n  public get outerControl(): FormControl<any> { return this._outerControl }\r\n  public set outerControl(value: FormControl<any> | AbstractControl<any>) {\r\n    this._outerControl = value as FormControl;\r\n\r\n    // Cancela a subscrição anterior (se houver) para evitar múltiplas subscrições\r\n    if (this._subscription) this._subscription.unsubscribe();\r\n\r\n    // Subscrição ao observável valueChanges para reagir a mudanças no valor\r\n    this._subscription = this._outerControl.valueChanges.subscribe(value => { this.updateSelectedValue(value) });\r\n    this._subscription = this._outerControl.statusChanges.subscribe(status => { this.setControlStatus(status) });\r\n  }\r\n\r\n  /** (obrigatório) Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\r\n   * @alias 'list'\r\n   * @type {RecordCombobox[]} */\r\n  @Input({ alias: 'list', required: true }) public comboboxList?: RecordCombobox[];\r\n\r\n  /** (opcional) Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\r\n   * @type {string} */\r\n  @Input() public labelText?: string;\r\n\r\n  /** (opcional) Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\r\n   * ! SERÁ DEPRECIADO EM BREVE\r\n   * @type {boolean}\r\n   * @default false */\r\n  @Input() public libRequired?: boolean = false;\r\n\r\n  /** (opcional) Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\r\n   * @type {boolean}\r\n   * @default false */\r\n  @Input()\r\n  public get disabled(): boolean { return this._disabled ?? false; }\r\n  public set disabled(value: boolean | undefined) {\r\n    if (value && value === true) this.innerControl.disable();\r\n    else this.innerControl.enable();\r\n\r\n    //this.setControlStatus();\r\n  }\r\n\r\n  /** (opcional) Placeholder do campo principal do combo\r\n   * @alias 'mainPlaceholder'\r\n   * @type {string}\r\n   * @default \"Selecione uma opção...\" */\r\n  @Input('mainPlaceholder') public mainInputPlaceholder?: string = \"Selecione uma opção...\";\r\n\r\n  /** (opcional) Placeholder do campo de pesquisa dentro do combo\r\n   * @alias 'searchPlaceholder'\r\n   * @type {string}\r\n   * @default \"Pesquisa...\" */\r\n  @Input('searchPlaceholder') public searchInputPlaceholder?: string = \"Pesquisa...\";\r\n\r\n  /** (opcional) Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\r\n   * @alias 'theme'\r\n   * @type {string}\r\n   * @default \"primary\"\r\n  */\r\n  @Input('theme') public colorTheme?: string = \"primary\";\r\n\r\n  /** (opcional) Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID.\r\n   * @type {boolean}\r\n   * @default false\r\n  */\r\n  @Input() public returnRecord?: boolean = false;\r\n\r\n  /** Evento emitido ao recarregar a lista de registros\r\n   * @example Ao ser emitido, o componente pai pode refazer o GET da lista, por exemplo.\r\n   * @emits EventEmitter<string> que leva o valor string da pesquisa feita para ser enviada para o GET\r\n   * @type {EventEmitter<string>} */\r\n  @Output() public onReloadList: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n\r\n  /** Evento emitido ao selecionar um registro da lista do combobox\r\n   * @example Ao ser emitido, o componente pai pode realizar uma validação com o valor selecionado.\r\n   * @emits EventEmitter<string|number|null> que leva o valor string da pesquisa feita para ser enviada para o GET\r\n   * @type {EventEmitter<string | number | null>} */\r\n  @Output() public onChange: EventEmitter<RecordCombobox | string | number | null> = new EventEmitter<RecordCombobox | string | number | null>();\r\n  \r\n\r\n  @ViewChild('mainInput') private _mainInput!: ElementRef;\r\n  @ViewChild('dropdownMenu') private _dropdownMenu!: ElementRef;\r\n  // #endregion PUBLIC\r\n\r\n  // #endregion ==========> PROPERTIES <==========\r\n\r\n\r\n  // #region ==========> INITIALIZATION <==========\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.adjustDropdownWidth();\r\n\r\n    this.setValidator();\r\n    this.updateSelectedValue();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.adjustDropdownWidth();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes[\"comboboxList\"]?.currentValue) this.updateSelectedValue();\r\n    if (changes[\"outerControl\"]?.currentValue) this.updateSelectedValue((changes[\"outerControl\"].currentValue as FormControl).value);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._subscription.unsubscribe();\r\n  }\r\n\r\n  // O que fazer quando o evento de redimensionamento ocorrer\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize(event: Event): void { this.adjustDropdownWidth() }\r\n  // #endregion ==========> INITIALIZATION <==========\r\n\r\n\r\n  // #region ==========> UTILS <==========\r\n  public setValue(item: RecordCombobox): void {\r\n    this.textoPesquisa = \"\";\r\n    this.innerControl.markAsDirty();\r\n    this._outerControl.markAsDirty();\r\n    \r\n    this._outerControl.setValue(item.ID);\r\n    this.innerControl.setValue(item.LABEL);\r\n\r\n    this.ariaExpanded = false;\r\n    this.setControlStatus(this.innerControl.status);\r\n    \r\n    this.onChange.emit(this.returnRecord ? item as RecordCombobox : item.ID);\r\n  }\r\n\r\n  public clearValue(): void {\r\n    this.textoPesquisa = \"\";\r\n    this.innerControl.markAsDirty();\r\n    this._outerControl.markAsDirty();\r\n\r\n    this._outerControl.setValue(null);\r\n    this.innerControl.setValue(null);\r\n\r\n    this.ariaExpanded = false;\r\n    this.setControlStatus(this.innerControl.status);\r\n\r\n    this.onChange.emit(null);\r\n  }\r\n\r\n  private updateSelectedValue(value?: string | number | null): void {\r\n    this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa\r\n    const selectedValue: string | number | null = value ?? this._outerControl.value;\r\n\r\n    if (!this.comboboxList || (selectedValue === null && selectedValue === '')) return;\r\n\r\n    const initializedValue = this.comboboxList.find(item => item.ID === selectedValue)\r\n    if (initializedValue) this.innerControl.setValue(initializedValue.LABEL);\r\n\r\n    // this.setControlStatus(this._outerControl.status);\r\n  }\r\n\r\n  private adjustDropdownWidth(): void {\r\n    if (this._mainInput && this._dropdownMenu) {\r\n      const inputWidth = this._mainInput.nativeElement.offsetWidth;\r\n      this._dropdownMenu.nativeElement.style.width = `${inputWidth}px`;\r\n    }\r\n  }\r\n\r\n  private setValidator(): void {\r\n    if (this._outerControl.hasValidator(Validators.required)) {\r\n      this.innerControl.addValidators(Validators.required);\r\n      this.isRequired = true;\r\n    }\r\n    else {\r\n      this.innerControl.removeValidators(Validators.required);\r\n      this.isRequired = false;\r\n    }\r\n  }\r\n\r\n  private setControlStatus(formStatus: FormControlStatus): void {\r\n    switch(formStatus) {\r\n      case 'VALID':\r\n        this.invalidControl = false;\r\n        this.innerControl.enable();\r\n        break;\r\n\r\n      case 'INVALID':\r\n        this.invalidControl = true;\r\n        this.innerControl.enable();\r\n        break;\r\n\r\n      case 'PENDING':\r\n        this.invalidControl = false;\r\n        this.innerControl.enable();\r\n        break;\r\n\r\n      case 'DISABLED':\r\n        this.invalidControl = false;\r\n        this.innerControl.disable();\r\n        break;\r\n\r\n    }\r\n  }\r\n\r\n  public reloadList(): void { this.onReloadList.emit(this.textoPesquisa) }\r\n  // #endregion ==========> UTILS <==========\r\n\r\n}\r\n","<label *ngIf=\"labelText && labelText != ''\" [libRequired]=\"isRequired\" class=\"form-label fw-bold\">{{ labelText }}</label>\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\n\n   <!-- Este elemento ng-content com o atributo [btnLeft] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\n   Ao usar o atributo [btnLeft], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\n   <ng-content select=\"[btnLeft]\"></ng-content>\n\n   <input  #mainInput class=\"form-select text-start rounded-end\" type=\"text\" data-bs-toggle=\"dropdown\" [placeholder]=\"mainInputPlaceholder\"\n            [formControl]=\"innerControl\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly [class.is-invalid]=\"invalidControl\"\n            (click)=\"ariaExpanded = !ariaExpanded; searchInput.focus()\" (focus)=\"searchInput.focus()\">\n\n   <ul  #dropdownMenu  class=\"dropdown-menu p-2 glb-max-height-350px overflow-y-scroll z-index-1020\" [class.show]=\"ariaExpanded\">\n      <div class=\"input-group mb-2\">\n         <input #searchInput (input)=\"textoPesquisa = searchInput.value\" type=\"text\" id=\"searchInput\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchInputPlaceholder\" (keyup.enter)=\"reloadList()\">\n         <button class=\"btn btn-{{colorTheme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\n      </div>\n\n      @if (comboboxList) {\n         <li *ngIf=\"innerControl.value != '' && innerControl.value != null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar opção selecionada</span> </li>\n         @for (item of comboboxList | textFilter:textoPesquisa; track $index) {\n            <li class=\"dropdown-item\" (click)=\"setValue(item)\">\n               <span *ngIf=\"item.AdditionalStringProperty1 || item.AdditionalStringProperty1 != ''\" class=\"glb-fs-12 fw-bold d-inline-block w-125\">{{ item.AdditionalStringProperty1 }}</span> {{ item.LABEL }}\n            </li>\n         }\n         @empty { <li class=\"dropdown-item fst-italic\">Nenhum registro encontrado com esta pesquisa...</li> }\n      }\n      @else { <li class=\"dropdown-item text-center\"> <div class=\"spinner-border\" role=\"status\"><span class=\"visually-hidden\">Carregando dados...</span></div> </li> }\n   </ul>\n\n   <!-- Este elemento ng-content com o atributo [btnRight] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado direito do combobox de pesquisa.\n   Ao usar o atributo [btnRight], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\n   <ng-content select=\"[btnRight]\"></ng-content>\n\n</div>\n\n<!-- #region MENSAGEM DE ERRO DE VALIDAÇÃO -->\n<app-field-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo é obrigatório.\" />\n<!-- #endregion MENSAGEM DE ERRO DE VALIDAÇÃO -->\n"]}
@@ -146,14 +146,14 @@ export class LibIconsComponent {
146
146
  this.safeSVG = this._sanitizer.bypassSecurityTrustHtml(unsanitizedSVG);
147
147
  }
148
148
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LibIconsComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
149
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: LibIconsComponent, selector: "lib-icon", inputs: { iconName: "iconName", iconColor: "iconColor", iconSize: "iconSize", iconFill: "iconFill" }, usesOnChanges: true, ngImport: i0, template: `
150
- <span [style.color]="color" [innerHTML]="safeSVG"></span>
149
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: LibIconsComponent, selector: "lib-icon", inputs: { iconName: "iconName", iconColor: "iconColor", iconSize: "iconSize", iconFill: "iconFill" }, usesOnChanges: true, ngImport: i0, template: `
150
+ <span [style.color]="color" [innerHTML]="safeSVG"></span>
151
151
  `, isInline: true, styles: [""] }); }
152
152
  }
153
153
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LibIconsComponent, decorators: [{
154
154
  type: Component,
155
- args: [{ selector: 'lib-icon', template: `
156
- <span [style.color]="color" [innerHTML]="safeSVG"></span>
155
+ args: [{ selector: 'lib-icon', template: `
156
+ <span [style.color]="color" [innerHTML]="safeSVG"></span>
157
157
  ` }]
158
158
  }], ctorParameters: () => [{ type: i1.DomSanitizer }], propDecorators: { iconName: [{
159
159
  type: Input,
@@ -165,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
165
165
  }], iconFill: [{
166
166
  type: Input
167
167
  }] } });
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-icons.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-icons/lib-icons.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, SimpleChanges, OnChanges, OnInit } from '@angular/core';\n\nimport { IconsList } from '../../models/icons/icon.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n@Component({\n  selector: 'lib-icon',\n  template: `\n    <span [style.color]=\"color\" [innerHTML]=\"safeSVG\"></span>\n  `,\n  styles: ``\n})\nexport class LibIconsComponent implements OnInit, OnChanges {\n\n  // #region ==========> PROPERTIES <==========\n\n  // #region PRIVATE\n  private iconsList: IconsList;\n  // #endregion PRIVATE\n\n  // #region PUBLIC\n\n  /** (obrigatório) Nome do ícone */\n  @Input({ required: true }) public iconName: string;\n\n      /** Cor do ícone\n       * Paleta de cores:\n       * @argument 'white' - #FFFFFF\n       * @argument 'blue' - #3767b2\n       * @argument 'gray' - #6C757D\n       * @argument 'light-gray' - #CED4DA\n       * @argument 'green' - #0F5132\n       * @argument 'light-blue' - #3767B2\n       * @argument 'yellow' - #FFC107\n       * @argument 'red' - #B23737\n       * @argument 'currentColor' - currentColor\n       * @argument string - HEX da cor específica\n      */\n    @Input()\n    public get iconColor(): 'white' | 'blue' | 'gray' | 'light-gray' | 'green' | 'light-blue' | 'yellow' | 'red' | 'currentColor' | string { return this.color; }\n    public set iconColor(value: 'white' | 'blue' | 'gray' | 'light-gray' | 'green' | 'light-blue' | 'yellow' | 'red' | 'currentColor' | string) {\n      switch (value) {\n        case \"white\": this.color = \"#FFFFFF\"; break;\n        case \"blue\": this.color = \"#3767b2\"; break;\n        case \"gray\": this.color = \"#6C757D\"; break;\n        case \"light-gray\": this.color = \"#CED4DA\"; break;\n        case \"green\": this.color = \"#0F5132\"; break;\n        case \"light-blue\": this.color = \"#3767B2\"; break;\n        case \"yellow\": this.color = \"#FFC107\"; break;\n        case \"red\": this.color = \"#B23737\"; break;\n        case \"currentColor\": this.color = \"currentColor\"; break;\n        default: this.color = value; break;\n      }\n    }\n\n    /** Tamanho do ícone\n     * Tamanhos disponíveis:\n     * @argument 'default' - 24px\n     * @argument 'medium-small' - 20px | Será depreciado em breve!\n     * @argument 'small' - 18px\n     * @argument number - número em pixels | Preferencialmente não utilizar!\n    */\n    @Input()\n    public get iconSize(): 'default' | 'medium-small' | 'small' | number { return this.size; }\n    public set iconSize(value: 'default' | 'medium-small' | 'small' | number) {\n      switch (value) {\n        case \"default\": this.size = 24; break;\n        case \"medium-small\": this.size = 20; break;\n        case \"small\": this.size = 18; break;\n        default: this.size = value as number; break;\n      }\n    }\n\n    @Input()\n    public get iconFill(): boolean { return this.fill; }\n    public set iconFill(value: boolean) { this.fill = value; }\n\n\n    protected safeSVG: SafeHtml;\n    protected size: number = 24;\n    protected fill: boolean = false;\n    protected color: string = \"currentColor\";\n  // #endregion PUBLIC\n\n  // #endregion ==========> PROPERTIES <==========\n\n\n  // #region ==========> INITIALIZATION <==========\n  constructor(private _sanitizer: DomSanitizer) {\n    this.iconsList = new IconsList(this.size, this.fill);\n  }\n\n  ngOnInit(): void {\n    this.iconsList = new IconsList(this.size, this.fill);\n    this.checkName();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['iconName']) this.checkName();\n    else {\n      switch (this.iconColor) {\n        case \"white\": this.color = \"#212529\"; break;\n        case \"blue\": this.color = \"#213B70\"; break;\n        case \"gray\": this.color = \"#212529\"; break;\n        case \"lightgray\": this.color = \"#CED4DA\"; break;\n        case \"green\": this.color = \"#D1E7DD\"; break;\n        case \"light-blue\": this.color = \"#3767B2\"; break;\n        case \"yellow\": this.color = \"#664D03\"; break;\n        case \"red\": this.color = \"#842029\"; break;\n        case \"currentColor\": this.color = \"currentColor\"; break;\n        default: this.color = this.iconColor; break;\n      }\n  \n      this.iconsList = new IconsList(this.size, this.fill);\n      this.getSVG();\n    }\n  }\n  // #endregion ==========> INITIALIZATION <==========\n\n\n  // #region ==========> UTILS <==========\n\n  /** Valida se o nome informado do ícone existe na lista, caso contrário mostra um erro no console */\n  private checkName(): void {\n    let hasIcon: boolean = this.iconsList.getIcon(this.iconName) ? true : false;\n    if (this.iconsList && !hasIcon) { console.error(`O ícone informado \"${this.iconName}\" não existe, utilize outro!`); }\n\n    this.getSVG();\n  }\n\n\n  public getSVG(): void {\n    let unsanitizedSVG = this.iconsList.getIcon(this.iconName) ? this.iconsList.getIcon(this.iconName)!.svg ?? \"\" : \"\";\n    this.safeSVG = this._sanitizer.bypassSecurityTrustHtml(unsanitizedSVG);\n  }\n  // #endregion ==========> UTILS <==========\n\n}\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-icons.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-icons/lib-icons.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, SimpleChanges, OnChanges, OnInit } from '@angular/core';\r\n\r\nimport { IconsList } from '../../models/icons/icon.model';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\n\r\n@Component({\r\n  selector: 'lib-icon',\r\n  template: `\r\n    <span [style.color]=\"color\" [innerHTML]=\"safeSVG\"></span>\r\n  `,\r\n  styles: ``\r\n})\r\nexport class LibIconsComponent implements OnInit, OnChanges {\r\n\r\n  // #region ==========> PROPERTIES <==========\r\n\r\n  // #region PRIVATE\r\n  private iconsList: IconsList;\r\n  // #endregion PRIVATE\r\n\r\n  // #region PUBLIC\r\n\r\n  /** (obrigatório) Nome do ícone */\r\n  @Input({ required: true }) public iconName: string;\r\n\r\n      /** Cor do ícone\r\n       * Paleta de cores:\r\n       * @argument 'white' - #FFFFFF\r\n       * @argument 'blue' - #3767b2\r\n       * @argument 'gray' - #6C757D\r\n       * @argument 'light-gray' - #CED4DA\r\n       * @argument 'green' - #0F5132\r\n       * @argument 'light-blue' - #3767B2\r\n       * @argument 'yellow' - #FFC107\r\n       * @argument 'red' - #B23737\r\n       * @argument 'currentColor' - currentColor\r\n       * @argument string - HEX da cor específica\r\n      */\r\n    @Input()\r\n    public get iconColor(): 'white' | 'blue' | 'gray' | 'light-gray' | 'green' | 'light-blue' | 'yellow' | 'red' | 'currentColor' | string { return this.color; }\r\n    public set iconColor(value: 'white' | 'blue' | 'gray' | 'light-gray' | 'green' | 'light-blue' | 'yellow' | 'red' | 'currentColor' | string) {\r\n      switch (value) {\r\n        case \"white\": this.color = \"#FFFFFF\"; break;\r\n        case \"blue\": this.color = \"#3767b2\"; break;\r\n        case \"gray\": this.color = \"#6C757D\"; break;\r\n        case \"light-gray\": this.color = \"#CED4DA\"; break;\r\n        case \"green\": this.color = \"#0F5132\"; break;\r\n        case \"light-blue\": this.color = \"#3767B2\"; break;\r\n        case \"yellow\": this.color = \"#FFC107\"; break;\r\n        case \"red\": this.color = \"#B23737\"; break;\r\n        case \"currentColor\": this.color = \"currentColor\"; break;\r\n        default: this.color = value; break;\r\n      }\r\n    }\r\n\r\n    /** Tamanho do ícone\r\n     * Tamanhos disponíveis:\r\n     * @argument 'default' - 24px\r\n     * @argument 'medium-small' - 20px | Será depreciado em breve!\r\n     * @argument 'small' - 18px\r\n     * @argument number - número em pixels | Preferencialmente não utilizar!\r\n    */\r\n    @Input()\r\n    public get iconSize(): 'default' | 'medium-small' | 'small' | number { return this.size; }\r\n    public set iconSize(value: 'default' | 'medium-small' | 'small' | number) {\r\n      switch (value) {\r\n        case \"default\": this.size = 24; break;\r\n        case \"medium-small\": this.size = 20; break;\r\n        case \"small\": this.size = 18; break;\r\n        default: this.size = value as number; break;\r\n      }\r\n    }\r\n\r\n    @Input()\r\n    public get iconFill(): boolean { return this.fill; }\r\n    public set iconFill(value: boolean) { this.fill = value; }\r\n\r\n\r\n    protected safeSVG: SafeHtml;\r\n    protected size: number = 24;\r\n    protected fill: boolean = false;\r\n    protected color: string = \"currentColor\";\r\n  // #endregion PUBLIC\r\n\r\n  // #endregion ==========> PROPERTIES <==========\r\n\r\n\r\n  // #region ==========> INITIALIZATION <==========\r\n  constructor(private _sanitizer: DomSanitizer) {\r\n    this.iconsList = new IconsList(this.size, this.fill);\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.iconsList = new IconsList(this.size, this.fill);\r\n    this.checkName();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['iconName']) this.checkName();\r\n    else {\r\n      switch (this.iconColor) {\r\n        case \"white\": this.color = \"#212529\"; break;\r\n        case \"blue\": this.color = \"#213B70\"; break;\r\n        case \"gray\": this.color = \"#212529\"; break;\r\n        case \"lightgray\": this.color = \"#CED4DA\"; break;\r\n        case \"green\": this.color = \"#D1E7DD\"; break;\r\n        case \"light-blue\": this.color = \"#3767B2\"; break;\r\n        case \"yellow\": this.color = \"#664D03\"; break;\r\n        case \"red\": this.color = \"#842029\"; break;\r\n        case \"currentColor\": this.color = \"currentColor\"; break;\r\n        default: this.color = this.iconColor; break;\r\n      }\r\n  \r\n      this.iconsList = new IconsList(this.size, this.fill);\r\n      this.getSVG();\r\n    }\r\n  }\r\n  // #endregion ==========> INITIALIZATION <==========\r\n\r\n\r\n  // #region ==========> UTILS <==========\r\n\r\n  /** Valida se o nome informado do ícone existe na lista, caso contrário mostra um erro no console */\r\n  private checkName(): void {\r\n    let hasIcon: boolean = this.iconsList.getIcon(this.iconName) ? true : false;\r\n    if (this.iconsList && !hasIcon) { console.error(`O ícone informado \"${this.iconName}\" não existe, utilize outro!`); }\r\n\r\n    this.getSVG();\r\n  }\r\n\r\n\r\n  public getSVG(): void {\r\n    let unsanitizedSVG = this.iconsList.getIcon(this.iconName) ? this.iconsList.getIcon(this.iconName)!.svg ?? \"\" : \"\";\r\n    this.safeSVG = this._sanitizer.bypassSecurityTrustHtml(unsanitizedSVG);\r\n  }\r\n  // #endregion ==========> UTILS <==========\r\n\r\n}\r\n"]}
@@ -4,16 +4,16 @@ import * as i1 from "@angular/common";
4
4
  export class LoadingButtonComponent {
5
5
  constructor() { }
6
6
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LoadingButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
7
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: LoadingButtonComponent, selector: "app-loading-button", inputs: { isLoading: "isLoading" }, ngImport: i0, template: `
8
- <img class="button-spinner" src="assets/imgs/spinner.gif" *ngIf="isLoading">
7
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: LoadingButtonComponent, selector: "app-loading-button", inputs: { isLoading: "isLoading" }, ngImport: i0, template: `
8
+ <img class="button-spinner" src="assets/imgs/spinner.gif" *ngIf="isLoading">
9
9
  `, isInline: true, styles: [".button-spinner{width:24px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
10
10
  }
11
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LoadingButtonComponent, decorators: [{
12
12
  type: Component,
13
- args: [{ selector: 'app-loading-button', template: `
14
- <img class="button-spinner" src="assets/imgs/spinner.gif" *ngIf="isLoading">
13
+ args: [{ selector: 'app-loading-button', template: `
14
+ <img class="button-spinner" src="assets/imgs/spinner.gif" *ngIf="isLoading">
15
15
  `, styles: [".button-spinner{width:24px}\n"] }]
16
16
  }], ctorParameters: () => [], propDecorators: { isLoading: [{
17
17
  type: Input
18
18
  }] } });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNwLWluZnJhL3NyYy9saWIvd2lkZ2V0cy9sb2FkaW5nLWJ1dHRvbi9sb2FkaW5nLWJ1dHRvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVdqRCxNQUFNLE9BQU8sc0JBQXNCO0lBR2pDLGdCQUFnQixDQUFDOytHQUhOLHNCQUFzQjttR0FBdEIsc0JBQXNCLDhGQVB2Qjs7R0FFVDs7NEZBS1Usc0JBQXNCO2tCQVRsQyxTQUFTOytCQUNFLG9CQUFvQixZQUNwQjs7R0FFVDt3REFNUSxTQUFTO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtbG9hZGluZy1idXR0b24nLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxpbWcgY2xhc3M9XCJidXR0b24tc3Bpbm5lclwiIHNyYz1cImFzc2V0cy9pbWdzL3NwaW5uZXIuZ2lmXCIgKm5nSWY9XCJpc0xvYWRpbmdcIj5cbiAgYCxcbiAgc3R5bGVzOiBgXG4gICAgLmJ1dHRvbi1zcGlubmVyeyB3aWR0aDogMjRweDsgfVxuICBgXG59KVxuZXhwb3J0IGNsYXNzIExvYWRpbmdCdXR0b25Db21wb25lbnQge1xuICBASW5wdXQoKSBpc0xvYWRpbmc6IGJvb2xlYW47XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxufVxuIl19
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNwLWluZnJhL3NyYy9saWIvd2lkZ2V0cy9sb2FkaW5nLWJ1dHRvbi9sb2FkaW5nLWJ1dHRvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVdqRCxNQUFNLE9BQU8sc0JBQXNCO0lBR2pDLGdCQUFnQixDQUFDOytHQUhOLHNCQUFzQjttR0FBdEIsc0JBQXNCLDhGQVB2Qjs7R0FFVDs7NEZBS1Usc0JBQXNCO2tCQVRsQyxTQUFTOytCQUNFLG9CQUFvQixZQUNwQjs7R0FFVDt3REFNUSxTQUFTO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtbG9hZGluZy1idXR0b24nLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8aW1nIGNsYXNzPVwiYnV0dG9uLXNwaW5uZXJcIiBzcmM9XCJhc3NldHMvaW1ncy9zcGlubmVyLmdpZlwiICpuZ0lmPVwiaXNMb2FkaW5nXCI+XHJcbiAgYCxcclxuICBzdHlsZXM6IGBcclxuICAgIC5idXR0b24tc3Bpbm5lcnsgd2lkdGg6IDI0cHg7IH1cclxuICBgXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMb2FkaW5nQnV0dG9uQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBpc0xvYWRpbmc6IGJvb2xlYW47XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG59XHJcbiJdfQ==
@@ -12,38 +12,38 @@ export class NavProdutosComponent {
12
12
  this.activeItem = this.router.url;
13
13
  }
14
14
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NavProdutosComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component }); }
15
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NavProdutosComponent, selector: "lib-nav-produtos", inputs: { navItems: "navItems" }, ngImport: i0, template: `
16
-
17
- <ul class="menu">
18
- <li class="menu-item"
19
- *ngFor="let item of navItems"
20
- [class.active]="activeItem == item.caminho"
21
- >
22
- <a [routerLink]="item.caminho" target="_blank">{{ item.label }}</a>
23
-
24
- <!-- <a [href]="item.caminho" target="_blank">{{ item.label }}</a> -->
25
- </li>
26
- </ul>
27
-
15
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NavProdutosComponent, selector: "lib-nav-produtos", inputs: { navItems: "navItems" }, ngImport: i0, template: `
16
+
17
+ <ul class="menu">
18
+ <li class="menu-item"
19
+ *ngFor="let item of navItems"
20
+ [class.active]="activeItem == item.caminho"
21
+ >
22
+ <a [routerLink]="item.caminho" target="_blank">{{ item.label }}</a>
23
+
24
+ <!-- <a [href]="item.caminho" target="_blank">{{ item.label }}</a> -->
25
+ </li>
26
+ </ul>
27
+
28
28
  `, isInline: true, styles: [".menu{list-style:none;padding:0;margin:0;display:flex;gap:20px}.menu-item a{text-align:center;position:relative;display:inline-block;padding-bottom:5px;color:#c7c7c7;text-decoration:none;border-bottom:2px solid #c7c7c7;transition:color .3s ease,border-bottom-color .3s ease;width:calc(100% + 15px)}.menu-item a:hover{color:#3e5154;border-bottom:2px solid #2847A0}.menu-item.active a:after{content:\"\";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:calc(100% + 5px);height:2px;background-color:#2847a0}.menu-item.active a{color:#3e5154}.menu-item.active a:before{content:\"\";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid #2847A0;opacity:1;transition:all .2s ease-in-out}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
29
29
  }
30
30
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NavProdutosComponent, decorators: [{
31
31
  type: Component,
32
- args: [{ selector: 'lib-nav-produtos', standalone: false, template: `
33
-
34
- <ul class="menu">
35
- <li class="menu-item"
36
- *ngFor="let item of navItems"
37
- [class.active]="activeItem == item.caminho"
38
- >
39
- <a [routerLink]="item.caminho" target="_blank">{{ item.label }}</a>
40
-
41
- <!-- <a [href]="item.caminho" target="_blank">{{ item.label }}</a> -->
42
- </li>
43
- </ul>
44
-
32
+ args: [{ selector: 'lib-nav-produtos', standalone: false, template: `
33
+
34
+ <ul class="menu">
35
+ <li class="menu-item"
36
+ *ngFor="let item of navItems"
37
+ [class.active]="activeItem == item.caminho"
38
+ >
39
+ <a [routerLink]="item.caminho" target="_blank">{{ item.label }}</a>
40
+
41
+ <!-- <a [href]="item.caminho" target="_blank">{{ item.label }}</a> -->
42
+ </li>
43
+ </ul>
44
+
45
45
  `, styles: [".menu{list-style:none;padding:0;margin:0;display:flex;gap:20px}.menu-item a{text-align:center;position:relative;display:inline-block;padding-bottom:5px;color:#c7c7c7;text-decoration:none;border-bottom:2px solid #c7c7c7;transition:color .3s ease,border-bottom-color .3s ease;width:calc(100% + 15px)}.menu-item a:hover{color:#3e5154;border-bottom:2px solid #2847A0}.menu-item.active a:after{content:\"\";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:calc(100% + 5px);height:2px;background-color:#2847a0}.menu-item.active a{color:#3e5154}.menu-item.active a:before{content:\"\";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid #2847A0;opacity:1;transition:all .2s ease-in-out}\n"] }]
46
46
  }], ctorParameters: () => [{ type: i1.Router }], propDecorators: { navItems: [{
47
47
  type: Input
48
48
  }] } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXByb2R1dG9zLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zcC1pbmZyYS9zcmMvbGliL3dpZGdldHMvbmF2LXByb2R1dG9zL25hdi1wcm9kdXRvcy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7Ozs7QUFzQnpELE1BQU0sT0FBTyxvQkFBb0I7SUFNL0IsWUFBb0IsTUFBYztRQUFkLFdBQU0sR0FBTixNQUFNLENBQVE7UUFKekIsYUFBUSxHQUF5QyxFQUFFLENBQUM7UUFFN0QsZUFBVSxHQUFXLEVBQUUsQ0FBQztJQUVhLENBQUM7SUFFdEMsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUM7SUFDcEMsQ0FBQzsrR0FWVSxvQkFBb0I7bUdBQXBCLG9CQUFvQiwwRkFoQnJCOzs7Ozs7Ozs7Ozs7O0dBYVQ7OzRGQUdVLG9CQUFvQjtrQkFuQmhDLFNBQVM7K0JBQ0Usa0JBQWtCLGNBQ2hCLEtBQUssWUFDUDs7Ozs7Ozs7Ozs7OztHQWFUOzJFQUtRLFFBQVE7c0JBQWhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5hdmlnYXRpb25FbmQsIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2xpYi1uYXYtcHJvZHV0b3MnLFxuICBzdGFuZGFsb25lOiBmYWxzZSxcbiAgdGVtcGxhdGU6IGBcblxuICAgIDx1bCBjbGFzcz1cIm1lbnVcIj5cbiAgICAgIDxsaSBjbGFzcz1cIm1lbnUtaXRlbVwiXG4gICAgICAgICpuZ0Zvcj1cImxldCBpdGVtIG9mIG5hdkl0ZW1zXCJcbiAgICAgICAgW2NsYXNzLmFjdGl2ZV09XCJhY3RpdmVJdGVtID09IGl0ZW0uY2FtaW5ob1wiXG4gICAgICAgID5cbiAgICAgICAgPGEgW3JvdXRlckxpbmtdPVwiaXRlbS5jYW1pbmhvXCIgdGFyZ2V0PVwiX2JsYW5rXCI+e3sgaXRlbS5sYWJlbCB9fTwvYT5cblxuICAgICAgICA8IS0tIDxhIFtocmVmXT1cIml0ZW0uY2FtaW5ob1wiIHRhcmdldD1cIl9ibGFua1wiPnt7IGl0ZW0ubGFiZWwgfX08L2E+IC0tPlxuICAgICAgPC9saT5cbiAgICA8L3VsPlxuXG4gIGAsXG4gIHN0eWxlVXJsczogWycuL25hdi1wcm9kdXRvcy5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgTmF2UHJvZHV0b3NDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIEBJbnB1dCgpIG5hdkl0ZW1zOiB7IGNhbWluaG86IHN0cmluZzsgbGFiZWw6IHN0cmluZyB9W10gPSBbXTtcblxuICBhY3RpdmVJdGVtOiBzdHJpbmcgPSAnJztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJvdXRlcjogUm91dGVyKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuYWN0aXZlSXRlbSA9IHRoaXMucm91dGVyLnVybDtcbiAgfVxuXG59XG4iXX0=
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXByb2R1dG9zLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zcC1pbmZyYS9zcmMvbGliL3dpZGdldHMvbmF2LXByb2R1dG9zL25hdi1wcm9kdXRvcy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7Ozs7QUFzQnpELE1BQU0sT0FBTyxvQkFBb0I7SUFNL0IsWUFBb0IsTUFBYztRQUFkLFdBQU0sR0FBTixNQUFNLENBQVE7UUFKekIsYUFBUSxHQUF5QyxFQUFFLENBQUM7UUFFN0QsZUFBVSxHQUFXLEVBQUUsQ0FBQztJQUVhLENBQUM7SUFFdEMsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUM7SUFDcEMsQ0FBQzsrR0FWVSxvQkFBb0I7bUdBQXBCLG9CQUFvQiwwRkFoQnJCOzs7Ozs7Ozs7Ozs7O0dBYVQ7OzRGQUdVLG9CQUFvQjtrQkFuQmhDLFNBQVM7K0JBQ0Usa0JBQWtCLGNBQ2hCLEtBQUssWUFDUDs7Ozs7Ozs7Ozs7OztHQWFUOzJFQUtRLFFBQVE7c0JBQWhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTmF2aWdhdGlvbkVuZCwgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLW5hdi1wcm9kdXRvcycsXHJcbiAgc3RhbmRhbG9uZTogZmFsc2UsXHJcbiAgdGVtcGxhdGU6IGBcclxuXHJcbiAgICA8dWwgY2xhc3M9XCJtZW51XCI+XHJcbiAgICAgIDxsaSBjbGFzcz1cIm1lbnUtaXRlbVwiXHJcbiAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgbmF2SXRlbXNcIlxyXG4gICAgICAgIFtjbGFzcy5hY3RpdmVdPVwiYWN0aXZlSXRlbSA9PSBpdGVtLmNhbWluaG9cIlxyXG4gICAgICAgID5cclxuICAgICAgICA8YSBbcm91dGVyTGlua109XCJpdGVtLmNhbWluaG9cIiB0YXJnZXQ9XCJfYmxhbmtcIj57eyBpdGVtLmxhYmVsIH19PC9hPlxyXG5cclxuICAgICAgICA8IS0tIDxhIFtocmVmXT1cIml0ZW0uY2FtaW5ob1wiIHRhcmdldD1cIl9ibGFua1wiPnt7IGl0ZW0ubGFiZWwgfX08L2E+IC0tPlxyXG4gICAgICA8L2xpPlxyXG4gICAgPC91bD5cclxuXHJcbiAgYCxcclxuICBzdHlsZVVybHM6IFsnLi9uYXYtcHJvZHV0b3MuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOYXZQcm9kdXRvc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIEBJbnB1dCgpIG5hdkl0ZW1zOiB7IGNhbWluaG86IHN0cmluZzsgbGFiZWw6IHN0cmluZyB9W10gPSBbXTtcclxuXHJcbiAgYWN0aXZlSXRlbTogc3RyaW5nID0gJyc7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcm91dGVyOiBSb3V0ZXIpIHt9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5hY3RpdmVJdGVtID0gdGhpcy5yb3V0ZXIudXJsO1xyXG4gIH1cclxuXHJcbn1cclxuIl19