@evotor-dev/ui-kit 8.0.0-beta.24 → 8.0.0-beta.25

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,34 +1,25 @@
1
- import { Component, HostBinding, Inject, Input } from '@angular/core';
2
- import { SidebarInjectionToken } from '../sidebar-injection-token';
1
+ import { booleanAttribute, Component, computed, inject, input } from '@angular/core';
2
+ import { EvoSidebarToken } from "../evo-sidebar.token";
3
3
  import * as i0 from "@angular/core";
4
4
  export class EvoSidebarContentComponent {
5
- // eslint-disable-next-line
6
- constructor(sidebar) {
7
- this.sidebar = sidebar;
8
- this.hostClass = 'evo-sidebar__content';
5
+ constructor() {
6
+ this.relativeFooter = input(false, { transform: booleanAttribute });
7
+ this.computedRelativeFooter = computed(() => this.relativeFooter() || this.sidebar.relativeFooter());
8
+ this.sidebar = inject(EvoSidebarToken);
9
9
  }
10
10
  ngOnInit() {
11
11
  if (!this.sidebar) {
12
12
  throw new Error(`EvoSidebarContentComponent must be used inside EvoSidebarComponent only!`);
13
13
  }
14
- this.relativeFooter = this.relativeFooter ?? this.sidebar.relativeFooter;
15
14
  }
16
- get hostClasses() {
17
- return this.relativeFooter ? `${this.hostClass} evo-sidebar__content_relative-footer` : this.hostClass;
18
- }
19
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarContentComponent, deps: [{ token: SidebarInjectionToken }], target: i0.ɵɵFactoryTarget.Component }); }
20
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: EvoSidebarContentComponent, isStandalone: true, selector: "evo-sidebar-content, [evo-sidebar-content]", inputs: { relativeFooter: "relativeFooter" }, host: { properties: { "class": "this.hostClasses" } }, ngImport: i0, template: "<ng-content />\n", styles: [":host{display:flex;flex-grow:1;flex-direction:column;padding:24px 15px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (min-width: 768px){:host{padding:40px 15px}}@media (min-width: 992px){:host{padding:40px 32px}}:host(.evo-sidebar__content_relative-footer){flex-grow:0}\n"] }); }
15
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
16
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.10", type: EvoSidebarContentComponent, isStandalone: true, selector: "evo-sidebar-content, [evo-sidebar-content]", inputs: { relativeFooter: { classPropertyName: "relativeFooter", publicName: "relativeFooter", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.evo-sidebar__content_relative-footer": "this.computedRelativeFooter()" }, classAttribute: "evo-sidebar__content" }, ngImport: i0, template: "<ng-content />\n", styles: [":host{display:flex;flex-grow:1;flex-direction:column;padding:24px 15px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (min-width: 768px){:host{padding:40px 15px}}@media (min-width: 992px){:host{padding:40px 32px}}:host(.evo-sidebar__content_relative-footer){flex-grow:0}\n"] }); }
21
17
  }
