@evotor-dev/ui-kit 8.0.0-beta.19 → 8.0.0-beta.20

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.
@@ -1,19 +1,19 @@
1
- import { Component, EventEmitter, Inject, Input, Output } from '@angular/core';
1
+ import { Component, computed, inject, input, output } from '@angular/core';
2
2
  import { EvoSidebarCloseTargets } from '../enums/evo-sidebar-close-targets';
3
3
  import { SidebarInjectionToken } from '../sidebar-injection-token';
4
4
  import { EvoIconComponent } from '../../evo-icon/evo-icon.component';
5
5
  import * as i0 from "@angular/core";
6
6
  export class EvoSidebarHeaderComponent {
7
- // eslint-disable-next-line
8
- constructor(sidebar) {
9
- this.sidebar = sidebar;
10
- this.back = new EventEmitter();
7
+ constructor() {
8
+ this.backButton = input(false);
9
+ this.back = output();
10
+ this.computedBackButton = computed(() => this.backButton() || this.sidebar.backButton());
11
+ this.sidebar = inject(SidebarInjectionToken);
11
12
  }
12
13
  ngOnInit() {
13
14
  if (!this.sidebar) {
14
15
  throw new Error(`EvoSidebarHeaderComponent must be used inside EvoSidebarComponent only!`);
15
16
  }
16
- this.backButton = this.backButton ?? this.sidebar.backButton;
17
17
  }
18
18
  handleBackClick() {
19
19
  this.back.emit();
@@ -21,20 +21,13 @@ export class EvoSidebarHeaderComponent {
21
21
  closeSidebar() {
22
22
  this.sidebar.closeSidebar(EvoSidebarCloseTargets.BUTTON);
23
23
  }
24
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarHeaderComponent, deps: [{ token: SidebarInjectionToken }], target: i0.ɵɵFactoryTarget.Component }); }
25
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.10", type: EvoSidebarHeaderComponent, isStandalone: true, selector: "evo-sidebar-header, [evo-sidebar-header]", inputs: { backButton: "backButton" }, outputs: { back: "back" }, host: { classAttribute: "evo-sidebar__header" }, ngImport: i0, template: "@if (backButton) {\n <div class=\"evo-sidebar__back\" (click)=\"handleBackClick()\">\n <evo-icon shape=\"chevron-left\" class=\"evo-sidebar__icon\" />\n </div>\n}\n\n<div class=\"evo-sidebar__title\">\n <ng-content />\n</div>\n\n<div class=\"evo-sidebar__close\" (click)=\"closeSidebar()\">\n <evo-icon shape=\"close\" class=\"evo-sidebar__icon\" />\n</div>\n", styles: [":host{display:flex;flex-shrink:0;align-items:flex-start;margin:0 15px;padding:16px 0;border-bottom:solid 1px #C6C6C6}@media (min-width: 768px){:host{padding-top:32px;padding-bottom:16px}}@media (min-width: 992px){:host{margin:0 32px}}.evo-sidebar__title{flex:1;color:#212121;font-weight:700;font-size:24px;font-family:var(--evo-font-secondary);line-height:32px}@media (min-width: 768px){.evo-sidebar__title{font-size:30px;line-height:38px}}.evo-sidebar__close{flex-shrink:0;margin-left:8px;padding:0;color:#231f20;cursor:pointer;transition:opacity .3s}.evo-sidebar__close:hover{opacity:.8}.evo-sidebar__icon{display:block;width:32px;height:32px;vertical-align:bottom;fill:#91b1b8}@media (min-width: 768px){.evo-sidebar__icon{width:36px;height:36px}}.evo-sidebar__back{flex-shrink:0;margin-right:8px;color:#231f20;cursor:pointer;-webkit-user-select:none;user-select:none}\n"], dependencies: [{ kind: "component", type: EvoIconComponent, selector: "evo-icon", inputs: ["shape", "svgWidth", "svgHeight", "svgViewBox"] }] }); }
24
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
25
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.10", type: EvoSidebarHeaderComponent, isStandalone: true, selector: "evo-sidebar-header, [evo-sidebar-header]", inputs: { backButton: { classPropertyName: "backButton", publicName: "backButton", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { back: "back" }, host: { classAttribute: "evo-sidebar__header" }, ngImport: i0, template: "@if (computedBackButton()) {\n <div class=\"evo-sidebar__back\" (click)=\"handleBackClick()\">\n <evo-icon shape=\"chevron-left\" class=\"evo-sidebar__icon\" />\n </div>\n}\n\n<div class=\"evo-sidebar__title\">\n <ng-content />\n</div>\n\n<div class=\"evo-sidebar__close\" (click)=\"closeSidebar()\">\n <evo-icon shape=\"close\" class=\"evo-sidebar__icon\" />\n</div>\n", styles: [":host{display:flex;flex-shrink:0;align-items:flex-start;margin:0 15px;padding:16px 0;border-bottom:solid 1px #C6C6C6}@media (min-width: 768px){:host{padding-top:32px;padding-bottom:16px}}@media (min-width: 992px){:host{margin:0 32px}}.evo-sidebar__title{flex:1;color:#212121;font-weight:700;font-size:24px;font-family:var(--evo-font-secondary);line-height:32px}@media (min-width: 768px){.evo-sidebar__title{font-size:30px;line-height:38px}}.evo-sidebar__close{flex-shrink:0;margin-left:8px;padding:0;color:#231f20;cursor:pointer;transition:opacity .3s}.evo-sidebar__close:hover{opacity:.8}.evo-sidebar__icon{display:block;width:32px;height:32px;vertical-align:bottom;fill:#91b1b8}@media (min-width: 768px){.evo-sidebar__icon{width:36px;height:36px}}.evo-sidebar__back{flex-shrink:0;margin-right:8px;color:#231f20;cursor:pointer;-webkit-user-select:none;user-select:none}\n"], dependencies: [{ kind: "component", type: EvoIconComponent, selector: "evo-icon", inputs: ["shape", "svgWidth", "svgHeight", "svgViewBox"] }] }); }
26
26
  }
