@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.
- package/esm2022/lib/components/evo-sidebar/evo-sidebar-header/evo-sidebar-header.component.mjs +11 -18
- package/esm2022/lib/components/evo-sidebar/evo-sidebar.component.mjs +80 -91
- package/esm2022/lib/components/evo-sidebar/evo-sidebar.service.mjs +9 -15
- package/esm2022/lib/components/evo-sidebar/interfaces.mjs +1 -1
- package/fesm2022/evotor-dev-ui-kit.mjs +174 -198
- package/fesm2022/evotor-dev-ui-kit.mjs.map +1 -1
- package/lib/components/evo-sidebar/evo-sidebar-header/evo-sidebar-header.component.d.ts +6 -6
- package/lib/components/evo-sidebar/evo-sidebar.component.d.ts +21 -23
- package/lib/components/evo-sidebar/evo-sidebar.service.d.ts +2 -5
- package/lib/components/evo-sidebar/interfaces.d.ts +2 -1
- package/package.json +1 -1
package/esm2022/lib/components/evo-sidebar/evo-sidebar-header/evo-sidebar-header.component.mjs
CHANGED
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { Component,
|
|
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
|
-
|
|
8
|
-
|
|
9
|
-
this.
|
|
10
|
-
this.
|
|
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: [
|
|
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 (
|
|
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 (
|
|
32
|
-
}]
|
|
33
|
-
|
|
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
|
-
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { delay, filter,
|
|
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(
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
23
|
-
this.
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
26
|
-
this.
|
|
27
|
-
this.back =
|
|
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.
|
|
32
|
-
this.
|
|
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
|
-
|
|
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),
|
|
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
|
|
67
|
+
this.closeTarget.set(EvoSidebarCloseTargets.DEFAULT);
|
|
58
68
|
}
|
|
59
69
|
// Dynamic content strategy
|
|
60
70
|
if (isOpen && params?.component) {
|
|
61
|
-
const { component, closeOnNavigation, size
|
|
62
|
-
this.isDynamicContent
|
|
63
|
-
this.
|
|
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
|
|
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
|
|
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
|
|
88
|
-
this.closeTarget
|
|
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
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
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.
|
|
132
|
+
this.contentContainer().insert(dynamicComponentRef.hostView);
|
|
128
133
|
}
|
|
129
134
|
clearView() {
|
|
130
|
-
|
|
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: [
|
|
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
|
|
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: [
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
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 {
|
|
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(
|
|
10
|
-
|
|
11
|
-
this.
|
|
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: [
|
|
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
|
-
}]
|
|
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,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1zaWRlYmFyL2ludGVyZmFjZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0b3IsIFR5cGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcbmltcG9ydCB7RXZvU2lkZWJhckNsb3NlVGFyZ2V0c30gZnJvbSAnLi9lbnVtcy9ldm8tc2lkZWJhci1jbG9zZS10YXJnZXRzJztcbmltcG9ydCB7RXZvU2lkZWJhclNpemVzfSBmcm9tICcuL2VudW1zL2V2by1zaWRlYmFyLXNpemVzJztcblxuZXhwb3J0IGludGVyZmFjZSBFdm9TaWRlYmFyQ29uZmlnIHtcbiAgICBob3N0Pzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEV2b1NpZGViYXJTdGF0ZSB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBpc09wZW46IGJvb2xlYW47XG4gICAgcGFyYW1zPzogRXZvU2lkZWJhclBhcmFtcztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFdm9TaWRlYmFyUGFyYW1zIHtcbiAgICBjbG9zZVRhcmdldD86IEV2b1NpZGViYXJDbG9zZVRhcmdldHM7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG4gICAgY29tcG9uZW50PzogVHlwZTxhbnk+O1xuICAgIGNsb3NlT25OYXZpZ2F0aW9uPzogYm9vbGVhbjtcbiAgICBzaXplPzogRXZvU2lkZWJhclNpemVzO1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxuICAgIGRhdGE/OiBhbnk7XG4gICAgaW5qZWN0b3I/OiBJbmplY3RvcjtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBbcHJvcGVydHk6IHN0cmluZ106IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFdm9PcGVuZWRTaWRlYmFyQWN0aW9ucyB7XG4gICAgYWZ0ZXJDbG9zZWQ6ICgpID0+IE9ic2VydmFibGU8RXZvU2lkZWJhclBhcmFtcz47XG59XG4iXX0=
|