22
18
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarContentComponent, decorators: [{
23
19
  type: Component,
24
- args: [{ selector: 'evo-sidebar-content, [evo-sidebar-content]', standalone: true, template: "<ng-content />\n", styles: [":host{display:flex;flex-grow:1;flex-direction:column;padding:24px 15px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (min-width: 768px){:host{padding:40px 15px}}@media (min-width: 992px){:host{padding:40px 32px}}:host(.evo-sidebar__content_relative-footer){flex-grow:0}\n"] }]
25
- }], ctorParameters: () => [{ type: undefined, decorators: [{
26
- type: Inject,
27
- args: [SidebarInjectionToken]
28
- }] }], propDecorators: { relativeFooter: [{
29
- type: Input
30
- }], hostClasses: [{
31
- type: HostBinding,
32
- args: ['class']
33
- }] } });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLXNpZGViYXItY29udGVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldm8tdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9ldm8tc2lkZWJhci9ldm8tc2lkZWJhci1jb250ZW50L2V2by1zaWRlYmFyLWNvbnRlbnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLXNpZGViYXIvZXZvLXNpZGViYXItY29udGVudC9ldm8tc2lkZWJhci1jb250ZW50LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFDNUUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sNEJBQTRCLENBQUM7O0FBUWpFLE1BQU0sT0FBTywwQkFBMEI7SUFLbkMsMkJBQTJCO0lBQzNCLFlBQW1ELE9BQVk7UUFBWixZQUFPLEdBQVAsT0FBTyxDQUFLO1FBSDlDLGNBQVMsR0FBRyxzQkFBc0IsQ0FBQztJQUdjLENBQUM7SUFFbkUsUUFBUTtRQUNKLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDaEIsTUFBTSxJQUFJLEtBQUssQ0FBQywwRUFBMEUsQ0FBQyxDQUFDO1FBQ2hHLENBQUM7UUFFRCxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxjQUFjLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUM7SUFDN0UsQ0FBQztJQUVELElBQ0ksV0FBVztRQUNYLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsU0FBUyx1Q0FBdUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUMzRyxDQUFDOytHQW5CUSwwQkFBMEIsa0JBTWYscUJBQXFCO21HQU5oQywwQkFBMEIsMk1DVHZDLGtCQUNBOzs0RkRRYSwwQkFBMEI7a0JBTnRDLFNBQVM7K0JBQ0ksNENBQTRDLGNBRzFDLElBQUk7OzBCQVFILE1BQU07MkJBQUMscUJBQXFCO3lDQUxoQyxjQUFjO3NCQUF0QixLQUFLO2dCQWdCRixXQUFXO3NCQURkLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBIb3N0QmluZGluZywgSW5qZWN0LCBJbnB1dCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7U2lkZWJhckluamVjdGlvblRva2VufSBmcm9tICcuLi9zaWRlYmFyLWluamVjdGlvbi10b2tlbic7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXZvLXNpZGViYXItY29udGVudCwgW2V2by1zaWRlYmFyLWNvbnRlbnRdJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZXZvLXNpZGViYXItY29udGVudC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZXZvLXNpZGViYXItY29udGVudC5jb21wb25lbnQuc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIEV2b1NpZGViYXJDb250ZW50Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSByZWxhdGl2ZUZvb3RlcjogYm9vbGVhbjtcblxuICAgIHByaXZhdGUgcmVhZG9ubHkgaG9zdENsYXNzID0gJ2V2by1zaWRlYmFyX19jb250ZW50JztcblxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxuICAgIGNvbnN0cnVjdG9yKEBJbmplY3QoU2lkZWJhckluamVjdGlvblRva2VuKSBwcml2YXRlIHNpZGViYXI6IGFueSkge31cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICBpZiAoIXRoaXMuc2lkZWJhcikge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBFdm9TaWRlYmFyQ29udGVudENvbXBvbmVudCBtdXN0IGJlIHVzZWQgaW5zaWRlIEV2b1NpZGViYXJDb21wb25lbnQgb25seSFgKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMucmVsYXRpdmVGb290ZXIgPSB0aGlzLnJlbGF0aXZlRm9vdGVyID8/IHRoaXMuc2lkZWJhci5yZWxhdGl2ZUZvb3RlcjtcbiAgICB9XG5cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgICBnZXQgaG9zdENsYXNzZXMoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnJlbGF0aXZlRm9vdGVyID8gYCR7dGhpcy5ob3N0Q2xhc3N9IGV2by1zaWRlYmFyX19jb250ZW50X3JlbGF0aXZlLWZvb3RlcmAgOiB0aGlzLmhvc3RDbGFzcztcbiAgICB9XG59XG4iLCI8bmctY29udGVudCAvPlxuIl19
20
+ args: [{ selector: 'evo-sidebar-content, [evo-sidebar-content]', standalone: true, host: {
21
+ class: 'evo-sidebar__content',
22
+ '[class.evo-sidebar__content_relative-footer]': 'this.computedRelativeFooter()',
23
+ }, template: "<ng-content />\n", styles: [":host{display:flex;flex-grow:1;flex-direction:column;padding:24px 15px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (min-width: 768px){:host{padding:40px 15px}}@media (min-width: 992px){:host{padding:40px 32px}}:host(.evo-sidebar__content_relative-footer){flex-grow:0}\n"] }]
24
+ }] });
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLXNpZGViYXItY29udGVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldm8tdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9ldm8tc2lkZWJhci9ldm8tc2lkZWJhci1jb250ZW50L2V2by1zaWRlYmFyLWNvbnRlbnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLXNpZGViYXIvZXZvLXNpZGViYXItY29udGVudC9ldm8tc2lkZWJhci1jb250ZW50LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxnQkFBZ0IsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFDM0YsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHNCQUFzQixDQUFDOztBQWFyRCxNQUFNLE9BQU8sMEJBQTBCO0lBWHZDO1FBYUksbUJBQWMsR0FBRyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUMsU0FBUyxFQUFFLGdCQUFnQixFQUFDLENBQUMsQ0FBQztRQUVwRCwyQkFBc0IsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRSxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FBQztRQUV4RixZQUFPLEdBQUcsTUFBTSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0tBT3REO0lBTEcsUUFBUTtRQUNKLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDaEIsTUFBTSxJQUFJLEtBQUssQ0FBQywwRUFBMEUsQ0FBQyxDQUFDO1FBQ2hHLENBQUM7SUFDTCxDQUFDOytHQVpRLDBCQUEwQjttR0FBMUIsMEJBQTBCLHNaQ2R2QyxrQkFDQTs7NEZEYWEsMEJBQTBCO2tCQVh0QyxTQUFTOytCQUNJLDRDQUE0QyxjQUcxQyxJQUFJLFFBRVY7d0JBQ0YsS0FBSyxFQUFFLHNCQUFzQjt3QkFDN0IsOENBQThDLEVBQUUsK0JBQStCO3FCQUNsRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Ym9vbGVhbkF0dHJpYnV0ZSwgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5qZWN0LCBpbnB1dCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7RXZvU2lkZWJhclRva2VufSBmcm9tIFwiLi4vZXZvLXNpZGViYXIudG9rZW5cIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldm8tc2lkZWJhci1jb250ZW50LCBbZXZvLXNpZGViYXItY29udGVudF0nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ldm8tc2lkZWJhci1jb250ZW50LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ldm8tc2lkZWJhci1jb250ZW50LmNvbXBvbmVudC5zY3NzJ10sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAnZXZvLXNpZGViYXJfX2NvbnRlbnQnLFxuICAgICAgICAnW2NsYXNzLmV2by1zaWRlYmFyX19jb250ZW50X3JlbGF0aXZlLWZvb3Rlcl0nOiAndGhpcy5jb21wdXRlZFJlbGF0aXZlRm9vdGVyKCknLFxuICAgIH0sXG59KVxuZXhwb3J0IGNsYXNzIEV2b1NpZGViYXJDb250ZW50Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICAgIHJlbGF0aXZlRm9vdGVyID0gaW5wdXQoZmFsc2UsIHt0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGV9KTtcblxuICAgIHJlYWRvbmx5IGNvbXB1dGVkUmVsYXRpdmVGb290ZXIgPSBjb21wdXRlZCgoKSA9PiB0aGlzLnJlbGF0aXZlRm9vdGVyKCkgfHwgdGhpcy5zaWRlYmFyLnJlbGF0aXZlRm9vdGVyKCkpO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSBzaWRlYmFyID0gaW5qZWN0KEV2b1NpZGViYXJUb2tlbik7XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgaWYgKCF0aGlzLnNpZGViYXIpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgRXZvU2lkZWJhckNvbnRlbnRDb21wb25lbnQgbXVzdCBiZSB1c2VkIGluc2lkZSBFdm9TaWRlYmFyQ29tcG9uZW50IG9ubHkhYCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8bmctY29udGVudCAvPlxuIl19
@@ -1,14 +1,14 @@
1
- import { Component, computed, inject, input, output } from '@angular/core';
1
+ import { booleanAttribute, Component, computed, inject, input, output } from '@angular/core';
2
2
  import { EvoSidebarCloseTargets } from '../enums/evo-sidebar-close-targets';
