ngx-sp-infra 3.9.2 → 3.9.6

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.
@@ -41,8 +41,8 @@ export class RequiredDirective {
41
41
  this._elementRef = _elementRef;
42
42
  this._renderer = _renderer;
43
43
  this._showMarker = true; // Valor padrão
44
- /** Identificador único para o elemento <span> criado. */
45
- this.spanID = "";
44
+ /** [DEPRECIADO] Identificador único para o elemento <span> criado. */
45
+ this.requiredID = "";
46
46
  }
47
47
  /**
48
48
  * Define se o asterisco de obrigatoriedade deve ser exibido.
@@ -50,7 +50,9 @@ export class RequiredDirective {
50
50
  */
51
51
  set showMarker(value) { this._showMarker = value !== false && value !== 'false'; /* Qualquer valor diferente de false será tratado como true*/ }
52
52
  get showMarker() { return this._showMarker; }
53
+ //@Input() labelID!: string;
53
54
  ngOnInit() {
55
+ this._spanID = `required-span-${Math.random() * 100}`;
54
56
  if (this.showMarker) {
55
57
  this.addMarker();
56
58
  }
@@ -67,27 +69,27 @@ export class RequiredDirective {
67
69
  }
68
70
  /** Adiciona o marcador de asterisco ao elemento <label>. */
69
71
  addMarker() {
70
- if (document.getElementById(this.spanID)) {
72
+ if (document.getElementById(this._spanID)) {
71
73
  return;
72
74
  }
73
75
  const spanElement = document.createElement("span");
74
76
  spanElement.className = "text-danger";
75
77
  spanElement.innerHTML = " *";
76
- spanElement.id = this.spanID;
78
+ spanElement.id = this._spanID;
77
79
  this._renderer.appendChild(this._elementRef.nativeElement, spanElement);
78
80
  }
79
81
  /** Remove o marcador de asterisco do elemento <label>. */
80
82
  removeMarker() {
81
- if (this.spanID === "") {
83
+ if (this._spanID === "") {
82
84
  return;
83
85
  }
84
- const spanElement = document.getElementById(this.spanID);
86
+ const spanElement = document.getElementById(this._spanID);
85
87
  if (spanElement !== null) {
86
88
  this._renderer.removeChild(this._elementRef.nativeElement, spanElement);
87
89
  }
88
90
  }
89
91
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: RequiredDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
90
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: RequiredDirective, selector: "label[libRequired], span[libRequired], p[libRequired]", inputs: { showMarker: ["libRequired", "showMarker"], spanID: ["requiredID", "spanID"] }, usesOnChanges: true, ngImport: i0 }); }
92
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: RequiredDirective, selector: "label[libRequired], span[libRequired], p[libRequired]", inputs: { showMarker: ["libRequired", "showMarker"], requiredID: "requiredID" }, usesOnChanges: true, ngImport: i0 }); }
91
93
  }
92
94
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: RequiredDirective, decorators: [{
93
95
  type: Directive,
@@ -97,8 +99,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
97
99
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { showMarker: [{
98
100
  type: Input,
99
101
  args: ["libRequired"]
100
- }], spanID: [{
101
- type: Input,
102
- args: ["requiredID"]
102
+ }], requiredID: [{
103
+ type: Input
103
104
  }] } });
