@wemake4u/form-player-se 1.0.39 → 1.0.41

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.
Files changed (86) hide show
  1. package/esm2022/lib/builtIn/builtIn.mjs +24 -0
  2. package/esm2022/lib/builtIn/console.json +253 -0
  3. package/esm2022/lib/builtIn/dialog.json +109 -0
  4. package/esm2022/lib/builtIn/feel.json +26 -0
  5. package/esm2022/lib/builtIn/form.json +172 -0
  6. package/esm2022/lib/builtIn/formGroup.json +218 -0
  7. package/esm2022/lib/builtIn/formatter.json +112 -0
  8. package/esm2022/lib/builtIn/function.json +53 -0
  9. package/esm2022/lib/builtIn/register.json +14 -0
  10. package/esm2022/lib/components/setFilter/setFilter.component.mjs +35 -5
  11. package/esm2022/lib/controls/accordion.mjs +50 -3
  12. package/esm2022/lib/controls/control.mjs +70 -25
  13. package/esm2022/lib/controls/factory.mjs +42 -42
  14. package/esm2022/lib/controls/tab.mjs +47 -25
  15. package/esm2022/lib/controls/table.mjs +89 -15
  16. package/esm2022/lib/controls/textfield.mjs +4 -3
  17. package/esm2022/lib/directives/accordionpanel.directive.mjs +10 -5
  18. package/esm2022/lib/directives/collapse.directive.mjs +22 -12
  19. package/esm2022/lib/directives/collapsepatch.directive.mjs +2 -1
  20. package/esm2022/lib/directives/datetime.directive.mjs +18 -21
  21. package/esm2022/lib/directives/dropdown.directive.mjs +31 -16
  22. package/esm2022/lib/directives/grid.directive.mjs +10 -8
  23. package/esm2022/lib/directives/readonly.directive.mjs +10 -9
  24. package/esm2022/lib/directives/register.directive.mjs +32 -15
  25. package/esm2022/lib/directives/required.directive.mjs +57 -0
  26. package/esm2022/lib/directives/tabcontrol.directive.mjs +10 -9
  27. package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +28 -5
  28. package/esm2022/lib/dynamic-form/dynamic-form.component.mjs +46 -21
  29. package/esm2022/lib/dynamic-host/dynamic-host.component.mjs +32 -10
  30. package/esm2022/lib/services/event.service.mjs +17 -6
  31. package/esm2022/lib/services/formatter.service.mjs +3 -1
  32. package/esm2022/lib/services/grid.service.mjs +4 -1
  33. package/esm2022/lib/services/listener.service.mjs +23 -0
  34. package/esm2022/lib/services/navigation.service.mjs +35 -0
  35. package/esm2022/lib/services/programmability.service.mjs +54 -38
  36. package/esm2022/lib/services/register.service.mjs +40 -2
  37. package/esm2022/lib/services/state.service.mjs +40 -0
  38. package/esm2022/lib/services/status.service.mjs +10 -5
  39. package/esm2022/lib/services/subscribe.service.mjs +54 -0
  40. package/esm2022/lib/services/validation.service.mjs +11 -2
  41. package/esm2022/lib/utils/deepEqual.mjs +46 -0
  42. package/esm2022/lib/utils/navigation.mjs +20 -0
  43. package/esm2022/lib/utils/observable.mjs +7 -0
  44. package/esm2022/lib/utils/patch.mjs +17 -0
  45. package/esm2022/lib/utils/proxy.mjs +28 -1
  46. package/esm2022/lib/utils/resolveRefs.mjs +67 -0
  47. package/esm2022/public-api.mjs +7 -1
  48. package/fesm2022/wemake4u-form-player-se.mjs +2027 -276
  49. package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
  50. package/lib/builtIn/builtIn.d.ts +32 -0
  51. package/lib/components/setFilter/setFilter.component.d.ts +1 -0
  52. package/lib/controls/accordion.d.ts +5 -1
  53. package/lib/controls/control.d.ts +31 -12
  54. package/lib/controls/factory.d.ts +2 -4
  55. package/lib/controls/tab.d.ts +9 -6
  56. package/lib/controls/table.d.ts +16 -5
  57. package/lib/controls/textfield.d.ts +1 -1
  58. package/lib/directives/accordionpanel.directive.d.ts +4 -2
  59. package/lib/directives/collapse.directive.d.ts +5 -3
  60. package/lib/directives/datetime.directive.d.ts +7 -8
  61. package/lib/directives/dropdown.directive.d.ts +6 -3
  62. package/lib/directives/grid.directive.d.ts +4 -3
  63. package/lib/directives/readonly.directive.d.ts +3 -4
  64. package/lib/directives/register.directive.d.ts +4 -3
  65. package/lib/directives/required.directive.d.ts +17 -0
  66. package/lib/directives/tabcontrol.directive.d.ts +5 -6
  67. package/lib/dynamic-fields/dynamic-fields.component.d.ts +4 -1
  68. package/lib/dynamic-form/dynamic-form.component.d.ts +4 -1
  69. package/lib/dynamic-host/dynamic-host.component.d.ts +6 -2
  70. package/lib/services/event.service.d.ts +8 -2
  71. package/lib/services/listener.service.d.ts +11 -0
  72. package/lib/services/navigation.service.d.ts +11 -0
  73. package/lib/services/programmability.service.d.ts +8 -9
  74. package/lib/services/register.service.d.ts +9 -0
  75. package/lib/services/state.service.d.ts +14 -0
  76. package/lib/services/status.service.d.ts +5 -1
  77. package/lib/services/subscribe.service.d.ts +14 -0
  78. package/lib/services/validation.service.d.ts +5 -2
  79. package/lib/utils/deepEqual.d.ts +1 -0
  80. package/lib/utils/navigation.d.ts +6 -0
  81. package/lib/utils/observable.d.ts +2 -0
  82. package/lib/utils/patch.d.ts +1 -0
  83. package/lib/utils/proxy.d.ts +2 -0
  84. package/lib/utils/resolveRefs.d.ts +12 -0
  85. package/package.json +1 -1
  86. package/public-api.d.ts +6 -0
@@ -1,9 +1,14 @@
1
1
  import { Directive, Host } from '@angular/core';
2
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "ngx-sirio-lib";
4
5
  export class AccordionPanelDirective {
5
- constructor(panel) {
6
- panel.opened.subscribe((event) => {
6
+ destroyRef;
7
+ constructor(panel, destroyRef) {
8
+ this.destroyRef = destroyRef;
9
+ panel.opened
10
+ .pipe(takeUntilDestroyed(this.destroyRef))
11
+ .subscribe((event) => {
7
12
  const element = event.component.body.el.nativeElement;
8
13
  // delay height calculation to allow for DOM updates
9
14
  setTimeout(() => {
@@ -13,7 +18,7 @@ export class AccordionPanelDirective {
13
18
  }, 0);
14
19
  });
15
20
  }
16
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AccordionPanelDirective, deps: [{ token: i1.SirioAccordionPanelComponent, host: true }], target: i0.ɵɵFactoryTarget.Directive });
21
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AccordionPanelDirective, deps: [{ token: i1.SirioAccordionPanelComponent, host: true }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Directive });
17
22
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: AccordionPanelDirective, isStandalone: true, selector: "[accordionPanel]", ngImport: i0 });
18
23
  }
19
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AccordionPanelDirective, decorators: [{
@@ -24,5 +29,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
24
29
  }]