3
- import { SidebarInjectionToken } from '../sidebar-injection-token';
3
+ import { EvoSidebarToken } from "../evo-sidebar.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
7
  constructor() {
8
- this.backButton = input(false);
8
+ this.backButton = input(false, { transform: booleanAttribute });
9
9
  this.back = output();
10
10
  this.computedBackButton = computed(() => this.backButton() || this.sidebar.backButton());
11
- this.sidebar = inject(SidebarInjectionToken);
11
+ this.sidebar = inject(EvoSidebarToken);
12
12
  }
13
13
  ngOnInit() {
14
14
  if (!this.sidebar) {
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
30
30
  class: 'evo-sidebar__header',
31
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
32
  }] });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLXNpZGViYXItaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1zaWRlYmFyL2V2by1zaWRlYmFyLWhlYWRlci9ldm8tc2lkZWJhci1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLXNpZGViYXIvZXZvLXNpZGViYXItaGVhZGVyL2V2by1zaWRlYmFyLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNqRixPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUMxRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUNqRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFjbkUsTUFBTSxPQUFPLHlCQUF5QjtJQVh0QztRQWFJLGVBQVUsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFakIsU0FBSSxHQUFHLE1BQU0sRUFBUSxDQUFDO1FBQ3RCLHVCQUFrQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDO1FBRTVFLFlBQU8sR0FBRyxNQUFNLENBQXNCLHFCQUFxQixDQUFDLENBQUM7S0FlakY7SUFiRyxRQUFRO1FBQ0osSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQixNQUFNLElBQUksS0FBSyxDQUFDLHlFQUF5RSxDQUFDLENBQUM7UUFDL0YsQ0FBQztJQUNMLENBQUM7SUFFRCxlQUFlO1FBQ1gsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsWUFBWTtRQUNSLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLHNCQUFzQixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdELENBQUM7K0dBckJRLHlCQUF5QjttR0FBekIseUJBQXlCLG1VQ2pCdEMsc1lBYUEsazZCREVjLGdCQUFnQjs7NEZBRWpCLHlCQUF5QjtrQkFYckMsU0FBUzsrQkFDSSwwQ0FBMEMsUUFJOUM7d0JBQ0YsS0FBSyxFQUFFLHFCQUFxQjtxQkFDL0IsY0FDVyxJQUFJLFdBQ1AsQ0FBQyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBjb21wdXRlZCwgaW5qZWN0LCBpbnB1dCwgT25Jbml0LCBvdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtFdm9TaWRlYmFyQ2xvc2VUYXJnZXRzfSBmcm9tICcuLi9lbnVtcy9ldm8tc2lkZWJhci1jbG9zZS10YXJnZXRzJztcbmltcG9ydCB7U2lkZWJhckluamVjdGlvblRva2VufSBmcm9tICcuLi9zaWRlYmFyLWluamVjdGlvbi10b2tlbic7XG5pbXBvcnQge0V2b0ljb25Db21wb25lbnR9IGZyb20gJy4uLy4uL2V2by1pY29uL2V2by1pY29uLmNvbXBvbmVudCc7XG5pbXBvcnQge0V2b1NpZGViYXJDb21wb25lbnR9IGZyb20gXCIuLi9ldm8tc2lkZWJhci5jb21wb25lbnRcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldm8tc2lkZWJhci1oZWFkZXIsIFtldm8tc2lkZWJhci1oZWFkZXJdJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZXZvLXNpZGViYXItaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ldm8tc2lkZWJhci1oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAnZXZvLXNpZGViYXJfX2hlYWRlcicsXG4gICAgfSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtFdm9JY29uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgRXZvU2lkZWJhckhlYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgICBiYWNrQnV0dG9uID0gaW5wdXQoZmFsc2UpO1xuXG4gICAgcmVhZG9ubHkgYmFjayA9IG91dHB1dDx2b2lkPigpO1xuICAgIHJlYWRvbmx5IGNvbXB1dGVkQmFja0J1dHRvbiA9IGNvbXB1dGVkKCgpID0+IHRoaXMuYmFja0J1dHRvbigpIHx8IHRoaXMuc2lkZWJhci5iYWNrQnV0dG9uKCkpO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSBzaWRlYmFyID0gaW5qZWN0PEV2b1NpZGViYXJDb21wb25lbnQ+KFNpZGViYXJJbmplY3Rpb25Ub2tlbik7XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgaWYgKCF0aGlzLnNpZGViYXIpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgRXZvU2lkZWJhckhlYWRlckNvbXBvbmVudCBtdXN0IGJlIHVzZWQgaW5zaWRlIEV2b1NpZGViYXJDb21wb25lbnQgb25seSFgKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGhhbmRsZUJhY2tDbGljaygpIHtcbiAgICAgICAgdGhpcy5iYWNrLmVtaXQoKTtcbiAgICB9XG5cbiAgICBjbG9zZVNpZGViYXIoKSB7XG4gICAgICAgIHRoaXMuc2lkZWJhci5jbG9zZVNpZGViYXIoRXZvU2lkZWJhckNsb3NlVGFyZ2V0cy5CVVRUT04pO1xuICAgIH1cbn1cbiIsIkBpZiAoY29tcHV0ZWRCYWNrQnV0dG9uKCkpIHtcbiAgICA8ZGl2IGNsYXNzPVwiZXZvLXNpZGViYXJfX2JhY2tcIiAoY2xpY2spPVwiaGFuZGxlQmFja0NsaWNrKClcIj5cbiAgICAgICAgPGV2by1pY29uIHNoYXBlPVwiY2hldnJvbi1sZWZ0XCIgY2xhc3M9XCJldm8tc2lkZWJhcl9faWNvblwiIC8+XG4gICAgPC9kaXY+XG59XG5cbjxkaXYgY2xhc3M9XCJldm8tc2lkZWJhcl9fdGl0bGVcIj5cbiAgICA8bmctY29udGVudCAvPlxuPC9kaXY+XG5cbjxkaXYgY2xhc3M9XCJldm8tc2lkZWJhcl9fY2xvc2VcIiAoY2xpY2spPVwiY2xvc2VTaWRlYmFyKClcIj5cbiAgICA8ZXZvLWljb24gc2hhcGU9XCJjbG9zZVwiIGNsYXNzPVwiZXZvLXNpZGViYXJfX2ljb25cIiAvPlxuPC9kaXY+XG4iXX0=
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLXNpZGViYXItaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1zaWRlYmFyL2V2by1zaWRlYmFyLWhlYWRlci9ldm8tc2lkZWJhci1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLXNpZGViYXIvZXZvLXNpZGViYXItaGVhZGVyL2V2by1zaWRlYmFyLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNuRyxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUMxRSxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7O0FBYW5FLE1BQU0sT0FBTyx5QkFBeUI7SUFYdEM7UUFhSSxlQUFVLEdBQUcsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFDLFNBQVMsRUFBRSxnQkFBZ0IsRUFBQyxDQUFDLENBQUM7UUFFaEQsU0FBSSxHQUFHLE1BQU0sRUFBUSxDQUFDO1FBQ3RCLHVCQUFrQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDO1FBRTVFLFlBQU8sR0FBRyxNQUFNLENBQUMsZUFBZSxDQUFDLENBQUM7S0FldEQ7SUFiRyxRQUFRO1FBQ0osSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQixNQUFNLElBQUksS0FBSyxDQUFDLHlFQUF5RSxDQUFDLENBQUM7UUFDL0YsQ0FBQztJQUNMLENBQUM7SUFFRCxlQUFlO1FBQ1gsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsWUFBWTtRQUNSLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLHNCQUFzQixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdELENBQUM7K0dBckJRLHlCQUF5QjttR0FBekIseUJBQXlCLG1VQ2hCdEMsc1lBYUEsazZCRENjLGdCQUFnQjs7NEZBRWpCLHlCQUF5QjtrQkFYckMsU0FBUzsrQkFDSSwwQ0FBMEMsUUFJOUM7d0JBQ0YsS0FBSyxFQUFFLHFCQUFxQjtxQkFDL0IsY0FDVyxJQUFJLFdBQ1AsQ0FBQyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Ym9vbGVhbkF0dHJpYnV0ZSwgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5qZWN0LCBpbnB1dCwgT25Jbml0LCBvdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtFdm9TaWRlYmFyQ2xvc2VUYXJnZXRzfSBmcm9tICcuLi9lbnVtcy9ldm8tc2lkZWJhci1jbG9zZS10YXJnZXRzJztcbmltcG9ydCB7RXZvU2lkZWJhclRva2VufSBmcm9tIFwiLi4vZXZvLXNpZGViYXIudG9rZW5cIjtcbmltcG9ydCB7RXZvSWNvbkNvbXBvbmVudH0gZnJvbSAnLi4vLi4vZXZvLWljb24vZXZvLWljb24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldm8tc2lkZWJhci1oZWFkZXIsIFtldm8tc2lkZWJhci1oZWFkZXJdJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZXZvLXNpZGViYXItaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ldm8tc2lkZWJhci1oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAnZXZvLXNpZGViYXJfX2hlYWRlcicsXG4gICAgfSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtFdm9JY29uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgRXZvU2lkZWJhckhlYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgICBiYWNrQnV0dG9uID0gaW5wdXQoZmFsc2UsIHt0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGV9KTtcblxuICAgIHJlYWRvbmx5IGJhY2sgPSBvdXRwdXQ8dm9pZD4oKTtcbiAgICByZWFkb25seSBjb21wdXRlZEJhY2tCdXR0b24gPSBjb21wdXRlZCgoKSA9PiB0aGlzLmJhY2tCdXR0b24oKSB8fCB0aGlzLnNpZGViYXIuYmFja0J1dHRvbigpKTtcblxuICAgIHByaXZhdGUgcmVhZG9ubHkgc2lkZWJhciA9IGluamVjdChFdm9TaWRlYmFyVG9rZW4pO1xuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIGlmICghdGhpcy5zaWRlYmFyKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYEV2b1NpZGViYXJIZWFkZXJDb21wb25lbnQgbXVzdCBiZSB1c2VkIGluc2lkZSBFdm9TaWRlYmFyQ29tcG9uZW50IG9ubHkhYCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBoYW5kbGVCYWNrQ2xpY2soKSB7XG4gICAgICAgIHRoaXMuYmFjay5lbWl0KCk7XG4gICAgfVxuXG4gICAgY2xvc2VTaWRlYmFyKCkge1xuICAgICAgICB0aGlzLnNpZGViYXIuY2xvc2VTaWRlYmFyKEV2b1NpZGViYXJDbG9zZVRhcmdldHMuQlVUVE9OKTtcbiAgICB9XG59XG4iLCJAaWYgKGNvbXB1dGVkQmFja0J1dHRvbigpKSB7XG4gICAgPGRpdiBjbGFzcz1cImV2by1zaWRlYmFyX19iYWNrXCIgKGNsaWNrKT1cImhhbmRsZUJhY2tDbGljaygpXCI+XG4gICAgICAgIDxldm8taWNvbiBzaGFwZT1cImNoZXZyb24tbGVmdFwiIGNsYXNzPVwiZXZvLXNpZGViYXJfX2ljb25cIiAvPlxuICAgIDwvZGl2PlxufVxuXG48ZGl2IGNsYXNzPVwiZXZvLXNpZGViYXJfX3RpdGxlXCI+XG4gICAgPG5nLWNvbnRlbnQgLz5cbjwvZGl2PlxuXG48ZGl2IGNsYXNzPVwiZXZvLXNpZGViYXJfX2Nsb3NlXCIgKGNsaWNrKT1cImNsb3NlU2lkZWJhcigpXCI+XG4gICAgPGV2by1pY29uIHNoYXBlPVwiY2xvc2VcIiBjbGFzcz1cImV2by1zaWRlYmFyX19pY29uXCIgLz5cbjwvZGl2PlxuIl19
@@ -1,4 +1,4 @@
1
- import { ChangeDetectorRef, Component, computed, createComponent, DestroyRef, EnvironmentInjector, forwardRef, inject, Injector, input, NgZone, output, signal, viewChild, ViewContainerRef, } from '@angular/core';
1
+ import { ChangeDetectorRef, Component, computed, createComponent, DestroyRef, EnvironmentInjector, inject, Injector, input, NgZone, output, signal, viewChild, ViewContainerRef, } from '@angular/core';
2
2
  import { fromEvent } from 'rxjs';