104
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWlyZWQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNwLWluZnJhL3NyYy9saWIvZGlyZWN0aXZlcy9yZXF1aXJlZC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQStDLE1BQU0sZUFBZSxDQUFDOztBQUUxRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQStCRztBQUlILE1BQU0sT0FBTyxpQkFBaUI7SUFHNUI7OztPQUdHO0lBQ0gsWUFDVSxXQUF1QixFQUN2QixTQUFvQjtRQURwQixnQkFBVyxHQUFYLFdBQVcsQ0FBWTtRQUN2QixjQUFTLEdBQVQsU0FBUyxDQUFXO1FBUnRCLGdCQUFXLEdBQVksSUFBSSxDQUFDLENBQUMsZUFBZTtRQW1CcEQseURBQXlEO1FBQ3BDLFdBQU0sR0FBVyxFQUFFLENBQUM7SUFYckMsQ0FBQztJQUVMOzs7T0FHRztJQUNILElBQ0ksVUFBVSxDQUFDLEtBQXVCLElBQUksSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLEtBQUssS0FBSyxJQUFJLEtBQUssS0FBSyxPQUFPLENBQUMsQ0FBQyw2REFBNkQsQ0FBQyxDQUFDO0lBQ2xLLElBQUksVUFBVSxLQUFjLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7SUFNdEQsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNuQixDQUFDO0lBQ0gsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxZQUFZLENBQUMsRUFBRSxZQUFZLEtBQUssT0FBTyxDQUFDLFlBQVksQ0FBQyxFQUFFLGFBQWEsSUFBSSxPQUFPLENBQUMsWUFBWSxDQUFDLEVBQUUsYUFBYSxLQUFLLFNBQVMsRUFBRSxDQUFDO1lBQ3ZJLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO2dCQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUFDLENBQUM7aUJBQ3JDLENBQUM7Z0JBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQUMsQ0FBQztRQUMvQixDQUFDO0lBQ0gsQ0FBQztJQUdELDREQUE0RDtJQUNwRCxTQUFTO1FBQ2YsSUFBSSxRQUFRLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQUMsT0FBTztRQUFDLENBQUM7UUFFckQsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNuRCxXQUFXLENBQUMsU0FBUyxHQUFHLGFBQWEsQ0FBQztRQUN0QyxXQUFXLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUM3QixXQUFXLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDN0IsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDMUUsQ0FBQztJQUVELDBEQUEwRDtJQUNsRCxZQUFZO1FBQ2xCLElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUFDLE9BQU87UUFBQyxDQUFDO1FBRW5DLE1BQU0sV0FBVyxHQUFHLFFBQVEsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3pELElBQUksV0FBVyxLQUFLLElBQUksRUFBRSxDQUFDO1lBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLEVBQUUsV0FBVyxDQUFDLENBQUM7UUFBQyxDQUFDO0lBQ3hHLENBQUM7K0dBdkRVLGlCQUFpQjttR0FBakIsaUJBQWlCOzs0RkFBakIsaUJBQWlCO2tCQUg3QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx1REFBdUQ7aUJBQ2xFO3VHQWtCSyxVQUFVO3NCQURiLEtBQUs7dUJBQUMsYUFBYTtnQkFLQyxNQUFNO3NCQUExQixLQUFLO3VCQUFDLFlBQVkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBPbkNoYW5nZXMsIE9uSW5pdCwgUmVuZGVyZXIyLCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuLyoqXG4gKiBEaXJldGl2YSBxdWUgYWRpY2lvbmEgdW0gYXN0ZXJpc2NvIHZlcm1lbGhvICgqKSBhbyBsYWRvIGRlIHVtIGVsZW1lbnRvIDxsYWJlbD5cbiAqIHBhcmEgaW5kaWNhciBxdWUgbyBjYW1wbyDDqSBvYnJpZ2F0w7NyaW8uXG4gKiBcbiAqICMjIFVzb1xuICogXG4gKiBObyBzZXUgdGVtcGxhdGUgSFRNTCwgdm9jw6ogcG9kZSB1c2FyIGEgZGlyZXRpdmEgZGUgZHVhcyBtYW5laXJhczpcbiAqIFxuICogMS4gU2VtIGVzcGVjaWZpY2FyIG8gdmFsb3IsIG9uZGUgbyBtYXJjYWRvciBzZXLDoSBleGliaWRvIHBvciBwYWRyw6NvOlxuICogXG4gKiBgYGBodG1sXG4gKiA8bGFiZWwgbGliUmVxdWlyZWQgZm9yPVwiaW5wdXRUZXN0ZVwiIGNsYXNzPVwiZm9ybS1sYWJlbFwiPlBlc3NvYTwvbGFiZWw+XG4gKiBgYGBcbiAqIFxuICogMi4gRXNwZWNpZmljYW5kbyBleHBsaWNpdGFtZW50ZSBvIHZhbG9yICh0cnVlIG91IGZhbHNlKTpcbiAqIFxuICogYGBgaHRtbFxuICogPGxhYmVsIFtsaWJSZXF1aXJlZF09XCJ0cnVlXCIgZm9yPVwiaW5wdXRUZXN0ZVwiIGNsYXNzPVwiZm9ybS1sYWJlbFwiPk5vbWU8L2xhYmVsPlxuICogPGxhYmVsIFtsaWJSZXF1aXJlZF09XCJmYWxzZVwiIGZvcj1cImlucHV0VGVzdGVcIiBjbGFzcz1cImZvcm0tbGFiZWxcIj5FbXByZXNhPC9sYWJlbD5cbiAqIGBgYFxuICogXG4gKiAjIyMgSW5wdXRzXG4gKiBcbiAqIC0gYGxpYlJlcXVpcmVkYDogYm9vbGVhbiB8IHN0cmluZ1xuICogICAtIERldGVybWluYSBzZSBvIGFzdGVyaXNjbyBkZSBvYnJpZ2F0b3JpZWRhZGUgZGV2ZSBzZXIgZXhpYmlkby4gXG4gKiAgIC0gQWNlaXRhIHZhbG9yZXMgYm9vbGVhbm9zIChgdHJ1ZWAgb3UgYGZhbHNlYCkgb3Ugc3RyaW5ncyAoYFwidHJ1ZVwiYCBvdSBgXCJmYWxzZVwiYCkuXG4gKiAgIC0gUGFkcsOjbzogYHRydWVgXG4gKiBcbiAqIC0gYHNpc0lEYDogc3RyaW5nXG4gKiAgIC0gSWRlbnRpZmljYWRvciDDum5pY28gcGFyYSBvIGVsZW1lbnRvIGA8c3Bhbj5gIGNyaWFkby5cbiAqICAgLSDDmnRpbCBwYXJhIG1hbmlwdWxhw6fDo28gZGlyZXRhIGRvIERPTSBvdSB0ZXN0ZXMuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogXCJsYWJlbFtsaWJSZXF1aXJlZF0sIHNwYW5bbGliUmVxdWlyZWRdLCBwW2xpYlJlcXVpcmVkXVwiXG59KVxuZXhwb3J0IGNsYXNzIFJlcXVpcmVkRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICBwcml2YXRlIF9zaG93TWFya2VyOiBib29sZWFuID0gdHJ1ZTsgLy8gVmFsb3IgcGFkcsOjb1xuXG4gIC8qKlxuICAgKiBAcGFyYW0gX2VsZW1lbnRSZWYgLSBSZWZlcsOqbmNpYSBhbyBlbGVtZW50byBET00gYW8gcXVhbCBhIGRpcmV0aXZhIGVzdMOhIGFzc29jaWFkYS5cbiAgICogQHBhcmFtIF9yZW5kZXJlciAtIFNlcnZpw6dvIEFuZ3VsYXIgcGFyYSBtYW5pcHVsYcOnw6NvIHNlZ3VyYSBkbyBET00uXG4gICAqL1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmLFxuICAgIHByaXZhdGUgX3JlbmRlcmVyOiBSZW5kZXJlcjIsXG4gICkgeyB9XG5cbiAgLyoqXG4gICAqIERlZmluZSBzZSBvIGFzdGVyaXNjbyBkZSBvYnJpZ2F0b3JpZWRhZGUgZGV2ZSBzZXIgZXhpYmlkby5cbiAgICogU2UgbmVuaHVtIHZhbG9yIGZvciBlc3BlY2lmaWNhZG8sIG8gcGFkcsOjbyDDqSB0cnVlLlxuICAgKi9cbiAgQElucHV0KFwibGliUmVxdWlyZWRcIilcbiAgc2V0IHNob3dNYXJrZXIodmFsdWU6IGJvb2xlYW4gfCBzdHJpbmcpIHsgdGhpcy5fc2hvd01hcmtlciA9IHZhbHVlICE9PSBmYWxzZSAmJiB2YWx1ZSAhPT0gJ2ZhbHNlJzsgLyogUXVhbHF1ZXIgdmFsb3IgZGlmZXJlbnRlIGRlIGZhbHNlIHNlcsOhIHRyYXRhZG8gY29tbyB0cnVlKi8gfVxuICBnZXQgc2hvd01hcmtlcigpOiBib29sZWFuIHsgcmV0dXJuIHRoaXMuX3Nob3dNYXJrZXI7IH1cblxuICAvKiogSWRlbnRpZmljYWRvciDDum5pY28gcGFyYSBvIGVsZW1lbnRvIDxzcGFuPiBjcmlhZG8uICovXG4gIEBJbnB1dChcInJlcXVpcmVkSURcIikgc3BhbklEOiBzdHJpbmcgPSBcIlwiO1xuXG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuc2hvd01hcmtlcikge1xuICAgICAgdGhpcy5hZGRNYXJrZXIoKTtcbiAgICB9XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgaWYgKGNoYW5nZXNbXCJzaG93TWFya2VyXCJdPy5jdXJyZW50VmFsdWUgIT09IGNoYW5nZXNbXCJzaG93TWFya2VyXCJdPy5wcmV2aW91c1ZhbHVlICYmIGNoYW5nZXNbXCJzaG93TWFya2VyXCJdPy5wcmV2aW91c1ZhbHVlICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIGlmICh0aGlzLnNob3dNYXJrZXIpIHsgdGhpcy5hZGRNYXJrZXIoKTsgfVxuICAgICAgZWxzZSB7IHRoaXMucmVtb3ZlTWFya2VyKCk7IH1cbiAgICB9XG4gIH1cblxuXG4gIC8qKiBBZGljaW9uYSBvIG1hcmNhZG9yIGRlIGFzdGVyaXNjbyBhbyBlbGVtZW50byA8bGFiZWw+LiAqL1xuICBwcml2YXRlIGFkZE1hcmtlcigpOiB2b2lkIHtcbiAgICBpZiAoZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQodGhpcy5zcGFuSUQpKSB7IHJldHVybjsgfVxuXG4gICAgY29uc3Qgc3BhbkVsZW1lbnQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwic3BhblwiKTtcbiAgICBzcGFuRWxlbWVudC5jbGFzc05hbWUgPSBcInRleHQtZGFuZ2VyXCI7XG4gICAgc3BhbkVsZW1lbnQuaW5uZXJIVE1MID0gXCIgKlwiO1xuICAgIHNwYW5FbGVtZW50LmlkID0gdGhpcy5zcGFuSUQ7XG4gICAgdGhpcy5fcmVuZGVyZXIuYXBwZW5kQ2hpbGQodGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCBzcGFuRWxlbWVudCk7XG4gIH1cblxuICAvKiogUmVtb3ZlIG8gbWFyY2Fkb3IgZGUgYXN0ZXJpc2NvIGRvIGVsZW1lbnRvIDxsYWJlbD4uICovXG4gIHByaXZhdGUgcmVtb3ZlTWFya2VyKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLnNwYW5JRCA9PT0gXCJcIikgeyByZXR1cm47IH1cblxuICAgIGNvbnN0IHNwYW5FbGVtZW50ID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQodGhpcy5zcGFuSUQpO1xuICAgIGlmIChzcGFuRWxlbWVudCAhPT0gbnVsbCkgeyB0aGlzLl9yZW5kZXJlci5yZW1vdmVDaGlsZCh0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsIHNwYW5FbGVtZW50KTsgfVxuICB9XG59XG4iXX0=
105
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWlyZWQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNwLWluZnJhL3NyYy9saWIvZGlyZWN0aXZlcy9yZXF1aXJlZC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQStDLE1BQU0sZUFBZSxDQUFDOztBQUUxRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQStCRztBQUlILE1BQU0sT0FBTyxpQkFBaUI7SUFHNUI7OztPQUdHO0lBQ0gsWUFDVSxXQUF1QixFQUN2QixTQUFvQjtRQURwQixnQkFBVyxHQUFYLFdBQVcsQ0FBWTtRQUN2QixjQUFTLEdBQVQsU0FBUyxDQUFXO1FBUnRCLGdCQUFXLEdBQVksSUFBSSxDQUFDLENBQUMsZUFBZTtRQW1CcEQsc0VBQXNFO1FBQzdELGVBQVUsR0FBVyxFQUFFLENBQUM7SUFYN0IsQ0FBQztJQUVMOzs7T0FHRztJQUNILElBQ0ksVUFBVSxDQUFDLEtBQXVCLElBQUksSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLEtBQUssS0FBSyxJQUFJLEtBQUssS0FBSyxPQUFPLENBQUMsQ0FBQyw2REFBNkQsQ0FBQyxDQUFDO0lBQ2xLLElBQUksVUFBVSxLQUFjLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7SUFNdEQsNEJBQTRCO0lBRzVCLFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxHQUFHLGlCQUFpQixJQUFJLENBQUMsTUFBTSxFQUFFLEdBQUcsR0FBRyxFQUFFLENBQUM7UUFFdEQsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQ25CLENBQUM7SUFDSCxDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLElBQUksT0FBTyxDQUFDLFlBQVksQ0FBQyxFQUFFLFlBQVksS0FBSyxPQUFPLENBQUMsWUFBWSxDQUFDLEVBQUUsYUFBYSxJQUFJLE9BQU8sQ0FBQyxZQUFZLENBQUMsRUFBRSxhQUFhLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDdkksSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQUMsQ0FBQztpQkFDckMsQ0FBQztnQkFBQyxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFBQyxDQUFDO1FBQy9CLENBQUM7SUFDSCxDQUFDO0lBR0QsNERBQTREO0lBQ3BELFNBQVM7UUFDZixJQUFJLFFBQVEsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFBQyxPQUFPO1FBQUMsQ0FBQztRQUV0RCxNQUFNLFdBQVcsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ25ELFdBQVcsQ0FBQyxTQUFTLEdBQUcsYUFBYSxDQUFDO1FBQ3RDLFdBQVcsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBQzdCLFdBQVcsQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQztRQUM5QixJQUFJLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsRUFBRSxXQUFXLENBQUMsQ0FBQztJQUMxRSxDQUFDO0lBRUQsMERBQTBEO0lBQ2xELFlBQVk7UUFDbEIsSUFBSSxJQUFJLENBQUMsT0FBTyxLQUFLLEVBQUUsRUFBRSxDQUFDO1lBQUMsT0FBTztRQUFDLENBQUM7UUFFcEMsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDMUQsSUFBSSxXQUFXLEtBQUssSUFBSSxFQUFFLENBQUM7WUFBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsRUFBRSxXQUFXLENBQUMsQ0FBQztRQUFDLENBQUM7SUFDeEcsQ0FBQzsrR0E1RFUsaUJBQWlCO21HQUFqQixpQkFBaUI7OzRGQUFqQixpQkFBaUI7a0JBSDdCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVEQUF1RDtpQkFDbEU7dUdBa0JLLFVBQVU7c0JBRGIsS0FBSzt1QkFBQyxhQUFhO2dCQUtYLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBPbkNoYW5nZXMsIE9uSW5pdCwgUmVuZGVyZXIyLCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuLyoqXG4gKiBEaXJldGl2YSBxdWUgYWRpY2lvbmEgdW0gYXN0ZXJpc2NvIHZlcm1lbGhvICgqKSBhbyBsYWRvIGRlIHVtIGVsZW1lbnRvIDxsYWJlbD5cbiAqIHBhcmEgaW5kaWNhciBxdWUgbyBjYW1wbyDDqSBvYnJpZ2F0w7NyaW8uXG4gKiBcbiAqICMjIFVzb1xuICogXG4gKiBObyBzZXUgdGVtcGxhdGUgSFRNTCwgdm9jw6ogcG9kZSB1c2FyIGEgZGlyZXRpdmEgZGUgZHVhcyBtYW5laXJhczpcbiAqIFxuICogMS4gU2VtIGVzcGVjaWZpY2FyIG8gdmFsb3IsIG9uZGUgbyBtYXJjYWRvciBzZXLDoSBleGliaWRvIHBvciBwYWRyw6NvOlxuICogXG4gKiBgYGBodG1sXG4gKiA8bGFiZWwgbGliUmVxdWlyZWQgZm9yPVwiaW5wdXRUZXN0ZVwiIGNsYXNzPVwiZm9ybS1sYWJlbFwiPlBlc3NvYTwvbGFiZWw+XG4gKiBgYGBcbiAqIFxuICogMi4gRXNwZWNpZmljYW5kbyBleHBsaWNpdGFtZW50ZSBvIHZhbG9yICh0cnVlIG91IGZhbHNlKTpcbiAqIFxuICogYGBgaHRtbFxuICogPGxhYmVsIFtsaWJSZXF1aXJlZF09XCJ0cnVlXCIgZm9yPVwiaW5wdXRUZXN0ZVwiIGNsYXNzPVwiZm9ybS1sYWJlbFwiPk5vbWU8L2xhYmVsPlxuICogPGxhYmVsIFtsaWJSZXF1aXJlZF09XCJmYWxzZVwiIGZvcj1cImlucHV0VGVzdGVcIiBjbGFzcz1cImZvcm0tbGFiZWxcIj5FbXByZXNhPC9sYWJlbD5cbiAqIGBgYFxuICogXG4gKiAjIyMgSW5wdXRzXG4gKiBcbiAqIC0gYGxpYlJlcXVpcmVkYDogYm9vbGVhbiB8IHN0cmluZ1xuICogICAtIERldGVybWluYSBzZSBvIGFzdGVyaXNjbyBkZSBvYnJpZ2F0b3JpZWRhZGUgZGV2ZSBzZXIgZXhpYmlkby4gXG4gKiAgIC0gQWNlaXRhIHZhbG9yZXMgYm9vbGVhbm9zIChgdHJ1ZWAgb3UgYGZhbHNlYCkgb3Ugc3RyaW5ncyAoYFwidHJ1ZVwiYCBvdSBgXCJmYWxzZVwiYCkuXG4gKiAgIC0gUGFkcsOjbzogYHRydWVgXG4gKiBcbiAqIC0gYHNpc0lEYDogc3RyaW5nXG4gKiAgIC0gSWRlbnRpZmljYWRvciDDum5pY28gcGFyYSBvIGVsZW1lbnRvIGA8c3Bhbj5gIGNyaWFkby5cbiAqICAgLSDDmnRpbCBwYXJhIG1hbmlwdWxhw6fDo28gZGlyZXRhIGRvIERPTSBvdSB0ZXN0ZXMuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogXCJsYWJlbFtsaWJSZXF1aXJlZF0sIHNwYW5bbGliUmVxdWlyZWRdLCBwW2xpYlJlcXVpcmVkXVwiXG59KVxuZXhwb3J0IGNsYXNzIFJlcXVpcmVkRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICBwcml2YXRlIF9zaG93TWFya2VyOiBib29sZWFuID0gdHJ1ZTsgLy8gVmFsb3IgcGFkcsOjb1xuXG4gIC8qKlxuICAgKiBAcGFyYW0gX2VsZW1lbnRSZWYgLSBSZWZlcsOqbmNpYSBhbyBlbGVtZW50byBET00gYW8gcXVhbCBhIGRpcmV0aXZhIGVzdMOhIGFzc29jaWFkYS5cbiAgICogQHBhcmFtIF9yZW5kZXJlciAtIFNlcnZpw6dvIEFuZ3VsYXIgcGFyYSBtYW5pcHVsYcOnw6NvIHNlZ3VyYSBkbyBET00uXG4gICAqL1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmLFxuICAgIHByaXZhdGUgX3JlbmRlcmVyOiBSZW5kZXJlcjIsXG4gICkgeyB9XG5cbiAgLyoqXG4gICAqIERlZmluZSBzZSBvIGFzdGVyaXNjbyBkZSBvYnJpZ2F0b3JpZWRhZGUgZGV2ZSBzZXIgZXhpYmlkby5cbiAgICogU2UgbmVuaHVtIHZhbG9yIGZvciBlc3BlY2lmaWNhZG8sIG8gcGFkcsOjbyDDqSB0cnVlLlxuICAgKi9cbiAgQElucHV0KFwibGliUmVxdWlyZWRcIilcbiAgc2V0IHNob3dNYXJrZXIodmFsdWU6IGJvb2xlYW4gfCBzdHJpbmcpIHsgdGhpcy5fc2hvd01hcmtlciA9IHZhbHVlICE9PSBmYWxzZSAmJiB2YWx1ZSAhPT0gJ2ZhbHNlJzsgLyogUXVhbHF1ZXIgdmFsb3IgZGlmZXJlbnRlIGRlIGZhbHNlIHNlcsOhIHRyYXRhZG8gY29tbyB0cnVlKi8gfVxuICBnZXQgc2hvd01hcmtlcigpOiBib29sZWFuIHsgcmV0dXJuIHRoaXMuX3Nob3dNYXJrZXI7IH1cblxuICAvKiogW0RFUFJFQ0lBRE9dIElkZW50aWZpY2Fkb3Igw7puaWNvIHBhcmEgbyBlbGVtZW50byA8c3Bhbj4gY3JpYWRvLiAqL1xuICBASW5wdXQoKSByZXF1aXJlZElEOiBzdHJpbmcgPSBcIlwiO1xuXG4gIHByaXZhdGUgX3NwYW5JRCE6IHN0cmluZztcbiAgLy9ASW5wdXQoKSBsYWJlbElEITogc3RyaW5nO1xuXG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fc3BhbklEID0gYHJlcXVpcmVkLXNwYW4tJHtNYXRoLnJhbmRvbSgpICogMTAwfWA7XG5cbiAgICBpZiAodGhpcy5zaG93TWFya2VyKSB7XG4gICAgICB0aGlzLmFkZE1hcmtlcigpO1xuICAgIH1cbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICBpZiAoY2hhbmdlc1tcInNob3dNYXJrZXJcIl0/LmN1cnJlbnRWYWx1ZSAhPT0gY2hhbmdlc1tcInNob3dNYXJrZXJcIl0/LnByZXZpb3VzVmFsdWUgJiYgY2hhbmdlc1tcInNob3dNYXJrZXJcIl0/LnByZXZpb3VzVmFsdWUgIT09IHVuZGVmaW5lZCkge1xuICAgICAgaWYgKHRoaXMuc2hvd01hcmtlcikgeyB0aGlzLmFkZE1hcmtlcigpOyB9XG4gICAgICBlbHNlIHsgdGhpcy5yZW1vdmVNYXJrZXIoKTsgfVxuICAgIH1cbiAgfVxuXG5cbiAgLyoqIEFkaWNpb25hIG8gbWFyY2Fkb3IgZGUgYXN0ZXJpc2NvIGFvIGVsZW1lbnRvIDxsYWJlbD4uICovXG4gIHByaXZhdGUgYWRkTWFya2VyKCk6IHZvaWQge1xuICAgIGlmIChkb2N1bWVudC5nZXRFbGVtZW50QnlJZCh0aGlzLl9zcGFuSUQpKSB7IHJldHVybjsgfVxuXG4gICAgY29uc3Qgc3BhbkVsZW1lbnQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwic3BhblwiKTtcbiAgICBzcGFuRWxlbWVudC5jbGFzc05hbWUgPSBcInRleHQtZGFuZ2VyXCI7XG4gICAgc3BhbkVsZW1lbnQuaW5uZXJIVE1MID0gXCIgKlwiO1xuICAgIHNwYW5FbGVtZW50LmlkID0gdGhpcy5fc3BhbklEO1xuICAgIHRoaXMuX3JlbmRlcmVyLmFwcGVuZENoaWxkKHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgc3BhbkVsZW1lbnQpO1xuICB9XG5cbiAgLyoqIFJlbW92ZSBvIG1hcmNhZG9yIGRlIGFzdGVyaXNjbyBkbyBlbGVtZW50byA8bGFiZWw+LiAqL1xuICBwcml2YXRlIHJlbW92ZU1hcmtlcigpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5fc3BhbklEID09PSBcIlwiKSB7IHJldHVybjsgfVxuXG4gICAgY29uc3Qgc3BhbkVsZW1lbnQgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCh0aGlzLl9zcGFuSUQpO1xuICAgIGlmIChzcGFuRWxlbWVudCAhPT0gbnVsbCkgeyB0aGlzLl9yZW5kZXJlci5yZW1vdmVDaGlsZCh0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsIHNwYW5FbGVtZW50KTsgfVxuICB9XG59XG4iXX0=
@@ -164,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
164
164
  }], clickOutside: [{
165
165
  type: Output
166
166
  }] } });
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clickoutside.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/click-outside/clickoutside.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective,\n\tElementRef,\n\tEventEmitter,\n\tInject,\n\tInput,\n\tNgZone,\n\tOnChanges,\n\tOnDestroy,\n\tOnInit,\n\tOutput,\n\tSimpleChanges,\n    } from '@angular/core';\n    import {DOCUMENT} from '@angular/common';\n    \n    @Directive({selector: '[clickOutside]'})\n    export class ClickOutsideDirective implements OnInit, OnChanges, OnDestroy {\n    \n\t@Input() clickOutsideEnabled = true;\n    \n\t@Input() attachOutsideOnClick = false;\n\t@Input() delayClickOutsideInit = false;\n\t@Input() emitOnBlur = false;\n    \n\t@Input() exclude = '';\n\t@Input() excludeBeforeClick = false;\n    \n\t@Input() clickOutsideEvents = '';\n    \n\t@Output() clickOutside: EventEmitter<Event> = new EventEmitter<Event>();\n    \n\tprivate _nodesExcluded: Array<HTMLElement> = [];\n\tprivate _events: Array<string> = ['click'];\n    \n\tconstructor(\n\t  private _el: ElementRef,\n\t  private _ngZone: NgZone,\n\t  @Inject(DOCUMENT) private document: Document) {\n\t  this._initOnClickBody = this._initOnClickBody.bind(this);\n\t  this._onClickBody = this._onClickBody.bind(this);\n\t  this._onWindowBlur = this._onWindowBlur.bind(this);\n\t}\n    \n\tngOnInit() {\n\t  this._init();\n\t}\n    \n\tngOnDestroy() {\n\t  this._removeClickOutsideListener();\n\t  this._removeAttachOutsideOnClickListener();\n\t  this._removeWindowBlurListener();\n\t}\n    \n\tngOnChanges(changes: SimpleChanges) {\n\t  if (changes['attachOutsideOnClick'] || changes['exclude'] || changes['emitOnBlur']) {\n\t    this._init();\n\t  }\n\t}\n    \n\tprivate _init() {\n\t  if (this.clickOutsideEvents !== '') {\n\t    this._events = this.clickOutsideEvents.split(',').map(e => e.trim());\n\t  }\n    \n\t  this._excludeCheck();\n    \n\t  if (this.attachOutsideOnClick) {\n\t    this._initAttachOutsideOnClickListener();\n\t  } else {\n\t    this._initOnClickBody();\n\t  }\n    \n\t  if (this.emitOnBlur) {\n\t    this._initWindowBlurListener();\n\t  }\n\t}\n    \n\tprivate _initOnClickBody() {\n\t  if (this.delayClickOutsideInit) {\n\t    setTimeout(this._initClickOutsideListener.bind(this));\n\t  } else {\n\t    this._initClickOutsideListener();\n\t  }\n\t}\n    \n\tprivate _excludeCheck() {\n\t  if (this.exclude) {\n\t    try {\n\t\tconst nodes = Array.from(this.document.querySelectorAll(this.exclude)) as Array<HTMLElement>;\n\t\tif (nodes) {\n\t\t  this._nodesExcluded = nodes;\n\t\t}\n\t    } catch (err) {\n\t\tconsole.error('[ng-click-outside] Check your exclude selector syntax.', err);\n\t    }\n\t  }\n\t}\n    \n\tprivate _onClickBody(ev: Event) {\n\t  if (!this.clickOutsideEnabled) {\n\t    return;\n\t  }\n    \n\t  if (this.excludeBeforeClick) {\n\t    this._excludeCheck();\n\t  }\n    \n\t  if (!this._el.nativeElement.contains(ev.target) && !this._shouldExclude(ev.target)) {\n\t    this._emit(ev);\n    \n\t    if (this.attachOutsideOnClick) {\n\t\tthis._removeClickOutsideListener();\n\t    }\n\t  }\n\t}\n    \n\t/**\n\t * Resolves problem with outside click on iframe\n\t * @see https://github.com/arkon/ng-click-outside/issues/32\n\t */\n\tprivate _onWindowBlur(ev: Event) {\n\t  setTimeout(() => {\n\t    if (!this.document.hidden) {\n\t\tthis._emit(ev);\n\t    }\n\t  });\n\t}\n    \n\tprivate _emit(ev: Event) {\n\t  if (!this.clickOutsideEnabled) {\n\t    return;\n\t  }\n    \n\t  this._ngZone.run(() => this.clickOutside.emit(ev));\n\t}\n    \n\tprivate _shouldExclude(target: any): boolean {\n\t  for (const excludedNode of this._nodesExcluded) {\n\t    if (excludedNode.contains(target)) {\n\t\treturn true;\n\t    }\n\t  }\n    \n\t  return false;\n\t}\n    \n\tprivate _initClickOutsideListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    this._events.forEach(e => this.document.addEventListener(e, this._onClickBody));\n\t  });\n\t}\n    \n\tprivate _removeClickOutsideListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    this._events.forEach(e => this.document.removeEventListener(e, this._onClickBody));\n\t  });\n\t}\n    \n\tprivate _initAttachOutsideOnClickListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    this._events.forEach(e => this._el.nativeElement.addEventListener(e, this._initOnClickBody));\n\t  });\n\t}\n    \n\tprivate _removeAttachOutsideOnClickListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    this._events.forEach(e => this._el.nativeElement.removeEventListener(e, this._initOnClickBody));\n\t  });\n\t}\n    \n\tprivate _initWindowBlurListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    window.addEventListener('blur', this._onWindowBlur);\n\t  });\n\t}\n    \n\tprivate _removeWindowBlurListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    window.removeEventListener('blur', this._onWindowBlur);\n\t  });\n\t}\n    \n    }"]}
167
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clickoutside.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/click-outside/clickoutside.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective,\n\tElementRef,\n\tEventEmitter,\n\tInject,\n\tInput,\n\tNgZone,\n\tOnChanges,\n\tOnDestroy,\n\tOnInit,\n\tOutput,\n\tSimpleChanges,\n    } from '@angular/core';\n    import {DOCUMENT} from '@angular/common';\n    \n    @Directive({selector: '[clickOutside]'})\n    export class ClickOutsideDirective implements OnInit, OnChanges, OnDestroy {\n    \n\t@Input() clickOutsideEnabled = true;\n    \n\t@Input() attachOutsideOnClick = false;\n\t@Input() delayClickOutsideInit = false;\n\t@Input() emitOnBlur = false;\n    \n\t@Input() exclude = '';\n\t@Input() excludeBeforeClick = false;\n    \n\t@Input() clickOutsideEvents = '';\n    \n\t@Output() clickOutside: EventEmitter<Event> = new EventEmitter<Event>();\n    \n\tprivate _nodesExcluded: Array<HTMLElement> = [];\n\tprivate _events: Array<string> = ['click'];\n    \n\tconstructor(\n\t\tprivate _el: ElementRef,\n\t\tprivate _ngZone: NgZone,\n\t\t@Inject(DOCUMENT) private document: Document) {\n\t\tthis._initOnClickBody = this._initOnClickBody.bind(this);\n\t\tthis._onClickBody = this._onClickBody.bind(this);\n\t\tthis._onWindowBlur = this._onWindowBlur.bind(this);\n\t}\n    \n\tngOnInit() {\n\t  this._init();\n\t}\n    \n\tngOnDestroy() {\n\t  this._removeClickOutsideListener();\n\t  this._removeAttachOutsideOnClickListener();\n\t  this._removeWindowBlurListener();\n\t}\n    \n\tngOnChanges(changes: SimpleChanges) {\n\t  if (changes['attachOutsideOnClick'] || changes['exclude'] || changes['emitOnBlur']) {\n\t    this._init();\n\t  }\n\t}\n    \n\tprivate _init() {\n\t  if (this.clickOutsideEvents !== '') {\n\t    this._events = this.clickOutsideEvents.split(',').map(e => e.trim());\n\t  }\n    \n\t  this._excludeCheck();\n    \n\t  if (this.attachOutsideOnClick) {\n\t    this._initAttachOutsideOnClickListener();\n\t  } else {\n\t    this._initOnClickBody();\n\t  }\n    \n\t  if (this.emitOnBlur) {\n\t    this._initWindowBlurListener();\n\t  }\n\t}\n    \n\tprivate _initOnClickBody() {\n\t  if (this.delayClickOutsideInit) {\n\t    setTimeout(this._initClickOutsideListener.bind(this));\n\t  } else {\n\t    this._initClickOutsideListener();\n\t  }\n\t}\n    \n\tprivate _excludeCheck() {\n\t  if (this.exclude) {\n\t    try {\n\t\tconst nodes = Array.from(this.document.querySelectorAll(this.exclude)) as Array<HTMLElement>;\n\t\tif (nodes) {\n\t\t  this._nodesExcluded = nodes;\n\t\t}\n\t    } catch (err) {\n\t\tconsole.error('[ng-click-outside] Check your exclude selector syntax.', err);\n\t    }\n\t  }\n\t}\n    \n\tprivate _onClickBody(ev: Event) {\n\t  if (!this.clickOutsideEnabled) {\n\t    return;\n\t  }\n    \n\t  if (this.excludeBeforeClick) {\n\t    this._excludeCheck();\n\t  }\n    \n\t  if (!this._el.nativeElement.contains(ev.target) && !this._shouldExclude(ev.target)) {\n\t    this._emit(ev);\n    \n\t    if (this.attachOutsideOnClick) {\n\t\tthis._removeClickOutsideListener();\n\t    }\n\t  }\n\t}\n    \n\t/**\n\t * Resolves problem with outside click on iframe\n\t * @see https://github.com/arkon/ng-click-outside/issues/32\n\t */\n\tprivate _onWindowBlur(ev: Event) {\n\t  setTimeout(() => {\n\t    if (!this.document.hidden) {\n\t\tthis._emit(ev);\n\t    }\n\t  });\n\t}\n    \n\tprivate _emit(ev: Event) {\n\t  if (!this.clickOutsideEnabled) {\n\t    return;\n\t  }\n    \n\t  this._ngZone.run(() => this.clickOutside.emit(ev));\n\t}\n    \n\tprivate _shouldExclude(target: any): boolean {\n\t  for (const excludedNode of this._nodesExcluded) {\n\t    if (excludedNode.contains(target)) {\n\t\treturn true;\n\t    }\n\t  }\n    \n\t  return false;\n\t}\n    \n\tprivate _initClickOutsideListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    this._events.forEach(e => this.document.addEventListener(e, this._onClickBody));\n\t  });\n\t}\n    \n\tprivate _removeClickOutsideListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    this._events.forEach(e => this.document.removeEventListener(e, this._onClickBody));\n\t  });\n\t}\n    \n\tprivate _initAttachOutsideOnClickListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    this._events.forEach(e => this._el.nativeElement.addEventListener(e, this._initOnClickBody));\n\t  });\n\t}\n    \n\tprivate _removeAttachOutsideOnClickListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    this._events.forEach(e => this._el.nativeElement.removeEventListener(e, this._initOnClickBody));\n\t  });\n\t}\n    \n\tprivate _initWindowBlurListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    window.addEventListener('blur', this._onWindowBlur);\n\t  });\n\t}\n    \n\tprivate _removeWindowBlurListener() {\n\t  this._ngZone.runOutsideAngular(() => {\n\t    window.removeEventListener('blur', this._onWindowBlur);\n\t  });\n\t}\n    \n    }"]}
@@ -24,7 +24,7 @@ import * as i6 from "../../pipes/text-filter.pipe";
24
24
  * - Inicialização de um valor selecionado, se fornecido.