27
27
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarHeaderComponent, decorators: [{
28
28
  type: Component,
29
29
  args: [{ selector: 'evo-sidebar-header, [evo-sidebar-header]', host: {
30
30
  class: 'evo-sidebar__header',
31
- }, standalone: true, imports: [EvoIconComponent], template: "@if (backButton) {\n <div class=\"evo-sidebar__back\" (click)=\"handleBackClick()\">\n <evo-icon shape=\"chevron-left\" class=\"evo-sidebar__icon\" />\n </div>\n}\n\n<div class=\"evo-sidebar__title\">\n <ng-content />\n</div>\n\n<div class=\"evo-sidebar__close\" (click)=\"closeSidebar()\">\n <evo-icon shape=\"close\" class=\"evo-sidebar__icon\" />\n</div>\n", styles: [":host{display:flex;flex-shrink:0;align-items:flex-start;margin:0 15px;padding:16px 0;border-bottom:solid 1px #C6C6C6}@media (min-width: 768px){:host{padding-top:32px;padding-bottom:16px}}@media (min-width: 992px){:host{margin:0 32px}}.evo-sidebar__title{flex:1;color:#212121;font-weight:700;font-size:24px;font-family:var(--evo-font-secondary);line-height:32px}@media (min-width: 768px){.evo-sidebar__title{font-size:30px;line-height:38px}}.evo-sidebar__close{flex-shrink:0;margin-left:8px;padding:0;color:#231f20;cursor:pointer;transition:opacity .3s}.evo-sidebar__close:hover{opacity:.8}.evo-sidebar__icon{display:block;width:32px;height:32px;vertical-align:bottom;fill:#91b1b8}@media (min-width: 768px){.evo-sidebar__icon{width:36px;height:36px}}.evo-sidebar__back{flex-shrink:0;margin-right:8px;color:#231f20;cursor:pointer;-webkit-user-select:none;user-select:none}\n"] }]
32
- }], ctorParameters: () => [{ type: undefined, decorators: [{
33
- type: Inject,
34
- args: [SidebarInjectionToken]
35
- }] }], propDecorators: { backButton: [{
36
- type: Input
37
- }], back: [{
38
- type: Output
39
- }] } });
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLXNpZGViYXItaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1zaWRlYmFyL2V2by1zaWRlYmFyLWhlYWRlci9ldm8tc2lkZWJhci1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLXNpZGViYXIvZXZvLXNpZGViYXItaGVhZGVyL2V2by1zaWRlYmFyLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNyRixPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUMxRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUNqRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFhbkUsTUFBTSxPQUFPLHlCQUF5QjtJQUtsQywyQkFBMkI7SUFDM0IsWUFBbUQsT0FBWTtRQUFaLFlBQU8sR0FBUCxPQUFPLENBQUs7UUFIckQsU0FBSSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7SUFHOEIsQ0FBQztJQUVuRSxRQUFRO1FBQ0osSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQixNQUFNLElBQUksS0FBSyxDQUFDLHlFQUF5RSxDQUFDLENBQUM7UUFDL0YsQ0FBQztRQUVELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQztJQUNqRSxDQUFDO0lBRUQsZUFBZTtRQUNYLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELFlBQVk7UUFDUixJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxzQkFBc0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM3RCxDQUFDOytHQXRCUSx5QkFBeUIsa0JBTWQscUJBQXFCO21HQU5oQyx5QkFBeUIsc05DaEJ0Qyw0WEFhQSxrNkJEQ2MsZ0JBQWdCOzs0RkFFakIseUJBQXlCO2tCQVhyQyxTQUFTOytCQUNJLDBDQUEwQyxRQUk5Qzt3QkFDRixLQUFLLEVBQUUscUJBQXFCO3FCQUMvQixjQUNXLElBQUksV0FDUCxDQUFDLGdCQUFnQixDQUFDOzswQkFRZCxNQUFNOzJCQUFDLHFCQUFxQjt5Q0FMaEMsVUFBVTtzQkFBbEIsS0FBSztnQkFFSSxJQUFJO3NCQUFiLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbmplY3QsIElucHV0LCBPbkluaXQsIE91dHB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0V2b1NpZGViYXJDbG9zZVRhcmdldHN9IGZyb20gJy4uL2VudW1zL2V2by1zaWRlYmFyLWNsb3NlLXRhcmdldHMnO1xuaW1wb3J0IHtTaWRlYmFySW5qZWN0aW9uVG9rZW59IGZyb20gJy4uL3NpZGViYXItaW5qZWN0aW9uLXRva2VuJztcbmltcG9ydCB7RXZvSWNvbkNvbXBvbmVudH0gZnJvbSAnLi4vLi4vZXZvLWljb24vZXZvLWljb24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldm8tc2lkZWJhci1oZWFkZXIsIFtldm8tc2lkZWJhci1oZWFkZXJdJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZXZvLXNpZGViYXItaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ldm8tc2lkZWJhci1oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAnZXZvLXNpZGViYXJfX2hlYWRlcicsXG4gICAgfSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtFdm9JY29uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgRXZvU2lkZWJhckhlYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQElucHV0KCkgYmFja0J1dHRvbjogYm9vbGVhbjtcblxuICAgIEBPdXRwdXQoKSBiYWNrID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG4gICAgY29uc3RydWN0b3IoQEluamVjdChTaWRlYmFySW5qZWN0aW9uVG9rZW4pIHByaXZhdGUgc2lkZWJhcjogYW55KSB7fVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIGlmICghdGhpcy5zaWRlYmFyKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYEV2b1NpZGViYXJIZWFkZXJDb21wb25lbnQgbXVzdCBiZSB1c2VkIGluc2lkZSBFdm9TaWRlYmFyQ29tcG9uZW50IG9ubHkhYCk7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmJhY2tCdXR0b24gPSB0aGlzLmJhY2tCdXR0b24gPz8gdGhpcy5zaWRlYmFyLmJhY2tCdXR0b247XG4gICAgfVxuXG4gICAgaGFuZGxlQmFja0NsaWNrKCkge1xuICAgICAgICB0aGlzLmJhY2suZW1pdCgpO1xuICAgIH1cblxuICAgIGNsb3NlU2lkZWJhcigpIHtcbiAgICAgICAgdGhpcy5zaWRlYmFyLmNsb3NlU2lkZWJhcihFdm9TaWRlYmFyQ2xvc2VUYXJnZXRzLkJVVFRPTik7XG4gICAgfVxufVxuIiwiQGlmIChiYWNrQnV0dG9uKSB7XG4gICAgPGRpdiBjbGFzcz1cImV2by1zaWRlYmFyX19iYWNrXCIgKGNsaWNrKT1cImhhbmRsZUJhY2tDbGljaygpXCI+XG4gICAgICAgIDxldm8taWNvbiBzaGFwZT1cImNoZXZyb24tbGVmdFwiIGNsYXNzPVwiZXZvLXNpZGViYXJfX2ljb25cIiAvPlxuICAgIDwvZGl2PlxufVxuXG48ZGl2IGNsYXNzPVwiZXZvLXNpZGViYXJfX3RpdGxlXCI+XG4gICAgPG5nLWNvbnRlbnQgLz5cbjwvZGl2PlxuXG48ZGl2IGNsYXNzPVwiZXZvLXNpZGViYXJfX2Nsb3NlXCIgKGNsaWNrKT1cImNsb3NlU2lkZWJhcigpXCI+XG4gICAgPGV2by1pY29uIHNoYXBlPVwiY2xvc2VcIiBjbGFzcz1cImV2by1zaWRlYmFyX19pY29uXCIgLz5cbjwvZGl2PlxuIl19
31
+ }, standalone: true, imports: [EvoIconComponent], template: "@if (computedBackButton()) {\n <div class=\"evo-sidebar__back\" (click)=\"handleBackClick()\">\n <evo-icon shape=\"chevron-left\" class=\"evo-sidebar__icon\" />\n </div>\n}\n\n<div class=\"evo-sidebar__title\">\n <ng-content />\n</div>\n\n<div class=\"evo-sidebar__close\" (click)=\"closeSidebar()\">\n <evo-icon shape=\"close\" class=\"evo-sidebar__icon\" />\n</div>\n", styles: [":host{display:flex;flex-shrink:0;align-items:flex-start;margin:0 15px;padding:16px 0;border-bottom:solid 1px #C6C6C6}@media (min-width: 768px){:host{padding-top:32px;padding-bottom:16px}}@media (min-width: 992px){:host{margin:0 32px}}.evo-sidebar__title{flex:1;color:#212121;font-weight:700;font-size:24px;font-family:var(--evo-font-secondary);line-height:32px}@media (min-width: 768px){.evo-sidebar__title{font-size:30px;line-height:38px}}.evo-sidebar__close{flex-shrink:0;margin-left:8px;padding:0;color:#231f20;cursor:pointer;transition:opacity .3s}.evo-sidebar__close:hover{opacity:.8}.evo-sidebar__icon{display:block;width:32px;height:32px;vertical-align:bottom;fill:#91b1b8}@media (min-width: 768px){.evo-sidebar__icon{width:36px;height:36px}}.evo-sidebar__back{flex-shrink:0;margin-right:8px;color:#231f20;cursor:pointer;-webkit-user-select:none;user-select:none}\n"] }]
32
+ }] });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLXNpZGViYXItaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1zaWRlYmFyL2V2by1zaWRlYmFyLWhlYWRlci9ldm8tc2lkZWJhci1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLXNpZGViYXIvZXZvLXNpZGViYXItaGVhZGVyL2V2by1zaWRlYmFyLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNqRixPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUMxRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUNqRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFjbkUsTUFBTSxPQUFPLHlCQUF5QjtJQVh0QztRQWFJLGVBQVUsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFakIsU0FBSSxHQUFHLE1BQU0sRUFBUSxDQUFDO1FBQ3RCLHVCQUFrQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDO1FBRTVFLFlBQU8sR0FBRyxNQUFNLENBQXNCLHFCQUFxQixDQUFDLENBQUM7S0FlakY7SUFiRyxRQUFRO1FBQ0osSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQixNQUFNLElBQUksS0FBSyxDQUFDLHlFQUF5RSxDQUFDLENBQUM7UUFDL0YsQ0FBQztJQUNMLENBQUM7SUFFRCxlQUFlO1FBQ1gsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsWUFBWTtRQUNSLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLHNCQUFzQixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdELENBQUM7K0dBckJRLHlCQUF5QjttR0FBekIseUJBQXlCLG1VQ2pCdEMsc1lBYUEsazZCREVjLGdCQUFnQjs7NEZBRWpCLHlCQUF5QjtrQkFYckMsU0FBUzsrQkFDSSwwQ0FBMEMsUUFJOUM7d0JBQ0YsS0FBSyxFQUFFLHFCQUFxQjtxQkFDL0IsY0FDVyxJQUFJLFdBQ1AsQ0FBQyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBjb21wdXRlZCwgaW5qZWN0LCBpbnB1dCwgT25Jbml0LCBvdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtFdm9TaWRlYmFyQ2xvc2VUYXJnZXRzfSBmcm9tICcuLi9lbnVtcy9ldm8tc2lkZWJhci1jbG9zZS10YXJnZXRzJztcbmltcG9ydCB7U2lkZWJhckluamVjdGlvblRva2VufSBmcm9tICcuLi9zaWRlYmFyLWluamVjdGlvbi10b2tlbic7XG5pbXBvcnQge0V2b0ljb25Db21wb25lbnR9IGZyb20gJy4uLy4uL2V2by1pY29uL2V2by1pY29uLmNvbXBvbmVudCc7XG5pbXBvcnQge0V2b1NpZGViYXJDb21wb25lbnR9IGZyb20gXCIuLi9ldm8tc2lkZWJhci5jb21wb25lbnRcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldm8tc2lkZWJhci1oZWFkZXIsIFtldm8tc2lkZWJhci1oZWFkZXJdJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZXZvLXNpZGViYXItaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ldm8tc2lkZWJhci1oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAnZXZvLXNpZGViYXJfX2hlYWRlcicsXG4gICAgfSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtFdm9JY29uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgRXZvU2lkZWJhckhlYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgICBiYWNrQnV0dG9uID0gaW5wdXQoZmFsc2UpO1xuXG4gICAgcmVhZG9ubHkgYmFjayA9IG91dHB1dDx2b2lkPigpO1xuICAgIHJlYWRvbmx5IGNvbXB1dGVkQmFja0J1dHRvbiA9IGNvbXB1dGVkKCgpID0+IHRoaXMuYmFja0J1dHRvbigpIHx8IHRoaXMuc2lkZWJhci5iYWNrQnV0dG9uKCkpO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSBzaWRlYmFyID0gaW5qZWN0PEV2b1NpZGViYXJDb21wb25lbnQ+KFNpZGViYXJJbmplY3Rpb25Ub2tlbik7XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgaWYgKCF0aGlzLnNpZGViYXIpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgRXZvU2lkZWJhckhlYWRlckNvbXBvbmVudCBtdXN0IGJlIHVzZWQgaW5zaWRlIEV2b1NpZGViYXJDb21wb25lbnQgb25seSFgKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGhhbmRsZUJhY2tDbGljaygpIHtcbiAgICAgICAgdGhpcy5iYWNrLmVtaXQoKTtcbiAgICB9XG5cbiAgICBjbG9zZVNpZGViYXIoKSB7XG4gICAgICAgIHRoaXMuc2lkZWJhci5jbG9zZVNpZGViYXIoRXZvU2lkZWJhckNsb3NlVGFyZ2V0cy5CVVRUT04pO1xuICAgIH1cbn1cbiIsIkBpZiAoY29tcHV0ZWRCYWNrQnV0dG9uKCkpIHtcbiAgICA8ZGl2IGNsYXNzPVwiZXZvLXNpZGViYXJfX2JhY2tcIiAoY2xpY2spPVwiaGFuZGxlQmFja0NsaWNrKClcIj5cbiAgICAgICAgPGV2by1pY29uIHNoYXBlPVwiY2hldnJvbi1sZWZ0XCIgY2xhc3M9XCJldm8tc2lkZWJhcl9faWNvblwiIC8+XG4gICAgPC9kaXY+XG59XG5cbjxkaXYgY2xhc3M9XCJldm8tc2lkZWJhcl9fdGl0bGVcIj5cbiAgICA8bmctY29udGVudCAvPlxuPC9kaXY+XG5cbjxkaXYgY2xhc3M9XCJldm8tc2lkZWJhcl9fY2xvc2VcIiAoY2xpY2spPVwiY2xvc2VTaWRlYmFyKClcIj5cbiAgICA8ZXZvLWljb24gc2hhcGU9XCJjbG9zZVwiIGNsYXNzPVwiZXZvLXNpZGViYXJfX2ljb25cIiAvPlxuPC9kaXY+XG4iXX0=
@@ -1,8 +1,9 @@
1
- // eslint-disable-next-line:max-line-length
2
- import { Component, EventEmitter, forwardRef, Injector, Input, Output, ViewChild, ViewContainerRef, } from '@angular/core';
3
- import { fromEvent, Subject } from 'rxjs';
4
- import { delay, filter, takeUntil, takeWhile, tap } from 'rxjs/operators';
1
+ import { ChangeDetectorRef, Component, computed, createComponent, DestroyRef, EnvironmentInjector, forwardRef, inject, Injector, input, NgZone, output, signal, viewChild, ViewContainerRef, } from '@angular/core';
2
+ import { fromEvent } from 'rxjs';
3
+ import { EvoSidebarService } from './evo-sidebar.service';
4
+ import { delay, filter, takeWhile, tap } from 'rxjs/operators';
5
5
  import { enterZone } from '../../operators';
