ngx-vector-components 5.72.1 → 5.73.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +15 -0
- package/esm2022/lib/components/fields/checkbox-field/checkbox-field.component.mjs +6 -8
- package/esm2022/lib/components/fields/dropdown-field/dropdown-field.component.mjs +6 -8
- package/esm2022/lib/components/fields/multiselect-field/multiselect-field.component.mjs +6 -8
- package/esm2022/lib/components/fields/radio-button-field/radio-button-field.component.mjs +6 -8
- package/esm2022/lib/models/profile.model.mjs +2 -1
- package/fesm2022/ngx-vector-components.mjs +21 -28
- package/fesm2022/ngx-vector-components.mjs.map +1 -1
- package/lib/models/profile.model.d.ts +2 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,20 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## [5.73.0] (29/11/2024)
|
|
4
|
+
|
|
5
|
+
### Features
|
|
6
|
+
|
|
7
|
+
- Add 'ADD_LOCATION_SHIFT_PRIORITY' permission in `profile.model.ts`
|
|
8
|
+
|
|
9
|
+
## [5.72.2] (27/11/2024)
|
|
10
|
+
|
|
11
|
+
### Fix
|
|
12
|
+
|
|
13
|
+
- Change rules to disabled controls in `checkbox-field-component.ts`
|
|
14
|
+
- Change rules to disabled controls in `dropdown-field-component.ts`
|
|
15
|
+
- Change rules to disabled controls in `multiselect-field-component.ts`
|
|
16
|
+
- Change rules to disabled controls in `radio-button-field-component.ts`
|
|
17
|
+
|
|
3
18
|
## [5.72.1] (27/11/2024)
|
|
4
19
|
|
|
5
20
|
### Fix
|
|
@@ -16,13 +16,11 @@ export class CheckboxFieldComponent {
|
|
|
16
16
|
this.valueChange = new EventEmitter();
|
|
17
17
|
}
|
|
18
18
|
ngOnInit() {
|
|
19
|
-
if (this.control) {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
this.control.enable();
|
|
25
|
-
}
|
|
19
|
+
if (this.control && this.disabled) {
|
|
20
|
+
this.control.disable();
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
this.control.enable();
|
|
26
24
|
}
|
|
27
25
|
}
|
|
28
26
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CheckboxFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -52,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
52
50
|
}], valueChange: [{
|
|
53
51
|
type: Output
|
|
54
52
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtZmllbGQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZlY3Rvci1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9maWVsZHMvY2hlY2tib3gtZmllbGQvY2hlY2tib3gtZmllbGQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZlY3Rvci1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9maWVsZHMvY2hlY2tib3gtZmllbGQvY2hlY2tib3gtZmllbGQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRL0UsTUFBTSxPQUFPLHNCQUFzQjtJQXFCakM7UUFuQk8sZUFBVSxHQUFZLEtBQUssQ0FBQztRQUk1QixVQUFLLEdBQVcsRUFBRSxDQUFDO1FBRW5CLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFFekIsY0FBUyxHQUF3QixTQUFTLENBQUM7UUFFM0MsVUFBSyxHQUF3QixLQUFLLENBQUM7UUFFbkMsY0FBUyxHQUFXLEVBQUUsQ0FBQztRQUV2QixZQUFPLEdBQXNCLElBQUksQ0FBQztRQUVsQyxhQUFRLEdBQVksS0FBSyxDQUFDO1FBRTFCLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztJQUNsQyxDQUFDO0lBRWhCLFFBQVE7UUFDTixJQUFJLElBQUksQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO1NBQ3hCO2FBQU07WUFDTCxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1NBQ3ZCO0lBQ0gsQ0FBQzsrR0E3QlUsc0JBQXNCO21HQUF0QixzQkFBc0IsOFNDUm5DLHU2Q0F1Q0E7OzRGRC9CYSxzQkFBc0I7a0JBTGxDLFNBQVM7K0JBQ0UsdUJBQXVCO3dEQU0xQixVQUFVO3NCQURoQixLQUFLO2dCQUdDLE9BQU87c0JBRGIsS0FBSztnQkFHQyxLQUFLO3NCQURYLEtBQUs7Z0JBR0MsT0FBTztzQkFEYixLQUFLO2dCQUdDLFNBQVM7c0JBRGYsS0FBSztnQkFHQyxLQUFLO3NCQURYLEtBQUs7Z0JBR0MsU0FBUztzQkFEZixLQUFLO2dCQUdDLE9BQU87c0JBRGIsS0FBSztnQkFHQyxRQUFRO3NCQURkLEtBQUs7Z0JBR0MsV0FBVztzQkFEakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTGlzdEl0ZW0gfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd2ZWN0b3ItY2hlY2tib3gtZmllbGQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jaGVja2JveC1maWVsZC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY2hlY2tib3gtZmllbGQuY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENoZWNrYm94RmllbGRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGlzUmVxdWlyZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjb250cm9sOiBhbnk7XHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgbGFiZWw6IHN0cmluZyA9ICcnO1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHJvdW5kZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBsYWJlbFNpemU6ICdkZWZhdWx0JyB8ICdsYXJnZScgPSAnZGVmYXVsdCc7XHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgdmFsdWU6IGJvb2xlYW4gfCB1bmRlZmluZWQgPSBmYWxzZTtcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBncm91cE5hbWU6IHN0cmluZyA9ICcnO1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIG9wdGlvbnM6IExpc3RJdGVtW10gfCBudWxsID0gbnVsbDtcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBkaXNhYmxlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyB2YWx1ZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcclxuICBjb25zdHJ1Y3RvcigpIHt9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgaWYgKHRoaXMuY29udHJvbCAmJiB0aGlzLmRpc2FibGVkKSB7XHJcbiAgICAgIHRoaXMuY29udHJvbC5kaXNhYmxlKCk7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLmNvbnRyb2wuZW5hYmxlKCk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJjaGVja2JveC1jb250YWluZXIgZmxleC13cmFwXCI+XHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImNvbnRyb2wgJiYgZ3JvdXBOYW1lOyBlbHNlIGVsc2VCbG9ja1wiPlxyXG4gICAgPGRpdiBjbGFzcz1cImNoZWNrYm94LWl0ZW0gbWItMyBtci0zXCIgKm5nRm9yPVwibGV0IG9wdGlvbiBvZiBvcHRpb25zXCI+XHJcbiAgICAgIDxwLWNoZWNrYm94XHJcbiAgICAgICAgW25hbWVdPVwiZ3JvdXBOYW1lXCJcclxuICAgICAgICBbZm9ybUNvbnRyb2xdPVwiY29udHJvbFwiXHJcbiAgICAgICAgW3ZhbHVlXT1cIm9wdGlvblwiXHJcbiAgICAgICAgY2hlY2tib3hJY29uPVwiZmFzIGZhLWNoZWNrXCJcclxuICAgICAgICBbY2xhc3Mucm91bmRlZC1jaGVja2JveF09XCJyb3VuZGVkXCJcclxuICAgICAgICBbaW5wdXRJZF09XCJvcHRpb24uY29kZVwiXHJcbiAgICAgID48L3AtY2hlY2tib3g+XHJcbiAgICAgIDxsYWJlbCBbZm9yXT1cIm9wdGlvbi5jb2RlXCI+IHt7IG9wdGlvbi5uYW1lIH19PC9sYWJlbD5cclxuICAgIDwvZGl2PlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG5cclxuICA8bmctdGVtcGxhdGUgI2Vsc2VCbG9jaz5cclxuICAgIDxwLWNoZWNrYm94XHJcbiAgICAgICpuZ0lmPVwiY29udHJvbCAmJiAhZ3JvdXBOYW1lXCJcclxuICAgICAgW2Zvcm1Db250cm9sXT1cImNvbnRyb2xcIlxyXG4gICAgICBjaGVja2JveEljb249XCJmYXMgZmEtY2hlY2tcIlxyXG4gICAgICBbYmluYXJ5XT1cInRydWVcIlxyXG4gICAgICBbY2xhc3Mucm91bmRlZC1jaGVja2JveF09XCJyb3VuZGVkXCJcclxuICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcclxuICAgID48L3AtY2hlY2tib3g+XHJcbiAgICA8cC1jaGVja2JveFxyXG4gICAgICAqbmdJZj1cIiFjb250cm9sICYmICFncm91cE5hbWVcIlxyXG4gICAgICBbbmdNb2RlbF09XCJ2YWx1ZVwiXHJcbiAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInZhbHVlID0gJGV2ZW50OyB2YWx1ZUNoYW5nZS5lbWl0KCRldmVudClcIlxyXG4gICAgICBjaGVja2JveEljb249XCJmYXMgZmEtY2hlY2tcIlxyXG4gICAgICBbYmluYXJ5XT1cInRydWVcIlxyXG4gICAgICBbY2xhc3Mucm91bmRlZC1jaGVja2JveF09XCJyb3VuZGVkXCJcclxuICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcclxuICAgID48L3AtY2hlY2tib3g+XHJcbiAgICA8bGFiZWwgKm5nSWY9XCJsYWJlbFwiIFtjbGFzcy5sYXJnZS1sYWJlbF09XCJsYWJlbFNpemUgPT09ICdsYXJnZSdcIiAoY2xpY2spPVwiY29udHJvbC5zZXRWYWx1ZSghY29udHJvbC52YWx1ZSlcIlxyXG4gICAgICA+e3sgbGFiZWwgfX1cclxuICAgICAgPHNwYW4gY2xhc3M9XCJyZWQtbGFiZWxcIiAqbmdJZj1cImlzUmVxdWlyZWRcIj4gKCopPC9zcGFuPlxyXG4gICAgPC9sYWJlbD5cclxuICA8L25nLXRlbXBsYXRlPlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -58,13 +58,11 @@ export class DropdownFieldComponent {
|
|
|
58
58
|
this.currentSearchQuery = '';
|
|
59
59
|
}
|
|
60
60
|
ngOnInit() {
|
|
61
|
-
if (this.control) {
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
this.control.enable();
|
|
67
|
-
}
|
|
61
|
+
if (this.control && this.disabled) {
|
|
62
|
+
this.control.disable();
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
this.control.enable();
|
|
68
66
|
}
|
|
69
67
|
if (this.initialLoad) {
|
|
70
68
|
this.search(null, true);
|
|
@@ -224,4 +222,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
224
222
|
}], onChange: [{
|
|
225
223
|
type: Output
|
|
226
224
|
}] } });
|
|
227
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/dropdown-field/dropdown-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/dropdown-field/dropdown-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, Renderer2, ViewEncapsulation } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ListItem } from '../../../models';\r\nimport { BaseDropdown } from '../../../services';\r\nimport { ObjectUtil } from '../../../utils';\r\n\r\nexport type DropdownButtonAction = {\r\n  label: string;\r\n  onClick: (value: any) => void;\r\n};\r\n\r\n@Component({\r\n  selector: 'vector-dropdown-field',\r\n  templateUrl: './dropdown-field.component.html',\r\n  styleUrls: ['./dropdown-field.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DropdownFieldComponent implements OnInit, OnDestroy {\r\n  @Input()\r\n  set options(_options: ListItem[]) {\r\n    this._options = _options;\r\n    this.pagedSuggestions = this.options || [];\r\n  }\r\n  @Input()\r\n  public isNgContent = false;\r\n  @Input()\r\n  public forceSelection = true;\r\n  @Input()\r\n  public isRequired: boolean | undefined = false;\r\n  @Input()\r\n  set control(_control: any) {\r\n    this._control = _control;\r\n    if (this.control) {\r\n      this.subscription.add(\r\n        this.control.valueChanges.subscribe(() => {\r\n          this.setControlValueFromSuggestions();\r\n        })\r\n      );\r\n    }\r\n  }\r\n  @Input()\r\n  public label: string = '';\r\n  @Input()\r\n  public service: BaseDropdown | undefined;\r\n  @Input()\r\n  public paged = true;\r\n  @Input()\r\n  public buttonAction: DropdownButtonAction | undefined;\r\n  @Input()\r\n  public dependencies: any;\r\n  @Input()\r\n  public hiddenErrorMessage: boolean = false;\r\n  @Input()\r\n  public dynamicFilters?: ListItem[];\r\n  @Input()\r\n  public minLengthToService: number = 0;\r\n  @Input()\r\n  public initialLoad = true;\r\n  @Input()\r\n  public disabled = false;\r\n  @Input()\r\n  public limitScrollPage: number = 20;\r\n  @Input()\r\n  public inputId?: string;\r\n  @Output()\r\n  public onFocus = new EventEmitter();\r\n  @Output()\r\n  public onChange = new EventEmitter();\r\n\r\n  get control() {\r\n    return this._control;\r\n  }\r\n\r\n  get options() {\r\n    return this._options;\r\n  }\r\n\r\n  get placeholder() {\r\n    if (!this.label) {\r\n      return '';\r\n    }\r\n    return `${this.label}${this.isRequired ? '*' : ''}`;\r\n  }\r\n\r\n  public pagedSuggestions: ListItem[] = [];\r\n  public unlistenAutocompleteVirtualScroll = () => {};\r\n  public selectedDynamicFilter: any = this.dynamicFilters ? this.dynamicFilters[0].code : undefined;\r\n\r\n  private _control: any;\r\n  private _options: any[] = [];\r\n  private currentScrollPage = -1;\r\n  private currentScrollIndex = 0;\r\n  private subscription = new Subscription();\r\n  private currentSearchQuery = '';\r\n\r\n  constructor(private renderer: Renderer2) {}\r\n\r\n  ngOnInit(): void {\r\n    if (this.control) {\r\n      if (this.disabled) {\r\n        this.control.disable();\r\n      } else {\r\n        this.control.enable();\r\n      }\r\n    }\r\n    if (this.initialLoad) {\r\n      this.search(null, true);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscription.unsubscribe();\r\n    if (this.unlistenAutocompleteVirtualScroll) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n  }\r\n\r\n  public fieldErrorLabel(): string {\r\n    if (this.control?.invalid && this.control.touched) {\r\n      if (this.control.hasError('required')) {\r\n        return 'Campo obrigatório';\r\n      }\r\n\r\n      return this.control?.errors && typeof this.control.errors['invalid'] === 'string'\r\n        ? this.control?.errors['invalid']\r\n        : 'Campo inválido';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  public search($event?: any, forceSearch = false): void {\r\n    this.currentSearchQuery = $event?.query.toUpperCase() || '';\r\n    this.currentScrollPage = -1;\r\n    this.currentScrollIndex = 0;\r\n    if (forceSearch || this.currentSearchQuery.length >= this.minLengthToService) {\r\n      this.pageResults();\r\n    } else {\r\n      this.pagedSuggestions = [];\r\n    }\r\n  }\r\n\r\n  public onOpenAutocompletePanel(): void {\r\n    const autocompletePanel = document.querySelector('.p-autocomplete-panel');\r\n    if (autocompletePanel && this.paged && this.currentSearchQuery.length >= this.minLengthToService) {\r\n      this.unlistenAutocompleteVirtualScroll = this.renderer.listen(autocompletePanel, 'scroll', (event) => {\r\n        const eventHeight = event.target.scrollHeight - event.target.clientHeight - 150;\r\n\r\n        if (Math.round(event.target.scrollTop) >= eventHeight) {\r\n          this.pageResults();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public onHideAutocompletePanel(): void {\r\n    if (this.paged) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n  }\r\n\r\n  private pageResults(): void {\r\n    if (this.service) {\r\n      this.currentScrollPage++;\r\n      this.service\r\n        .getPaged(\r\n          encodeURIComponent(this.currentSearchQuery),\r\n          this.currentScrollPage,\r\n          this.limitScrollPage,\r\n          this.dependencies\r\n        )\r\n        .subscribe({\r\n          next: (response) => {\r\n            this.pagedSuggestions = this.currentScrollPage === 0 ? response : this.pagedSuggestions?.concat(response);\r\n            const controlValue = typeof this.control.value == 'object' ? this.control.value?.code : this.control.value;\r\n            if (this.control.value && this.pagedSuggestions?.find((item) => item.code == controlValue)) {\r\n              this.setControlValueFromSuggestions();\r\n            }\r\n            if (this.forceSelection) {\r\n              this.handleSearchErrors();\r\n            }\r\n          },\r\n          error: (err) => {},\r\n        });\r\n    } else {\r\n      const filteredOptions = this.filterListByQuery(this.options, this.currentSearchQuery.toUpperCase());\r\n      this.pagedSuggestions = filteredOptions.slice(0, this.currentScrollIndex + this.limitScrollPage);\r\n\r\n      if (this.options?.length && this.options.length > this.limitScrollPage) {\r\n        this.currentScrollIndex = this.currentScrollIndex + this.limitScrollPage;\r\n      }\r\n\r\n      this.setControlValueFromSuggestions();\r\n      if (this.forceSelection) {\r\n        this.handleSearchErrors();\r\n      }\r\n    }\r\n  }\r\n\r\n  private setControlValueFromSuggestions() {\r\n    const code =\r\n      (ObjectUtil.isValid(this.control.value?.code) && `${this.control.value?.code}`) || `${this.control.value}`;\r\n    if (this.control.value && this.pagedSuggestions?.length) {\r\n      let itemsArray = this.pagedSuggestions;\r\n      if (this.options?.length) {\r\n        itemsArray = this.options;\r\n      }\r\n      const itemFromSuggestions = itemsArray.find((opt) => `${opt.code}`.toUpperCase() === code.toUpperCase());\r\n      if (itemFromSuggestions) {\r\n        this.control.setValue(itemFromSuggestions, { emitEvent: false });\r\n      } else {\r\n        this.service?.getById(+code).subscribe((response) => {\r\n          this.control.setValue(response, { emitEvent: false });\r\n        });\r\n      }\r\n    } else if (this.control.value && !this.pagedSuggestions?.length) {\r\n      this.service?.getById(+code).subscribe((response) => {\r\n        this.control.setValue(response, { emitEvent: false });\r\n      });\r\n    }\r\n  }\r\n\r\n  private handleSearchErrors() {\r\n    if (this.pagedSuggestions?.length) {\r\n      delete this.control.errors?.itemNotFound;\r\n    } else if (this.currentSearchQuery) {\r\n      this.control.setErrors({ itemNotFound: true });\r\n    }\r\n  }\r\n\r\n  private filterListByQuery(list: ListItem[] = [], query: string): ListItem[] {\r\n    return list.filter(\r\n      (opt) => String(opt.code).toUpperCase().includes(query) || opt.name.toUpperCase().includes(query)\r\n    );\r\n  }\r\n}\r\n","<div class=\"relative\">\r\n  <div class=\"input-container\">\r\n    <div class=\"input-inner-container\" *ngIf=\"!isNgContent\">\r\n      <p-dropdown\r\n        *ngIf=\"dynamicFilters\"\r\n        appendTo=\"body\"\r\n        optionLabel=\"name\"\r\n        optionValue=\"code\"\r\n        [(ngModel)]=\"selectedDynamicFilter\"\r\n        [options]=\"dynamicFilters\"\r\n        [disabled]=\"disabled\"\r\n        [inputId]=\"inputId\"\r\n      >\r\n      </p-dropdown>\r\n      <p-autoComplete\r\n        appendTo=\"body\"\r\n        field=\"name\"\r\n        [forceSelection]=\"forceSelection\"\r\n        [dropdown]=\"true\"\r\n        [formControl]=\"control\"\r\n        [placeholder]=\"placeholder\"\r\n        [suggestions]=\"pagedSuggestions\"\r\n        [dropdownIcon]=\"dynamicFilters ? 'pi pi-search' : 'pi pi-chevron-down'\"\r\n        [delay]=\"800\"\r\n        (completeMethod)=\"search($event)\"\r\n        (onShow)=\"onOpenAutocompletePanel()\"\r\n        (onHide)=\"onHideAutocompletePanel()\"\r\n        (onFocus)=\"onFocus.emit($event)\"\r\n        (onChange)=\"onChange.emit($event)\"\r\n        [disabled]=\"disabled\"\r\n        [inputId]=\"inputId\"\r\n      >\r\n      </p-autoComplete>\r\n    </div>\r\n\r\n    <div class=\"input-inner-container\" *ngIf=\"isNgContent\">\r\n      <p-autoComplete\r\n        appendTo=\"body\"\r\n        field=\"name\"\r\n        [forceSelection]=\"forceSelection\"\r\n        [dropdown]=\"true\"\r\n        [formControl]=\"control\"\r\n        [placeholder]=\"placeholder\"\r\n        [suggestions]=\"pagedSuggestions\"\r\n        [dropdownIcon]=\"dynamicFilters ? 'pi pi-search' : 'pi pi-chevron-down'\"\r\n        [delay]=\"800\"\r\n        (completeMethod)=\"search($event)\"\r\n        (onShow)=\"onOpenAutocompletePanel()\"\r\n        (onHide)=\"onHideAutocompletePanel()\"\r\n        (onFocus)=\"onFocus.emit($event)\"\r\n        (onChange)=\"onChange.emit($event)\"\r\n        [disabled]=\"disabled\"\r\n        [inputId]=\"inputId\"\r\n      >\r\n        <ng-template let-option pTemplate=\"item\">\r\n          <div class=\"option-content\">\r\n            <span class=\"option-label\">{{ option.name }}</span>\r\n            <br />\r\n            <span class=\"option-sublabel\">{{ option.code }}</span>\r\n          </div>\r\n        </ng-template>\r\n      </p-autoComplete>\r\n    </div>\r\n\r\n    <vector-button\r\n      *ngIf=\"buttonAction\"\r\n      [label]=\"buttonAction.label\"\r\n      [disabled]=\"disabled\"\r\n      (onClick)=\"buttonAction.onClick(control.value)\"\r\n    ></vector-button>\r\n  </div>\r\n  <vector-field-error-message *ngIf=\"!hiddenErrorMessage\" [control]=\"control\"></vector-field-error-message>\r\n</div>\r\n"]}
|
|
225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/dropdown-field/dropdown-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/dropdown-field/dropdown-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, Renderer2, ViewEncapsulation } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ListItem } from '../../../models';\r\nimport { BaseDropdown } from '../../../services';\r\nimport { ObjectUtil } from '../../../utils';\r\n\r\nexport type DropdownButtonAction = {\r\n  label: string;\r\n  onClick: (value: any) => void;\r\n};\r\n\r\n@Component({\r\n  selector: 'vector-dropdown-field',\r\n  templateUrl: './dropdown-field.component.html',\r\n  styleUrls: ['./dropdown-field.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DropdownFieldComponent implements OnInit, OnDestroy {\r\n  @Input()\r\n  set options(_options: ListItem[]) {\r\n    this._options = _options;\r\n    this.pagedSuggestions = this.options || [];\r\n  }\r\n  @Input()\r\n  public isNgContent = false;\r\n  @Input()\r\n  public forceSelection = true;\r\n  @Input()\r\n  public isRequired: boolean | undefined = false;\r\n  @Input()\r\n  set control(_control: any) {\r\n    this._control = _control;\r\n    if (this.control) {\r\n      this.subscription.add(\r\n        this.control.valueChanges.subscribe(() => {\r\n          this.setControlValueFromSuggestions();\r\n        })\r\n      );\r\n    }\r\n  }\r\n  @Input()\r\n  public label: string = '';\r\n  @Input()\r\n  public service: BaseDropdown | undefined;\r\n  @Input()\r\n  public paged = true;\r\n  @Input()\r\n  public buttonAction: DropdownButtonAction | undefined;\r\n  @Input()\r\n  public dependencies: any;\r\n  @Input()\r\n  public hiddenErrorMessage: boolean = false;\r\n  @Input()\r\n  public dynamicFilters?: ListItem[];\r\n  @Input()\r\n  public minLengthToService: number = 0;\r\n  @Input()\r\n  public initialLoad = true;\r\n  @Input()\r\n  public disabled = false;\r\n  @Input()\r\n  public limitScrollPage: number = 20;\r\n  @Input()\r\n  public inputId?: string;\r\n  @Output()\r\n  public onFocus = new EventEmitter();\r\n  @Output()\r\n  public onChange = new EventEmitter();\r\n\r\n  get control() {\r\n    return this._control;\r\n  }\r\n\r\n  get options() {\r\n    return this._options;\r\n  }\r\n\r\n  get placeholder() {\r\n    if (!this.label) {\r\n      return '';\r\n    }\r\n    return `${this.label}${this.isRequired ? '*' : ''}`;\r\n  }\r\n\r\n  public pagedSuggestions: ListItem[] = [];\r\n  public unlistenAutocompleteVirtualScroll = () => {};\r\n  public selectedDynamicFilter: any = this.dynamicFilters ? this.dynamicFilters[0].code : undefined;\r\n\r\n  private _control: any;\r\n  private _options: any[] = [];\r\n  private currentScrollPage = -1;\r\n  private currentScrollIndex = 0;\r\n  private subscription = new Subscription();\r\n  private currentSearchQuery = '';\r\n\r\n  constructor(private renderer: Renderer2) {}\r\n\r\n  ngOnInit(): void {\r\n    if (this.control && this.disabled) {\r\n      this.control.disable();\r\n    } else {\r\n      this.control.enable();\r\n    }\r\n    \r\n    if (this.initialLoad) {\r\n      this.search(null, true);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscription.unsubscribe();\r\n    if (this.unlistenAutocompleteVirtualScroll) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n  }\r\n\r\n  public fieldErrorLabel(): string {\r\n    if (this.control?.invalid && this.control.touched) {\r\n      if (this.control.hasError('required')) {\r\n        return 'Campo obrigatório';\r\n      }\r\n\r\n      return this.control?.errors && typeof this.control.errors['invalid'] === 'string'\r\n        ? this.control?.errors['invalid']\r\n        : 'Campo inválido';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  public search($event?: any, forceSearch = false): void {\r\n    this.currentSearchQuery = $event?.query.toUpperCase() || '';\r\n    this.currentScrollPage = -1;\r\n    this.currentScrollIndex = 0;\r\n    if (forceSearch || this.currentSearchQuery.length >= this.minLengthToService) {\r\n      this.pageResults();\r\n    } else {\r\n      this.pagedSuggestions = [];\r\n    }\r\n  }\r\n\r\n  public onOpenAutocompletePanel(): void {\r\n    const autocompletePanel = document.querySelector('.p-autocomplete-panel');\r\n    if (autocompletePanel && this.paged && this.currentSearchQuery.length >= this.minLengthToService) {\r\n      this.unlistenAutocompleteVirtualScroll = this.renderer.listen(autocompletePanel, 'scroll', (event) => {\r\n        const eventHeight = event.target.scrollHeight - event.target.clientHeight - 150;\r\n\r\n        if (Math.round(event.target.scrollTop) >= eventHeight) {\r\n          this.pageResults();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public onHideAutocompletePanel(): void {\r\n    if (this.paged) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n  }\r\n\r\n  private pageResults(): void {\r\n    if (this.service) {\r\n      this.currentScrollPage++;\r\n      this.service\r\n        .getPaged(\r\n          encodeURIComponent(this.currentSearchQuery),\r\n          this.currentScrollPage,\r\n          this.limitScrollPage,\r\n          this.dependencies\r\n        )\r\n        .subscribe({\r\n          next: (response) => {\r\n            this.pagedSuggestions = this.currentScrollPage === 0 ? response : this.pagedSuggestions?.concat(response);\r\n            const controlValue = typeof this.control.value == 'object' ? this.control.value?.code : this.control.value;\r\n            if (this.control.value && this.pagedSuggestions?.find((item) => item.code == controlValue)) {\r\n              this.setControlValueFromSuggestions();\r\n            }\r\n            if (this.forceSelection) {\r\n              this.handleSearchErrors();\r\n            }\r\n          },\r\n          error: (err) => {},\r\n        });\r\n    } else {\r\n      const filteredOptions = this.filterListByQuery(this.options, this.currentSearchQuery.toUpperCase());\r\n      this.pagedSuggestions = filteredOptions.slice(0, this.currentScrollIndex + this.limitScrollPage);\r\n\r\n      if (this.options?.length && this.options.length > this.limitScrollPage) {\r\n        this.currentScrollIndex = this.currentScrollIndex + this.limitScrollPage;\r\n      }\r\n\r\n      this.setControlValueFromSuggestions();\r\n      if (this.forceSelection) {\r\n        this.handleSearchErrors();\r\n      }\r\n    }\r\n  }\r\n\r\n  private setControlValueFromSuggestions() {\r\n    const code =\r\n      (ObjectUtil.isValid(this.control.value?.code) && `${this.control.value?.code}`) || `${this.control.value}`;\r\n    if (this.control.value && this.pagedSuggestions?.length) {\r\n      let itemsArray = this.pagedSuggestions;\r\n      if (this.options?.length) {\r\n        itemsArray = this.options;\r\n      }\r\n      const itemFromSuggestions = itemsArray.find((opt) => `${opt.code}`.toUpperCase() === code.toUpperCase());\r\n      if (itemFromSuggestions) {\r\n        this.control.setValue(itemFromSuggestions, { emitEvent: false });\r\n      } else {\r\n        this.service?.getById(+code).subscribe((response) => {\r\n          this.control.setValue(response, { emitEvent: false });\r\n        });\r\n      }\r\n    } else if (this.control.value && !this.pagedSuggestions?.length) {\r\n      this.service?.getById(+code).subscribe((response) => {\r\n        this.control.setValue(response, { emitEvent: false });\r\n      });\r\n    }\r\n  }\r\n\r\n  private handleSearchErrors() {\r\n    if (this.pagedSuggestions?.length) {\r\n      delete this.control.errors?.itemNotFound;\r\n    } else if (this.currentSearchQuery) {\r\n      this.control.setErrors({ itemNotFound: true });\r\n    }\r\n  }\r\n\r\n  private filterListByQuery(list: ListItem[] = [], query: string): ListItem[] {\r\n    return list.filter(\r\n      (opt) => String(opt.code).toUpperCase().includes(query) || opt.name.toUpperCase().includes(query)\r\n    );\r\n  }\r\n}\r\n","<div class=\"relative\">\r\n  <div class=\"input-container\">\r\n    <div class=\"input-inner-container\" *ngIf=\"!isNgContent\">\r\n      <p-dropdown\r\n        *ngIf=\"dynamicFilters\"\r\n        appendTo=\"body\"\r\n        optionLabel=\"name\"\r\n        optionValue=\"code\"\r\n        [(ngModel)]=\"selectedDynamicFilter\"\r\n        [options]=\"dynamicFilters\"\r\n        [disabled]=\"disabled\"\r\n        [inputId]=\"inputId\"\r\n      >\r\n      </p-dropdown>\r\n      <p-autoComplete\r\n        appendTo=\"body\"\r\n        field=\"name\"\r\n        [forceSelection]=\"forceSelection\"\r\n        [dropdown]=\"true\"\r\n        [formControl]=\"control\"\r\n        [placeholder]=\"placeholder\"\r\n        [suggestions]=\"pagedSuggestions\"\r\n        [dropdownIcon]=\"dynamicFilters ? 'pi pi-search' : 'pi pi-chevron-down'\"\r\n        [delay]=\"800\"\r\n        (completeMethod)=\"search($event)\"\r\n        (onShow)=\"onOpenAutocompletePanel()\"\r\n        (onHide)=\"onHideAutocompletePanel()\"\r\n        (onFocus)=\"onFocus.emit($event)\"\r\n        (onChange)=\"onChange.emit($event)\"\r\n        [disabled]=\"disabled\"\r\n        [inputId]=\"inputId\"\r\n      >\r\n      </p-autoComplete>\r\n    </div>\r\n\r\n    <div class=\"input-inner-container\" *ngIf=\"isNgContent\">\r\n      <p-autoComplete\r\n        appendTo=\"body\"\r\n        field=\"name\"\r\n        [forceSelection]=\"forceSelection\"\r\n        [dropdown]=\"true\"\r\n        [formControl]=\"control\"\r\n        [placeholder]=\"placeholder\"\r\n        [suggestions]=\"pagedSuggestions\"\r\n        [dropdownIcon]=\"dynamicFilters ? 'pi pi-search' : 'pi pi-chevron-down'\"\r\n        [delay]=\"800\"\r\n        (completeMethod)=\"search($event)\"\r\n        (onShow)=\"onOpenAutocompletePanel()\"\r\n        (onHide)=\"onHideAutocompletePanel()\"\r\n        (onFocus)=\"onFocus.emit($event)\"\r\n        (onChange)=\"onChange.emit($event)\"\r\n        [disabled]=\"disabled\"\r\n        [inputId]=\"inputId\"\r\n      >\r\n        <ng-template let-option pTemplate=\"item\">\r\n          <div class=\"option-content\">\r\n            <span class=\"option-label\">{{ option.name }}</span>\r\n            <br />\r\n            <span class=\"option-sublabel\">{{ option.code }}</span>\r\n          </div>\r\n        </ng-template>\r\n      </p-autoComplete>\r\n    </div>\r\n\r\n    <vector-button\r\n      *ngIf=\"buttonAction\"\r\n      [label]=\"buttonAction.label\"\r\n      [disabled]=\"disabled\"\r\n      (onClick)=\"buttonAction.onClick(control.value)\"\r\n    ></vector-button>\r\n  </div>\r\n  <vector-field-error-message *ngIf=\"!hiddenErrorMessage\" [control]=\"control\"></vector-field-error-message>\r\n</div>\r\n"]}
|
|
@@ -76,13 +76,11 @@ export class MultiselectFieldComponent {
|
|
|
76
76
|
if (this.initialLoad && this.filterVirtualScrool) {
|
|
77
77
|
this.search(null, true);
|
|
78
78
|
}
|
|
79
|
-
if (this.control) {
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
this.control.enable();
|
|
85
|
-
}
|
|
79
|
+
if (this.control && this.disabled) {
|
|
80
|
+
this.control.disable();
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
this.control.enable();
|
|
86
84
|
}
|
|
87
85
|
}
|
|
88
86
|
fieldErrorLabel() {
|
|
@@ -220,4 +218,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
220
218
|
}], onClosePanel: [{
|
|
221
219
|
type: Output
|
|
222
220
|
}] } });
|
|
223
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiselect-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/multiselect-field/multiselect-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/multiselect-field/multiselect-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, Renderer2 } from '@angular/core';\r\nimport { ListItem } from '../../../models';\r\nimport { BaseDropdown } from '../../../services';\r\nimport { ObjectUtil } from '../../../utils';\r\n\r\nexport type ListItemOptionsFlagType = ListItem & {\r\n  align: 'center' | 'left';\r\n  showDescriptionOnRight: boolean;\r\n  type: 'img' | 'icon';\r\n  iconSource?: string;\r\n  iconSize?: '1em' | '1.25em' | '1.5em' | '1.75em' | '2em';\r\n  iconClass?: string;\r\n  imgSource?: string;\r\n  imgSize?: '15' | '20' | '25';\r\n  imgClass?: string;\r\n};\r\n\r\n@Component({\r\n  selector: 'vector-multiselect-field',\r\n  templateUrl: './multiselect-field.component.html',\r\n  styleUrls: ['./multiselect-field.component.scss'],\r\n})\r\nexport class MultiselectFieldComponent {\r\n  @Input()\r\n  set pagedSugestion(_pagedSugestion: ListItem[]) {\r\n    this._pagedSugestion = _pagedSugestion;\r\n    this.options = this.pagedSugestion || [];\r\n  }\r\n  @Input()\r\n  public isRequired: boolean = false;\r\n  @Input()\r\n  public control: any;\r\n  @Input()\r\n  public label: string = '';\r\n  @Input()\r\n  public options: ListItem[] | ListItemOptionsFlagType[] = [];\r\n  @Input()\r\n  public filter = false;\r\n  @Input()\r\n  public showSelectAllOption: boolean = true;\r\n  @Input()\r\n  public display: string = 'comma';\r\n  @Input()\r\n  public paged = true;\r\n  @Input()\r\n  public disabled: boolean = false;\r\n  @Input()\r\n  public minLengthToService: number = 0;\r\n  @Input()\r\n  public initialLoad = true;\r\n  @Input()\r\n  public service: BaseDropdown | undefined;\r\n  @Input()\r\n  public filterVirtualScrool = false;\r\n  @Input()\r\n  public showHeader: boolean = true;\r\n  @Input()\r\n  public showFlags: boolean = false;\r\n  private _showFlagsOptions?: ListItemOptionsFlagType[] | undefined;\r\n\r\n  @Input()\r\n  set showFlagsOptions(value: ListItemOptionsFlagType[]) {\r\n    if (!this.showFlags) {\r\n      throw new Error('showFlags is set to false. Setting showFlagsOptions is not allowed.');\r\n    }\r\n    value.forEach((option) => {\r\n      if (option.type === 'img') {\r\n        if (!option.imgSource) {\r\n          throw new Error(\"imgSource is required when type is 'img'\");\r\n        }\r\n        if (!option.imgSize) {\r\n          throw new Error(\"imgSize is required when type is 'img'\");\r\n        }\r\n      } else if (option.type === 'icon') {\r\n        if (!option.iconSource) {\r\n          throw new Error(\"iconSource is required when type is 'icon'\");\r\n        }\r\n        if (!option.iconSize) {\r\n          throw new Error(\"iconSize is required when type is 'icon'\");\r\n        }\r\n      }\r\n    });\r\n    this._showFlagsOptions = value;\r\n  }\r\n\r\n  get showFlagsOptions(): ListItemOptionsFlagType[] {\r\n    if (!this._showFlagsOptions) {\r\n      throw new Error('showFlagsOptions was not set');\r\n    }\r\n    return this._showFlagsOptions;\r\n  }\r\n\r\n  @Output()\r\n  public onChange = new EventEmitter();\r\n  @Output()\r\n  public onClosePanel = new EventEmitter();\r\n\r\n  private currentSearchQuery = '';\r\n  private currentScrollPage = -1;\r\n  private currentScrollIndex = 0;\r\n\r\n  public unlistenAutocompleteVirtualScroll = () => {};\r\n\r\n  get placeholder() {\r\n    if (!this.label) {\r\n      return '';\r\n    }\r\n    return `${this.label}${this.isRequired ? '*' : ''}`;\r\n  }\r\n\r\n  get pagedSugestion() {\r\n    return this._pagedSugestion;\r\n  }\r\n\r\n  private _pagedSugestion: ListItem[] = [];\r\n\r\n  constructor(private renderer: Renderer2) {}\r\n\r\n  ngOnInit(): void {\r\n    if (this.initialLoad && this.filterVirtualScrool) {\r\n      this.search(null, true);\r\n    }\r\n\r\n    if (this.control) {\r\n      if (this.disabled) {\r\n        this.control.disable();\r\n      } else {\r\n        this.control.enable();\r\n      }\r\n    }\r\n  }\r\n\r\n  public fieldErrorLabel(): string {\r\n    if (this.control && this.control.invalid && this.control.touched) {\r\n      if (this.control.hasError('required')) {\r\n        return 'Campo obrigatório';\r\n      }\r\n\r\n      return typeof this.control.errors['invalid'] === 'string' ? this.control.errors['invalid'] : 'Campo inválido';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  public onOpenAutocompletePanel(): void {\r\n    this.search();\r\n    const multiSelectPanel = document.querySelector('.p-multiselect-items-wrapper');\r\n\r\n    if (multiSelectPanel && this.paged && this.currentSearchQuery.length >= this.minLengthToService) {\r\n      this.unlistenAutocompleteVirtualScroll = this.renderer.listen(multiSelectPanel, 'scroll', (event) => {\r\n        const eventHeight = event.target.scrollHeight - event.target.clientHeight - 150;\r\n\r\n        if (Math.round(event.target.scrollTop) >= eventHeight) {\r\n          this.pageResults();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public customFormattingMultiSelectFieldWithFlags(): void {\r\n    setTimeout(() => {\r\n      const vectorMultiselectField = document.querySelector('vector-multiselect-field.multiselect-flags');\r\n\r\n      if (vectorMultiselectField) {\r\n        const pOverlayElement = vectorMultiselectField.querySelector('p-overlay');\r\n\r\n        if (pOverlayElement) {\r\n          const classList = Array.from(pOverlayElement.classList);\r\n          const targetClass = classList.find((className) => className.startsWith('ng-tns-'));\r\n\r\n          if (targetClass) {\r\n            const classReferenceCode = targetClass.replace('ng-tns-', '');\r\n            const targetDivWithRefCode = document.querySelector(`div.ng-tns-${classReferenceCode}`);\r\n\r\n            if (targetDivWithRefCode) {\r\n              targetDivWithRefCode.classList.add('multiselect-flags');\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }, 200);\r\n  }\r\n\r\n  public onHideAutocompletePanel(): void {\r\n    if (this.paged) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n  }\r\n\r\n  public search($event?: any, forceSearch = false): void {\r\n    this.currentSearchQuery = $event?.filter.toUpperCase() || '';\r\n    this.currentScrollPage = -1;\r\n    this.currentScrollIndex = 0;\r\n    if (forceSearch || this.currentSearchQuery.length >= this.minLengthToService) {\r\n      this.pageResults();\r\n    } else {\r\n      this.options = [];\r\n    }\r\n  }\r\n\r\n  private pageResults(): void {\r\n    const filteredOptions = this.filterListByQuery(this.pagedSugestion, this.currentSearchQuery.toUpperCase());\r\n    this.options = filteredOptions.slice(0, this.currentScrollIndex + 20);\r\n\r\n    if (this.pagedSugestion?.length && this.pagedSugestion.length > 20) {\r\n      this.currentScrollIndex = this.currentScrollIndex + 20;\r\n    }\r\n\r\n    this.setControlValueFromSuggestions();\r\n  }\r\n\r\n  private filterListByQuery(list: ListItem[] = [], query: string): ListItem[] {\r\n    return list.filter(\r\n      (opt) => String(opt.code).toUpperCase().includes(query) || opt.name.toUpperCase().includes(query)\r\n    );\r\n  }\r\n  private setControlValueFromSuggestions() {\r\n    const code =\r\n      (ObjectUtil.isValid(this.control.value?.code) && `${this.control.value?.code}`) || `${this.control.value}`;\r\n    if (this.control.value && this.options?.length) {\r\n      let itemsArray = this.options;\r\n      if (this.options?.length) {\r\n        itemsArray = this.options;\r\n      }\r\n      const itemFromSuggestions = itemsArray.find((opt) => `${opt.code}`.toUpperCase() === code.toUpperCase());\r\n      if (itemFromSuggestions) {\r\n        this.control.setValue(itemFromSuggestions, { emitEvent: false });\r\n      } else {\r\n        this.service?.getById(+code).subscribe((response) => {\r\n          this.control.setValue(response, { emitEvent: false });\r\n        });\r\n      }\r\n    } else if (this.control.value && !this.options?.length) {\r\n      this.service?.getById(+code).subscribe((response) => {\r\n        this.control.setValue(response, { emitEvent: false });\r\n      });\r\n    }\r\n  }\r\n}\r\n","<div class=\"multiselect-field-input-container\">\r\n  <p-multiSelect\r\n    *ngIf=\"!filterVirtualScrool\"\r\n    #multiselect\r\n    appendTo=\"body\"\r\n    optionLabel=\"name\"\r\n    optionValue=\"code\"\r\n    dropdownIcon=\"fas fa-sort-down\"\r\n    selectedItemsLabel=\"Selecionar todos\"\r\n    [panelStyleClass]=\"filter ? 'has-filter' : ''\"\r\n    [options]=\"options\"\r\n    [formControl]=\"control\"\r\n    [placeholder]=\"placeholder\"\r\n    [filter]=\"filter\"\r\n    [maxSelectedLabels]=\"options.length - 1\"\r\n    [showToggleAll]=\"showSelectAllOption\"\r\n    [dropdownIcon]=\"'pi pi-chevron-down'\"\r\n    [display]=\"display\"\r\n    (onChange)=\"onChange.emit($event)\"\r\n    (onPanelHide)=\"onClosePanel.emit($event)\"\r\n    (onPanelShow)=\"customFormattingMultiSelectFieldWithFlags()\"\r\n    [disabled]=\"disabled\"\r\n    [showHeader]=\"showHeader\"\r\n  >\r\n    <ng-container *ngIf=\"showFlags\">\r\n      <ng-template let-option pTemplate=\"item\">\r\n        <div class=\"grid-nogutter w-full flex\">\r\n          <div\r\n            class=\"md:col-6 sm:col-12 align-content-center\"\r\n            [ngClass]=\"option.align === 'center' ? 'md:text-center' : 'md:text-left'\"\r\n          >\r\n            <img\r\n              *ngIf=\"option.type == 'img'\"\r\n              [src]=\"option.imgSource\"\r\n              [ngClass]=\"option.imgClass\"\r\n              [style]=\"{ height: option.imgSize + 'px' }\"\r\n            />\r\n            <i\r\n              *ngIf=\"option.type == 'icon'\"\r\n              [className]=\"option.iconSource\"\r\n              [ngClass]=\"option.iconClass\"\r\n              [style]=\"{ 'font-size': option.iconSize }\"\r\n            ></i>\r\n          </div>\r\n\r\n          <div *ngIf=\"option.showDescriptionOnRight\" class=\"col-6 hidden md:block align-content-center\">\r\n            <span class=\"block\">{{ option.name }}</span>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n    </ng-container>\r\n  </p-multiSelect>\r\n\r\n  <p-multiSelect\r\n    *ngIf=\"filterVirtualScrool\"\r\n    #multiselect\r\n    appendTo=\"body\"\r\n    optionLabel=\"name\"\r\n    optionValue=\"code\"\r\n    dropdownIcon=\"fas fa-sort-down\"\r\n    selectedItemsLabel=\"Selecionar todos\"\r\n    [panelStyleClass]=\"filter ? 'has-filter' : ''\"\r\n    [options]=\"options\"\r\n    [formControl]=\"control\"\r\n    [placeholder]=\"placeholder\"\r\n    [filter]=\"filter\"\r\n    [maxSelectedLabels]=\"options.length - 1\"\r\n    [showHeader]=\"true\"\r\n    [showToggleAll]=\"showSelectAllOption\"\r\n    [dropdownIcon]=\"'pi pi-chevron-down'\"\r\n    [display]=\"display\"\r\n    (onChange)=\"onChange.emit($event)\"\r\n    (onFilter)=\"search($event)\"\r\n    (onPanelShow)=\"onOpenAutocompletePanel()\"\r\n    (onPanelHide)=\"onHideAutocompletePanel()\"\r\n    [disabled]=\"disabled\"\r\n  >\r\n  </p-multiSelect>\r\n  <p-multiSelect\r\n    *ngIf=\"filterVirtualScrool\"\r\n    #multiselect\r\n    appendTo=\"body\"\r\n    optionLabel=\"name\"\r\n    optionValue=\"code\"\r\n    dropdownIcon=\"fas fa-sort-down\"\r\n    selectedItemsLabel=\"Selecionar todos\"\r\n    [panelStyleClass]=\"filter ? 'has-filter' : ''\"\r\n    [options]=\"options\"\r\n    [formControl]=\"control\"\r\n    [placeholder]=\"placeholder\"\r\n    [filter]=\"filter\"\r\n    [maxSelectedLabels]=\"options.length - 1\"\r\n    [showHeader]=\"true\"\r\n    [showToggleAll]=\"showSelectAllOption\"\r\n    [dropdownIcon]=\"'pi pi-chevron-down'\"\r\n    [display]=\"display\"\r\n    (onChange)=\"onChange.emit($event)\"\r\n    (onFilter)=\"search($event)\"\r\n    (onPanelShow)=\"onOpenAutocompletePanel()\"\r\n    (onPanelHide)=\"onHideAutocompletePanel()\"\r\n    [disabled]=\"disabled\"\r\n  >\r\n  </p-multiSelect>\r\n  <span class=\"input-error\">{{ fieldErrorLabel() }}</span>\r\n</div>\r\n"]}
|
|
221
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiselect-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/multiselect-field/multiselect-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/multiselect-field/multiselect-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, Renderer2 } from '@angular/core';\r\nimport { ListItem } from '../../../models';\r\nimport { BaseDropdown } from '../../../services';\r\nimport { ObjectUtil } from '../../../utils';\r\n\r\nexport type ListItemOptionsFlagType = ListItem & {\r\n  align: 'center' | 'left';\r\n  showDescriptionOnRight: boolean;\r\n  type: 'img' | 'icon';\r\n  iconSource?: string;\r\n  iconSize?: '1em' | '1.25em' | '1.5em' | '1.75em' | '2em';\r\n  iconClass?: string;\r\n  imgSource?: string;\r\n  imgSize?: '15' | '20' | '25';\r\n  imgClass?: string;\r\n};\r\n\r\n@Component({\r\n  selector: 'vector-multiselect-field',\r\n  templateUrl: './multiselect-field.component.html',\r\n  styleUrls: ['./multiselect-field.component.scss'],\r\n})\r\nexport class MultiselectFieldComponent {\r\n  @Input()\r\n  set pagedSugestion(_pagedSugestion: ListItem[]) {\r\n    this._pagedSugestion = _pagedSugestion;\r\n    this.options = this.pagedSugestion || [];\r\n  }\r\n  @Input()\r\n  public isRequired: boolean = false;\r\n  @Input()\r\n  public control: any;\r\n  @Input()\r\n  public label: string = '';\r\n  @Input()\r\n  public options: ListItem[] | ListItemOptionsFlagType[] = [];\r\n  @Input()\r\n  public filter = false;\r\n  @Input()\r\n  public showSelectAllOption: boolean = true;\r\n  @Input()\r\n  public display: string = 'comma';\r\n  @Input()\r\n  public paged = true;\r\n  @Input()\r\n  public disabled: boolean = false;\r\n  @Input()\r\n  public minLengthToService: number = 0;\r\n  @Input()\r\n  public initialLoad = true;\r\n  @Input()\r\n  public service: BaseDropdown | undefined;\r\n  @Input()\r\n  public filterVirtualScrool = false;\r\n  @Input()\r\n  public showHeader: boolean = true;\r\n  @Input()\r\n  public showFlags: boolean = false;\r\n  private _showFlagsOptions?: ListItemOptionsFlagType[] | undefined;\r\n\r\n  @Input()\r\n  set showFlagsOptions(value: ListItemOptionsFlagType[]) {\r\n    if (!this.showFlags) {\r\n      throw new Error('showFlags is set to false. Setting showFlagsOptions is not allowed.');\r\n    }\r\n    value.forEach((option) => {\r\n      if (option.type === 'img') {\r\n        if (!option.imgSource) {\r\n          throw new Error(\"imgSource is required when type is 'img'\");\r\n        }\r\n        if (!option.imgSize) {\r\n          throw new Error(\"imgSize is required when type is 'img'\");\r\n        }\r\n      } else if (option.type === 'icon') {\r\n        if (!option.iconSource) {\r\n          throw new Error(\"iconSource is required when type is 'icon'\");\r\n        }\r\n        if (!option.iconSize) {\r\n          throw new Error(\"iconSize is required when type is 'icon'\");\r\n        }\r\n      }\r\n    });\r\n    this._showFlagsOptions = value;\r\n  }\r\n\r\n  get showFlagsOptions(): ListItemOptionsFlagType[] {\r\n    if (!this._showFlagsOptions) {\r\n      throw new Error('showFlagsOptions was not set');\r\n    }\r\n    return this._showFlagsOptions;\r\n  }\r\n\r\n  @Output()\r\n  public onChange = new EventEmitter();\r\n  @Output()\r\n  public onClosePanel = new EventEmitter();\r\n\r\n  private currentSearchQuery = '';\r\n  private currentScrollPage = -1;\r\n  private currentScrollIndex = 0;\r\n\r\n  public unlistenAutocompleteVirtualScroll = () => {};\r\n\r\n  get placeholder() {\r\n    if (!this.label) {\r\n      return '';\r\n    }\r\n    return `${this.label}${this.isRequired ? '*' : ''}`;\r\n  }\r\n\r\n  get pagedSugestion() {\r\n    return this._pagedSugestion;\r\n  }\r\n\r\n  private _pagedSugestion: ListItem[] = [];\r\n\r\n  constructor(private renderer: Renderer2) {}\r\n\r\n  ngOnInit(): void {\r\n    if (this.initialLoad && this.filterVirtualScrool) {\r\n      this.search(null, true);\r\n    }\r\n\r\n    if (this.control && this.disabled) {\r\n      this.control.disable();\r\n    } else {\r\n      this.control.enable();\r\n    }\r\n  }\r\n\r\n  public fieldErrorLabel(): string {\r\n    if (this.control && this.control.invalid && this.control.touched) {\r\n      if (this.control.hasError('required')) {\r\n        return 'Campo obrigatório';\r\n      }\r\n\r\n      return typeof this.control.errors['invalid'] === 'string' ? this.control.errors['invalid'] : 'Campo inválido';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  public onOpenAutocompletePanel(): void {\r\n    this.search();\r\n    const multiSelectPanel = document.querySelector('.p-multiselect-items-wrapper');\r\n\r\n    if (multiSelectPanel && this.paged && this.currentSearchQuery.length >= this.minLengthToService) {\r\n      this.unlistenAutocompleteVirtualScroll = this.renderer.listen(multiSelectPanel, 'scroll', (event) => {\r\n        const eventHeight = event.target.scrollHeight - event.target.clientHeight - 150;\r\n\r\n        if (Math.round(event.target.scrollTop) >= eventHeight) {\r\n          this.pageResults();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public customFormattingMultiSelectFieldWithFlags(): void {\r\n    setTimeout(() => {\r\n      const vectorMultiselectField = document.querySelector('vector-multiselect-field.multiselect-flags');\r\n\r\n      if (vectorMultiselectField) {\r\n        const pOverlayElement = vectorMultiselectField.querySelector('p-overlay');\r\n\r\n        if (pOverlayElement) {\r\n          const classList = Array.from(pOverlayElement.classList);\r\n          const targetClass = classList.find((className) => className.startsWith('ng-tns-'));\r\n\r\n          if (targetClass) {\r\n            const classReferenceCode = targetClass.replace('ng-tns-', '');\r\n            const targetDivWithRefCode = document.querySelector(`div.ng-tns-${classReferenceCode}`);\r\n\r\n            if (targetDivWithRefCode) {\r\n              targetDivWithRefCode.classList.add('multiselect-flags');\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }, 200);\r\n  }\r\n\r\n  public onHideAutocompletePanel(): void {\r\n    if (this.paged) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n  }\r\n\r\n  public search($event?: any, forceSearch = false): void {\r\n    this.currentSearchQuery = $event?.filter.toUpperCase() || '';\r\n    this.currentScrollPage = -1;\r\n    this.currentScrollIndex = 0;\r\n    if (forceSearch || this.currentSearchQuery.length >= this.minLengthToService) {\r\n      this.pageResults();\r\n    } else {\r\n      this.options = [];\r\n    }\r\n  }\r\n\r\n  private pageResults(): void {\r\n    const filteredOptions = this.filterListByQuery(this.pagedSugestion, this.currentSearchQuery.toUpperCase());\r\n    this.options = filteredOptions.slice(0, this.currentScrollIndex + 20);\r\n\r\n    if (this.pagedSugestion?.length && this.pagedSugestion.length > 20) {\r\n      this.currentScrollIndex = this.currentScrollIndex + 20;\r\n    }\r\n\r\n    this.setControlValueFromSuggestions();\r\n  }\r\n\r\n  private filterListByQuery(list: ListItem[] = [], query: string): ListItem[] {\r\n    return list.filter(\r\n      (opt) => String(opt.code).toUpperCase().includes(query) || opt.name.toUpperCase().includes(query)\r\n    );\r\n  }\r\n  private setControlValueFromSuggestions() {\r\n    const code =\r\n      (ObjectUtil.isValid(this.control.value?.code) && `${this.control.value?.code}`) || `${this.control.value}`;\r\n    if (this.control.value && this.options?.length) {\r\n      let itemsArray = this.options;\r\n      if (this.options?.length) {\r\n        itemsArray = this.options;\r\n      }\r\n      const itemFromSuggestions = itemsArray.find((opt) => `${opt.code}`.toUpperCase() === code.toUpperCase());\r\n      if (itemFromSuggestions) {\r\n        this.control.setValue(itemFromSuggestions, { emitEvent: false });\r\n      } else {\r\n        this.service?.getById(+code).subscribe((response) => {\r\n          this.control.setValue(response, { emitEvent: false });\r\n        });\r\n      }\r\n    } else if (this.control.value && !this.options?.length) {\r\n      this.service?.getById(+code).subscribe((response) => {\r\n        this.control.setValue(response, { emitEvent: false });\r\n      });\r\n    }\r\n  }\r\n}\r\n","<div class=\"multiselect-field-input-container\">\r\n  <p-multiSelect\r\n    *ngIf=\"!filterVirtualScrool\"\r\n    #multiselect\r\n    appendTo=\"body\"\r\n    optionLabel=\"name\"\r\n    optionValue=\"code\"\r\n    dropdownIcon=\"fas fa-sort-down\"\r\n    selectedItemsLabel=\"Selecionar todos\"\r\n    [panelStyleClass]=\"filter ? 'has-filter' : ''\"\r\n    [options]=\"options\"\r\n    [formControl]=\"control\"\r\n    [placeholder]=\"placeholder\"\r\n    [filter]=\"filter\"\r\n    [maxSelectedLabels]=\"options.length - 1\"\r\n    [showToggleAll]=\"showSelectAllOption\"\r\n    [dropdownIcon]=\"'pi pi-chevron-down'\"\r\n    [display]=\"display\"\r\n    (onChange)=\"onChange.emit($event)\"\r\n    (onPanelHide)=\"onClosePanel.emit($event)\"\r\n    (onPanelShow)=\"customFormattingMultiSelectFieldWithFlags()\"\r\n    [disabled]=\"disabled\"\r\n    [showHeader]=\"showHeader\"\r\n  >\r\n    <ng-container *ngIf=\"showFlags\">\r\n      <ng-template let-option pTemplate=\"item\">\r\n        <div class=\"grid-nogutter w-full flex\">\r\n          <div\r\n            class=\"md:col-6 sm:col-12 align-content-center\"\r\n            [ngClass]=\"option.align === 'center' ? 'md:text-center' : 'md:text-left'\"\r\n          >\r\n            <img\r\n              *ngIf=\"option.type == 'img'\"\r\n              [src]=\"option.imgSource\"\r\n              [ngClass]=\"option.imgClass\"\r\n              [style]=\"{ height: option.imgSize + 'px' }\"\r\n            />\r\n            <i\r\n              *ngIf=\"option.type == 'icon'\"\r\n              [className]=\"option.iconSource\"\r\n              [ngClass]=\"option.iconClass\"\r\n              [style]=\"{ 'font-size': option.iconSize }\"\r\n            ></i>\r\n          </div>\r\n\r\n          <div *ngIf=\"option.showDescriptionOnRight\" class=\"col-6 hidden md:block align-content-center\">\r\n            <span class=\"block\">{{ option.name }}</span>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n    </ng-container>\r\n  </p-multiSelect>\r\n\r\n  <p-multiSelect\r\n    *ngIf=\"filterVirtualScrool\"\r\n    #multiselect\r\n    appendTo=\"body\"\r\n    optionLabel=\"name\"\r\n    optionValue=\"code\"\r\n    dropdownIcon=\"fas fa-sort-down\"\r\n    selectedItemsLabel=\"Selecionar todos\"\r\n    [panelStyleClass]=\"filter ? 'has-filter' : ''\"\r\n    [options]=\"options\"\r\n    [formControl]=\"control\"\r\n    [placeholder]=\"placeholder\"\r\n    [filter]=\"filter\"\r\n    [maxSelectedLabels]=\"options.length - 1\"\r\n    [showHeader]=\"true\"\r\n    [showToggleAll]=\"showSelectAllOption\"\r\n    [dropdownIcon]=\"'pi pi-chevron-down'\"\r\n    [display]=\"display\"\r\n    (onChange)=\"onChange.emit($event)\"\r\n    (onFilter)=\"search($event)\"\r\n    (onPanelShow)=\"onOpenAutocompletePanel()\"\r\n    (onPanelHide)=\"onHideAutocompletePanel()\"\r\n    [disabled]=\"disabled\"\r\n  >\r\n  </p-multiSelect>\r\n  <p-multiSelect\r\n    *ngIf=\"filterVirtualScrool\"\r\n    #multiselect\r\n    appendTo=\"body\"\r\n    optionLabel=\"name\"\r\n    optionValue=\"code\"\r\n    dropdownIcon=\"fas fa-sort-down\"\r\n    selectedItemsLabel=\"Selecionar todos\"\r\n    [panelStyleClass]=\"filter ? 'has-filter' : ''\"\r\n    [options]=\"options\"\r\n    [formControl]=\"control\"\r\n    [placeholder]=\"placeholder\"\r\n    [filter]=\"filter\"\r\n    [maxSelectedLabels]=\"options.length - 1\"\r\n    [showHeader]=\"true\"\r\n    [showToggleAll]=\"showSelectAllOption\"\r\n    [dropdownIcon]=\"'pi pi-chevron-down'\"\r\n    [display]=\"display\"\r\n    (onChange)=\"onChange.emit($event)\"\r\n    (onFilter)=\"search($event)\"\r\n    (onPanelShow)=\"onOpenAutocompletePanel()\"\r\n    (onPanelHide)=\"onHideAutocompletePanel()\"\r\n    [disabled]=\"disabled\"\r\n  >\r\n  </p-multiSelect>\r\n  <span class=\"input-error\">{{ fieldErrorLabel() }}</span>\r\n</div>\r\n"]}
|
|
@@ -20,13 +20,11 @@ export class RadioButtonFieldComponent {
|
|
|
20
20
|
this.disabled = false;
|
|
21
21
|
}
|
|
22
22
|
ngOnInit() {
|
|
23
|
-
if (this.control) {
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
this.control.enable();
|
|
29
|
-
}
|
|
23
|
+
if (this.control && this.disabled) {
|
|
24
|
+
this.control.disable();
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.control.enable();
|
|
30
28
|
}
|
|
31
29
|
}
|
|
32
30
|
get layoutClass() {
|
|
@@ -61,4 +59,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
61
59
|
}], disabled: [{
|
|
62
60
|
type: Input
|
|
63
61
|
}] } });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tYnV0dG9uLWZpZWxkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12ZWN0b3ItY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvZmllbGRzL3JhZGlvLWJ1dHRvbi1maWVsZC9yYWRpby1idXR0b24tZmllbGQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZlY3Rvci1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9maWVsZHMvcmFkaW8tYnV0dG9uLWZpZWxkL3JhZGlvLWJ1dHRvbi1maWVsZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV6RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0saUJBQWlCLENBQUM7Ozs7Ozs7QUFhOUMsTUFBTSxPQUFPLHlCQUF5QjtJQW1CcEMsWUFBb0IsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFqQi9DLGNBQVMsR0FBVyxFQUFFLENBQUM7UUFFdkIsWUFBTyxHQUF3QjtZQUNwQyxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFLEVBQUUsS0FBSyxFQUFFLFdBQVcsQ0FBQyxHQUFHLEVBQUU7WUFDckQsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxFQUFFLEtBQUssRUFBRSxXQUFXLENBQUMsRUFBRSxFQUFFO1NBQ3BELENBQUM7UUFJSyxXQUFNLEdBQThCLFVBQVUsQ0FBQztRQUUvQyx3QkFBbUIsR0FBRyxLQUFLLENBQUM7UUFFNUIsWUFBTyxHQUFHLEtBQUssQ0FBQztRQUVoQixhQUFRLEdBQVksS0FBSyxDQUFDO0lBRXdCLENBQUM7SUFFMUQsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pDLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7U0FDeEI7YUFBTTtZQUNMLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7U0FDdkI7SUFDSCxDQUFDO0lBRUQsSUFBSSxXQUFXO1FBQ2IsT0FBTyxFQUFFLFVBQVUsRUFBRSxJQUFJLENBQUMsTUFBTSxLQUFLLFlBQVksRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLE1BQU0sS0FBSyxVQUFVLEVBQUUsQ0FBQztJQUM1RixDQUFDO0lBRU8sV0FBVztRQUNqQixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBQzdELE9BQU8sS0FBSyxLQUFLLGVBQWUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDbkQsQ0FBQztJQUVPLFVBQVU7UUFDaEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUM1RCxPQUFPLEtBQUssS0FBSyxjQUFjLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQ2xELENBQUM7K0dBekNVLHlCQUF5QjttR0FBekIseUJBQXlCLHFQQ2Z0Qyxnb0JBb0JBOzs0RkRMYSx5QkFBeUI7a0JBTHJDLFNBQVM7K0JBQ0UsMkJBQTJCO3FGQU05QixTQUFTO3NCQURmLEtBQUs7Z0JBR0MsT0FBTztzQkFEYixLQUFLO2dCQU1DLE9BQU87c0JBRGIsS0FBSztnQkFHQyxNQUFNO3NCQURaLEtBQUs7Z0JBR0MsbUJBQW1CO3NCQUR6QixLQUFLO2dCQUdDLE9BQU87c0JBRGIsS0FBSztnQkFHQyxRQUFRO3NCQURkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5pbXBvcnQgeyBCb29sZWFuVHlwZSB9IGZyb20gJy4uLy4uLy4uL21vZGVscyc7XHJcblxyXG5leHBvcnQgdHlwZSBSYWRpb0J1dHRvbk9wdGlvbiA9IHtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIHZhbHVlOiBzdHJpbmc7XHJcbiAgdGV4dFRvb2x0aXA/OiBzdHJpbmc7XHJcbn07XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3ZlY3Rvci1yYWRpby1idXR0b24tZmllbGQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9yYWRpby1idXR0b24tZmllbGQuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3JhZGlvLWJ1dHRvbi1maWVsZC5jb21wb25lbnQuc2NzcyddLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmFkaW9CdXR0b25GaWVsZENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZ3JvdXBOYW1lOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBvcHRpb25zOiBSYWRpb0J1dHRvbk9wdGlvbltdID0gW1xyXG4gICAgeyBsYWJlbDogdGhpcy5nZXRZZXNMYWJlbCgpLCB2YWx1ZTogQm9vbGVhblR5cGUuWUVTIH0sXHJcbiAgICB7IGxhYmVsOiB0aGlzLmdldE5vTGFiZWwoKSwgdmFsdWU6IEJvb2xlYW5UeXBlLk5PIH0sXHJcbiAgXTtcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjb250cm9sOiBhbnk7XHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgbGF5b3V0OiAndmVydGljYWwnIHwgJ2hvcml6b250YWwnID0gJ3ZlcnRpY2FsJztcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBqdXN0aWZ5U3BhY2VCZXR3ZWVuID0gZmFsc2U7XHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgYWRkSWNvbiA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSkge31cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICBpZiAodGhpcy5jb250cm9sICYmIHRoaXMuZGlzYWJsZWQpIHtcclxuICAgICAgdGhpcy5jb250cm9sLmRpc2FibGUoKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMuY29udHJvbC5lbmFibGUoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGdldCBsYXlvdXRDbGFzcygpIHtcclxuICAgIHJldHVybiB7IGhvcml6b250YWw6IHRoaXMubGF5b3V0ID09PSAnaG9yaXpvbnRhbCcsIHZlcnRpY2FsOiB0aGlzLmxheW91dCA9PT0gJ3ZlcnRpY2FsJyB9O1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBnZXRZZXNMYWJlbCgpIHtcclxuICAgIGNvbnN0IGxhYmVsID0gdGhpcy50cmFuc2xhdGVTZXJ2aWNlLmluc3RhbnQoJ2FwcC5sYWJlbC55ZXMnKTtcclxuICAgIHJldHVybiBsYWJlbCAhPT0gJ2FwcC5sYWJlbC55ZXMnID8gbGFiZWwgOiAnU2ltJztcclxuICB9XHJcblxyXG4gIHByaXZhdGUgZ2V0Tm9MYWJlbCgpIHtcclxuICAgIGNvbnN0IGxhYmVsID0gdGhpcy50cmFuc2xhdGVTZXJ2aWNlLmluc3RhbnQoJ2FwcC5sYWJlbC5ubycpO1xyXG4gICAgcmV0dXJuIGxhYmVsICE9PSAnYXBwLmxhYmVsLm5vJyA/IGxhYmVsIDogJ07Do28nO1xyXG4gIH1cclxufVxyXG4iLCI8ZGl2XHJcbiAgY2xhc3M9XCJyYWRpby1idXR0b25zLWNvbnRhaW5lclwiXHJcbiAgW25nQ2xhc3NdPVwibGF5b3V0Q2xhc3NcIlxyXG4gIFtuZ1N0eWxlXT1cInsgJ2p1c3RpZnktY29udGVudCc6IGp1c3RpZnlTcGFjZUJldHdlZW4gPyAnc3BhY2UtYmV0d2VlbicgOiAnZmxleC1zdGFydCcgfVwiXHJcbj5cclxuICA8ZGl2ICpuZ0Zvcj1cImxldCBvcHRpb24gb2Ygb3B0aW9uc1wiIGNsYXNzPVwicmFkaW8tYnV0dG9uLWl0ZW1cIj5cclxuICAgIDxwLXJhZGlvQnV0dG9uXHJcbiAgICAgIFtuYW1lXT1cImdyb3VwTmFtZVwiXHJcbiAgICAgIFt2YWx1ZV09XCJvcHRpb24udmFsdWVcIlxyXG4gICAgICBbbGFiZWxdPVwib3B0aW9uLmxhYmVsXCJcclxuICAgICAgW2Zvcm1Db250cm9sXT1cImNvbnRyb2xcIlxyXG4gICAgPjwvcC1yYWRpb0J1dHRvbj5cclxuICAgIDxpXHJcbiAgICAgICpuZ0lmPVwiYWRkSWNvblwiXHJcbiAgICAgIGNsYXNzPVwiZmFzIGZhLWluZm8tY2lyY2xlIG10LTEgcHItMyBwbC0yXCJcclxuICAgICAgcFRvb2x0aXA9XCJ7eyBvcHRpb24udGV4dFRvb2x0aXAgfX1cIlxyXG4gICAgICB0b29sdGlwUG9zaXRpb249XCJib3R0b21cIlxyXG4gICAgPjwvaT5cclxuICA8L2Rpdj5cclxuPC9kaXY+XHJcbiJdfQ==
|