25
30
  }], ctorParameters: () => [{ type: i1.SirioAccordionPanelComponent, decorators: [{
26
31
  type: Host
27
- }] }] });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9ucGFuZWwuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNpcmlvL3NyYy9saWIvZGlyZWN0aXZlcy9hY2NvcmRpb25wYW5lbC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU9oRCxNQUFNLE9BQU8sdUJBQXVCO0lBRWxDLFlBQ1UsS0FBbUM7UUFFM0MsS0FBSyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFrRCxFQUFFLEVBQUU7WUFDNUUsTUFBTSxPQUFPLEdBQUksS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFZLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQztZQUMvRCxvREFBb0Q7WUFDcEQsVUFBVSxDQUFDLEdBQUcsRUFBRTtnQkFDZCw0Q0FBNEM7Z0JBQzVDLDZDQUE2QztnQkFDN0MsT0FBTyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsRUFBRSxDQUFDO1lBQzVCLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNSLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzt3R0FkVSx1QkFBdUI7NEZBQXZCLHVCQUF1Qjs7NEZBQXZCLHVCQUF1QjtrQkFKbkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7OzBCQUlJLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEhvc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU2lyaW9BY2NvcmRpb25QYW5lbENvbXBvbmVudCwgTmd4U2lyaW9FdmVudCB9IGZyb20gJ25neC1zaXJpby1saWInO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbYWNjb3JkaW9uUGFuZWxdJyxcclxuICBzdGFuZGFsb25lOiB0cnVlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBY2NvcmRpb25QYW5lbERpcmVjdGl2ZSB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgQEhvc3QoKSBwYW5lbDogU2lyaW9BY2NvcmRpb25QYW5lbENvbXBvbmVudFxyXG4gICkge1xyXG4gICAgcGFuZWwub3BlbmVkLnN1YnNjcmliZSgoZXZlbnQ6IE5neFNpcmlvRXZlbnQ8U2lyaW9BY2NvcmRpb25QYW5lbENvbXBvbmVudD4pID0+IHtcclxuICAgICAgY29uc3QgZWxlbWVudCA9IChldmVudC5jb21wb25lbnQuYm9keSBhcyBhbnkpLmVsLm5hdGl2ZUVsZW1lbnQ7XHJcbiAgICAgIC8vIGRlbGF5IGhlaWdodCBjYWxjdWxhdGlvbiB0byBhbGxvdyBmb3IgRE9NIHVwZGF0ZXNcclxuICAgICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgICAgLy9jb25zdCBzY3JvbGxIZWlnaHQgPSBlbGVtZW50LnNjcm9sbEhlaWdodDtcclxuICAgICAgICAvL2VsZW1lbnQuc3R5bGUuaGVpZ2h0ID0gYCR7c2Nyb2xsSGVpZ2h0fXB4YDtcclxuICAgICAgICBlbGVtZW50LnN0eWxlLmhlaWdodCA9ICcnO1xyXG4gICAgICB9LCAwKTtcclxuICAgIH0pOyAgICBcclxuICB9XHJcbn1cclxuIl19
32
+ }] }, { type: i0.DestroyRef }] });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9ucGFuZWwuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNpcmlvL3NyYy9saWIvZGlyZWN0aXZlcy9hY2NvcmRpb25wYW5lbC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFjLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQU9oRSxNQUFNLE9BQU8sdUJBQXVCO0lBSXhCO0lBRlYsWUFDVSxLQUFtQyxFQUNuQyxVQUFzQjtRQUF0QixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBRTlCLEtBQUssQ0FBQyxNQUFNO2FBQ1QsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQzthQUN6QyxTQUFTLENBQUMsQ0FBQyxLQUFrRCxFQUFFLEVBQUU7WUFDbEUsTUFBTSxPQUFPLEdBQUksS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFZLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQztZQUMvRCxvREFBb0Q7WUFDcEQsVUFBVSxDQUFDLEdBQUcsRUFBRTtnQkFDZCw0Q0FBNEM7Z0JBQzVDLDZDQUE2QztnQkFDN0MsT0FBTyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsRUFBRSxDQUFDO1lBQzVCLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNSLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzt3R0FqQlUsdUJBQXVCOzRGQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBSm5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzswQkFJSSxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgRGlyZWN0aXZlLCBIb3N0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IHRha2VVbnRpbERlc3Ryb3llZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcclxuaW1wb3J0IHsgU2lyaW9BY2NvcmRpb25QYW5lbENvbXBvbmVudCwgTmd4U2lyaW9FdmVudCB9IGZyb20gJ25neC1zaXJpby1saWInO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbYWNjb3JkaW9uUGFuZWxdJyxcclxuICBzdGFuZGFsb25lOiB0cnVlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBY2NvcmRpb25QYW5lbERpcmVjdGl2ZSB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgQEhvc3QoKSBwYW5lbDogU2lyaW9BY2NvcmRpb25QYW5lbENvbXBvbmVudCxcclxuICAgIHByaXZhdGUgZGVzdHJveVJlZjogRGVzdHJveVJlZlxyXG4gICkge1xyXG4gICAgcGFuZWwub3BlbmVkXHJcbiAgICAgIC5waXBlKHRha2VVbnRpbERlc3Ryb3llZCh0aGlzLmRlc3Ryb3lSZWYpKVxyXG4gICAgICAuc3Vic2NyaWJlKChldmVudDogTmd4U2lyaW9FdmVudDxTaXJpb0FjY29yZGlvblBhbmVsQ29tcG9uZW50PikgPT4ge1xyXG4gICAgICBjb25zdCBlbGVtZW50ID0gKGV2ZW50LmNvbXBvbmVudC5ib2R5IGFzIGFueSkuZWwubmF0aXZlRWxlbWVudDtcclxuICAgICAgLy8gZGVsYXkgaGVpZ2h0IGNhbGN1bGF0aW9uIHRvIGFsbG93IGZvciBET00gdXBkYXRlc1xyXG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgICAvL2NvbnN0IHNjcm9sbEhlaWdodCA9IGVsZW1lbnQuc2Nyb2xsSGVpZ2h0O1xyXG4gICAgICAgIC8vZWxlbWVudC5zdHlsZS5oZWlnaHQgPSBgJHtzY3JvbGxIZWlnaHR9cHhgO1xyXG4gICAgICAgIGVsZW1lbnQuc3R5bGUuaGVpZ2h0ID0gJyc7XHJcbiAgICAgIH0sIDApO1xyXG4gICAgfSk7ICAgIFxyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,12 +1,16 @@
1
1
  import { Directive, Input } from '@angular/core';
2
- import { Subscription } from 'rxjs';
2
+ import { ListenerService } from '../services/listener.service';
3
3
  import { Texts } from '../locale/locale';
4
4
  import { localize } from '../locale/localize';
5
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
5
6
  import * as i0 from "@angular/core";
6
- import * as i1 from "@wemake4u/interact";
7
+ import * as i1 from "../services/listener.service";
8
+ import * as i2 from "@wemake4u/interact";
7
9
  export class CollapseDirective {
8
10
  el;
9
11
  renderer;
12
+ destroyRef;
13
+ listenerService;
10
14
  languageService;
11
15
  maxHeight = null;
12
16
  currentHeight = null;
@@ -16,18 +20,19 @@ export class CollapseDirective {
16
20
  viewInitialized = false;
17
21
  timeoutFocusOut;
18
22
  unlistenFocusOut;
19
- subscription = new Subscription();
20
- constructor(el, renderer, languageService) {
23
+ constructor(el, renderer, destroyRef, listenerService, languageService) {
21
24
  this.el = el;
22
25
  this.renderer = renderer;
26
+ this.destroyRef = destroyRef;
27
+ this.listenerService = listenerService;
23
28
  this.languageService = languageService;
24
- this.subscription = languageService.onLanguageChanged()
29
+ languageService.onLanguageChanged()
30
+ .pipe(takeUntilDestroyed(this.destroyRef))
25
31
  .subscribe(() => this.applyCollapseLogic());
26
32
  }
27
33
  ngOnDestroy() {
28
34
  this.resetButton();
29
35
  this.resetFocusHandler();
30
- this.subscription.unsubscribe();
31
36
  }
32
37
  ngAfterViewInit() {
33
38
  this.viewInitialized = true;
@@ -84,7 +89,7 @@ export class CollapseDirective {
84
89
  this.renderer.addClass(this.iconSpan, 'fa-chevron-down');
85
90
  this.renderer.appendChild(this.button, text);
86
91
  this.renderer.appendChild(this.button, this.iconSpan);
87
- this.renderer.listen(this.button, 'click', () => this.toggleExpand());
92
+ this.listenerService.listen(this.button, 'click', () => this.toggleExpand());
88
93
  this.renderer.setStyle(this.button, 'margin-top', '8px');
89
94
  this.renderer.appendChild(element.parentNode, this.button);
90
95
  }
@@ -144,17 +149,22 @@ export class CollapseDirective {
144
149
  locale(component, key) {
145
150
  return localize(this.language, component, key);
146
151
  }
147
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CollapseDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.LanguageService }], target: i0.ɵɵFactoryTarget.Directive });
148
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: CollapseDirective, isStandalone: true, selector: "[collapse]", inputs: { maxHeight: ["collapse", "maxHeight"] }, usesOnChanges: true, ngImport: i0 });
152
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CollapseDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.DestroyRef }, { token: i1.ListenerService }, { token: i2.LanguageService }], target: i0.ɵɵFactoryTarget.Directive });
153
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: CollapseDirective, isStandalone: true, selector: "[collapse]", inputs: { maxHeight: ["collapse", "maxHeight"] }, providers: [
154
+ ListenerService
155
+ ], usesOnChanges: true, ngImport: i0 });
149
156
  }