6
+ import { Location } from '@angular/common';
6
7
  import { EVO_SIDEBAR_DATA, evoSidebarRootId } from './tokens';
7
8
  import { sidebarAnimation } from '../../common/animations/sidebar.animation';
8
9
  import { EvoSidebarCloseTargets } from './enums/evo-sidebar-close-targets';
@@ -13,86 +14,88 @@ import { EvoSidebarFooterComponent } from './evo-sidebar-footer/evo-sidebar-foot
13
14
  import { EvoSidebarContentComponent } from './evo-sidebar-content/evo-sidebar-content.component';
14
15
  import { EvoSidebarHeaderComponent } from './evo-sidebar-header/evo-sidebar-header.component';
15
16
  import { EvoUiClassDirective } from '../../directives/evo-ui-class.directive';
17
+ import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
16
18
  import * as i0 from "@angular/core";
17
- import * as i1 from "@angular/common";
18
- import * as i2 from "./evo-sidebar.service";
19
19
  export class EvoSidebarComponent {
20
- constructor(zone, location, componentFactoryResolver, sidebarService, cdr) {
21
- this.zone = zone;
22
- this.location = location;
23
- this.componentFactoryResolver = componentFactoryResolver;
24
- this.sidebarService = sidebarService;
25
- this.cdr = cdr;
26
- this.size = EvoSidebarSizes.NORMAL;
27
- this.back = new EventEmitter();
28
- this.isVisible = false;
29
- this.isDynamicContent = false;
20
+ constructor() {
21
+ this.contentContainer = viewChild.required('sidebarContentContainer', { read: ViewContainerRef });
22
+ this.backButton = input(false);
23
+ this.id = input(evoSidebarRootId);
24
+ this.header = input();
25
+ this.size = input(EvoSidebarSizes.NORMAL);
26
+ this.relativeFooter = input(false);
27
+ this.back = output();
30
28
  this.closeTargets = EvoSidebarCloseTargets;
31
- this.closeTarget = EvoSidebarCloseTargets.DEFAULT;
32
- this.destroy$ = new Subject();
29
+ this.computedSize = computed(() => this.localSize() || this.size());
30
+ this.isDynamicContent = signal(false);
31
+ this.isVisible = signal(false);
32
+ this.localSize = signal(null);
33
+ this.totalClasses = computed(() => {
34
+ const classes = [];
35
+ if (this.isVisible()) {
36
+ classes.push(EvoSidebarStates.VISIBLE);
37
+ }
38
+ classes.push(this.computedSize() ?? EvoSidebarSizes.NORMAL);
39
+ return classes;
40
+ });
41
+ this.closeTarget = signal(EvoSidebarCloseTargets.DEFAULT);
42
+ this.cdr = inject(ChangeDetectorRef);
43
+ this.destroyRef = inject(DestroyRef);
44
+ this.environmentInjector = inject(EnvironmentInjector);
45
+ this.location = inject(Location);
46
+ this.sidebarService = inject(EvoSidebarService);
47
+ this.zone = inject(NgZone);
33
48
  }
34
49
  ngOnDestroy() {
35
50
  this.clearView();
36
- this.sidebarService.deregister(this.id);
51
+ this.sidebarService.deregister(this.id());
37
52
  this.locationSubscription?.unsubscribe();
38
- this.destroy$.next();
39
- this.destroy$.complete();
40
53
  }
41
54
  ngOnInit() {
42
- if (!this.id) {
43
- this.id = evoSidebarRootId;
44
- }
45
- this.sidebarService.register(this.id);
55
+ this.sidebarService.register(this.id());
46
56
  this.sidebarService
47
- .getEventsSubscription(this.id, true)
57
+ .getEventsSubscription(this.id(), true)
48
58
  .pipe(
49
59
  // async hack to avoid "Expression has changed after it was checked" error
50
- delay(0), takeUntil(this.destroy$))
60
+ delay(0), takeUntilDestroyed(this.destroyRef))
51
61
  .subscribe((sidebarState) => {
52
62
  const { isOpen, params } = sidebarState;
53
63
  if (isOpen) {
54
64
  this.subscribeToKeyEvent();
55
65
  }
56
66
  else {
57
- this.closeTarget = EvoSidebarCloseTargets.DEFAULT;
67
+ this.closeTarget.set(EvoSidebarCloseTargets.DEFAULT);
58
68
  }
59
69
  // Dynamic content strategy
60
70
  if (isOpen && params?.component) {
61
- const { component, closeOnNavigation, size, data } = params;
62
- this.isDynamicContent = true;
63
- this.insertComponent(component, data);
71
+ const { component, closeOnNavigation, size } = params;
72
+ this.isDynamicContent.set(true);
73
+ this.clearView();
74
+ this.insertComponent(component, params);
64
75
  if (size) {
65
- this.size = size;
76
+ this.localSize.set(size);
66
77
  }
67
78
  if (!this.locationSubscription && closeOnNavigation !== false) {
68
79
  this.closeOnLocationUpdates();
69
80
  }
70
81
  }
71
- this.isVisible = isOpen;
82
+ this.isVisible.set(isOpen);
72
83
  this.cdr.markForCheck();
73
84
  });
74
85
  }
75
86
  get currentState() {
76
- return this.isVisible ? EvoSidebarStates.VISIBLE : EvoSidebarStates.HIDDEN;
77
- }
78
- get totalClasses() {
79
- const classes = [];
80
- if (this.isVisible) {
81
- classes.push(EvoSidebarStates.VISIBLE);
82
- }
83
- classes.push(this.size ?? EvoSidebarSizes.NORMAL);
84
- return classes;
87
+ return this.isVisible() ? EvoSidebarStates.VISIBLE : EvoSidebarStates.HIDDEN;
85
88
  }
86
89
  closeSidebar(source) {
87
- this.isVisible = false;
88
- this.closeTarget = source;
90
+ this.isVisible.set(false);
91
+ this.closeTarget.set(source);
89
92
  }
90
93
  handleAnimationDone(event) {
91
94
  const isClosed = event.fromState === EvoSidebarStates.VISIBLE;
92
- if (isClosed && !this.isVisible) {
93
- this.sidebarService.close(this.id, { closeTarget: this.closeTarget });
95
+ if (isClosed && !this.isVisible()) {
96
+ this.sidebarService.close(this.id(), { closeTarget: this.closeTarget() });
94
97
  this.clearView();
95
- if (this.id === evoSidebarRootId) {
98
+ if (this.id() === evoSidebarRootId) {
96
99
  this.sidebarService.deregister(evoSidebarRootId);
97
100
  this.sidebarService.cleanupDefaultHost();
98
101
  }
@@ -104,42 +107,38 @@ export class EvoSidebarComponent {
104
107
  subscribeToKeyEvent() {
105
108
  this.zone.runOutsideAngular(() => {
106
109
  fromEvent(document.body, 'keyup')
107
- .pipe(takeWhile(() => this.isVisible), filter((event) => event.code === 'Escape'), enterZone(this.zone), tap(() => this.closeSidebar(EvoSidebarCloseTargets.ESC)))
110
+ .pipe(takeWhile(() => this.isVisible()), filter((event) => event.code === 'Escape'), enterZone(this.zone), tap(() => this.closeSidebar(EvoSidebarCloseTargets.ESC)))
108
111
  .subscribe();
109
112
  });
110
113
  }
111
114
  // eslint-disable-next-line
112
- insertComponent(component, data) {
113
- this.clearView();
114
- const componentFactory = this.componentFactoryResolver.resolveComponentFactory(component);
115
- const injector = Injector.create({
116
- providers: [
117
- {
118
- provide: EVO_SIDEBAR_DATA,
119
- useValue: data,
120
- },
121
- {
122
- provide: SidebarInjectionToken,
123
- useValue: this,
124
- },
125
- ],
115
+ insertComponent(component, { data, injector }) {
116
+ const dynamicComponentRef = createComponent(component, {
117
+ environmentInjector: this.environmentInjector,
118
+ elementInjector: Injector.create({
119
+ providers: [
120
+ {
121
+ provide: EVO_SIDEBAR_DATA,
122
+ useValue: data,
123
+ },
124
+ {
125
+ provide: SidebarInjectionToken,
126
+ useValue: this,
127
+ },
128
+ ],
129
+ parent: injector,
130
+ }),
126
131
  });
127
- this.dynamicComponentRef = this.contentContainer.createComponent(componentFactory, 0, injector);
132
+ this.contentContainer().insert(dynamicComponentRef.hostView);
128
133
  }
129
134
  clearView() {
130
- if (!this.dynamicComponentRef) {
131
- return;
132
- }
133
- this.contentContainer.clear();
134
- this.dynamicComponentRef = null;
135
+ this.contentContainer().clear();
135
136
  }
136
137
  closeOnLocationUpdates() {
137
- this.locationSubscription = this.location.subscribe(() => {
138
- this.closeSidebar(EvoSidebarCloseTargets.DEFAULT);
139
- });
138
+ this.locationSubscription = this.location.subscribe(() => this.closeSidebar(EvoSidebarCloseTargets.DEFAULT));
140
139
  }
141
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarComponent, deps: [{ token: i0.NgZone }, { token: i1.Location }, { token: i0.ComponentFactoryResolver }, { token: i2.EvoSidebarService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
142
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.10", type: EvoSidebarComponent, isStandalone: true, selector: "evo-sidebar", inputs: { backButton: "backButton", id: "id", header: "header", size: "size", relativeFooter: "relativeFooter" }, outputs: { back: "back" }, viewQueries: [{ propertyName: "contentContainer", first: true, predicate: ["sidebarContentContainer"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "@if (isVisible) {\n <div class=\"evo-sidebar__background\" (click)=\"closeSidebar(closeTargets.BACKGROUND)\"></div>\n}\n\n<div class=\"evo-sidebar\" [@open]=\"currentState\" [evoUiClass]=\"totalClasses\" (@open.done)=\"handleAnimationDone($event)\">\n <ng-template #sidebarContentContainer />\n\n @if (!isDynamicContent) {\n <div evo-sidebar-header [backButton]=\"backButton\" (back)=\"handleBackClick()\">\n {{ header }}\n </div>\n <div evo-sidebar-content [relativeFooter]=\"relativeFooter\">\n <ng-content select=\"[content]\" />\n </div>\n <div evo-sidebar-footer>\n <ng-content select=\"[footer]\" />\n </div>\n }\n</div>\n", styles: [".evo-sidebar{position:fixed;top:0;right:0;z-index:3000;display:flex;flex-direction:column;width:100%;height:100%;background-color:#fff;transform:translate(100vw);transition:box-shadow .1s .5s}.evo-sidebar_visible{box-shadow:0 8px 10px #00000024,0 3px 14px #0000001f;transition-delay:unset}@media (min-width: 992px){.evo-sidebar_normal{width:674px;transform:translate(674px)}}@media (min-width: 992px){.evo-sidebar_middle{width:995px;transform:translate(100%)}}@media (min-width: 992px){.evo-sidebar_large{width:80%;transform:translate(100%)}}.evo-sidebar__background{position:fixed;inset:0;z-index:1000;background-color:#000;opacity:.3}\n"], dependencies: [{ kind: "directive", type: EvoUiClassDirective, selector: "[evoUiClass]", inputs: ["class", "evoUiClass"] }, { kind: "component", type: EvoSidebarHeaderComponent, selector: "evo-sidebar-header, [evo-sidebar-header]", inputs: ["backButton"], outputs: ["back"] }, { kind: "component", type: EvoSidebarContentComponent, selector: "evo-sidebar-content, [evo-sidebar-content]", inputs: ["relativeFooter"] }, { kind: "component", type: EvoSidebarFooterComponent, selector: "evo-sidebar-footer, [evo-sidebar-footer]" }], viewProviders: [
140
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
141
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.10", type: EvoSidebarComponent, isStandalone: true, selector: "evo-sidebar", inputs: { backButton: { classPropertyName: "backButton", publicName: "backButton", isSignal: true, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, header: { classPropertyName: "header", publicName: "header", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, relativeFooter: { classPropertyName: "relativeFooter", publicName: "relativeFooter", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { back: "back" }, viewQueries: [{ propertyName: "contentContainer", first: true, predicate: ["sidebarContentContainer"], descendants: true, read: ViewContainerRef, isSignal: true }], ngImport: i0, template: "@if (isVisible()) {\n <div class=\"evo-sidebar__background\" (click)=\"closeSidebar(closeTargets.BACKGROUND)\"></div>\n}\n\n<div class=\"evo-sidebar\" [@open]=\"currentState\" [evoUiClass]=\"totalClasses()\" (@open.done)=\"handleAnimationDone($event)\">\n <ng-template #sidebarContentContainer />\n @if (!isDynamicContent()) {\n <div evo-sidebar-header [backButton]=\"backButton()\" (back)=\"handleBackClick()\">\n {{ header() }}\n </div>\n <div evo-sidebar-content [relativeFooter]=\"relativeFooter()\">\n <ng-content select=\"[content]\" />\n </div>\n <div evo-sidebar-footer>\n <ng-content select=\"[footer]\" />\n </div>\n }\n</div>\n", styles: [".evo-sidebar{position:fixed;top:0;right:0;z-index:3000;display:flex;flex-direction:column;width:100%;height:100%;background-color:#fff;transform:translate(100vw);transition:box-shadow .1s .5s}.evo-sidebar_visible{box-shadow:0 8px 10px #00000024,0 3px 14px #0000001f;transition-delay:unset}@media (min-width: 992px){.evo-sidebar_normal{width:674px;transform:translate(674px)}}@media (min-width: 992px){.evo-sidebar_middle{width:995px;transform:translate(100%)}}@media (min-width: 992px){.evo-sidebar_large{width:80%;transform:translate(100%)}}.evo-sidebar__background{position:fixed;inset:0;z-index:1000;background-color:#000;opacity:.3}\n"], dependencies: [{ kind: "directive", type: EvoUiClassDirective, selector: "[evoUiClass]", inputs: ["class", "evoUiClass"] }, { kind: "component", type: EvoSidebarHeaderComponent, selector: "evo-sidebar-header, [evo-sidebar-header]", inputs: ["backButton"], outputs: ["back"] }, { kind: "component", type: EvoSidebarContentComponent, selector: "evo-sidebar-content, [evo-sidebar-content]", inputs: ["relativeFooter"] }, { kind: "component", type: EvoSidebarFooterComponent, selector: "evo-sidebar-footer, [evo-sidebar-footer]" }], viewProviders: [
143
142
  {
144
143
  provide: SidebarInjectionToken,
145
144
  useExisting: forwardRef(() => EvoSidebarComponent),
@@ -153,21 +152,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
153
152
  provide: SidebarInjectionToken,
154
153
  useExisting: forwardRef(() => EvoSidebarComponent),
155
154
  },
156
- ], standalone: true, imports: [EvoUiClassDirective, EvoSidebarHeaderComponent, EvoSidebarContentComponent, EvoSidebarFooterComponent], template: "@if (isVisible) {\n <div class=\"evo-sidebar__background\" (click)=\"closeSidebar(closeTargets.BACKGROUND)\"></div>\n}\n\n<div class=\"evo-sidebar\" [@open]=\"currentState\" [evoUiClass]=\"totalClasses\" (@open.done)=\"handleAnimationDone($event)\">\n <ng-template #sidebarContentContainer />\n\n @if (!isDynamicContent) {\n <div evo-sidebar-header [backButton]=\"backButton\" (back)=\"handleBackClick()\">\n {{ header }}\n </div>\n <div evo-sidebar-content [relativeFooter]=\"relativeFooter\">\n <ng-content select=\"[content]\" />\n </div>\n <div evo-sidebar-footer>\n <ng-content select=\"[footer]\" />\n </div>\n }\n</div>\n", styles: [".evo-sidebar{position:fixed;top:0;right:0;z-index:3000;display:flex;flex-direction:column;width:100%;height:100%;background-color:#fff;transform:translate(100vw);transition:box-shadow .1s .5s}.evo-sidebar_visible{box-shadow:0 8px 10px #00000024,0 3px 14px #0000001f;transition-delay:unset}@media (min-width: 992px){.evo-sidebar_normal{width:674px;transform:translate(674px)}}@media (min-width: 992px){.evo-sidebar_middle{width:995px;transform:translate(100%)}}@media (min-width: 992px){.evo-sidebar_large{width:80%;transform:translate(100%)}}.evo-sidebar__background{position:fixed;inset:0;z-index:1000;background-color:#000;opacity:.3}\n"] }]
157
- }], ctorParameters: () => [{ type: i0.NgZone }, { type: i1.Location }, { type: i0.ComponentFactoryResolver }, { type: i2.EvoSidebarService }, { type: i0.ChangeDetectorRef }], propDecorators: { contentContainer: [{
158
- type: ViewChild,
159
- args: ['sidebarContentContainer', { read: ViewContainerRef }]
160
- }], backButton: [{
161
- type: Input
162
- }], id: [{
163
- type: Input
164
- }], header: [{
165
- type: Input
166
- }], size: [{
167
- type: Input
168
- }], relativeFooter: [{
169
- type: Input
170
- }], back: [{
171
- type: Output
172
- }] } });
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-sidebar.component.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-sidebar/evo-sidebar.component.ts","../../../../../../projects/evo-ui-kit/src/lib/components/evo-sidebar/evo-sidebar.component.html"],"names":[],"mappings":"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","sourcesContent":["// eslint-disable-next-line:max-line-length\nimport {\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    EventEmitter,\n    forwardRef,\n    Injector,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    Type,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport {fromEvent, Subject, SubscriptionLike} from 'rxjs';\nimport {EvoSidebarService} from './evo-sidebar.service';\nimport {AnimationEvent} from '@angular/animations';\nimport {delay, filter, takeUntil, takeWhile, tap} from 'rxjs/operators';\nimport {enterZone} from '../../operators';\nimport {Location} from '@angular/common';\nimport {EvoSidebarState} from './interfaces';\nimport {EVO_SIDEBAR_DATA, evoSidebarRootId} from './tokens';\nimport {sidebarAnimation} from '../../common/animations/sidebar.animation';\nimport {EvoSidebarCloseTargets} from './enums/evo-sidebar-close-targets';\nimport {EvoSidebarStates} from './enums/evo-sidebar-states';\nimport {EvoSidebarSizes} from './enums/evo-sidebar-sizes';\nimport {SidebarInjectionToken} from './sidebar-injection-token';\nimport {EvoSidebarFooterComponent} from './evo-sidebar-footer/evo-sidebar-footer.component';\nimport {EvoSidebarContentComponent} from './evo-sidebar-content/evo-sidebar-content.component';\nimport {EvoSidebarHeaderComponent} from './evo-sidebar-header/evo-sidebar-header.component';\nimport {EvoUiClassDirective} from '../../directives/evo-ui-class.directive';\n\n@Component({\n    selector: 'evo-sidebar',\n    styleUrls: ['./evo-sidebar.component.scss'],\n    templateUrl: './evo-sidebar.component.html',\n    animations: [sidebarAnimation],\n    viewProviders: [\n        {\n            provide: SidebarInjectionToken,\n            useExisting: forwardRef(() => EvoSidebarComponent),\n        },\n    ],\n    standalone: true,\n    imports: [EvoUiClassDirective, EvoSidebarHeaderComponent, EvoSidebarContentComponent, EvoSidebarFooterComponent],\n})\nexport class EvoSidebarComponent implements OnDestroy, OnInit {\n    @ViewChild('sidebarContentContainer', {read: ViewContainerRef})\n    contentContainer: ViewContainerRef;\n\n    @Input() backButton: boolean;\n    @Input() id: string;\n    @Input() header: string;\n    @Input() size: EvoSidebarSizes = EvoSidebarSizes.NORMAL;\n    @Input() relativeFooter: boolean;\n\n    @Output() back = new EventEmitter<void>();\n\n    isVisible = false;\n\n    isDynamicContent = false;\n\n    readonly closeTargets = EvoSidebarCloseTargets;\n\n    private closeTarget: EvoSidebarCloseTargets = EvoSidebarCloseTargets.DEFAULT;\n\n    // eslint-disable-next-line\n    private dynamicComponentRef: ComponentRef<any>;\n\n    private locationSubscription: SubscriptionLike;\n\n    private readonly destroy$ = new Subject<void>();\n\n    constructor(\n        private readonly zone: NgZone,\n        private readonly location: Location,\n        private readonly componentFactoryResolver: ComponentFactoryResolver,\n        public sidebarService: EvoSidebarService,\n        private readonly cdr: ChangeDetectorRef,\n    ) {}\n\n    ngOnDestroy() {\n        this.clearView();\n        this.sidebarService.deregister(this.id);\n        this.locationSubscription?.unsubscribe();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    ngOnInit() {\n        if (!this.id) {\n            this.id = evoSidebarRootId;\n        }\n        this.sidebarService.register(this.id);\n        this.sidebarService\n            .getEventsSubscription(this.id, true)\n            .pipe(\n                // async hack to avoid \"Expression has changed after it was checked\" error\n                delay(0),\n                takeUntil(this.destroy$),\n            )\n            .subscribe((sidebarState: EvoSidebarState) => {\n                const {isOpen, params} = sidebarState;\n                if (isOpen) {\n                    this.subscribeToKeyEvent();\n                } else {\n                    this.closeTarget = EvoSidebarCloseTargets.DEFAULT;\n                }\n\n                // Dynamic content strategy\n                if (isOpen && params?.component) {\n                    const {component, closeOnNavigation, size, data} = params;\n                    this.isDynamicContent = true;\n                    this.insertComponent(component, data);\n                    if (size) {\n                        this.size = size;\n                    }\n                    if (!this.locationSubscription && closeOnNavigation !== false) {\n                        this.closeOnLocationUpdates();\n                    }\n                }\n\n                this.isVisible = isOpen;\n                this.cdr.markForCheck();\n            });\n    }\n\n    get currentState(): string {\n        return this.isVisible ? EvoSidebarStates.VISIBLE : EvoSidebarStates.HIDDEN;\n    }\n\n    get totalClasses(): string[] {\n        const classes: string[] = [];\n\n        if (this.isVisible) {\n            classes.push(EvoSidebarStates.VISIBLE);\n        }\n\n        classes.push(this.size ?? EvoSidebarSizes.NORMAL);\n\n        return classes;\n    }\n\n    closeSidebar(source: EvoSidebarCloseTargets) {\n        this.isVisible = false;\n        this.closeTarget = source;\n    }\n\n    handleAnimationDone(event: AnimationEvent) {\n        const isClosed = event.fromState === EvoSidebarStates.VISIBLE;\n\n        if (isClosed && !this.isVisible) {\n            this.sidebarService.close(this.id, {closeTarget: this.closeTarget});\n            this.clearView();\n            if (this.id === evoSidebarRootId) {\n                this.sidebarService.deregister(evoSidebarRootId);\n                this.sidebarService.cleanupDefaultHost();\n            }\n        }\n    }\n\n    handleBackClick() {\n        this.back.emit();\n    }\n\n    private subscribeToKeyEvent() {\n        this.zone.runOutsideAngular(() => {\n            fromEvent(document.body, 'keyup')\n                .pipe(\n                    takeWhile(() => this.isVisible),\n                    filter((event: KeyboardEvent) => event.code === 'Escape'),\n                    enterZone(this.zone),\n                    tap(() => this.closeSidebar(EvoSidebarCloseTargets.ESC)),\n                )\n                .subscribe();\n        });\n    }\n\n    // eslint-disable-next-line\n    private insertComponent(component: Type<any>, data: any) {\n        this.clearView();\n\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory<Component>(component);\n\n        const injector: Injector = Injector.create({\n            providers: [\n                {\n                    provide: EVO_SIDEBAR_DATA,\n                    useValue: data,\n                },\n                {\n                    provide: SidebarInjectionToken,\n                    useValue: this,\n                },\n            ],\n        });\n\n        this.dynamicComponentRef = this.contentContainer.createComponent(componentFactory, 0, injector);\n    }\n\n    private clearView() {\n        if (!this.dynamicComponentRef) {\n            return;\n        }\n        this.contentContainer.clear();\n        this.dynamicComponentRef = null;\n    }\n\n    private closeOnLocationUpdates() {\n        this.locationSubscription = this.location.subscribe(() => {\n            this.closeSidebar(EvoSidebarCloseTargets.DEFAULT);\n        });\n    }\n}\n","@if (isVisible) {\n    <div class=\"evo-sidebar__background\" (click)=\"closeSidebar(closeTargets.BACKGROUND)\"></div>\n}\n\n<div class=\"evo-sidebar\" [@open]=\"currentState\" [evoUiClass]=\"totalClasses\" (@open.done)=\"handleAnimationDone($event)\">\n    <ng-template #sidebarContentContainer />\n\n    @if (!isDynamicContent) {\n        <div evo-sidebar-header [backButton]=\"backButton\" (back)=\"handleBackClick()\">\n            {{ header }}\n        </div>\n        <div evo-sidebar-content [relativeFooter]=\"relativeFooter\">\n            <ng-content select=\"[content]\" />\n        </div>\n        <div evo-sidebar-footer>\n            <ng-content select=\"[footer]\" />\n        </div>\n    }\n</div>\n"]}
155
+ ], standalone: true, imports: [
156
+ EvoUiClassDirective,
157
+ EvoSidebarHeaderComponent,
158
+ EvoSidebarContentComponent,
159
+ EvoSidebarFooterComponent,
160
+ ], template: "@if (isVisible()) {\n <div class=\"evo-sidebar__background\" (click)=\"closeSidebar(closeTargets.BACKGROUND)\"></div>\n}\n\n<div class=\"evo-sidebar\" [@open]=\"currentState\" [evoUiClass]=\"totalClasses()\" (@open.done)=\"handleAnimationDone($event)\">\n <ng-template #sidebarContentContainer />\n @if (!isDynamicContent()) {\n <div evo-sidebar-header [backButton]=\"backButton()\" (back)=\"handleBackClick()\">\n {{ header() }}\n </div>\n <div evo-sidebar-content [relativeFooter]=\"relativeFooter()\">\n <ng-content select=\"[content]\" />\n </div>\n <div evo-sidebar-footer>\n <ng-content select=\"[footer]\" />\n </div>\n }\n</div>\n", styles: [".evo-sidebar{position:fixed;top:0;right:0;z-index:3000;display:flex;flex-direction:column;width:100%;height:100%;background-color:#fff;transform:translate(100vw);transition:box-shadow .1s .5s}.evo-sidebar_visible{box-shadow:0 8px 10px #00000024,0 3px 14px #0000001f;transition-delay:unset}@media (min-width: 992px){.evo-sidebar_normal{width:674px;transform:translate(674px)}}@media (min-width: 992px){.evo-sidebar_middle{width:995px;transform:translate(100%)}}@media (min-width: 992px){.evo-sidebar_large{width:80%;transform:translate(100%)}}.evo-sidebar__background{position:fixed;inset:0;z-index:1000;background-color:#000;opacity:.3}\n"] }]
161
+ }] });
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-sidebar.component.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-sidebar/evo-sidebar.component.ts","../../../../../../projects/evo-ui-kit/src/lib/components/evo-sidebar/evo-sidebar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    computed,\n    createComponent,\n    DestroyRef,\n    EnvironmentInjector,\n    forwardRef,\n    inject,\n    Injector,\n    input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    output,\n    signal,\n    Type,\n    viewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport {fromEvent, SubscriptionLike} from 'rxjs';\nimport {EvoSidebarService} from './evo-sidebar.service';\nimport {AnimationEvent} from '@angular/animations';\nimport {delay, filter, takeWhile, tap} from 'rxjs/operators';\nimport {enterZone} from '../../operators';\nimport {Location} from '@angular/common';\nimport {EvoSidebarParams, EvoSidebarState} from './interfaces';\nimport {EVO_SIDEBAR_DATA, evoSidebarRootId} from './tokens';\nimport {sidebarAnimation} from '../../common/animations/sidebar.animation';\nimport {EvoSidebarCloseTargets} from './enums/evo-sidebar-close-targets';\nimport {EvoSidebarStates} from './enums/evo-sidebar-states';\nimport {EvoSidebarSizes} from './enums/evo-sidebar-sizes';\nimport {SidebarInjectionToken} from './sidebar-injection-token';\nimport {EvoSidebarFooterComponent} from './evo-sidebar-footer/evo-sidebar-footer.component';\nimport {EvoSidebarContentComponent} from './evo-sidebar-content/evo-sidebar-content.component';\nimport {EvoSidebarHeaderComponent} from './evo-sidebar-header/evo-sidebar-header.component';\nimport {EvoUiClassDirective} from '../../directives/evo-ui-class.directive';\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\n\n@Component({\n    selector: 'evo-sidebar',\n    styleUrls: ['./evo-sidebar.component.scss'],\n    templateUrl: './evo-sidebar.component.html',\n    animations: [sidebarAnimation],\n    viewProviders: [\n        {\n            provide: SidebarInjectionToken,\n            useExisting: forwardRef(() => EvoSidebarComponent),\n        },\n    ],\n    standalone: true,\n    imports: [\n        EvoUiClassDirective,\n        EvoSidebarHeaderComponent,\n        EvoSidebarContentComponent,\n        EvoSidebarFooterComponent,\n    ],\n})\nexport class EvoSidebarComponent implements OnDestroy, OnInit {\n\n    contentContainer = viewChild.required('sidebarContentContainer', {read: ViewContainerRef});\n\n    backButton = input(false);\n    id = input(evoSidebarRootId);\n    header = input<string>();\n    size = input(EvoSidebarSizes.NORMAL);\n    relativeFooter = input(false);\n\n    readonly back = output<void>();\n\n    readonly closeTargets = EvoSidebarCloseTargets;\n    readonly computedSize = computed(() => this.localSize() || this.size());\n    readonly isDynamicContent = signal(false);\n    readonly isVisible = signal(false);\n    readonly localSize = signal<EvoSidebarSizes | null>(null);\n    readonly totalClasses = computed(() => {\n        const classes: string[] = [];\n\n        if (this.isVisible()) {\n            classes.push(EvoSidebarStates.VISIBLE);\n        }\n\n        classes.push(this.computedSize() ?? EvoSidebarSizes.NORMAL);\n        return classes;\n    })\n    private readonly closeTarget = signal(EvoSidebarCloseTargets.DEFAULT);\n\n    private locationSubscription: SubscriptionLike;\n\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly environmentInjector = inject(EnvironmentInjector);\n    private readonly location = inject(Location);\n    private readonly sidebarService = inject(EvoSidebarService);\n    private readonly zone = inject(NgZone);\n\n    ngOnDestroy() {\n        this.clearView();\n        this.sidebarService.deregister(this.id());\n        this.locationSubscription?.unsubscribe();\n    }\n\n    ngOnInit() {\n        this.sidebarService.register(this.id());\n        this.sidebarService\n            .getEventsSubscription(this.id(), true)\n            .pipe(\n                // async hack to avoid \"Expression has changed after it was checked\" error\n                delay(0),\n                takeUntilDestroyed(this.destroyRef),\n            )\n            .subscribe((sidebarState: EvoSidebarState) => {\n                const {isOpen, params} = sidebarState;\n\n                if (isOpen) {\n                    this.subscribeToKeyEvent();\n                } else {\n                    this.closeTarget.set(EvoSidebarCloseTargets.DEFAULT);\n                }\n\n                // Dynamic content strategy\n                if (isOpen && params?.component) {\n                    const {component, closeOnNavigation, size} = params;\n\n                    this.isDynamicContent.set(true);\n                    this.clearView();\n                    this.insertComponent(component, params);\n\n                    if (size) {\n                        this.localSize.set(size);\n                    }\n\n                    if (!this.locationSubscription && closeOnNavigation !== false) {\n                        this.closeOnLocationUpdates();\n                    }\n                }\n\n                this.isVisible.set(isOpen);\n                this.cdr.markForCheck();\n            });\n    }\n\n    get currentState(): string {\n        return this.isVisible() ? EvoSidebarStates.VISIBLE : EvoSidebarStates.HIDDEN;\n    }\n\n    closeSidebar(source: EvoSidebarCloseTargets) {\n        this.isVisible.set(false);\n        this.closeTarget.set(source);\n    }\n\n    handleAnimationDone(event: AnimationEvent) {\n        const isClosed = event.fromState === EvoSidebarStates.VISIBLE;\n\n        if (isClosed && !this.isVisible()) {\n            this.sidebarService.close(this.id(), {closeTarget: this.closeTarget()});\n            this.clearView();\n            if (this.id() === evoSidebarRootId) {\n                this.sidebarService.deregister(evoSidebarRootId);\n                this.sidebarService.cleanupDefaultHost();\n            }\n        }\n    }\n\n    handleBackClick() {\n        this.back.emit();\n    }\n\n    private subscribeToKeyEvent() {\n        this.zone.runOutsideAngular(() => {\n            fromEvent(document.body, 'keyup')\n                .pipe(\n                    takeWhile(() => this.isVisible()),\n                    filter((event: KeyboardEvent) => event.code === 'Escape'),\n                    enterZone(this.zone),\n                    tap(() => this.closeSidebar(EvoSidebarCloseTargets.ESC)),\n                )\n                .subscribe();\n        });\n    }\n\n    // eslint-disable-next-line\n    private insertComponent(component: Type<unknown>, {data, injector}: EvoSidebarParams) {\n        const dynamicComponentRef = createComponent(component, {\n            environmentInjector: this.environmentInjector,\n            elementInjector: Injector.create({\n                providers: [\n                    {\n                        provide: EVO_SIDEBAR_DATA,\n                        useValue: data,\n                    },\n                    {\n                        provide: SidebarInjectionToken,\n                        useValue: this,\n                    },\n                ],\n                parent: injector,\n            }),\n        });\n\n        this.contentContainer().insert(dynamicComponentRef.hostView);\n    }\n\n    private clearView() {\n        this.contentContainer().clear();\n    }\n\n    private closeOnLocationUpdates() {\n        this.locationSubscription = this.location.subscribe(() => this.closeSidebar(EvoSidebarCloseTargets.DEFAULT));\n    }\n}\n","@if (isVisible()) {\n    <div class=\"evo-sidebar__background\" (click)=\"closeSidebar(closeTargets.BACKGROUND)\"></div>\n}\n\n<div class=\"evo-sidebar\" [@open]=\"currentState\" [evoUiClass]=\"totalClasses()\" (@open.done)=\"handleAnimationDone($event)\">\n    <ng-template #sidebarContentContainer />\n    @if (!isDynamicContent()) {\n        <div evo-sidebar-header [backButton]=\"backButton()\" (back)=\"handleBackClick()\">\n            {{ header() }}\n        </div>\n        <div evo-sidebar-content [relativeFooter]=\"relativeFooter()\">\n            <ng-content select=\"[content]\" />\n        </div>\n        <div evo-sidebar-footer>\n            <ng-content select=\"[footer]\" />\n        </div>\n    }\n</div>\n"]}
@@ -1,20 +1,19 @@
1
- import { Inject, Injectable, Optional } from '@angular/core';
1
+ import { inject, Injectable } from '@angular/core';
2
2
  import { Subject } from 'rxjs';
3
3
  import { distinctUntilChanged, filter, take, tap } from 'rxjs/operators';
4
4
  import { cloneDeep, isEqual } from 'lodash-es';
5
+ import { EvoAbstractPortal } from '../evo-portal';
5
6
  import { EVO_SIDEBAR_CONFIG, evoSidebarDefaultConfig, evoSidebarRootId } from './tokens';
6
7
  import * as i0 from "@angular/core";
7
- import * as i1 from "../evo-portal";
8
8
  export class EvoSidebarService {
9
- constructor(portal, // EvoSidebarPortal provided
10
- _config) {
11
- this.portal = portal;
12
- this._config = _config;
9
+ constructor() {
10
+ this.portal = inject(EvoAbstractPortal); // EvoSidebarPortal provided
11
+ this._config = inject(EVO_SIDEBAR_CONFIG, { optional: true });
13
12
  this.sidebarEvents$ = new Subject();
14
13
  this.registeredSidebars = {};
15
14
  this.config = {
16
15
  ...evoSidebarDefaultConfig,
17
- ..._config,
16
+ ...this._config,
18
17
  };
19
18
  }
20
19
  deregister(id) {
@@ -91,15 +90,10 @@ export class EvoSidebarService {
91
90
  },
92
91
  };
93
92
  }
94
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarService, deps: [{ token: i1.EvoAbstractPortal }, { token: EVO_SIDEBAR_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
93
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
95
94
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarService }); }
96
95
  }
97
96
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarService, decorators: [{
98
97
  type: Injectable
99
- }], ctorParameters: () => [{ type: i1.EvoAbstractPortal }, { type: undefined, decorators: [{
100
- type: Optional
101
- }, {
102
- type: Inject,
103
- args: [EVO_SIDEBAR_CONFIG]
104
- }] }] });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-sidebar.service.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-sidebar/evo-sidebar.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable, Optional} from '@angular/core';\nimport {Observable, Subject} from 'rxjs';\nimport {distinctUntilChanged, filter, take, tap} from 'rxjs/operators';\nimport {cloneDeep, isEqual} from 'lodash-es';\nimport {EvoAbstractPortal} from '../evo-portal';\nimport {EvoOpenedSidebarActions, EvoSidebarConfig, EvoSidebarParams, EvoSidebarState} from './interfaces';\nimport {EVO_SIDEBAR_CONFIG, evoSidebarDefaultConfig, evoSidebarRootId} from './tokens';\n\n@Injectable()\nexport class EvoSidebarService {\n    private readonly sidebarEvents$ = new Subject<EvoSidebarState>();\n    private registeredSidebars: {[id: string]: EvoSidebarState} = {};\n    private readonly config: EvoSidebarConfig;\n\n    constructor(\n        private readonly portal: EvoAbstractPortal, // EvoSidebarPortal provided\n        @Optional()\n        @Inject(EVO_SIDEBAR_CONFIG)\n        private readonly _config: EvoSidebarConfig,\n    ) {\n        this.config = {\n            ...evoSidebarDefaultConfig,\n            ..._config,\n        };\n    }\n\n    deregister(id: string) {\n        delete this.registeredSidebars[id];\n    }\n\n    register(id: string) {\n        if (this.registeredSidebars[id]) {\n            throw Error(`[EvoUiKit]: Another evo-sidebar with id = \"${id}\" already registered!`);\n        } else {\n            this.registeredSidebars[id] = {id, isOpen: false};\n        }\n    }\n\n    open(params: EvoSidebarParams): EvoOpenedSidebarActions;\n    open(id: string, params?: EvoSidebarParams): EvoOpenedSidebarActions;\n    open(idOrParams: string | EvoSidebarParams, params?: EvoSidebarParams): EvoOpenedSidebarActions {\n        if (typeof idOrParams === 'string') {\n            this.sidebarEvents$.next({\n                id: idOrParams,\n                isOpen: true,\n                params,\n            });\n            return this.getOpenedSidebarActions(idOrParams);\n        } else {\n            this.openWithDefaultHost(idOrParams);\n            return this.getOpenedSidebarActions(evoSidebarRootId);\n        }\n    }\n\n    openWithDefaultHost(params: EvoSidebarParams) {\n        if (!this.portal.hasAttachedPortal()) {\n            this.portal.attach(this.config.host);\n            setTimeout(() => {\n                this.open(evoSidebarRootId, params);\n            }, 0);\n        } else {\n            this.open(evoSidebarRootId, params);\n        }\n    }\n\n    close(params?: EvoSidebarParams): void;\n    close(id: string, params?: EvoSidebarParams): void;\n    close(idOrParams?: string | EvoSidebarParams, params?: EvoSidebarParams): void {\n        if (typeof idOrParams === 'string') {\n            this.sidebarEvents$.next({id: idOrParams, isOpen: false, params});\n        } else {\n            this.closeWithDefaultHost(idOrParams);\n        }\n    }\n\n    closeWithDefaultHost(params?: EvoSidebarParams) {\n        this.sidebarEvents$.next({id: evoSidebarRootId, isOpen: false, params});\n    }\n\n    getEventsSubscription(id: string, immediate?: boolean): Observable<EvoSidebarState> {\n        return this.sidebarEvents$.pipe(\n            filter((data: EvoSidebarState) => data.id === id),\n            filter((data: EvoSidebarState) => {\n                if (!data.isOpen) {\n                    return data.params && data.params.closeTarget ? true : immediate;\n                }\n\n                return true;\n            }),\n            distinctUntilChanged((prev: EvoSidebarState, next: EvoSidebarState) => {\n                return immediate ? false : isEqual(prev, next);\n            }),\n            tap((data: EvoSidebarState) => {\n                if (!immediate) {\n                    this.registeredSidebars[data.id] = cloneDeep(data);\n                }\n            }),\n        );\n    }\n\n    cleanupDefaultHost() {\n        if (!this.portal.hasAttachedPortal()) {\n            return;\n        }\n        this.portal.detach();\n    }\n\n    getOpenedSidebarActions(id: string): EvoOpenedSidebarActions {\n        return {\n            afterClosed: () => {\n                return this.getEventsSubscription(id).pipe(\n                    filter(({isOpen}) => !isOpen),\n                    take(1),\n                );\n            },\n        };\n    }\n}\n"]}
98
+ }] });
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-sidebar.service.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-sidebar/evo-sidebar.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {inject, Injectable} from '@angular/core';\nimport {Observable, Subject} from 'rxjs';\nimport {distinctUntilChanged, filter, take, tap} from 'rxjs/operators';\nimport {cloneDeep, isEqual} from 'lodash-es';\nimport {EvoAbstractPortal} from '../evo-portal';\nimport {EvoOpenedSidebarActions, EvoSidebarConfig, EvoSidebarParams, EvoSidebarState} from './interfaces';\nimport {EVO_SIDEBAR_CONFIG, evoSidebarDefaultConfig, evoSidebarRootId} from './tokens';\n\n@Injectable()\nexport class EvoSidebarService {\n\n    private readonly portal = inject(EvoAbstractPortal); // EvoSidebarPortal provided\n    private readonly _config = inject<EvoSidebarConfig>(EVO_SIDEBAR_CONFIG, {optional: true});\n\n    private readonly sidebarEvents$ = new Subject<EvoSidebarState>();\n    private registeredSidebars: {[id: string]: EvoSidebarState} = {};\n    private readonly config: EvoSidebarConfig = {\n        ...evoSidebarDefaultConfig,\n        ...this._config,\n    };\n\n    deregister(id: string) {\n        delete this.registeredSidebars[id];\n    }\n\n    register(id: string) {\n        if (this.registeredSidebars[id]) {\n            throw Error(`[EvoUiKit]: Another evo-sidebar with id = \"${id}\" already registered!`);\n        } else {\n            this.registeredSidebars[id] = {id, isOpen: false};\n        }\n    }\n\n    open(params: EvoSidebarParams): EvoOpenedSidebarActions;\n    open(id: string, params?: EvoSidebarParams): EvoOpenedSidebarActions;\n    open(idOrParams: string | EvoSidebarParams, params?: EvoSidebarParams): EvoOpenedSidebarActions {\n        if (typeof idOrParams === 'string') {\n            this.sidebarEvents$.next({\n                id: idOrParams,\n                isOpen: true,\n                params,\n            });\n            return this.getOpenedSidebarActions(idOrParams);\n        } else {\n            this.openWithDefaultHost(idOrParams);\n            return this.getOpenedSidebarActions(evoSidebarRootId);\n        }\n    }\n\n    openWithDefaultHost(params: EvoSidebarParams) {\n        if (!this.portal.hasAttachedPortal()) {\n            this.portal.attach(this.config.host);\n            setTimeout(() => {\n                this.open(evoSidebarRootId, params);\n            }, 0);\n        } else {\n            this.open(evoSidebarRootId, params);\n        }\n    }\n\n    close(params?: EvoSidebarParams): void;\n    close(id: string, params?: EvoSidebarParams): void;\n    close(idOrParams?: string | EvoSidebarParams, params?: EvoSidebarParams): void {\n        if (typeof idOrParams === 'string') {\n            this.sidebarEvents$.next({id: idOrParams, isOpen: false, params});\n        } else {\n            this.closeWithDefaultHost(idOrParams);\n        }\n    }\n\n    closeWithDefaultHost(params?: EvoSidebarParams) {\n        this.sidebarEvents$.next({id: evoSidebarRootId, isOpen: false, params});\n    }\n\n    getEventsSubscription(id: string, immediate?: boolean): Observable<EvoSidebarState> {\n        return this.sidebarEvents$.pipe(\n            filter((data: EvoSidebarState) => data.id === id),\n            filter((data: EvoSidebarState) => {\n                if (!data.isOpen) {\n                    return data.params && data.params.closeTarget ? true : immediate;\n                }\n\n                return true;\n            }),\n            distinctUntilChanged((prev: EvoSidebarState, next: EvoSidebarState) => {\n                return immediate ? false : isEqual(prev, next);\n            }),\n            tap((data: EvoSidebarState) => {\n                if (!immediate) {\n                    this.registeredSidebars[data.id] = cloneDeep(data);\n                }\n            }),\n        );\n    }\n\n    cleanupDefaultHost() {\n        if (!this.portal.hasAttachedPortal()) {\n            return;\n        }\n        this.portal.detach();\n    }\n\n    getOpenedSidebarActions(id: string): EvoOpenedSidebarActions {\n        return {\n            afterClosed: () => {\n                return this.getEventsSubscription(id).pipe(\n                    filter(({isOpen}) => !isOpen),\n                    take(1),\n                );\n            },\n        };\n    }\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1zaWRlYmFyL2ludGVyZmFjZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7VHlwZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge09ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtFdm9TaWRlYmFyQ2xvc2VUYXJnZXRzfSBmcm9tICcuL2VudW1zL2V2by1zaWRlYmFyLWNsb3NlLXRhcmdldHMnO1xuaW1wb3J0IHtFdm9TaWRlYmFyU2l6ZXN9IGZyb20gJy4vZW51bXMvZXZvLXNpZGViYXItc2l6ZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV2b1NpZGViYXJDb25maWcge1xuICAgIGhvc3Q/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRXZvU2lkZWJhclN0YXRlIHtcbiAgICBpZDogc3RyaW5nO1xuICAgIGlzT3BlbjogYm9vbGVhbjtcbiAgICBwYXJhbXM/OiBFdm9TaWRlYmFyUGFyYW1zO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEV2b1NpZGViYXJQYXJhbXMge1xuICAgIGNsb3NlVGFyZ2V0PzogRXZvU2lkZWJhckNsb3NlVGFyZ2V0cztcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBjb21wb25lbnQ/OiBUeXBlPGFueT47XG4gICAgY2xvc2VPbk5hdmlnYXRpb24/OiBib29sZWFuO1xuICAgIHNpemU/OiBFdm9TaWRlYmFyU2l6ZXM7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG4gICAgZGF0YT86IGFueTtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBbcHJvcGVydHk6IHN0cmluZ106IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFdm9PcGVuZWRTaWRlYmFyQWN0aW9ucyB7XG4gICAgYWZ0ZXJDbG9zZWQ6ICgpID0+IE9ic2VydmFibGU8RXZvU2lkZWJhclBhcmFtcz47XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1zaWRlYmFyL2ludGVyZmFjZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0b3IsIFR5cGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcbmltcG9ydCB7RXZvU2lkZWJhckNsb3NlVGFyZ2V0c30gZnJvbSAnLi9lbnVtcy9ldm8tc2lkZWJhci1jbG9zZS10YXJnZXRzJztcbmltcG9ydCB7RXZvU2lkZWJhclNpemVzfSBmcm9tICcuL2VudW1zL2V2by1zaWRlYmFyLXNpemVzJztcblxuZXhwb3J0IGludGVyZmFjZSBFdm9TaWRlYmFyQ29uZmlnIHtcbiAgICBob3N0Pzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEV2b1NpZGViYXJTdGF0ZSB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBpc09wZW46IGJvb2xlYW47XG4gICAgcGFyYW1zPzogRXZvU2lkZWJhclBhcmFtcztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFdm9TaWRlYmFyUGFyYW1zIHtcbiAgICBjbG9zZVRhcmdldD86IEV2b1NpZGViYXJDbG9zZVRhcmdldHM7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG4gICAgY29tcG9uZW50PzogVHlwZTxhbnk+O1xuICAgIGNsb3NlT25OYXZpZ2F0aW9uPzogYm9vbGVhbjtcbiAgICBzaXplPzogRXZvU2lkZWJhclNpemVzO1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxuICAgIGRhdGE/OiBhbnk7XG4gICAgaW5qZWN0b3I/OiBJbmplY3RvcjtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBbcHJvcGVydHk6IHN0cmluZ106IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFdm9PcGVuZWRTaWRlYmFyQWN0aW9ucyB7XG4gICAgYWZ0ZXJDbG9zZWQ6ICgpID0+IE9ic2VydmFibGU8RXZvU2lkZWJhclBhcmFtcz47XG59XG4iXX0=