3
3
  import { EvoSidebarService } from './evo-sidebar.service';
4
4
  import { delay, filter, takeWhile, tap } from 'rxjs/operators';
@@ -9,7 +9,7 @@ import { sidebarAnimation } from '../../common/animations/sidebar.animation';
9
9
  import { EvoSidebarCloseTargets } from './enums/evo-sidebar-close-targets';
10
10
  import { EvoSidebarStates } from './enums/evo-sidebar-states';
11
11
  import { EvoSidebarSizes } from './enums/evo-sidebar-sizes';
12
- import { SidebarInjectionToken } from './sidebar-injection-token';
12
+ import { EvoSidebarToken } from "./evo-sidebar.token";
13
13
  import { EvoSidebarFooterComponent } from './evo-sidebar-footer/evo-sidebar-footer.component';
14
14
  import { EvoSidebarContentComponent } from './evo-sidebar-content/evo-sidebar-content.component';
15
15
  import { EvoSidebarHeaderComponent } from './evo-sidebar-header/evo-sidebar-header.component';
@@ -122,7 +122,7 @@ export class EvoSidebarComponent {
122
122
  useValue: data,
123
123
  },
124
124
  {
125
- provide: SidebarInjectionToken,
125
+ provide: EvoSidebarToken,
126
126
  useValue: this,
127
127
  },