150
157
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CollapseDirective, decorators: [{
151
158
  type: Directive,
152
159
  args: [{
153
160
  selector: '[collapse]',
154
- standalone: true
161
+ standalone: true,
162
+ providers: [
163
+ ListenerService
164
+ ]
155
165
  }]
156
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.LanguageService }], propDecorators: { maxHeight: [{
166
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.DestroyRef }, { type: i1.ListenerService }, { type: i2.LanguageService }], propDecorators: { maxHeight: [{
157
167
  type: Input,
158
168
  args: ['collapse']
159
169
  }] } });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collapse.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/directives/collapse.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Renderer2, Input, OnChanges, SimpleChanges, OnDestroy } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { LanguageService } from '@wemake4u/interact';\r\nimport { Texts } from '../locale/locale';\r\nimport { localize } from '../locale/localize';\r\n\r\n@Directive({\r\n  selector: '[collapse]',\r\n  standalone: true\r\n})\r\nexport class CollapseDirective implements OnChanges, OnDestroy {\r\n  @Input('collapse') maxHeight: number | null = null;\r\n  \r\n  private currentHeight: number | null = null;\r\n  private button: HTMLButtonElement | null = null;\r\n  private iconSpan: HTMLElement | null = null;\r\n  private expanded = false;\r\n  private viewInitialized = false;\r\n  private timeoutFocusOut: any;\r\n  private unlistenFocusOut!: () => void;\r\n  private subscription = new Subscription();\r\n\r\n  constructor(private el: ElementRef\r\n    , private renderer: Renderer2\r\n    , private languageService: LanguageService) {\r\n\r\n    this.subscription = languageService.onLanguageChanged()\r\n      .subscribe(() => this.applyCollapseLogic());\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.resetButton();\r\n    this.resetFocusHandler();\r\n    this.subscription.unsubscribe();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.viewInitialized = true;\r\n    this.currentHeight = this.maxHeight;\r\n    this.applyCollapseLogic();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['language'] || changes['maxHeight']) {\r\n      this.currentHeight = this.maxHeight;\r\n      if (this.viewInitialized) {\r\n        this.applyCollapseLogic();\r\n      }\r\n    }\r\n  }\r\n\r\n  private get language(): string {\r\n    return this.languageService.getLanguage();\r\n  }\r\n\r\n  private applyCollapseLogic(): void {\r\n    \r\n    this.resetStyles();\r\n    \r\n    this.resetButton();\r\n    \r\n    this.resetFocusHandler();\r\n\r\n    if (this.maxHeight == null || this.maxHeight <= 0) {\r\n      this.expanded = true;\r\n      return;\r\n    }\r\n\r\n    this.expanded = false;\r\n\r\n    this.applyStyle();\r\n\r\n    const element = this.el.nativeElement as HTMLElement;\r\n\r\n    setTimeout(() => {\r\n      if (element.scrollHeight > this.maxHeight!) {\r\n        this.applyButton();\r\n        this.applyFocusHandler();\r\n      }\r\n    }, 100);\r\n    \r\n  }\r\n\r\n  private applyStyle() {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.renderer.setStyle(element, 'overflow', 'hidden');\r\n    this.renderer.setStyle(element, 'max-height', `${this.maxHeight}px`);\r\n  }\r\n\r\n  private resetStyles() {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.renderer.setStyle(element, 'overflow', null);\r\n    this.renderer.setStyle(element, 'max-height', null);\r\n  }\r\n\r\n  private applyButton(): void {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.button = this.renderer.createElement('button');\r\n    this.renderer.addClass(this.button, 'sirio-btn');\r\n    this.renderer.setStyle(this.button, 'padding', '0px');\r\n\r\n    const text = this.renderer.createText(this.locale(Texts, 'ReadMore'));\r\n\r\n    this.iconSpan = this.renderer.createElement('span');\r\n    this.renderer.addClass(this.iconSpan, 'fa');\r\n    this.renderer.addClass(this.iconSpan, 'fa-chevron-down');\r\n    \r\n    this.renderer.appendChild(this.button, text);\r\n    this.renderer.appendChild(this.button, this.iconSpan);\r\n\r\n    this.renderer.listen(this.button, 'click', () => this.toggleExpand());\r\n    this.renderer.setStyle(this.button, 'margin-top', '8px');\r\n\r\n    this.renderer.appendChild(element.parentNode, this.button);\r\n  }\r\n\r\n  private resetButton() {\r\n    if (this.button && this.button.parentNode) {\r\n      this.renderer.removeChild(this.button.parentNode, this.button);\r\n      this.button = null;\r\n    }\r\n  }\r\n\r\n  private applyFocusHandler() {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.unlistenFocusOut = this.renderer.listen(element, 'focusout', () => {\r\n      clearTimeout(this.timeoutFocusOut);\r\n      this.timeoutFocusOut = setTimeout(() => {\r\n        if (!element.contains(document.activeElement)) {\r\n          element.scrollTop = 0;\r\n          //console.log('NESSUN elemento interno ha più il focus');\r\n        }\r\n      }, 0);\r\n    });\r\n  }\r\n\r\n  private resetFocusHandler() {\r\n    if (this.unlistenFocusOut) {\r\n      this.unlistenFocusOut();\r\n    }\r\n    clearTimeout(this.timeoutFocusOut);\r\n  }\r\n\r\n  private toggleExpand(): void {\r\n    this.expanded = !this.expanded;\r\n    if (this.expanded) {\r\n      this.expand();\r\n    } else {\r\n      this.collapse();\r\n    }\r\n  }\r\n\r\n  private expand(): void {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.renderer.setStyle(element, 'max-height', 'none');\r\n    this.renderer.setStyle(element, 'overflow', 'visible');\r\n    this.button!.childNodes[0].textContent = this.locale(Texts, 'ReadLess');\r\n    this.updateIcon('fa-chevron-up', 'fa-chevron-down');\r\n  }\r\n\r\n  private collapse(): void {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.renderer.setStyle(element, 'max-height', `${this.currentHeight}px`);\r\n    this.renderer.setStyle(element, 'overflow', 'hidden');\r\n    this.button!.childNodes[0].textContent = this.locale(Texts, 'ReadMore');\r\n    this.updateIcon('fa-chevron-down', 'fa-chevron-up');\r\n  }\r\n\r\n  private updateIcon(add: string, remove: string) {\r\n    if (this.iconSpan) {\r\n      this.renderer.removeClass(this.iconSpan, remove);\r\n      this.renderer.addClass(this.iconSpan, add);\r\n    }\r\n  }\r\n\r\n  private locale(component: any, key: string): string {\r\n    return localize(this.language, component, key);\r\n  }\r\n\r\n  \r\n}\r\n"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collapse.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/directives/collapse.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Renderer2, Input, OnChanges, SimpleChanges, OnDestroy, DestroyRef } from '@angular/core';\r\nimport { ListenerService } from '../services/listener.service';\r\n\r\nimport { LanguageService } from '@wemake4u/interact';\r\nimport { Texts } from '../locale/locale';\r\nimport { localize } from '../locale/localize';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Directive({\r\n  selector: '[collapse]',\r\n  standalone: true,\r\n  providers: [\r\n    ListenerService\r\n  ]\r\n})\r\nexport class CollapseDirective implements OnChanges, OnDestroy {\r\n  @Input('collapse') maxHeight: number | null = null;\r\n  \r\n  private currentHeight: number | null = null;\r\n  private button: HTMLButtonElement | null = null;\r\n  private iconSpan: HTMLElement | null = null;\r\n  private expanded = false;\r\n  private viewInitialized = false;\r\n  private timeoutFocusOut: any;\r\n  private unlistenFocusOut!: () => void;\r\n  \r\n  constructor(private el: ElementRef\r\n    , private renderer: Renderer2\r\n    , private destroyRef: DestroyRef\r\n    , private listenerService: ListenerService   \r\n    , private languageService: LanguageService) {\r\n\r\n    languageService.onLanguageChanged()\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe(() => this.applyCollapseLogic());\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.resetButton();\r\n    this.resetFocusHandler();    \r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.viewInitialized = true;\r\n    this.currentHeight = this.maxHeight;\r\n    this.applyCollapseLogic();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['language'] || changes['maxHeight']) {\r\n      this.currentHeight = this.maxHeight;\r\n      if (this.viewInitialized) {\r\n        this.applyCollapseLogic();\r\n      }\r\n    }\r\n  }\r\n\r\n  private get language(): string {\r\n    return this.languageService.getLanguage();\r\n  }\r\n\r\n  private applyCollapseLogic(): void {\r\n    \r\n    this.resetStyles();\r\n    \r\n    this.resetButton();\r\n    \r\n    this.resetFocusHandler();\r\n\r\n    if (this.maxHeight == null || this.maxHeight <= 0) {\r\n      this.expanded = true;\r\n      return;\r\n    }\r\n\r\n    this.expanded = false;\r\n\r\n    this.applyStyle();\r\n\r\n    const element = this.el.nativeElement as HTMLElement;\r\n\r\n    setTimeout(() => {\r\n      if (element.scrollHeight > this.maxHeight!) {\r\n        this.applyButton();\r\n        this.applyFocusHandler();\r\n      }\r\n    }, 100);\r\n    \r\n  }\r\n\r\n  private applyStyle() {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.renderer.setStyle(element, 'overflow', 'hidden');\r\n    this.renderer.setStyle(element, 'max-height', `${this.maxHeight}px`);\r\n  }\r\n\r\n  private resetStyles() {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.renderer.setStyle(element, 'overflow', null);\r\n    this.renderer.setStyle(element, 'max-height', null);\r\n  }\r\n\r\n  private applyButton(): void {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.button = this.renderer.createElement('button');\r\n    this.renderer.addClass(this.button, 'sirio-btn');\r\n    this.renderer.setStyle(this.button, 'padding', '0px');\r\n\r\n    const text = this.renderer.createText(this.locale(Texts, 'ReadMore'));\r\n\r\n    this.iconSpan = this.renderer.createElement('span');\r\n    this.renderer.addClass(this.iconSpan, 'fa');\r\n    this.renderer.addClass(this.iconSpan, 'fa-chevron-down');\r\n    \r\n    this.renderer.appendChild(this.button, text);\r\n    this.renderer.appendChild(this.button, this.iconSpan);\r\n\r\n    this.listenerService.listen(this.button, 'click', () => this.toggleExpand());\r\n\r\n    this.renderer.setStyle(this.button, 'margin-top', '8px');\r\n\r\n    this.renderer.appendChild(element.parentNode, this.button);\r\n  }\r\n\r\n  private resetButton() {\r\n    if (this.button && this.button.parentNode) {\r\n      this.renderer.removeChild(this.button.parentNode, this.button);\r\n      this.button = null;\r\n    }\r\n  }\r\n\r\n  private applyFocusHandler() {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.unlistenFocusOut = this.renderer.listen(element, 'focusout', () => {\r\n      clearTimeout(this.timeoutFocusOut);\r\n      this.timeoutFocusOut = setTimeout(() => {\r\n        if (!element.contains(document.activeElement)) {\r\n          element.scrollTop = 0;\r\n          //console.log('NESSUN elemento interno ha più il focus');\r\n        }\r\n      }, 0);\r\n    });\r\n  }\r\n\r\n  private resetFocusHandler() {\r\n    if (this.unlistenFocusOut) {\r\n      this.unlistenFocusOut();\r\n    }\r\n    clearTimeout(this.timeoutFocusOut);\r\n  }\r\n\r\n  private toggleExpand(): void {\r\n    this.expanded = !this.expanded;\r\n    if (this.expanded) {\r\n      this.expand();\r\n    } else {\r\n      this.collapse();\r\n    }\r\n  }\r\n\r\n  private expand(): void {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.renderer.setStyle(element, 'max-height', 'none');\r\n    this.renderer.setStyle(element, 'overflow', 'visible');\r\n    this.button!.childNodes[0].textContent = this.locale(Texts, 'ReadLess');\r\n    this.updateIcon('fa-chevron-up', 'fa-chevron-down');\r\n  }\r\n\r\n  private collapse(): void {\r\n    const element = this.el.nativeElement as HTMLElement;\r\n    this.renderer.setStyle(element, 'max-height', `${this.currentHeight}px`);\r\n    this.renderer.setStyle(element, 'overflow', 'hidden');\r\n    this.button!.childNodes[0].textContent = this.locale(Texts, 'ReadMore');\r\n    this.updateIcon('fa-chevron-down', 'fa-chevron-up');\r\n  }\r\n\r\n  private updateIcon(add: string, remove: string) {\r\n    if (this.iconSpan) {\r\n      this.renderer.removeClass(this.iconSpan, remove);\r\n      this.renderer.addClass(this.iconSpan, add);\r\n    }\r\n  }\r\n\r\n  private locale(component: any, key: string): string {\r\n    return localize(this.language, component, key);\r\n  }\r\n\r\n  \r\n}\r\n"]}
@@ -19,6 +19,7 @@ export class CollapsePatchDirective {
19
19
  _closeCollapse();
20
20
  thisRef.renderer.removeClass(thisRef.element, 'is-open');
21
21
  };
22
+ host.activeState = true;
22
23
  }
23
24
  get isOpen() {
24
25
  return this.host._isOpen;
@@ -36,4 +37,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
36
37
  }], ctorParameters: () => [{ type: i1.SirioCollapseComponent, decorators: [{
37
38
  type: Host
38
39
  }] }] });
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGFwc2VwYXRjaC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2lyaW8vc3JjL2xpYi9kaXJlY3RpdmVzL2NvbGxhcHNlcGF0Y2guZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFRaEQsTUFBTSxPQUFPLHNCQUFzQjtJQUNMO0lBQTVCLFlBQTRCLElBQTRCO1FBQTVCLFNBQUksR0FBSixJQUFJLENBQXdCO1FBRXRELE1BQU0sT0FBTyxHQUFHLElBQVcsQ0FBQztRQUU1QixPQUFPLENBQUMsa0JBQWtCLEdBQUcsR0FBRyxFQUFFO1lBQ2hDLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQy9ELENBQUMsQ0FBQTtRQUVELE1BQU0sYUFBYSxHQUFHLE9BQU8sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzFELE9BQU8sQ0FBQyxhQUFhLEdBQUcsR0FBRyxFQUFFO1lBQzNCLGFBQWEsRUFBRSxDQUFDO1lBQ2hCLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDeEQsQ0FBQyxDQUFDO1FBRUYsTUFBTSxjQUFjLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDNUQsT0FBTyxDQUFDLGNBQWMsR0FBRyxHQUFHLEVBQUU7WUFDNUIsY0FBYyxFQUFFLENBQUM7WUFDakIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxTQUFTLENBQUMsQ0FBQztRQUMzRCxDQUFDLENBQUM7SUFFSixDQUFDO0lBRUQsSUFBSSxNQUFNO1FBQ1IsT0FBTyxJQUFJLENBQUMsSUFBWSxDQUFDLE9BQU8sQ0FBQztJQUNuQyxDQUFDO3dHQXpCVSxzQkFBc0I7NEZBQXRCLHNCQUFzQjs7NEZBQXRCLHNCQUFzQjtrQkFMbEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7OzBCQUVjLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEhvc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU2lyaW9Db2xsYXBzZUNvbXBvbmVudCB9IGZyb20gJ25neC1zaXJpby1saWInO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbY29sbGFwc2VFeHRlbnNpb25dJyxcclxuICBleHBvcnRBczogJ2NvbGxhcHNlRXh0ZW5zaW9uJyxcclxuICBzdGFuZGFsb25lOiB0cnVlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb2xsYXBzZVBhdGNoRGlyZWN0aXZlIHtcclxuICBjb25zdHJ1Y3RvcihASG9zdCgpIHByaXZhdGUgaG9zdDogU2lyaW9Db2xsYXBzZUNvbXBvbmVudCkge1xyXG5cclxuICAgIGNvbnN0IHRoaXNSZWYgPSBob3N0IGFzIGFueTtcclxuXHJcbiAgICB0aGlzUmVmLl9zZXRDb2xsYXBzZUhlaWdodCA9ICgpID0+IHtcclxuICAgICAgdGhpc1JlZi5yZW5kZXJlci5zZXRTdHlsZSh0aGlzUmVmLmVsZW1lbnQsICdoZWlnaHQnLCAnYXV0bycpO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IF9vcGVuQ29sbGFwc2UgPSB0aGlzUmVmLl9vcGVuQ29sbGFwc2UuYmluZCh0aGlzUmVmKTtcclxuICAgIHRoaXNSZWYuX29wZW5Db2xsYXBzZSA9ICgpID0+IHtcclxuICAgICAgX29wZW5Db2xsYXBzZSgpO1xyXG4gICAgICB0aGlzUmVmLnJlbmRlcmVyLmFkZENsYXNzKHRoaXNSZWYuZWxlbWVudCwgJ2lzLW9wZW4nKTtcclxuICAgIH07XHJcblxyXG4gICAgY29uc3QgX2Nsb3NlQ29sbGFwc2UgPSB0aGlzUmVmLl9jbG9zZUNvbGxhcHNlLmJpbmQodGhpc1JlZik7XHJcbiAgICB0aGlzUmVmLl9jbG9zZUNvbGxhcHNlID0gKCkgPT4ge1xyXG4gICAgICBfY2xvc2VDb2xsYXBzZSgpO1xyXG4gICAgICB0aGlzUmVmLnJlbmRlcmVyLnJlbW92ZUNsYXNzKHRoaXNSZWYuZWxlbWVudCwgJ2lzLW9wZW4nKTtcclxuICAgIH07XHJcblxyXG4gIH1cclxuXHJcbiAgZ2V0IGlzT3BlbigpOiBib29sZWFuIHtcclxuICAgIHJldHVybih0aGlzLmhvc3QgYXMgYW55KS5faXNPcGVuO1xyXG4gIH1cclxufVxyXG4iXX0=
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGFwc2VwYXRjaC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2lyaW8vc3JjL2xpYi9kaXJlY3RpdmVzL2NvbGxhcHNlcGF0Y2guZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFRaEQsTUFBTSxPQUFPLHNCQUFzQjtJQUNMO0lBQTVCLFlBQTRCLElBQTRCO1FBQTVCLFNBQUksR0FBSixJQUFJLENBQXdCO1FBRXRELE1BQU0sT0FBTyxHQUFHLElBQVcsQ0FBQztRQUU1QixPQUFPLENBQUMsa0JBQWtCLEdBQUcsR0FBRyxFQUFFO1lBQ2hDLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQy9ELENBQUMsQ0FBQTtRQUVELE1BQU0sYUFBYSxHQUFHLE9BQU8sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzFELE9BQU8sQ0FBQyxhQUFhLEdBQUcsR0FBRyxFQUFFO1lBQzNCLGFBQWEsRUFBRSxDQUFDO1lBQ2hCLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDeEQsQ0FBQyxDQUFDO1FBRUYsTUFBTSxjQUFjLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDNUQsT0FBTyxDQUFDLGNBQWMsR0FBRyxHQUFHLEVBQUU7WUFDNUIsY0FBYyxFQUFFLENBQUM7WUFDakIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxTQUFTLENBQUMsQ0FBQztRQUMzRCxDQUFDLENBQUM7UUFFRixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFBSSxNQUFNO1FBQ1IsT0FBTyxJQUFJLENBQUMsSUFBWSxDQUFDLE9BQU8sQ0FBQztJQUNuQyxDQUFDO3dHQTFCVSxzQkFBc0I7NEZBQXRCLHNCQUFzQjs7NEZBQXRCLHNCQUFzQjtrQkFMbEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7OzBCQUVjLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEhvc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU2lyaW9Db2xsYXBzZUNvbXBvbmVudCB9IGZyb20gJ25neC1zaXJpby1saWInO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbY29sbGFwc2VFeHRlbnNpb25dJyxcclxuICBleHBvcnRBczogJ2NvbGxhcHNlRXh0ZW5zaW9uJyxcclxuICBzdGFuZGFsb25lOiB0cnVlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb2xsYXBzZVBhdGNoRGlyZWN0aXZlIHtcclxuICBjb25zdHJ1Y3RvcihASG9zdCgpIHByaXZhdGUgaG9zdDogU2lyaW9Db2xsYXBzZUNvbXBvbmVudCkge1xyXG5cclxuICAgIGNvbnN0IHRoaXNSZWYgPSBob3N0IGFzIGFueTtcclxuXHJcbiAgICB0aGlzUmVmLl9zZXRDb2xsYXBzZUhlaWdodCA9ICgpID0+IHtcclxuICAgICAgdGhpc1JlZi5yZW5kZXJlci5zZXRTdHlsZSh0aGlzUmVmLmVsZW1lbnQsICdoZWlnaHQnLCAnYXV0bycpO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IF9vcGVuQ29sbGFwc2UgPSB0aGlzUmVmLl9vcGVuQ29sbGFwc2UuYmluZCh0aGlzUmVmKTtcclxuICAgIHRoaXNSZWYuX29wZW5Db2xsYXBzZSA9ICgpID0+IHtcclxuICAgICAgX29wZW5Db2xsYXBzZSgpO1xyXG4gICAgICB0aGlzUmVmLnJlbmRlcmVyLmFkZENsYXNzKHRoaXNSZWYuZWxlbWVudCwgJ2lzLW9wZW4nKTtcclxuICAgIH07XHJcblxyXG4gICAgY29uc3QgX2Nsb3NlQ29sbGFwc2UgPSB0aGlzUmVmLl9jbG9zZUNvbGxhcHNlLmJpbmQodGhpc1JlZik7XHJcbiAgICB0aGlzUmVmLl9jbG9zZUNvbGxhcHNlID0gKCkgPT4ge1xyXG4gICAgICBfY2xvc2VDb2xsYXBzZSgpO1xyXG4gICAgICB0aGlzUmVmLnJlbmRlcmVyLnJlbW92ZUNsYXNzKHRoaXNSZWYuZWxlbWVudCwgJ2lzLW9wZW4nKTtcclxuICAgIH07XHJcblxyXG4gICAgaG9zdC5hY3RpdmVTdGF0ZSA9IHRydWU7XHJcbiAgfVxyXG5cclxuICBnZXQgaXNPcGVuKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuKHRoaXMuaG9zdCBhcyBhbnkpLl9pc09wZW47XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -2,32 +2,30 @@ import { Directive, Input, forwardRef } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import { toLocalString, toLocalDateString, isValidTime, isValidDate } from '../utils/date';
4
4
  import { dateToStore } from '../directives/date.directive';
5
- import { Subject } from 'rxjs';
6
- import { takeUntil } from 'rxjs/operators';
5
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
7
6
  import * as i0 from "@angular/core";
8
7
  import * as i1 from "@angular/forms";
9
8
  export class DateTimeCoordinatorDirective {
9
+ destroyRef;
10
+ constructor(destroyRef) {
11
+ this.destroyRef = destroyRef;
12
+ }
10
13
  datePicker;
11
14
  timePicker;
12
15
  onChange = (_) => { };
13
16
  onTouched = () => { };
14
17
  dateValue = null;
15
18
  timeValue = null;
16
- destroy$ = new Subject();
17
- ngOnDestroy() {
18
- this.destroy$.next();
19
- this.destroy$.complete();
20
- }
21
19
  ngAfterViewInit() {
22
20
  this.datePicker?.blurEvent
23
- .pipe(takeUntil(this.destroy$))
21
+ .pipe(takeUntilDestroyed(this.destroyRef))
24
22
  .subscribe((event) => {
25
23
  const value = dateToStore(event.component.value);
26
24
  this.dateValue = isValidDate(value ?? "") ? value : null;
27
25
  this.recalculate("date");
28
26
  });
29
27
  this.timePicker?.blurEvent
30
- .pipe(takeUntil(this.destroy$))
28
+ .pipe(takeUntilDestroyed(this.destroyRef))
31
29
  .subscribe((event) => {
32
30
  this.timeValue = isValidTime(event.component.value)
33
31
  ? event.component.value : null;
@@ -80,7 +78,7 @@ export class DateTimeCoordinatorDirective {
80
78
  let combined = `${this.dateValue}T${this.timeValue}:00`;
81
79
  this.onChange(combined);
82
80
  }
83
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DateTimeCoordinatorDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
81
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DateTimeCoordinatorDirective, deps: [{ token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Directive });
84
82
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: DateTimeCoordinatorDirective, isStandalone: true, selector: "[dateTimeCoordinator]", inputs: { datePicker: "datePicker", timePicker: "timePicker" }, providers: [
85
83
  {
86
84
  provide: NG_VALUE_ACCESSOR,
@@ -102,7 +100,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
102
100
  }
103
101
  ]
104
102
  }]
105
- }], propDecorators: { datePicker: [{
103
+ }], ctorParameters: () => [{ type: i0.DestroyRef }], propDecorators: { datePicker: [{
106
104
  type: Input
107
105
  }], timePicker: [{
108
106
  type: Input
@@ -110,22 +108,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
110
108
  const classNames = ['sirio-is-invalid', 'sirio-is-valid', 'sirio-is-warning', 'sirio-is-pending'];
111
109
  export class DateTimeValidationDirective {
112
110
  ngControl;
111
+ destroyRef;
113
112
  renderer;
114
113
  isWarning = false;
115
114
  showWhenValid = false;
116
- sub;
117
- constructor(ngControl, renderer) {
115
+ constructor(ngControl, destroyRef, renderer) {
118
116
  this.ngControl = ngControl;
117
+ this.destroyRef = destroyRef;
119
118
  this.renderer = renderer;
120
119
  }
121
- ngOnDestroy() {
122
- this.sub?.unsubscribe();
123
- }
124
120
  ngAfterViewInit() {
125
121
  if (!this.ngControl?.statusChanges) {
126
122
  return;
127
123
  }
128
- this.sub = this.ngControl.statusChanges.subscribe(status => {
124
+ this.ngControl.statusChanges
125
+ .pipe(takeUntilDestroyed(this.destroyRef))
126
+ .subscribe(status => {
129
127
  const coordinator = this.getCoordinator();
130
128
  if (coordinator) {
131
129
  this.checkValidation(coordinator.datePicker.validationTarget);
@@ -161,7 +159,6 @@ export class DateTimeValidationDirective {
161
159
  if (!isValid && !this.isWarning) {
162
160
  this.setInvalid(validationTarget);
163
161
  }
164
- //this.cd.detectChanges();
165
162
  }
166
163
  cleanupValidation(validationTarget) {
167
164
  classNames.forEach(c => this.renderer.removeClass(validationTarget, c));
@@ -182,7 +179,7 @@ export class DateTimeValidationDirective {
182
179
  this.cleanupValidation(validationTarget);
183
180
  this.renderer.addClass(validationTarget, className);
184
181
  }
185
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DateTimeValidationDirective, deps: [{ token: i1.NgControl }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
182
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DateTimeValidationDirective, deps: [{ token: i1.NgControl }, { token: i0.DestroyRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
186
183
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: DateTimeValidationDirective, isStandalone: true, selector: "[dateTimeValidator]", inputs: { isWarning: "isWarning", showWhenValid: "showWhenValid" }, ngImport: i0 });
187
184
  }
188
185
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DateTimeValidationDirective, decorators: [{
@@ -191,9 +188,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
191
188
  selector: '[dateTimeValidator]',
192
189
  standalone: true
193
190
  }]
194
- }], ctorParameters: () => [{ type: i1.NgControl }, { type: i0.Renderer2 }], propDecorators: { isWarning: [{
191
+ }], ctorParameters: () => [{ type: i1.NgControl }, { type: i0.DestroyRef }, { type: i0.Renderer2 }], propDecorators: { isWarning: [{
195
192
  type: Input
196
193
  }], showWhenValid: [{
197
194
  type: Input
198
195
  }] } });
199
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/directives/datetime.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, AfterViewInit, Input, forwardRef, OnDestroy, Renderer2 } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\r\nimport { NgxSirioEvent, SirioDatepickerComponent, SirioTimepickerComponent, } from 'ngx-sirio-lib';\r\nimport { toLocalString, toLocalDateString, isValidTime, isValidDate, isValidDateObject } from '../utils/date';\r\nimport { dateToStore } from '../directives/date.directive';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\n@Directive({\r\n  selector: '[dateTimeCoordinator]',\r\n  standalone: true,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => DateTimeCoordinatorDirective),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class DateTimeCoordinatorDirective implements ControlValueAccessor, AfterViewInit, OnDestroy {\r\n\r\n  @Input() datePicker!: SirioDatepickerComponent;\r\n  @Input() timePicker!: SirioTimepickerComponent;\r\n  \r\n  private onChange = (_: any) => { };\r\n  private onTouched = () => { };\r\n\r\n  private dateValue: string | null = null;\r\n  private timeValue: string | null = null;\r\n\r\n  private destroy$ = new Subject<void>();\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    this.datePicker?.blurEvent\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((event: NgxSirioEvent<SirioDatepickerComponent>) => {\r\n        const value = dateToStore(event.component.value);\r\n        this.dateValue = isValidDate(value ?? \"\") ? value : null;\r\n        this.recalculate(\"date\");\r\n      });\r\n\r\n    this.timePicker?.blurEvent\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((event: NgxSirioEvent<SirioTimepickerComponent>) => {\r\n        this.timeValue = isValidTime(event.component.value)\r\n          ? event.component.value : null;\r\n        this.recalculate(\"time\");\r\n      });\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (!value) {\r\n      this.dateValue = null;\r\n      this.timeValue = null;\r\n      this.datePicker?.writeValue(null);\r\n      this.timePicker?.writeValue(null);\r\n      return;\r\n    }\r\n\r\n    const date = value instanceof Date ? value : new Date(value);\r\n    const local = toLocalString(date);\r\n    this.dateValue = local ? local.substring(0, 10) : null;\r\n    this.timeValue = local ? local.substring(11, 16) : null;\r\n    this.datePicker?.writeValue(this.dateValue);\r\n    this.timePicker?.writeValue(this.timeValue);\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.datePicker?.setDisabledState(isDisabled);\r\n    this.timePicker?.setDisabledState(isDisabled);\r\n  }\r\n\r\n  registerOnChange(fn: any): void { this.onChange = fn; }\r\n  registerOnTouched(fn: any): void { this.onTouched = fn; }\r\n\r\n  private recalculate(part: \"date\" | \"time\") {\r\n    // Case: both fields cleared\r\n    if (!this.dateValue && !this.timeValue) {\r\n      this.onChange(null);\r\n      return;\r\n    }\r\n\r\n    // Case: date is set but time is empty → apply default time\r\n    if (this.dateValue && !this.timeValue) {\r\n      this.timeValue = '00:00';\r\n      this.timePicker?.writeValue(this.timeValue);\r\n    }\r\n\r\n    // Case: time is set but date is empty → apply default date\r\n    if (part === \"time\" && !this.dateValue && this.timeValue) {\r\n      const today = new Date();\r\n      this.dateValue = toLocalDateString(today);\r\n      this.datePicker?.writeValue(this.dateValue);\r\n    }\r\n\r\n    // If after applying the rules one of the values is still missing → null\r\n    if (!this.dateValue || !this.timeValue) {\r\n      this.onChange(null);\r\n      return;\r\n    }\r\n\r\n    let combined = `${this.dateValue}T${this.timeValue}:00`;\r\n\r\n    this.onChange(combined);\r\n  }\r\n\r\n}\r\n\r\nconst classNames = ['sirio-is-invalid', 'sirio-is-valid', 'sirio-is-warning', 'sirio-is-pending'];\r\n\r\n@Directive({\r\n  selector: '[dateTimeValidator]',\r\n  standalone: true  \r\n})\r\nexport class DateTimeValidationDirective implements AfterViewInit, OnDestroy {\r\n  @Input() isWarning: boolean = false;\r\n  @Input() showWhenValid: boolean = false;\r\n\r\n  private sub?: Subscription;\r\n\r\n  constructor(private ngControl: NgControl,\r\n    private renderer: Renderer2)\r\n  {    \r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.sub?.unsubscribe();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.ngControl?.statusChanges) {\r\n      return;\r\n    }\r\n\r\n    this.sub = this.ngControl.statusChanges.subscribe(status => {\r\n      const coordinator = this.getCoordinator();\r\n      if (coordinator) {\r\n        this.checkValidation(coordinator.datePicker.validationTarget);\r\n        this.checkValidation(coordinator.timePicker.validationTarget);\r\n      }\r\n    });\r\n  }\r\n\r\n  private getCoordinator(): DateTimeCoordinatorDirective | null {\r\n    return this.ngControl?.valueAccessor as DateTimeCoordinatorDirective ?? null;\r\n  }\r\n\r\n  private checkValidation(validationTarget: any) {\r\n    if (this.ngControl?.status === \"PENDING\") {\r\n      this.setPending(validationTarget);\r\n      return;\r\n    }\r\n\r\n    const isDisabled = this.ngControl?.disabled;\r\n    if (isDisabled) {\r\n      this.cleanupValidation(validationTarget);\r\n      return;\r\n    }\r\n    const isValid = this.ngControl?.valid;\r\n    if (isValid) {\r\n      if (this.showWhenValid) {\r\n        this.setValid(validationTarget);\r\n      }\r\n      else {\r\n        this.cleanupValidation(validationTarget);\r\n      }\r\n    }\r\n    if (!isValid && this.isWarning) {\r\n      this.setWarning(validationTarget);\r\n    }\r\n    if (!isValid && !this.isWarning) {\r\n      this.setInvalid(validationTarget);\r\n    }\r\n    //this.cd.detectChanges();\r\n  }\r\n\r\n  private cleanupValidation(validationTarget: any) {\r\n    classNames.forEach(c => this.renderer.removeClass(validationTarget, c));\r\n  }\r\n\r\n  private setValid(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-valid');\r\n  }\r\n\r\n  private setInvalid(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-invalid');\r\n  }\r\n\r\n  private setWarning(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-warning');\r\n  }\r\n\r\n  private setPending(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-pending');\r\n  }\r\n\r\n  private applyClass(validationTarget: any, className: string) {\r\n    this.cleanupValidation(validationTarget);\r\n    this.renderer.addClass(validationTarget, className);\r\n  }\r\n\r\n}\r\n"]}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/directives/datetime.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, AfterViewInit, Input, forwardRef, Renderer2, DestroyRef } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\r\nimport { NgxSirioEvent, SirioDatepickerComponent, SirioTimepickerComponent, } from 'ngx-sirio-lib';\r\nimport { toLocalString, toLocalDateString, isValidTime, isValidDate, isValidDateObject } from '../utils/date';\r\nimport { dateToStore } from '../directives/date.directive';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Directive({\r\n  selector: '[dateTimeCoordinator]',\r\n  standalone: true,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => DateTimeCoordinatorDirective),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class DateTimeCoordinatorDirective implements ControlValueAccessor, AfterViewInit {\r\n\r\n  constructor(\r\n    private destroyRef: DestroyRef) {\r\n  }\r\n\r\n  @Input() datePicker!: SirioDatepickerComponent;\r\n  @Input() timePicker!: SirioTimepickerComponent;\r\n  \r\n  private onChange = (_: any) => { };\r\n  private onTouched = () => { };\r\n\r\n  private dateValue: string | null = null;\r\n  private timeValue: string | null = null;\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    this.datePicker?.blurEvent\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe((event: NgxSirioEvent<SirioDatepickerComponent>) => {\r\n        const value = dateToStore(event.component.value);\r\n        this.dateValue = isValidDate(value ?? \"\") ? value : null;\r\n        this.recalculate(\"date\");\r\n      });\r\n\r\n    this.timePicker?.blurEvent\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe((event: NgxSirioEvent<SirioTimepickerComponent>) => {\r\n        this.timeValue = isValidTime(event.component.value)\r\n          ? event.component.value : null;\r\n        this.recalculate(\"time\");\r\n      });\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (!value) {\r\n      this.dateValue = null;\r\n      this.timeValue = null;\r\n      this.datePicker?.writeValue(null);\r\n      this.timePicker?.writeValue(null);\r\n      return;\r\n    }\r\n\r\n    const date = value instanceof Date ? value : new Date(value);\r\n    const local = toLocalString(date);\r\n    this.dateValue = local ? local.substring(0, 10) : null;\r\n    this.timeValue = local ? local.substring(11, 16) : null;\r\n    this.datePicker?.writeValue(this.dateValue);\r\n    this.timePicker?.writeValue(this.timeValue);\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.datePicker?.setDisabledState(isDisabled);\r\n    this.timePicker?.setDisabledState(isDisabled);\r\n  }\r\n\r\n  registerOnChange(fn: any): void { this.onChange = fn; }\r\n  registerOnTouched(fn: any): void { this.onTouched = fn; }\r\n\r\n  private recalculate(part: \"date\" | \"time\") {\r\n    // Case: both fields cleared\r\n    if (!this.dateValue && !this.timeValue) {\r\n      this.onChange(null);\r\n      return;\r\n    }\r\n\r\n    // Case: date is set but time is empty → apply default time\r\n    if (this.dateValue && !this.timeValue) {\r\n      this.timeValue = '00:00';\r\n      this.timePicker?.writeValue(this.timeValue);\r\n    }\r\n\r\n    // Case: time is set but date is empty → apply default date\r\n    if (part === \"time\" && !this.dateValue && this.timeValue) {\r\n      const today = new Date();\r\n      this.dateValue = toLocalDateString(today);\r\n      this.datePicker?.writeValue(this.dateValue);\r\n    }\r\n\r\n    // If after applying the rules one of the values is still missing → null\r\n    if (!this.dateValue || !this.timeValue) {\r\n      this.onChange(null);\r\n      return;\r\n    }\r\n\r\n    let combined = `${this.dateValue}T${this.timeValue}:00`;\r\n\r\n    this.onChange(combined);\r\n  }\r\n\r\n}\r\n\r\nconst classNames = ['sirio-is-invalid', 'sirio-is-valid', 'sirio-is-warning', 'sirio-is-pending'];\r\n\r\n@Directive({\r\n  selector: '[dateTimeValidator]',\r\n  standalone: true  \r\n})\r\nexport class DateTimeValidationDirective implements AfterViewInit {\r\n  @Input() isWarning: boolean = false;\r\n  @Input() showWhenValid: boolean = false;\r\n\r\n  constructor(private ngControl: NgControl,\r\n    private destroyRef: DestroyRef,\r\n    private renderer: Renderer2)\r\n  {    \r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.ngControl?.statusChanges) {\r\n      return;\r\n    }\r\n\r\n    this.ngControl.statusChanges\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe(status => {\r\n        const coordinator = this.getCoordinator();\r\n        if (coordinator) {\r\n          this.checkValidation(coordinator.datePicker.validationTarget);\r\n          this.checkValidation(coordinator.timePicker.validationTarget);\r\n        }\r\n      });\r\n  }\r\n\r\n  private getCoordinator(): DateTimeCoordinatorDirective | null {\r\n    return this.ngControl?.valueAccessor as DateTimeCoordinatorDirective ?? null;\r\n  }\r\n\r\n  private checkValidation(validationTarget: any) {\r\n    if (this.ngControl?.status === \"PENDING\") {\r\n      this.setPending(validationTarget);\r\n      return;\r\n    }\r\n\r\n    const isDisabled = this.ngControl?.disabled;\r\n    if (isDisabled) {\r\n      this.cleanupValidation(validationTarget);\r\n      return;\r\n    }\r\n    const isValid = this.ngControl?.valid;\r\n    if (isValid) {\r\n      if (this.showWhenValid) {\r\n        this.setValid(validationTarget);\r\n      }\r\n      else {\r\n        this.cleanupValidation(validationTarget);\r\n      }\r\n    }\r\n    if (!isValid && this.isWarning) {\r\n      this.setWarning(validationTarget);\r\n    }\r\n    if (!isValid && !this.isWarning) {\r\n      this.setInvalid(validationTarget);\r\n    }\r\n    \r\n  }\r\n\r\n  private cleanupValidation(validationTarget: any) {\r\n    classNames.forEach(c => this.renderer.removeClass(validationTarget, c));\r\n  }\r\n\r\n  private setValid(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-valid');\r\n  }\r\n\r\n  private setInvalid(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-invalid');\r\n  }\r\n\r\n  private setWarning(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-warning');\r\n  }\r\n\r\n  private setPending(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-pending');\r\n  }\r\n\r\n  private applyClass(validationTarget: any, className: string) {\r\n    this.cleanupValidation(validationTarget);\r\n    this.renderer.addClass(validationTarget, className);\r\n  }\r\n\r\n}\r\n"]}
@@ -1,13 +1,20 @@
1
1
  import { Directive, Host } from '@angular/core';
2
+ import { ListenerService } from '../services/listener.service';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
2
4
  import * as i0 from "@angular/core";
3
- import * as i1 from "ngx-sirio-lib";
5
+ import * as i1 from "../services/listener.service";
6
+ import * as i2 from "ngx-sirio-lib";
4
7
  export class DropdownDirective {
5
8
  el;
6
9
  renderer;
10
+ listenerService;
11
+ destroyRef;
7
12
  sirioSelect;
8
- constructor(el, renderer, sirioSelect) {
13
+ constructor(el, renderer, listenerService, destroyRef, sirioSelect) {
9
14
  this.el = el;
10
15
  this.renderer = renderer;
16
+ this.listenerService = listenerService;
17
+ this.destroyRef = destroyRef;
11
18
  this.sirioSelect = sirioSelect;
12
19
  }
13
20
  ngAfterViewInit() {
@@ -40,22 +47,25 @@ export class DropdownDirective {
40
47
  const dropMenu = dropDown.querySelector('.sirio-dropdown-menu');
41
48
  const input = searchable.querySelector('input');
42
49
  this.renderer.insertBefore(dropDown, searchable, dropMenu);
43
- this.renderer.listen(input, 'blur', (event) => {
50
+ this.listenerService.listen(input, 'focus', () => {
51
+ input.select();
52
+ });
53
+ this.listenerService.listen(input, 'blur', (event) => {
44
54
  if (event.relatedTarget !== dropMenu)
45
55
  this.sirioSelect.panel.close();
46
56
  });
47
- this.renderer.listen(input, 'keyup', (event) => {
57
+ this.listenerService.listen(input, 'keyup', (event) => {
48
58
  this.onKeyUp(event, input);
49
59
  });
50
- this.renderer.listen(input, 'keydown', (event) => {
60
+ this.listenerService.listen(input, 'keydown', (event) => {
51
61
  this.onKeyDown(event);
52
62
  });
53
- this.sirioSelect.panel.panelOpened.subscribe(() => {
54
- this.activate(searchable);
55
- });
56
- this.sirioSelect.panel.panelClosed.subscribe(() => {
57
- this.deactivate(searchable);
58
- });
63
+ this.sirioSelect.panel.panelOpened
64
+ .pipe(takeUntilDestroyed(this.destroyRef))
65
+ .subscribe(() => this.activate(searchable));
66
+ this.sirioSelect.panel.panelClosed
67
+ .pipe(takeUntilDestroyed(this.destroyRef))
68
+ .subscribe(() => this.deactivate(searchable));
59
69
  }
60
70
  }
61
71
  handleOptionsChanges() {
@@ -261,16 +271,21 @@ export class DropdownDirective {
261
271
  }
262
272
  return null;
263
273
  }
264
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DropdownDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.SirioSelectComponent, host: true }], target: i0.ɵɵFactoryTarget.Directive });
265
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: DropdownDirective, isStandalone: true, selector: "[dropdown]", ngImport: i0 });
274
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DropdownDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.ListenerService }, { token: i0.DestroyRef }, { token: i2.SirioSelectComponent, host: true }], target: i0.ɵɵFactoryTarget.Directive });
275
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: DropdownDirective, isStandalone: true, selector: "[dropdown]", providers: [
276
+ ListenerService
277
+ ], ngImport: i0 });
266
278
  }
267
279
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DropdownDirective, decorators: [{
268
280
  type: Directive,
269
281
  args: [{
270
282
  selector: '[dropdown]',
271
- standalone: true
283
+ standalone: true,
284
+ providers: [
285
+ ListenerService
286
+ ]
272
287
  }]
273
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.SirioSelectComponent, decorators: [{
288
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.ListenerService }, { type: i0.DestroyRef }, { type: i2.SirioSelectComponent, decorators: [{
274
289
  type: Host
275
290
  }] }] });
276
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/directives/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, AfterViewInit, OnDestroy, ElementRef, Host, Renderer2 } from '@angular/core';\r\nimport { SirioSelectComponent } from 'ngx-sirio-lib';\r\nimport { Subscription } from 'rxjs';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\n\r\n@Directive({\r\n  selector: '[dropdown]',\r\n  standalone: true\r\n})\r\nexport class DropdownDirective implements AfterViewInit, OnDestroy {\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private renderer: Renderer2,    \r\n    @Host() private sirioSelect: SirioSelectComponent\r\n  ) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.handleValue();\r\n    this.handleSearchable();\r\n    this.handleOptionsChanges();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.addValidator();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.optionsSubscription?.unsubscribe();\r\n    this.removeValidator();\r\n  }\r\n\r\n  private handleValue(): void {\r\n    const falsyValues = [null, false, 0, \"\"];\r\n\r\n    if (this.sirioSelect\r\n      && Array.isArray(this.sirioSelect.options)\r\n      && falsyValues.includes(this.sirioSelect.value))\r\n    {\r\n      const valueOption = this.sirioSelect.options.find(\r\n        option => option.value === this.sirioSelect.value\r\n      );\r\n\r\n      if (valueOption) {\r\n        valueOption.isSelected = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  private handleSearchable(): void {\r\n\r\n    const searchable = this.el.nativeElement.querySelector('.searchable');\r\n    if (searchable) {\r\n      const dropDown = this.el.nativeElement.querySelector('.sirio-dropdown');\r\n      const dropMenu = dropDown.querySelector('.sirio-dropdown-menu');\r\n      const input = searchable.querySelector('input');\r\n      this.renderer.insertBefore(dropDown, searchable, dropMenu);\r\n\r\n      this.renderer.listen(input, 'blur', (event: FocusEvent) => {\r\n        if (event.relatedTarget !== dropMenu)\r\n          this.sirioSelect.panel.close();\r\n      });\r\n\r\n      this.renderer.listen(input, 'keyup', (event: KeyboardEvent) => {\r\n        this.onKeyUp(event, input);        \r\n      });\r\n\r\n      this.renderer.listen(input, 'keydown', (event: KeyboardEvent) => {\r\n        this.onKeyDown(event);\r\n      });\r\n\r\n      this.sirioSelect.panel.panelOpened.subscribe(() => {\r\n        this.activate(searchable);\r\n      });\r\n\r\n      this.sirioSelect.panel.panelClosed.subscribe(() => {\r\n        this.deactivate(searchable);\r\n      });\r\n\r\n    }    \r\n  }\r\n\r\n  private handleOptionsChanges(): void {\r\n    this.optionsSubscription = this.sirioSelect.panel.options.changes.subscribe(() => {\r\n      setTimeout(() => {\r\n        this.handleValue();\r\n        this.canValidate = true;\r\n        this.refreshValidators();\r\n      });      \r\n    });\r\n  }\r\n\r\n  private optionsSubscription?: Subscription;\r\n\r\n  private canValidate: boolean = false;\r\n\r\n  private validator = this.validateOptions.bind(this);\r\n\r\n  private addValidator(): void {\r\n    this.sirioSelect.control?.addValidators(this.validator);\r\n  }\r\n\r\n  private removeValidator(): void {\r\n    this.sirioSelect.control?.removeValidators(this.validator);\r\n  }\r\n\r\n  private validateOptions(control: AbstractControl): ValidationErrors | null {\r\n    if (!this.canValidate) return null;\r\n    const value = control.value;\r\n    if (value) {\r\n      const valueOption = this.sirioSelect.options.find(\r\n        option => option.value === value\r\n      );\r\n      if (!valueOption) {\r\n        return { error: true, message: `\"${value}\" non è un valore valido` };\r\n      }\r\n    }    \r\n    return null;\r\n  }\r\n\r\n  private refreshValidators() {\r\n    this.sirioSelect.control?.updateValueAndValidity({ onlySelf: true, emitEvent: false });\r\n  }\r\n\r\n  private deactivate(element: HTMLElement): void {\r\n    this.renderer.setStyle(element, 'display', 'none');\r\n  }\r\n\r\n  private activate(element: HTMLElement): void {\r\n    let currentValue = \"\";\r\n\r\n    if (this.sirioSelect.optionsSelected.length > 0) {\r\n      currentValue = this.sirioSelect.optionsSelected[0].text\r\n    }\r\n\r\n    const input = element.querySelector(\"input\");\r\n\r\n    if (!input)\r\n      return;\r\n\r\n    input.value = currentValue;\r\n\r\n    const dropMenu = this.el.nativeElement.querySelector('.sirio-dropdown-menu');\r\n\r\n    this.sirioSelect.options.forEach((option) => {\r\n      this.show(option, true);\r\n      if (currentValue == option.text) {\r\n        dropMenu.scrollTop = this.native(option).offsetTop;\r\n      }      \r\n    });\r\n\r\n    this.renderer.setStyle(element, 'display', 'inline-block');\r\n\r\n    setTimeout(() => {\r\n      input.setSelectionRange(input.value.length, input.value.length);\r\n      input.focus();\r\n    });\r\n  }\r\n\r\n  private onKeyUp(event: KeyboardEvent, input: any) {\r\n    const { code } = event;\r\n\r\n    switch (code) {\r\n      case 'Enter':\r\n      case 'Space':\r\n      case 'ArrowDown':\r\n      case 'ArrowUp':\r\n      case 'Escape':\r\n        return;\r\n    }\r\n\r\n    const value = this.comparable(input.value);\r\n    let firstMatch = true;\r\n\r\n    this.sirioSelect.options.forEach((option, index) => {\r\n      const match = this.comparable(option.text).includes(value);\r\n      this.show(option, match);\r\n      if (match && firstMatch) {\r\n        option.setFocus();\r\n        firstMatch = false;\r\n      }\r\n      else {\r\n        option.removeFocus();\r\n      }\r\n    });\r\n  }\r\n\r\n  private onKeyDown(event: KeyboardEvent) {\r\n    const panel = this.sirioSelect.panel;\r\n    if (!panel) {\r\n      return;\r\n    }\r\n    const panelIsOpen = panel.panelIsOpen;\r\n    const { code } = event;\r\n    if (panelIsOpen) {\r\n      switch (code) {\r\n        case 'Enter':\r\n        case 'Space':\r\n          if (panel.optionFocused) {\r\n            panel.optionFocused?.onOptionSelected(event);\r\n          }\r\n          else {\r\n            panel.close(event);\r\n            event?.preventDefault();\r\n          }\r\n          break;\r\n        case 'ArrowDown':\r\n          this.scrollDown();\r\n          event?.preventDefault();\r\n          break;\r\n        case 'ArrowUp':\r\n          this.scrollUp();\r\n          event?.preventDefault();\r\n          break;\r\n        case 'Escape':\r\n          panel.close(event);\r\n          break;\r\n        default:\r\n          break;\r\n      }\r\n    }\r\n    if (!panelIsOpen) {\r\n      switch (code) {\r\n        case 'Enter':\r\n        case 'Space':\r\n          panel.open(event);\r\n          event?.preventDefault();\r\n          break;\r\n        default:\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  private native(option: any) {\r\n    return option.viewContainerRef.element.nativeElement;\r\n  }\r\n\r\n  private isHidden(option: any) {\r\n    return this.native(option).style.display === 'none';\r\n  }\r\n\r\n  private show(option: any, value: boolean) {\r\n    this.native(option).style.display = value ? '' : 'none';\r\n  }\r\n\r\n  private comparable(text: string) {\r\n    return text.toLowerCase().trim();\r\n  }\r\n\r\n  private scrollDown() {\r\n    const panel = this.sirioSelect.panel;\r\n    if (!panel.optionFocused) {\r\n      panel.scrollBarTop();\r\n      panel.options.first.setFocus();\r\n      return;\r\n    }\r\n    const nextOptionFocused = this.findNextVisibleOption(panel.optionFocusedIndex + 1, panel.options);\r\n    panel.scrollBarDown();\r\n    panel.optionFocused?.removeFocus();\r\n    if (nextOptionFocused) {\r\n      nextOptionFocused?.setFocus();\r\n      return;\r\n    }\r\n    panel.scrollBarTop();\r\n    const firstVisible = this.findNextVisibleOption(0, panel.options);\r\n    if (firstVisible) {\r\n      firstVisible.setFocus();\r\n    }\r\n  }\r\n\r\n  private scrollUp() {\r\n    const panel = this.sirioSelect.panel;\r\n    if (!panel.optionFocused) {\r\n      panel.scrollBarTop();\r\n      panel.options.last.setFocus();\r\n      return;\r\n    }    \r\n    const nextOptionFocused = this.findPreviousVisibleOption(panel.optionFocusedIndex - 1, panel.options);\r\n    if (nextOptionFocused) {\r\n      panel.scrollBarUp();\r\n      panel.optionFocused?.removeFocus();\r\n      nextOptionFocused?.setFocus();\r\n      return;\r\n    }\r\n    panel.optionFocused?.removeFocus();\r\n    panel.scrollBarBottom();\r\n    const lastVisible = this.findPreviousVisibleOption(panel.options.length - 1, panel.options);\r\n    if (lastVisible) {\r\n      lastVisible.setFocus();\r\n    }\r\n  }\r\n\r\n  private findPreviousVisibleOption(startIndex: number, options: any): any | null {\r\n    let i = startIndex;\r\n    while (i >= 0) {\r\n      const option = options.get(i);\r\n      if (!this.isHidden(option)) {\r\n        return option;\r\n      }\r\n      i--;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  private findNextVisibleOption(startIndex: number, options: any): any | null {\r\n    let i = startIndex;\r\n    while (i < options.length) {\r\n      const option = options.get(i);\r\n      if (!this.isHidden(option)) {\r\n        return option;\r\n      }\r\n      i++;\r\n    }\r\n    return null;\r\n  }\r\n}\r\n"]}
291
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/directives/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, AfterViewInit, OnDestroy, ElementRef, Host, Renderer2, DestroyRef } from '@angular/core';\r\nimport { ListenerService } from '../services/listener.service';\r\nimport { SirioSelectComponent } from 'ngx-sirio-lib';\r\nimport { Subscription } from 'rxjs';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Directive({\r\n  selector: '[dropdown]',\r\n  standalone: true,\r\n  providers: [\r\n    ListenerService\r\n  ]\r\n})\r\nexport class DropdownDirective implements AfterViewInit, OnDestroy {\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private renderer: Renderer2,\r\n    private listenerService: ListenerService,    \r\n    private destroyRef: DestroyRef,\r\n    @Host() private sirioSelect: SirioSelectComponent\r\n  ) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.handleValue();\r\n    this.handleSearchable();\r\n    this.handleOptionsChanges();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.addValidator();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.optionsSubscription?.unsubscribe();\r\n    this.removeValidator();\r\n  }\r\n\r\n  private handleValue(): void {\r\n    const falsyValues = [null, false, 0, \"\"];\r\n\r\n    if (this.sirioSelect\r\n      && Array.isArray(this.sirioSelect.options)\r\n      && falsyValues.includes(this.sirioSelect.value))\r\n    {\r\n      const valueOption = this.sirioSelect.options.find(\r\n        option => option.value === this.sirioSelect.value\r\n      );\r\n\r\n      if (valueOption) {\r\n        valueOption.isSelected = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  private handleSearchable(): void {\r\n\r\n    const searchable = this.el.nativeElement.querySelector('.searchable');\r\n    if (searchable) {\r\n      const dropDown = this.el.nativeElement.querySelector('.sirio-dropdown');\r\n      const dropMenu = dropDown.querySelector('.sirio-dropdown-menu');\r\n      const input = searchable.querySelector('input');\r\n      this.renderer.insertBefore(dropDown, searchable, dropMenu);\r\n\r\n      this.listenerService.listen(input, 'focus', () => {\r\n        input.select();\r\n      });\r\n\r\n      this.listenerService.listen(input, 'blur', (event: FocusEvent) => {\r\n        if (event.relatedTarget !== dropMenu)\r\n          this.sirioSelect.panel.close();\r\n      });\r\n\r\n      this.listenerService.listen(input, 'keyup', (event: KeyboardEvent) => {\r\n        this.onKeyUp(event, input);        \r\n      });\r\n\r\n      this.listenerService.listen(input, 'keydown', (event: KeyboardEvent) => {\r\n        this.onKeyDown(event);\r\n      });\r\n\r\n      this.sirioSelect.panel.panelOpened\r\n        .pipe(takeUntilDestroyed(this.destroyRef))\r\n        .subscribe(() => this.activate(searchable));\r\n\r\n      this.sirioSelect.panel.panelClosed\r\n        .pipe(takeUntilDestroyed(this.destroyRef))\r\n        .subscribe(() => this.deactivate(searchable));\r\n    }    \r\n  }\r\n\r\n  private handleOptionsChanges(): void {\r\n    this.optionsSubscription = this.sirioSelect.panel.options.changes.subscribe(() => {\r\n      setTimeout(() => {\r\n        this.handleValue();\r\n        this.canValidate = true;\r\n        this.refreshValidators();\r\n      });      \r\n    });\r\n  }\r\n\r\n  private optionsSubscription?: Subscription;\r\n\r\n  private canValidate: boolean = false;\r\n\r\n  private validator = this.validateOptions.bind(this);\r\n\r\n  private addValidator(): void {\r\n    this.sirioSelect.control?.addValidators(this.validator);\r\n  }\r\n\r\n  private removeValidator(): void {\r\n    this.sirioSelect.control?.removeValidators(this.validator);\r\n  }\r\n\r\n  private validateOptions(control: AbstractControl): ValidationErrors | null {\r\n    if (!this.canValidate) return null;\r\n    const value = control.value;\r\n    if (value) {\r\n      const valueOption = this.sirioSelect.options.find(\r\n        option => option.value === value\r\n      );\r\n      if (!valueOption) {\r\n        return { error: true, message: `\"${value}\" non è un valore valido` };\r\n      }\r\n    }    \r\n    return null;\r\n  }\r\n\r\n  private refreshValidators() {\r\n    this.sirioSelect.control?.updateValueAndValidity({ onlySelf: true, emitEvent: false });\r\n  }\r\n\r\n  private deactivate(element: HTMLElement): void {\r\n    this.renderer.setStyle(element, 'display', 'none');\r\n  }\r\n\r\n  private activate(element: HTMLElement): void {\r\n    let currentValue = \"\";\r\n\r\n    if (this.sirioSelect.optionsSelected.length > 0) {\r\n      currentValue = this.sirioSelect.optionsSelected[0].text\r\n    }\r\n\r\n    const input = element.querySelector(\"input\");\r\n\r\n    if (!input)\r\n      return;\r\n\r\n    input.value = currentValue;\r\n\r\n    const dropMenu = this.el.nativeElement.querySelector('.sirio-dropdown-menu');\r\n\r\n    this.sirioSelect.options.forEach((option) => {\r\n      this.show(option, true);\r\n      if (currentValue == option.text) {\r\n        dropMenu.scrollTop = this.native(option).offsetTop;\r\n      }      \r\n    });\r\n\r\n    this.renderer.setStyle(element, 'display', 'inline-block');\r\n\r\n    setTimeout(() => {\r\n      input.setSelectionRange(input.value.length, input.value.length);\r\n      input.focus();\r\n    });\r\n  }\r\n\r\n  private onKeyUp(event: KeyboardEvent, input: any) {\r\n    const { code } = event;\r\n\r\n    switch (code) {\r\n      case 'Enter':\r\n      case 'Space':\r\n      case 'ArrowDown':\r\n      case 'ArrowUp':\r\n      case 'Escape':\r\n        return;\r\n    }\r\n\r\n    const value = this.comparable(input.value);\r\n    let firstMatch = true;\r\n\r\n    this.sirioSelect.options.forEach((option, index) => {\r\n      const match = this.comparable(option.text).includes(value);\r\n      this.show(option, match);\r\n      if (match && firstMatch) {\r\n        option.setFocus();\r\n        firstMatch = false;\r\n      }\r\n      else {\r\n        option.removeFocus();\r\n      }\r\n    });\r\n  }\r\n\r\n  private onKeyDown(event: KeyboardEvent) {\r\n    const panel = this.sirioSelect.panel;\r\n    if (!panel) {\r\n      return;\r\n    }\r\n    const panelIsOpen = panel.panelIsOpen;\r\n    const { code } = event;\r\n    if (panelIsOpen) {\r\n      switch (code) {\r\n        case 'Enter':\r\n        case 'Space':\r\n          if (panel.optionFocused) {\r\n            panel.optionFocused?.onOptionSelected(event);\r\n          }\r\n          else {\r\n            panel.close(event);\r\n            event?.preventDefault();\r\n          }\r\n          break;\r\n        case 'ArrowDown':\r\n          this.scrollDown();\r\n          event?.preventDefault();\r\n          break;\r\n        case 'ArrowUp':\r\n          this.scrollUp();\r\n          event?.preventDefault();\r\n          break;\r\n        case 'Escape':\r\n          panel.close(event);\r\n          break;\r\n        default:\r\n          break;\r\n      }\r\n    }\r\n    if (!panelIsOpen) {\r\n      switch (code) {\r\n        case 'Enter':\r\n        case 'Space':\r\n          panel.open(event);\r\n          event?.preventDefault();\r\n          break;\r\n        default:\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  private native(option: any) {\r\n    return option.viewContainerRef.element.nativeElement;\r\n  }\r\n\r\n  private isHidden(option: any) {\r\n    return this.native(option).style.display === 'none';\r\n  }\r\n\r\n  private show(option: any, value: boolean) {\r\n    this.native(option).style.display = value ? '' : 'none';\r\n  }\r\n\r\n  private comparable(text: string) {\r\n    return text.toLowerCase().trim();\r\n  }\r\n\r\n  private scrollDown() {\r\n    const panel = this.sirioSelect.panel;\r\n    if (!panel.optionFocused) {\r\n      panel.scrollBarTop();\r\n      panel.options.first.setFocus();\r\n      return;\r\n    }\r\n    const nextOptionFocused = this.findNextVisibleOption(panel.optionFocusedIndex + 1, panel.options);\r\n    panel.scrollBarDown();\r\n    panel.optionFocused?.removeFocus();\r\n    if (nextOptionFocused) {\r\n      nextOptionFocused?.setFocus();\r\n      return;\r\n    }\r\n    panel.scrollBarTop();\r\n    const firstVisible = this.findNextVisibleOption(0, panel.options);\r\n    if (firstVisible) {\r\n      firstVisible.setFocus();\r\n    }\r\n  }\r\n\r\n  private scrollUp() {\r\n    const panel = this.sirioSelect.panel;\r\n    if (!panel.optionFocused) {\r\n      panel.scrollBarTop();\r\n      panel.options.last.setFocus();\r\n      return;\r\n    }    \r\n    const nextOptionFocused = this.findPreviousVisibleOption(panel.optionFocusedIndex - 1, panel.options);\r\n    if (nextOptionFocused) {\r\n      panel.scrollBarUp();\r\n      panel.optionFocused?.removeFocus();\r\n      nextOptionFocused?.setFocus();\r\n      return;\r\n    }\r\n    panel.optionFocused?.removeFocus();\r\n    panel.scrollBarBottom();\r\n    const lastVisible = this.findPreviousVisibleOption(panel.options.length - 1, panel.options);\r\n    if (lastVisible) {\r\n      lastVisible.setFocus();\r\n    }\r\n  }\r\n\r\n  private findPreviousVisibleOption(startIndex: number, options: any): any | null {\r\n    let i = startIndex;\r\n    while (i >= 0) {\r\n      const option = options.get(i);\r\n      if (!this.isHidden(option)) {\r\n        return option;\r\n      }\r\n      i--;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  private findNextVisibleOption(startIndex: number, options: any): any | null {\r\n    let i = startIndex;\r\n    while (i < options.length) {\r\n      const option = options.get(i);\r\n      if (!this.isHidden(option)) {\r\n        return option;\r\n      }\r\n      i++;\r\n    }\r\n    return null;\r\n  }\r\n}\r\n"]}