25
25
  *
26
26
  * ## Inputs:
27
- * - `outerControl` (FormControl | AbstractControl): Control para seleção dos valores, atualizará automaticamente o control do componente pai também
27
+ * - `control` (FormControl | AbstractControl): Control para seleção dos valores, atualizará automaticamente o control do componente pai também
28
28
  * - `comboboxList` (RecordCombobox[]): Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner
29
29
  * - `labelText` (string): Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido
30
30
  * - `disabled` (boolean): Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo
@@ -52,8 +52,8 @@ export class LibComboboxComponent {
52
52
  /** (obrigatório) Control para seleção dos valores, atualizará automaticamente o control do componente pai também
53
53
  * @alias 'control'
54
54
  * @type {FormControl<any> | AbstractControl<any>} */
55
- get outerControl() { return this._outerControl; }
56
- set outerControl(value) {
55
+ get control() { return this._outerControl; }
56
+ set control(value) {
57
57
  this._outerControl = value;
58
58
  // Cancela a subscrição anterior (se houver) para evitar múltiplas subscrições
59
59
  if (this._subscription)
@@ -130,6 +130,7 @@ export class LibComboboxComponent {
130
130
  }
131
131
  ngOnInit() {
132
132
  this.comboboxID = `lib-combobox-${Math.random() * 100}`;
133
+ this.labelID = `${Math.random() * 100}`;
133
134
  this.adjustDropdownWidth();
134
135
  this.setValidator();
135
136
  this.updateSelectedValue();
@@ -138,13 +139,13 @@ export class LibComboboxComponent {
138
139
  this.adjustDropdownWidth();
139
140
  }
140
141
  ngOnChanges(changes) {
141
- if (changes["comboboxList"]?.currentValue)
142
+ if (changes["list"]?.currentValue)
142
143
  this.updateSelectedValue();
143
144
  if (changes["libRequired"]?.currentValue != undefined)
144
145
  this.setValidator();
145
- if (changes["outerControl"]?.currentValue) {
146
+ if (changes["control"]?.currentValue) {
146
147
  this.setValidator();
147
- this.updateSelectedValue(changes["outerControl"].currentValue.value);
148
+ this.updateSelectedValue(changes["control"].currentValue.value);
148
149
  }
149
150
  }
150
151
  ngOnDestroy() {
@@ -175,13 +176,17 @@ export class LibComboboxComponent {
175
176
  this.changeValue.emit(null);
176
177
  }
177
178
  updateSelectedValue(value) {
179
+ console.log("this.innerControl", this.innerControl);
178
180
  this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa
179
181
  const selectedValue = value ?? this._outerControl.value;
182
+ console.log("selectedValue", selectedValue);
180
183
  if (!this.list || (selectedValue === null && selectedValue === ''))
181
184
  return;
182
185
  const initializedValue = this.list.find(item => item.ID === selectedValue);
186
+ console.log("initializedValue", initializedValue);
183
187
  if (initializedValue)
184
188
  this.innerControl.setValue(`${initializedValue.AdditionalStringProperty1 && initializedValue.AdditionalStringProperty1 != '' ? initializedValue.AdditionalStringProperty1 : ""}${this.separator === undefined ? " " : " " + this.separator + " "}${initializedValue.LABEL}`);
189
+ console.log("this.innerControl", this.innerControl);
185
190
  }
186
191
  adjustDropdownWidth() {
187
192
  if (this._mainInput && this._dropdownMenu) {
@@ -235,14 +240,14 @@ export class LibComboboxComponent {
235
240
  }
236
241
  reloadList() { this.reloadListChange.emit(this.textoPesquisa); }
237
242
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LibComboboxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
238
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: LibComboboxComponent, selector: "lib-combobox", inputs: { outerControl: ["control", "outerControl"], list: "list", labelText: "labelText", separator: "separator", libRequired: "libRequired", disabled: "disabled", mainPlaceholder: "mainPlaceholder", searchPlaceholder: "searchPlaceholder", theme: "theme", returnRecord: "returnRecord" }, outputs: { reloadListChange: "reloadListChange", changeValue: "changeValue" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "_mainInput", first: true, predicate: ["mainInput"], descendants: true }, { propertyName: "_searchInput", first: true, predicate: ["searchInput"], descendants: true }, { propertyName: "_dropdownMenu", first: true, predicate: ["dropdownMenu"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<!-- eslint-disable @angular-eslint/template/interactive-supports-focus -->\n<!-- eslint-disable @angular-eslint/template/click-events-have-key-events -->\n\n<label *ngIf=\"labelText && labelText !== ''\" [for]=\"comboboxID\" [libRequired]=\"isRequired\" [requiredID]=\"comboboxID ?? ''\" 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\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\n Ao usar o atributo [btnLeft], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\n <ng-content select=\"[btnLeft]\"></ng-content>\n\n <input #mainInput class=\"form-select text-start rounded-end cursor-pointer\" type=\"text\" data-bs-toggle=\"dropdown\" [placeholder]=\"mainPlaceholder\"\n [formControl]=\"innerControl\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly [class.is-invalid]=\"invalidControl\"\n [id]=\"comboboxID\"\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]=\"searchPlaceholder\" (keyup.enter)=\"reloadList()\">\n <button class=\"btn btn-{{theme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\n </div>\n\n @if (list) {\n <li *ngIf=\"innerControl.value !== '' && innerControl.value !== null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar op\u00E7\u00E3o selecionada</span> </li>\n @for (item of list | 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\">\n {{ item.AdditionalStringProperty1 + (separator === undefined ? \"\" : \" \"+separator) }}\n </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\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado direito do combobox de pesquisa.\n Ao usar o atributo [btnRight], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\n <ng-content select=\"[btnRight]\"></ng-content>\n\n</div>\n\n<!-- #region MENSAGEM DE ERRO DE VALIDA\u00C7\u00C3O -->\n<app-field-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo \u00E9 obrigat\u00F3rio.\" />\n<!-- #endregion MENSAGEM DE ERRO DE VALIDA\u00C7\u00C3O -->\n", styles: [".glb-max-height-350px{max-height:350px!important}.form-label{font-size:16px!important}.z-index-1020{z-index:1020!important}.cursor-pointer{cursor:pointer!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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"] }, { kind: "component", type: i3.FieldErrorMessageComponent, selector: "app-field-error-message", inputs: ["customMessage", "control", "label"] }, { kind: "component", type: i4.SvgStorageComponent, selector: "app-svg-storage", inputs: ["svgName", "svgColor", "svgFill", "svgSize", "svgStrokeWidth"] }, { kind: "directive", type: i5.RequiredDirective, selector: "label[libRequired], span[libRequired], p[libRequired]", inputs: ["libRequired", "requiredID"] }, { kind: "pipe", type: i6.TextFilterPipe, name: "textFilter" }] }); }
243
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: LibComboboxComponent, selector: "lib-combobox", inputs: { control: "control", list: "list", labelText: "labelText", separator: "separator", libRequired: "libRequired", disabled: "disabled", mainPlaceholder: "mainPlaceholder", searchPlaceholder: "searchPlaceholder", theme: "theme", returnRecord: "returnRecord" }, outputs: { reloadListChange: "reloadListChange", changeValue: "changeValue" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "_mainInput", first: true, predicate: ["mainInput"], descendants: true }, { propertyName: "_searchInput", first: true, predicate: ["searchInput"], descendants: true }, { propertyName: "_dropdownMenu", first: true, predicate: ["dropdownMenu"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<!-- eslint-disable @angular-eslint/template/interactive-supports-focus -->\n<!-- eslint-disable @angular-eslint/template/click-events-have-key-events -->\n\n<label *ngIf=\"labelText && labelText !== ''\" class=\"form-label fw-bold\" [id]=\"labelID\" [for]=\"comboboxID\" [libRequired]=\"isRequired\">{{ labelText }}</label>\n\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\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\n Ao usar o atributo [btnLeft], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\n <ng-content select=\"[btnLeft]\"></ng-content>\n\n <input #mainInput class=\"form-select text-start rounded-end cursor-pointer\" type=\"text\"\n data-bs-toggle=\"dropdown\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly\n [placeholder]=\"mainPlaceholder\" [formControl]=\"innerControl\" [class.is-invalid]=\"invalidControl\" [id]=\"comboboxID\"\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-{{comboboxID}}\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchPlaceholder\" (keyup.enter)=\"reloadList()\">\n <button class=\"btn btn-{{theme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\n </div>\n\n @if (list) {\n <li *ngIf=\"innerControl.value !== '' && innerControl.value !== null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar op\u00E7\u00E3o selecionada</span> </li>\n @for (item of list | 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\">\n {{ item.AdditionalStringProperty1 + (separator === undefined ? \"\" : \" \"+separator) }}\n </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\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado direito do combobox de pesquisa.\n Ao usar o atributo [btnRight], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\n <ng-content select=\"[btnRight]\"></ng-content>\n\n</div>\n\n<!-- #region MENSAGEM DE ERRO DE VALIDA\u00C7\u00C3O -->\n<app-field-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo \u00E9 obrigat\u00F3rio.\" />\n<!-- #endregion MENSAGEM DE ERRO DE VALIDA\u00C7\u00C3O -->\n", styles: [".glb-max-height-350px{max-height:350px!important}.form-label{font-size:16px!important}.z-index-1020{z-index:1020!important}.cursor-pointer{cursor:pointer!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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"] }, { kind: "component", type: i3.FieldErrorMessageComponent, selector: "app-field-error-message", inputs: ["customMessage", "control", "label"] }, { kind: "component", type: i4.SvgStorageComponent, selector: "app-svg-storage", inputs: ["svgName", "svgColor", "svgFill", "svgSize", "svgStrokeWidth"] }, { kind: "directive", type: i5.RequiredDirective, selector: "label[libRequired], span[libRequired], p[libRequired]", inputs: ["libRequired", "requiredID"] }, { kind: "pipe", type: i6.TextFilterPipe, name: "textFilter" }] }); }
239
244
  }
240
245
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LibComboboxComponent, decorators: [{
241
246
  type: Component,
242
- args: [{ selector: 'lib-combobox', template: "<!-- eslint-disable @angular-eslint/template/interactive-supports-focus -->\n<!-- eslint-disable @angular-eslint/template/click-events-have-key-events -->\n\n<label *ngIf=\"labelText && labelText !== ''\" [for]=\"comboboxID\" [libRequired]=\"isRequired\" [requiredID]=\"comboboxID ?? ''\" 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\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\n Ao usar o atributo [btnLeft], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\n <ng-content select=\"[btnLeft]\"></ng-content>\n\n <input #mainInput class=\"form-select text-start rounded-end cursor-pointer\" type=\"text\" data-bs-toggle=\"dropdown\" [placeholder]=\"mainPlaceholder\"\n [formControl]=\"innerControl\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly [class.is-invalid]=\"invalidControl\"\n [id]=\"comboboxID\"\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]=\"searchPlaceholder\" (keyup.enter)=\"reloadList()\">\n <button class=\"btn btn-{{theme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\n </div>\n\n @if (list) {\n <li *ngIf=\"innerControl.value !== '' && innerControl.value !== null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar op\u00E7\u00E3o selecionada</span> </li>\n @for (item of list | 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\">\n {{ item.AdditionalStringProperty1 + (separator === undefined ? \"\" : \" \"+separator) }}\n </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\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado direito do combobox de pesquisa.\n Ao usar o atributo [btnRight], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\n <ng-content select=\"[btnRight]\"></ng-content>\n\n</div>\n\n<!-- #region MENSAGEM DE ERRO DE VALIDA\u00C7\u00C3O -->\n<app-field-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo \u00E9 obrigat\u00F3rio.\" />\n<!-- #endregion MENSAGEM DE ERRO DE VALIDA\u00C7\u00C3O -->\n", styles: [".glb-max-height-350px{max-height:350px!important}.form-label{font-size:16px!important}.z-index-1020{z-index:1020!important}.cursor-pointer{cursor:pointer!important}\n"] }]
243
- }], ctorParameters: () => [], propDecorators: { outerControl: [{
247
+ args: [{ selector: 'lib-combobox', template: "<!-- eslint-disable @angular-eslint/template/interactive-supports-focus -->\n<!-- eslint-disable @angular-eslint/template/click-events-have-key-events -->\n\n<label *ngIf=\"labelText && labelText !== ''\" class=\"form-label fw-bold\" [id]=\"labelID\" [for]=\"comboboxID\" [libRequired]=\"isRequired\">{{ labelText }}</label>\n\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\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\n Ao usar o atributo [btnLeft], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\n <ng-content select=\"[btnLeft]\"></ng-content>\n\n <input #mainInput class=\"form-select text-start rounded-end cursor-pointer\" type=\"text\"\n data-bs-toggle=\"dropdown\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly\n [placeholder]=\"mainPlaceholder\" [formControl]=\"innerControl\" [class.is-invalid]=\"invalidControl\" [id]=\"comboboxID\"\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-{{comboboxID}}\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchPlaceholder\" (keyup.enter)=\"reloadList()\">\n <button class=\"btn btn-{{theme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\n </div>\n\n @if (list) {\n <li *ngIf=\"innerControl.value !== '' && innerControl.value !== null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar op\u00E7\u00E3o selecionada</span> </li>\n @for (item of list | 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\">\n {{ item.AdditionalStringProperty1 + (separator === undefined ? \"\" : \" \"+separator) }}\n </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\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado direito do combobox de pesquisa.\n Ao usar o atributo [btnRight], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\n <ng-content select=\"[btnRight]\"></ng-content>\n\n</div>\n\n<!-- #region MENSAGEM DE ERRO DE VALIDA\u00C7\u00C3O -->\n<app-field-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo \u00E9 obrigat\u00F3rio.\" />\n<!-- #endregion MENSAGEM DE ERRO DE VALIDA\u00C7\u00C3O -->\n", styles: [".glb-max-height-350px{max-height:350px!important}.form-label{font-size:16px!important}.z-index-1020{z-index:1020!important}.cursor-pointer{cursor:pointer!important}\n"] }]
248
+ }], ctorParameters: () => [], propDecorators: { control: [{
244
249
  type: Input,
245
- args: [{ alias: 'control', required: true }]
250
+ args: [{ required: true }]
246
251
  }], list: [{
247
252
  type: Input,
248
253
  args: [{ required: true }]
@@ -279,4 +284,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
279
284
  type: HostListener,
280
285
  args: ['window:resize', ['$event']]
281
286
  }] } });