128
128
  ],
@@ -140,8 +140,8 @@ export class EvoSidebarComponent {
140
140
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
141
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\n class=\"evo-sidebar\"\n [@open]=\"currentState\"\n [evoUiClass]=\"totalClasses()\"\n (@open.done)=\"handleAnimationDone($event)\"\n>\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: [
142
142
  {
143
- provide: SidebarInjectionToken,
144
- useExisting: forwardRef(() => EvoSidebarComponent),
143
+ provide: EvoSidebarToken,
144
+ useExisting: EvoSidebarComponent,
145
145
  },
146
146
  ], animations: [sidebarAnimation] }); }
147
147
  }
@@ -149,8 +149,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
149
149
  type: Component,
150
150
  args: [{ selector: 'evo-sidebar', animations: [sidebarAnimation], viewProviders: [
151
151
  {
152
- provide: SidebarInjectionToken,
153
- useExisting: forwardRef(() => EvoSidebarComponent),
152
+ provide: EvoSidebarToken,
153
+ useExisting: EvoSidebarComponent,
154
154
  },
155
155
  ], standalone: true, imports: [
156
156
  EvoUiClassDirective,
@@ -159,4 +159,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
159
159
  EvoSidebarFooterComponent,
160
160
  ], template: "@if (isVisible()) {\n <div class=\"evo-sidebar__background\" (click)=\"closeSidebar(closeTargets.BACKGROUND)\"></div>\n}\n\n<div\n class=\"evo-sidebar\"\n [@open]=\"currentState\"\n [evoUiClass]=\"totalClasses()\"\n (@open.done)=\"handleAnimationDone($event)\"\n>\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"] }]
161
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\n    class=\"evo-sidebar\"\n    [@open]=\"currentState\"\n    [evoUiClass]=\"totalClasses()\"\n    (@open.done)=\"handleAnimationDone($event)\"\n>\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"]}
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    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 {EvoSidebarToken} from \"./evo-sidebar.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: EvoSidebarToken,\n            useExisting: 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: EvoSidebarToken,\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\n    class=\"evo-sidebar\"\n    [@open]=\"currentState\"\n    [evoUiClass]=\"totalClasses()\"\n    (@open.done)=\"handleAnimationDone($event)\"\n>\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"]}
@@ -0,0 +1,3 @@
1
+ export class EvoSidebarToken {
2
+ }
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLXNpZGViYXIudG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldm8tdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9ldm8tc2lkZWJhci9ldm8tc2lkZWJhci50b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQWdCLGVBQWU7Q0FLcEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1NpZ25hbH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7RXZvU2lkZWJhckNsb3NlVGFyZ2V0c30gZnJvbSBcIi4vZW51bXMvZXZvLXNpZGViYXItY2xvc2UtdGFyZ2V0c1wiO1xuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgRXZvU2lkZWJhclRva2VuIHtcbiAgICBhYnN0cmFjdCBiYWNrQnV0dG9uOiBTaWduYWw8Ym9vbGVhbj47XG4gICAgYWJzdHJhY3QgcmVsYXRpdmVGb290ZXI6IFNpZ25hbDxib29sZWFuPjtcblxuICAgIGFic3RyYWN0IGNsb3NlU2lkZWJhcih0YXJnZXQ6IEV2b1NpZGViYXJDbG9zZVRhcmdldHMpOiB2b2lkO1xufVxuIl19
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { InjectionToken, Injectable, PLATFORM_ID, ɵstringify as _stringify, Directive, Input, EventEmitter, Output, HostListener, Optional, ViewContainerRef, TemplateRef, Inject, NgModule, CUSTOM_ELEMENTS_SCHEMA, inject, SecurityContext, Component, ChangeDetectionStrategy, HostBinding, Pipe, forwardRef, ViewChild, ViewEncapsulation, ContentChild, ElementRef, ComponentRef, input, output, computed, viewChild, signal, ChangeDetectorRef, DestroyRef, EnvironmentInjector, NgZone, createComponent, Injector, ApplicationRef, ComponentFactoryResolver, makeEnvironmentProviders, Host, ContentChildren, ViewChildren } from '@angular/core';
2
+ import { InjectionToken, Injectable, PLATFORM_ID, ɵstringify as _stringify, Directive, Input, EventEmitter, Output, HostListener, Optional, ViewContainerRef, TemplateRef, Inject, NgModule, CUSTOM_ELEMENTS_SCHEMA, inject, SecurityContext, Component, ChangeDetectionStrategy, HostBinding, Pipe, forwardRef, ViewChild, ViewEncapsulation, ContentChild, ElementRef, ComponentRef, input, booleanAttribute, computed, output, viewChild, signal, ChangeDetectorRef, DestroyRef, EnvironmentInjector, NgZone, createComponent, Injector, ApplicationRef, ComponentFactoryResolver, makeEnvironmentProviders, Host, ContentChildren, ViewChildren } from '@angular/core';
3
3
  import * as i1 from '@angular/common';