282
- //# 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, OnChanges } 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  styles: `\n    .glb-max-height-350px { max-height: 350px !important; }\n    .form-label { font-size: 16px !important; }\n    .z-index-1020 { z-index: 1020 !important; }\n    .cursor-pointer { cursor: pointer !important; }\n  `\n})\nexport class LibComboboxComponent implements OnInit, AfterViewInit, OnDestroy, OnChanges {\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    if (value === false) {\n      this.textoPesquisa = \"\";\n      this._searchInput.nativeElement.value = \"\";\n    }\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\n  protected comboboxID?: string;\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<unknown> { return this._outerControl }\n  public set outerControl(value: FormControl<unknown> | AbstractControl<unknown>) {\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({ required: true }) public list?: 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) Texto ou caractere separador entre a informação de ID e LABEL\n   * @example \" - \"\n   * @type {string} */\n  @Input() public separator?: string = \" \";\n\n  /** (opcional) Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\n   * @type {boolean} */\n  @Input()\n  public libRequired?: boolean;\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() public mainPlaceholder?: 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() public searchPlaceholder?: 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() public theme?: 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 reloadListChange: 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 changeValue: EventEmitter<RecordCombobox | string | number | null> = new EventEmitter<RecordCombobox | string | number | null>();\n  \n\n  @ViewChild('mainInput') private _mainInput!: ElementRef;\n  @ViewChild('searchInput') private _searchInput!: 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.comboboxID = `lib-combobox-${Math.random() * 100}`;\n\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[\"libRequired\"]?.currentValue != undefined) this.setValidator();\n    if (changes[\"outerControl\"]?.currentValue) {\n      this.setValidator();\n      this.updateSelectedValue((changes[\"outerControl\"].currentValue as FormControl).value);\n    }\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(): 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(\n      `${item.AdditionalStringProperty1 && item.AdditionalStringProperty1 != '' ? item.AdditionalStringProperty1 : \"\"}${this.separator === undefined ? \" \" : \" \"+this.separator+\" \"}${item.LABEL}`\n    );\n\n    this.ariaExpanded = false;\n    this.setControlStatus(this.innerControl.status);\n    \n    this.changeValue.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.changeValue.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.list || (selectedValue === null && selectedValue === '')) return;\n\n    const initializedValue = this.list.find(item => item.ID === selectedValue)\n    if (initializedValue) this.innerControl.setValue(\n      `${initializedValue.AdditionalStringProperty1 && initializedValue.AdditionalStringProperty1 != '' ? initializedValue.AdditionalStringProperty1 : \"\"}${this.separator === undefined ? \" \" : \" \"+this.separator+\" \"}${initializedValue.LABEL}`\n    );\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  /** Serve para aplicar ou remover o Validator.required do controle.\n   * Por padrão ele priorizará a propriedade libRequired para esta validação. */\n  private setValidator(): void {\n    if (this.libRequired !== undefined) {\n      if (this.libRequired) {\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    else {\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\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.reloadListChange.emit(this.textoPesquisa) }\n  // #endregion ==========> UTILS <==========\n\n}\n","<!-- eslint-disable @angular-eslint/template/interactive-supports-focus -->\n<!-- eslint-disable @angular-eslint/template/click-events-have-key-events -->\n\n<label *ngIf=\"labelText && labelText !== ''\" [for]=\"comboboxID\" [libRequired]=\"isRequired\" [requiredID]=\"comboboxID ?? ''\" 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 cursor-pointer\" type=\"text\" data-bs-toggle=\"dropdown\" [placeholder]=\"mainPlaceholder\"\n            [formControl]=\"innerControl\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly [class.is-invalid]=\"invalidControl\"\n            [id]=\"comboboxID\"\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]=\"searchPlaceholder\" (keyup.enter)=\"reloadList()\">\n         <button class=\"btn btn-{{theme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\n      </div>\n\n      @if (list) {\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 list | 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\">\n                  {{ item.AdditionalStringProperty1 + (separator === undefined ? \"\" : \" \"+separator) }}\n               </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"]}
287
+ //# 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, OnChanges } 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 * - `control` (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  styles: `\n    .glb-max-height-350px { max-height: 350px !important; }\n    .form-label { font-size: 16px !important; }\n    .z-index-1020 { z-index: 1020 !important; }\n    .cursor-pointer { cursor: pointer !important; }\n  `\n})\nexport class LibComboboxComponent implements OnInit, AfterViewInit, OnDestroy, OnChanges {\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    if (value === false) {\n      this.textoPesquisa = \"\";\n      this._searchInput.nativeElement.value = \"\";\n    }\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\n  protected comboboxID!: string;\n  protected labelID!: string;\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({ required: true })\n  public get control(): FormControl<unknown> { return this._outerControl }\n  public set control(value: FormControl<unknown> | AbstractControl<unknown>) {\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({ required: true }) public list?: 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) Texto ou caractere separador entre a informação de ID e LABEL\n   * @example \" - \"\n   * @type {string} */\n  @Input() public separator?: string = \" \";\n\n  /** (opcional) Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\n   * @type {boolean} */\n  @Input()\n  public libRequired?: boolean;\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() public mainPlaceholder?: 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() public searchPlaceholder?: 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() public theme?: 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 reloadListChange: 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 changeValue: EventEmitter<RecordCombobox | string | number | null> = new EventEmitter<RecordCombobox | string | number | null>();\n  \n\n  @ViewChild('mainInput') private _mainInput!: ElementRef<HTMLInputElement>;\n  @ViewChild('searchInput') private _searchInput!: ElementRef<HTMLInputElement>;\n  @ViewChild('dropdownMenu') private _dropdownMenu!: ElementRef<HTMLDivElement>;\n  // #endregion PUBLIC\n\n  // #endregion ==========> PROPERTIES <==========\n\n\n  // #region ==========> INITIALIZATION <==========\n  constructor() { }\n\n  ngOnInit(): void {\n    this.comboboxID = `lib-combobox-${Math.random() * 100}`;\n    this.labelID = `${Math.random() * 100}`;\n\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[\"list\"]?.currentValue) this.updateSelectedValue();\n    if (changes[\"libRequired\"]?.currentValue != undefined) this.setValidator();\n    if (changes[\"control\"]?.currentValue) {\n      this.setValidator();\n      this.updateSelectedValue((changes[\"control\"].currentValue as FormControl).value);\n    }\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(): 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(\n      `${item.AdditionalStringProperty1 && item.AdditionalStringProperty1 != '' ? item.AdditionalStringProperty1 : \"\"}${this.separator === undefined ? \" \" : \" \"+this.separator+\" \"}${item.LABEL}`\n    );\n\n    this.ariaExpanded = false;\n    this.setControlStatus(this.innerControl.status);\n    \n    this.changeValue.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.changeValue.emit(null);\n  }\n\n  private updateSelectedValue(value?: string | number | null): void {\n    console.log(\"this.innerControl\", this.innerControl);\n    this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa\n    \n    const selectedValue: string | number | null = value ?? this._outerControl.value;\n    console.log(\"selectedValue\", selectedValue);\n    \n    if (!this.list || (selectedValue === null && selectedValue === '')) return;\n    \n    const initializedValue = this.list.find(item => item.ID === selectedValue)\n    console.log(\"initializedValue\", initializedValue);\n    \n    if (initializedValue) this.innerControl.setValue(\n      `${initializedValue.AdditionalStringProperty1 && initializedValue.AdditionalStringProperty1 != '' ? initializedValue.AdditionalStringProperty1 : \"\"}${this.separator === undefined ? \" \" : \" \"+this.separator+\" \"}${initializedValue.LABEL}`\n    );\n    console.log(\"this.innerControl\", this.innerControl);\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  /** Serve para aplicar ou remover o Validator.required do controle.\n   * Por padrão ele priorizará a propriedade libRequired para esta validação. */\n  private setValidator(): void {\n    if (this.libRequired !== undefined) {\n      if (this.libRequired) {\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    else {\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\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.reloadListChange.emit(this.textoPesquisa) }\n  // #endregion ==========> UTILS <==========\n\n}\n","<!-- eslint-disable @angular-eslint/template/interactive-supports-focus -->\n<!-- eslint-disable @angular-eslint/template/click-events-have-key-events -->\n\n<label *ngIf=\"labelText && labelText !== ''\" class=\"form-label fw-bold\" [id]=\"labelID\" [for]=\"comboboxID\" [libRequired]=\"isRequired\">{{ labelText }}</label>\n\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 cursor-pointer\" type=\"text\"\n            data-bs-toggle=\"dropdown\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly\n            [placeholder]=\"mainPlaceholder\" [formControl]=\"innerControl\" [class.is-invalid]=\"invalidControl\" [id]=\"comboboxID\"\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-{{comboboxID}}\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchPlaceholder\" (keyup.enter)=\"reloadList()\">\n         <button class=\"btn btn-{{theme}}\" (click)=\"reloadList()\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> </button>\n      </div>\n\n      @if (list) {\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 list | 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\">\n                  {{ item.AdditionalStringProperty1 + (separator === undefined ? \"\" : \" \"+separator) }}\n               </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"]}