4
4
  import { isPlatformBrowser, CommonModule, AsyncPipe, NgClass, NgTemplateOutlet, NgIf, NgStyle, Location, NgFor } from '@angular/common';
5
5
  import * as i1$2 from '@angular/forms';
@@ -4251,7 +4251,8 @@ var EvoSidebarSizes;
4251
4251
  EvoSidebarSizes["LARGE"] = "large";
4252
4252
  })(EvoSidebarSizes || (EvoSidebarSizes = {}));
4253
4253
 
4254
- const SidebarInjectionToken = new InjectionToken('SidebarInjectionToken');
4254
+ class EvoSidebarToken {
4255
+ }
4255
4256
 
4256
4257
  class EvoSidebarFooterComponent {
4257
4258
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
@@ -4265,42 +4266,33 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
4265
4266
  }] });
4266
4267
 
4267
4268
  class EvoSidebarContentComponent {
4268
- // eslint-disable-next-line
4269
- constructor(sidebar) {
4270
- this.sidebar = sidebar;
4271
- this.hostClass = 'evo-sidebar__content';
4269
+ constructor() {
4270
+ this.relativeFooter = input(false, { transform: booleanAttribute });
4271
+ this.computedRelativeFooter = computed(() => this.relativeFooter() || this.sidebar.relativeFooter());
4272
+ this.sidebar = inject(EvoSidebarToken);
4272
4273
  }
4273
4274
  ngOnInit() {
4274
4275
  if (!this.sidebar) {
4275
4276
  throw new Error(`EvoSidebarContentComponent must be used inside EvoSidebarComponent only!`);
4276
4277
  }
4277
- this.relativeFooter = this.relativeFooter ?? this.sidebar.relativeFooter;
4278
4278
  }
4279
- get hostClasses() {
4280
- return this.relativeFooter ? `${this.hostClass} evo-sidebar__content_relative-footer` : this.hostClass;
4281
- }
4282
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarContentComponent, deps: [{ token: SidebarInjectionToken }], target: i0.ɵɵFactoryTarget.Component }); }
4283
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: EvoSidebarContentComponent, isStandalone: true, selector: "evo-sidebar-content, [evo-sidebar-content]", inputs: { relativeFooter: "relativeFooter" }, host: { properties: { "class": "this.hostClasses" } }, ngImport: i0, template: "<ng-content />\n", styles: [":host{display:flex;flex-grow:1;flex-direction:column;padding:24px 15px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (min-width: 768px){:host{padding:40px 15px}}@media (min-width: 992px){:host{padding:40px 32px}}:host(.evo-sidebar__content_relative-footer){flex-grow:0}\n"] }); }
4279
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
4280
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.10", type: EvoSidebarContentComponent, isStandalone: true, selector: "evo-sidebar-content, [evo-sidebar-content]", inputs: { relativeFooter: { classPropertyName: "relativeFooter", publicName: "relativeFooter", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.evo-sidebar__content_relative-footer": "this.computedRelativeFooter()" }, classAttribute: "evo-sidebar__content" }, ngImport: i0, template: "<ng-content />\n", styles: [":host{display:flex;flex-grow:1;flex-direction:column;padding:24px 15px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (min-width: 768px){:host{padding:40px 15px}}@media (min-width: 992px){:host{padding:40px 32px}}:host(.evo-sidebar__content_relative-footer){flex-grow:0}\n"] }); }
4284
4281
  }
4285
4282
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarContentComponent, decorators: [{
4286
4283
  type: Component,
4287
- args: [{ selector: 'evo-sidebar-content, [evo-sidebar-content]', standalone: true, template: "<ng-content />\n", styles: [":host{display:flex;flex-grow:1;flex-direction:column;padding:24px 15px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (min-width: 768px){:host{padding:40px 15px}}@media (min-width: 992px){:host{padding:40px 32px}}:host(.evo-sidebar__content_relative-footer){flex-grow:0}\n"] }]
4288
- }], ctorParameters: () => [{ type: undefined, decorators: [{
4289
- type: Inject,
4290
- args: [SidebarInjectionToken]
4291
- }] }], propDecorators: { relativeFooter: [{
4292
- type: Input
4293
- }], hostClasses: [{
4294
- type: HostBinding,
4295
- args: ['class']
4296
- }] } });
4284
+ args: [{ selector: 'evo-sidebar-content, [evo-sidebar-content]', standalone: true, host: {
4285
+ class: 'evo-sidebar__content',
4286
+ '[class.evo-sidebar__content_relative-footer]': 'this.computedRelativeFooter()',
4287
+ }, template: "<ng-content />\n", styles: [":host{display:flex;flex-grow:1;flex-direction:column;padding:24px 15px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (min-width: 768px){:host{padding:40px 15px}}@media (min-width: 992px){:host{padding:40px 32px}}:host(.evo-sidebar__content_relative-footer){flex-grow:0}\n"] }]
4288
+ }] });
4297
4289
 
4298
4290
  class EvoSidebarHeaderComponent {
4299
4291
  constructor() {
4300
- this.backButton = input(false);
4292
+ this.backButton = input(false, { transform: booleanAttribute });
4301
4293
  this.back = output();
4302
4294
  this.computedBackButton = computed(() => this.backButton() || this.sidebar.backButton());
4303
- this.sidebar = inject(SidebarInjectionToken);
4295
+ this.sidebar = inject(EvoSidebarToken);
4304
4296
  }
4305
4297
  ngOnInit() {
4306
4298
  if (!this.sidebar) {
@@ -4429,7 +4421,7 @@ class EvoSidebarComponent {
4429
4421
  useValue: data,
4430
4422
  },
4431
4423
  {
4432
- provide: SidebarInjectionToken,
4424
+ provide: EvoSidebarToken,
4433
4425
  useValue: this,
4434
4426
  },
4435
4427
  ],
@@ -4447,8 +4439,8 @@ class EvoSidebarComponent {
4447
4439
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoSidebarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
4448
4440
  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\n class=\"evo-sidebar\"\n [@open]=\"currentState\"\n [evoUiClass]=\"totalClasses()\"\n (@open.done)=\"handleAnimationDone($event)\"\n>\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: [
4449
4441
  {
4450
- provide: SidebarInjectionToken,
4451
- useExisting: forwardRef(() => EvoSidebarComponent),
4442
+ provide: EvoSidebarToken,
4443
+ useExisting: EvoSidebarComponent,
4452
4444
  },
4453
4445
  ], animations: [sidebarAnimation] }); }
4454
4446
  }
@@ -4456,8 +4448,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
4456
4448
  type: Component,
4457
4449
  args: [{ selector: 'evo-sidebar', animations: [sidebarAnimation], viewProviders: [
4458
4450
  {
4459
- provide: SidebarInjectionToken,
4460
- useExisting: forwardRef(() => EvoSidebarComponent),
4451
+ provide: EvoSidebarToken,
4452
+ useExisting: EvoSidebarComponent,
4461
4453
  },
4462
4454
  ], standalone: true, imports: [
4463
4455
  EvoUiClassDirective,