@ngutil/layout 0.0.3-dev.9 → 0.0.4

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.
@@ -0,0 +1,6 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class DockingBackdropComponent {
3
+ state: "visible" | "hidden";
4
+ static ɵfac: i0.ɵɵFactoryDeclaration<DockingBackdropComponent, never>;
5
+ static ɵcmp: i0.ɵɵComponentDeclaration<DockingBackdropComponent, "nu-docking-backdrop", never, {}, {}, never, never, true, never>;
6
+ }
@@ -1,5 +1,5 @@
1
1
  import * as i0 from "@angular/core";
2
2
  export declare class DockingContentComponent {
3
3
  static ɵfac: i0.ɵɵFactoryDeclaration<DockingContentComponent, never>;
4
- static ɵcmp: i0.ɵɵComponentDeclaration<DockingContentComponent, "nu-docking-content", never, {}, {}, never, ["*"], true, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<DockingContentComponent, "nu-docking-content", ["nuDockingContent"], {}, {}, never, ["*"], true, never>;
5
5
  }
@@ -1,4 +1,4 @@
1
- import { AfterViewInit, OnChanges, QueryList, SimpleChanges } from "@angular/core";
1
+ import { AfterViewInit, ElementRef, OnChanges, QueryList, SimpleChanges } from "@angular/core";
2
2
  import { Observable } from "rxjs";
3
3
  import { Destructible } from "@ngutil/common";
4
4
  import { DockingContentComponent } from "./docking-content.component";
@@ -8,17 +8,17 @@ type DockingVerticalPosition = "top" | "middle" | "bottom";
8
8
  type DockingHorizontalPositon = "left" | "center" | "right";
9
9
  type DockingPosition = `${DockingVerticalPosition}:${DockingHorizontalPositon}`;
10
10
  export type DockingRange = DockingVerticalPosition | DockingHorizontalPositon | DockingPosition | `${DockingPosition}-${DockingPosition}`;
11
- export type DockingPositionMode = "absolute" | "fixed";
12
11
  export declare class DockingLayoutComponent extends Destructible implements AfterViewInit, OnChanges {
13
12
  #private;
14
13
  contentOnly: boolean;
15
- positionMode: DockingPositionMode;
16
14
  contentComponent?: DockingContentComponent;
15
+ backdropEl?: ElementRef<HTMLElement>;
17
16
  dockingPanels: QueryList<DockingPanelComponent>;
18
17
  readonly panels: Observable<Array<DockingPanelComponent>>;
19
18
  ngAfterViewInit(): void;
20
19
  ngOnChanges(changes: SimpleChanges): void;
20
+ onHideBackdropPanel(event: Event): void;
21
21
  static ɵfac: i0.ɵɵFactoryDeclaration<DockingLayoutComponent, never>;
22
- static ɵcmp: i0.ɵɵComponentDeclaration<DockingLayoutComponent, "nu-docking", never, { "contentOnly": { "alias": "contentOnly"; "required": false; }; "positionMode": { "alias": "positionMode"; "required": false; }; }, {}, ["contentComponent", "dockingPanels"], ["nu-docking-panel", "*", "nu-docking-content"], true, never>;
22
+ static ɵcmp: i0.ɵɵComponentDeclaration<DockingLayoutComponent, "nu-docking", never, { "contentOnly": { "alias": "contentOnly"; "required": false; }; }, {}, ["contentComponent", "dockingPanels"], ["nu-docking-panel", "*", "nu-docking-content"], true, never>;
23
23
  }
24
24
  export {};
@@ -1,13 +1,14 @@
1
- import { ElementRef } from "@angular/core";
1
+ import { AfterViewInit, ElementRef } from "@angular/core";
2
2
  import { BehaviorSubject, Observable } from "rxjs";
3
3
  import { BooleanInput, Destructible, NumberWithUnit, NumberWithUnitInput } from "@ngutil/common";
4
4
  import { L9Range, L9RangeName } from "../l9/range";
5
5
  import * as i0 from "@angular/core";
6
- export type DockingPanelState = "full" | "mini" | "invisible";
7
- export type DockingPanelMode = "overlay" | "embedded";
8
- export declare class DockingPanelComponent extends Destructible {
6
+ export type DockingPanelState = "full" | "mini" | "hidden";
7
+ export type DockingPanelMode = "over" | "push" | "rigid";
8
+ export declare class DockingPanelComponent extends Destructible implements AfterViewInit {
9
9
  #private;
10
10
  readonly el: ElementRef<any>;
11
+ readonly content: ElementRef<HTMLElement>;
11
12
  set positionInput(val: L9Range | L9RangeName);
12
13
  readonly position: BehaviorSubject<L9Range>;
13
14
  set stateInput(val: DockingPanelState);
@@ -18,6 +19,8 @@ export declare class DockingPanelComponent extends Destructible {
18
19
  set miniSizeInput(val: NumberWithUnitInput);
19
20
  set minimizable(val: BooleanInput);
20
21
  get minimizable(): boolean;
22
+ set backdrop(val: BooleanInput);
23
+ get backdrop(): boolean;
21
24
  readonly fullSize: Observable<NumberWithUnit>;
22
25
  readonly miniSize: Observable<NumberWithUnit>;
23
26
  readonly changes: Observable<{
@@ -26,13 +29,18 @@ export declare class DockingPanelComponent extends Destructible {
26
29
  mode: DockingPanelMode;
27
30
  fullSize: NumberWithUnit;
28
31
  miniSize: NumberWithUnit;
32
+ contentSize: {
33
+ width: NumberWithUnit;
34
+ height: NumberWithUnit;
35
+ };
29
36
  }>;
30
37
  constructor();
38
+ ngAfterViewInit(): void;
31
39
  open(): void;
32
40
  close(): void;
33
41
  minimize(): void;
34
42
  static ɵfac: i0.ɵɵFactoryDeclaration<DockingPanelComponent, never>;
35
- static ɵcmp: i0.ɵɵComponentDeclaration<DockingPanelComponent, "nu-docking-panel", ["nuDockingPanel"], { "positionInput": { "alias": "position"; "required": false; }; "stateInput": { "alias": "state"; "required": false; }; "modeInput": { "alias": "mode"; "required": false; }; "fullSizeInput": { "alias": "fullSize"; "required": false; }; "miniSizeInput": { "alias": "miniSize"; "required": false; }; "minimizable": { "alias": "minimizable"; "required": false; }; }, { "state": "stateChanges"; }, never, ["*"], true, never>;
43
+ static ɵcmp: i0.ɵɵComponentDeclaration<DockingPanelComponent, "nu-docking-panel", ["nuDockingPanel"], { "positionInput": { "alias": "position"; "required": false; }; "stateInput": { "alias": "state"; "required": false; }; "modeInput": { "alias": "mode"; "required": false; }; "fullSizeInput": { "alias": "fullSize"; "required": false; }; "miniSizeInput": { "alias": "miniSize"; "required": false; }; "minimizable": { "alias": "minimizable"; "required": false; }; "backdrop": { "alias": "backdrop"; "required": false; }; }, { "state": "stateChanges"; }, never, ["*"], true, never>;
36
44
  }
37
45
  type ChangesObservable = typeof DockingPanelComponent.prototype.changes;
38
46
  export type DockingPanelChanges = ChangesObservable extends Observable<infer T> ? T : never;
@@ -0,0 +1,17 @@
1
+ import { Component, HostBinding } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class DockingBackdropComponent {
4
+ constructor() {
5
+ this.state = "hidden";
6
+ }
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingBackdropComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: DockingBackdropComponent, isStandalone: true, selector: "nu-docking-backdrop", host: { properties: { "[attr.state]": "this.state" } }, ngImport: i0, template: ``, isInline: true, styles: [":host{display:flex;flex-direction:column;align-items:stretch;position:absolute;inset:0;transition:opacity var(---docking-layout-anim-duration) var(---docking-layout-anim-ease);z-index:-1;background-color:var(---docking-layout-backdrop-color)}:host[state=hidden]{animation:var(---docking-layout-anim-duration) var(---docking-layout-anim-ease) hide;animation-fill-mode:forwards;pointer-events:none;touch-action:none;opacity:0}:host[state=visible]{visibility:visible;opacity:.3}@keyframes hide{99%{visibility:visible}to{visibility:hidden}}\n"] }); }
9
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingBackdropComponent, decorators: [{
11
+ type: Component,
12
+ args: [{ standalone: true, selector: "nu-docking-backdrop", template: ``, styles: [":host{display:flex;flex-direction:column;align-items:stretch;position:absolute;inset:0;transition:opacity var(---docking-layout-anim-duration) var(---docking-layout-anim-ease);z-index:-1;background-color:var(---docking-layout-backdrop-color)}:host[state=hidden]{animation:var(---docking-layout-anim-duration) var(---docking-layout-anim-ease) hide;animation-fill-mode:forwards;pointer-events:none;touch-action:none;opacity:0}:host[state=visible]{visibility:visible;opacity:.3}@keyframes hide{99%{visibility:visible}to{visibility:hidden}}\n"] }]
13
+ }], propDecorators: { state: [{
14
+ type: HostBinding,
15
+ args: ["[attr.state]"]
16
+ }] } });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1iYWNrZHJvcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sYXlvdXQvc3JjL2RvY2tpbmcvZG9ja2luZy1iYWNrZHJvcC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBUXRELE1BQU0sT0FBTyx3QkFBd0I7SUFOckM7UUFRSSxVQUFLLEdBQXlCLFFBQVEsQ0FBQTtLQUN6Qzs4R0FIWSx3QkFBd0I7a0dBQXhCLHdCQUF3Qix1SUFGdkIsRUFBRTs7MkZBRUgsd0JBQXdCO2tCQU5wQyxTQUFTO2lDQUNNLElBQUksWUFDTixxQkFBcUIsWUFFckIsRUFBRTs4QkFJWixLQUFLO3NCQURKLFdBQVc7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6IFwibnUtZG9ja2luZy1iYWNrZHJvcFwiLFxuICAgIHN0eWxlVXJsOiBcIi4vZG9ja2luZy1iYWNrZHJvcC5jb21wb25lbnQuc2Nzc1wiLFxuICAgIHRlbXBsYXRlOiBgYFxufSlcbmV4cG9ydCBjbGFzcyBEb2NraW5nQmFja2Ryb3BDb21wb25lbnQge1xuICAgIEBIb3N0QmluZGluZyhcIlthdHRyLnN0YXRlXVwiKVxuICAgIHN0YXRlOiBcInZpc2libGVcIiB8IFwiaGlkZGVuXCIgPSBcImhpZGRlblwiXG59XG4iXX0=
@@ -2,10 +2,10 @@ import { Component } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  export class DockingContentComponent {
4
4
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: DockingContentComponent, isStandalone: true, selector: "nu-docking-content", ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [":host{display:flex;flex-flow:column nowrap;align-items:stretch;box-sizing:border-box;flex:1;overflow:auto}\n"] }); }
5
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: DockingContentComponent, isStandalone: true, selector: "nu-docking-content", exportAs: ["nuDockingContent"], ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [":host{display:flex;flex-flow:column nowrap;align-items:stretch;box-sizing:border-box;flex:1}\n"] }); }
6
6
  }
7
7
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingContentComponent, decorators: [{
8
8
  type: Component,
9
- args: [{ standalone: true, selector: "nu-docking-content", template: `<ng-content></ng-content>`, styles: [":host{display:flex;flex-flow:column nowrap;align-items:stretch;box-sizing:border-box;flex:1;overflow:auto}\n"] }]
9
+ args: [{ standalone: true, selector: "nu-docking-content", exportAs: "nuDockingContent", template: `<ng-content></ng-content>`, styles: [":host{display:flex;flex-flow:column nowrap;align-items:stretch;box-sizing:border-box;flex:1}\n"] }]
10
10
  }] });
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xheW91dC9zcmMvZG9ja2luZy9kb2NraW5nLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBUXpDLE1BQU0sT0FBTyx1QkFBdUI7OEdBQXZCLHVCQUF1QjtrR0FBdkIsdUJBQXVCLDhFQUZ0QiwyQkFBMkI7OzJGQUU1Qix1QkFBdUI7a0JBTm5DLFNBQVM7aUNBQ00sSUFBSSxZQUNOLG9CQUFvQixZQUVwQiwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6IFwibnUtZG9ja2luZy1jb250ZW50XCIsXG4gICAgc3R5bGVVcmw6IFwiLi9kb2NraW5nLWNvbnRlbnQuY29tcG9uZW50LnNjc3NcIixcbiAgICB0ZW1wbGF0ZTogYDxuZy1jb250ZW50PjwvbmctY29udGVudD5gXG59KVxuZXhwb3J0IGNsYXNzIERvY2tpbmdDb250ZW50Q29tcG9uZW50IHt9XG4iXX0=
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xheW91dC9zcmMvZG9ja2luZy9kb2NraW5nLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBU3pDLE1BQU0sT0FBTyx1QkFBdUI7OEdBQXZCLHVCQUF1QjtrR0FBdkIsdUJBQXVCLDhHQUZ0QiwyQkFBMkI7OzJGQUU1Qix1QkFBdUI7a0JBUG5DLFNBQVM7aUNBQ00sSUFBSSxZQUNOLG9CQUFvQixZQUNwQixrQkFBa0IsWUFFbEIsMkJBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiBcIm51LWRvY2tpbmctY29udGVudFwiLFxuICAgIGV4cG9ydEFzOiBcIm51RG9ja2luZ0NvbnRlbnRcIixcbiAgICBzdHlsZVVybDogXCIuL2RvY2tpbmctY29udGVudC5jb21wb25lbnQuc2Nzc1wiLFxuICAgIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PmBcbn0pXG5leHBvcnQgY2xhc3MgRG9ja2luZ0NvbnRlbnRDb21wb25lbnQge31cbiJdfQ==
@@ -1,58 +1,33 @@
1
- import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, ElementRef, inject, Input, QueryList } from "@angular/core";
1
+ import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, ElementRef, inject, Input, QueryList, ViewChild } from "@angular/core";
2
2
  import { combineLatest, map, shareReplay, startWith, Subject, switchMap } from "rxjs";
3
- import { Destructible, FastDOM, NumberWithUnit } from "@ngutil/common";
3
+ import { Destructible, FastDOM } from "@ngutil/common";
4
+ import { DockingBackdropComponent } from "./docking-backdrop.component";
4
5
  import { DockingContentComponent } from "./docking-content.component";
5
6
  import { DockingPanelComponent } from "./docking-panel.component";
6
7
  import * as i0 from "@angular/core";
7
- const EMBEDDED_ZINDEX = 20;
8
- const OVERLAY_ZINDEX = EMBEDDED_ZINDEX * 2;
9
- // interface PanelRefChanges {
10
- // ref: PanelRef
11
- // changes: DockingPanelChanges
12
- // }
13
- // class PanelRef {
14
- // style: Partial<CSSStyleDeclaration> = {}
15
- // readonly changes: Observable<PanelRefChanges>
16
- // constructor(public readonly panel: DockingPanelDirective) {
17
- // this.changes = panel.changes.pipe(
18
- // map(changes => {
19
- // return { ref: this, changes }
20
- // })
21
- // )
22
- // }
23
- // }
8
+ const RIGID_ZINDEX = 100;
9
+ const OVER_ZINDEX = RIGID_ZINDEX * 2;
10
+ const BACKDROP_ZINDEX = 10000;
24
11
  export class DockingLayoutComponent extends Destructible {
25
12
  constructor() {
26
13
  super(...arguments);
27
14
  this.#el = inject((ElementRef));
28
15
  this.contentOnly = false;
29
- this.positionMode = "absolute";
30
16
  this.#reflow = new Subject();
17
+ this.#backdropPanel = null;
31
18
  }
32
19
  #el;
33
20
  #reflow;
21
+ #backdropPanel;
34
22
  ngAfterViewInit() {
35
23
  // eslint-disable-next-line prettier/prettier
36
24
  this.panels = this.dockingPanels.changes.pipe(startWith(null), map(() => this.dockingPanels.toArray()), shareReplay(1));
37
- // this.panels.subscribe(panels => console.log({ panels }))
38
25
  this.d
39
26
  .sub(combineLatest({ panels: this.panels, reflow: this.#reflow.pipe(startWith(null)) }))
40
27
  .pipe(switchMap(({ panels }) => combineLatest(panels.map(panel => panel.changes.pipe(map(changes => {
41
28
  return { panel, changes };
42
29
  }))))))
43
30
  .subscribe(this.#layout.bind(this));
44
- // this.d
45
- // .sub(merge(this.dockingPanels.changes, this.#reflow))
46
- // .pipe(
47
- // startWith(null),
48
- // map(() => this.dockingPanels.map(panel => new PanelRef(panel))),
49
- // switchMap(refs => combineLatest(refs.map(ref => ref.changes))),
50
- // map(changes => {
51
- // this.#layout(changes)
52
- // return changes.map(c => c.ref)
53
- // })
54
- // )
55
- // .subscribe(this.panels)
56
31
  }
57
32
  ngOnChanges(changes) {
58
33
  if ("contentOnly" in changes || "positionMode" in changes) {
@@ -64,8 +39,10 @@ export class DockingLayoutComponent extends Destructible {
64
39
  let paddingRight = 0;
65
40
  let paddingBottom = 0;
66
41
  let paddingLeft = 0;
67
- let embeddedZIndex = EMBEDDED_ZINDEX;
68
- let overlayZIndex = OVERLAY_ZINDEX;
42
+ let rigidZIndex = RIGID_ZINDEX;
43
+ let overZIndex = OVER_ZINDEX;
44
+ let backdropZIndex = -1;
45
+ this.#backdropPanel = null;
69
46
  if (this.contentOnly) {
70
47
  // TODO:...
71
48
  }
@@ -78,7 +55,7 @@ export class DockingLayoutComponent extends Destructible {
78
55
  ? panelState.miniSize.value
79
56
  : 0;
80
57
  const isHorizontal = panelState.position.orient === "horizontal";
81
- const isEmbedded = panelState.mode === "embedded";
58
+ const isRigid = panelState.mode === "rigid";
82
59
  let panelTop = null;
83
60
  let panelRight = null;
84
61
  let panelBottom = null;
@@ -87,13 +64,13 @@ export class DockingLayoutComponent extends Destructible {
87
64
  panelLeft = 0;
88
65
  panelRight = 0;
89
66
  if (panelState.position.cells[0].v === "top") {
90
- if (isEmbedded) {
67
+ if (isRigid) {
91
68
  paddingTop = Math.max(paddingTop, panelSize);
92
69
  }
93
70
  panelTop = 0;
94
71
  }
95
72
  else if (panelState.position.cells[0].v === "bottom") {
96
- if (isEmbedded) {
73
+ if (isRigid) {
97
74
  paddingBottom = Math.max(paddingBottom, panelSize);
98
75
  }
99
76
  panelBottom = 0;
@@ -103,37 +80,30 @@ export class DockingLayoutComponent extends Destructible {
103
80
  panelTop = 0;
104
81
  panelBottom = 0;
105
82
  if (panelState.position.cells[0].h === "left") {
106
- if (isEmbedded) {
83
+ if (isRigid) {
107
84
  paddingLeft = Math.max(paddingLeft, panelSize);
108
85
  }
109
86
  panelLeft = 0;
110
87
  }
111
88
  else if (panelState.position.cells[0].h === "right") {
112
- if (isEmbedded) {
89
+ if (isRigid) {
113
90
  paddingRight = Math.max(paddingRight, panelSize);
114
91
  }
115
92
  panelRight = 0;
116
93
  }
117
94
  }
118
- const panelGivenSize = panelState.state === "full"
119
- ? panelState.fullSize
120
- : panelState.state === "mini"
121
- ? panelState.miniSize
122
- : new NumberWithUnit(0, "px");
95
+ let panelZIndex = isRigid ? (rigidZIndex += 2) : (overZIndex += 2);
96
+ if (panelState.state !== "hidden" && entry.panel.backdrop) {
97
+ backdropZIndex = BACKDROP_ZINDEX;
98
+ panelZIndex = backdropZIndex + 1;
99
+ this.#backdropPanel = entry.panel;
100
+ }
123
101
  FastDOM.setStyle(entry.panel.el.nativeElement, {
124
- "z-index": `${isEmbedded ? embeddedZIndex++ : overlayZIndex++}`,
102
+ "z-index": `${panelZIndex}`,
125
103
  "--docking-panel-t": panelTop != null ? `${panelTop}px` : null,
126
104
  "--docking-panel-r": panelRight != null ? `${panelRight}px` : null,
127
105
  "--docking-panel-b": panelBottom != null ? `${panelBottom}px` : null,
128
- "--docking-panel-l": panelLeft != null ? `${panelLeft}px` : null,
129
- "--docking-panel-w": !isHorizontal
130
- ? `${panelGivenSize.unit === "auto" ? "auto" : panelGivenSize}`
131
- : null,
132
- "--docking-panel-h": isHorizontal
133
- ? `${panelGivenSize.unit === "auto" ? "auto" : panelGivenSize}`
134
- : null,
135
- "--docking-panel-real-w": !isHorizontal ? `${panelSize}px` : null,
136
- "--docking-panel-real-h": isHorizontal ? `${panelSize}px` : null
106
+ "--docking-panel-l": panelLeft != null ? `${panelLeft}px` : null
137
107
  });
138
108
  }
139
109
  FastDOM.setStyle(this.#el.nativeElement, {
@@ -142,10 +112,22 @@ export class DockingLayoutComponent extends Destructible {
142
112
  "--docking-layout-bottom": `${paddingBottom}px`,
143
113
  "--docking-layout-left": `${paddingLeft}px`
144
114
  });
115
+ if (this.backdropEl) {
116
+ FastDOM.setAttributes(this.backdropEl.nativeElement, {
117
+ state: backdropZIndex < 0 ? "hidden" : "visible"
118
+ });
119
+ FastDOM.setStyle(this.backdropEl.nativeElement, { "z-index": `${backdropZIndex}` });
120
+ }
121
+ }
122
+ }
123
+ onHideBackdropPanel(event) {
124
+ event.preventDefault();
125
+ if (this.#backdropPanel) {
126
+ this.#backdropPanel.close();
145
127
  }
146
128
  }
147
129
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingLayoutComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
148
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: DockingLayoutComponent, isStandalone: true, selector: "nu-docking", inputs: { contentOnly: "contentOnly", positionMode: "positionMode" }, queries: [{ propertyName: "contentComponent", first: true, predicate: DockingContentComponent, descendants: true }, { propertyName: "dockingPanels", predicate: DockingPanelComponent }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: `
130
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: DockingLayoutComponent, isStandalone: true, selector: "nu-docking", inputs: { contentOnly: "contentOnly" }, queries: [{ propertyName: "contentComponent", first: true, predicate: DockingContentComponent, descendants: true }, { propertyName: "dockingPanels", predicate: DockingPanelComponent }], viewQueries: [{ propertyName: "backdropEl", first: true, predicate: ["backdrop"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: `
149
131
  <ng-content select="nu-docking-panel"></ng-content>
150
132
 
151
133
  @if (!contentComponent) {
@@ -155,11 +137,13 @@ export class DockingLayoutComponent extends Destructible {
155
137
  } @else {
156
138
  <ng-content select="nu-docking-content"></ng-content>
157
139
  }
158
- `, isInline: true, styles: [":host{---docking-layout-top: var(--docking-layout-top, 0px);---docking-layout-right: var(--docking-layout-right, 0px);---docking-layout-bottom: var(--docking-layout-bottom, 0px);---docking-layout-left: var(--docking-layout-left, 0px);---docking-layout-anim-duration: var(--docking-layout-anim-duration, .2s);---docking-layout-anim-ease: var(--docking-layout-anim-ease, ease-out);display:flex;flex-flow:column nowrap;align-items:stretch;position:relative;overflow:hidden;box-sizing:border-box;z-index:0;padding:var(---docking-layout-top) var(---docking-layout-right) var(---docking-layout-bottom) var(---docking-layout-left);transition:padding var(---docking-layout-anim-duration) var(---docking-layout-anim-ease)}\n"], dependencies: [{ kind: "component", type: DockingContentComponent, selector: "nu-docking-content" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
140
+
141
+ <nu-docking-backdrop #backdrop (click)="onHideBackdropPanel($event)" />
142
+ `, isInline: true, styles: [":host{---docking-layout-top: var(--docking-layout-top, 0px);---docking-layout-right: var(--docking-layout-right, 0px);---docking-layout-bottom: var(--docking-layout-bottom, 0px);---docking-layout-left: var(--docking-layout-left, 0px);---docking-layout-anim-duration: var(--docking-layout-anim-duration, .3s);---docking-layout-anim-ease: var(--docking-layout-anim-ease, cubic-bezier(.4, 0, .2, 1));---docking-layout-backdrop-color: var(--docking-layout-backdrop-color, #000);display:flex;flex-flow:column nowrap;align-items:stretch;position:relative;overflow:hidden;box-sizing:border-box;z-index:0;padding:var(---docking-layout-top) var(---docking-layout-right) var(---docking-layout-bottom) var(---docking-layout-left);transition:padding var(---docking-layout-anim-duration) var(---docking-layout-anim-ease)}\n"], dependencies: [{ kind: "component", type: DockingContentComponent, selector: "nu-docking-content", exportAs: ["nuDockingContent"] }, { kind: "component", type: DockingBackdropComponent, selector: "nu-docking-backdrop" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
159
143
  }
160
144
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingLayoutComponent, decorators: [{
161
145
  type: Component,
162
- args: [{ selector: "nu-docking", standalone: true, imports: [DockingContentComponent], template: `
146
+ args: [{ selector: "nu-docking", standalone: true, imports: [DockingContentComponent, DockingBackdropComponent], template: `
163
147
  <ng-content select="nu-docking-panel"></ng-content>
164
148
 
165
149
  @if (!contentComponent) {
@@ -169,16 +153,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
169
153
  } @else {
170
154
  <ng-content select="nu-docking-content"></ng-content>
171
155
  }
172
- `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{---docking-layout-top: var(--docking-layout-top, 0px);---docking-layout-right: var(--docking-layout-right, 0px);---docking-layout-bottom: var(--docking-layout-bottom, 0px);---docking-layout-left: var(--docking-layout-left, 0px);---docking-layout-anim-duration: var(--docking-layout-anim-duration, .2s);---docking-layout-anim-ease: var(--docking-layout-anim-ease, ease-out);display:flex;flex-flow:column nowrap;align-items:stretch;position:relative;overflow:hidden;box-sizing:border-box;z-index:0;padding:var(---docking-layout-top) var(---docking-layout-right) var(---docking-layout-bottom) var(---docking-layout-left);transition:padding var(---docking-layout-anim-duration) var(---docking-layout-anim-ease)}\n"] }]
156
+
157
+ <nu-docking-backdrop #backdrop (click)="onHideBackdropPanel($event)" />
158
+ `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{---docking-layout-top: var(--docking-layout-top, 0px);---docking-layout-right: var(--docking-layout-right, 0px);---docking-layout-bottom: var(--docking-layout-bottom, 0px);---docking-layout-left: var(--docking-layout-left, 0px);---docking-layout-anim-duration: var(--docking-layout-anim-duration, .3s);---docking-layout-anim-ease: var(--docking-layout-anim-ease, cubic-bezier(.4, 0, .2, 1));---docking-layout-backdrop-color: var(--docking-layout-backdrop-color, #000);display:flex;flex-flow:column nowrap;align-items:stretch;position:relative;overflow:hidden;box-sizing:border-box;z-index:0;padding:var(---docking-layout-top) var(---docking-layout-right) var(---docking-layout-bottom) var(---docking-layout-left);transition:padding var(---docking-layout-anim-duration) var(---docking-layout-anim-ease)}\n"] }]
173
159
  }], propDecorators: { contentOnly: [{
174
160
  type: Input
175
- }], positionMode: [{
176
- type: Input
177
161
  }], contentComponent: [{
178
162
  type: ContentChild,
179
163
  args: [DockingContentComponent]
164
+ }], backdropEl: [{
165
+ type: ViewChild,
166
+ args: ["backdrop", { read: ElementRef, static: true }]
180
167
  }], dockingPanels: [{
181
168
  type: ContentChildren,
182
169
  args: [DockingPanelComponent]
183
170
  }] } });
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docking-layout.component.js","sourceRoot":"","sources":["../../../../../packages/layout/src/docking/docking-layout.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    inject,\n    Input,\n    OnChanges,\n    QueryList,\n    SimpleChanges\n} from \"@angular/core\"\n\nimport { combineLatest, map, Observable, shareReplay, startWith, Subject, switchMap } from \"rxjs\"\n\nimport { Destructible, FastDOM, NumberWithUnit } from \"@ngutil/common\"\n\nimport { DockingContentComponent } from \"./docking-content.component\"\nimport { type DockingPanelChanges, DockingPanelComponent } from \"./docking-panel.component\"\n\ntype DockingVerticalPosition = \"top\" | \"middle\" | \"bottom\"\ntype DockingHorizontalPositon = \"left\" | \"center\" | \"right\"\ntype DockingPosition = `${DockingVerticalPosition}:${DockingHorizontalPositon}`\nexport type DockingRange =\n    | DockingVerticalPosition\n    | DockingHorizontalPositon\n    | DockingPosition\n    | `${DockingPosition}-${DockingPosition}`\n\nexport type DockingPositionMode = \"absolute\" | \"fixed\"\n\nconst EMBEDDED_ZINDEX = 20\nconst OVERLAY_ZINDEX = EMBEDDED_ZINDEX * 2\n\ntype PanelsChanges = Array<{ panel: DockingPanelComponent; changes: DockingPanelChanges }>\n\n// interface PanelRefChanges {\n//     ref: PanelRef\n//     changes: DockingPanelChanges\n// }\n\n// class PanelRef {\n//     style: Partial<CSSStyleDeclaration> = {}\n//     readonly changes: Observable<PanelRefChanges>\n//     constructor(public readonly panel: DockingPanelDirective) {\n//         this.changes = panel.changes.pipe(\n//             map(changes => {\n//                 return { ref: this, changes }\n//             })\n//         )\n//     }\n// }\n\n@Component({\n    selector: \"nu-docking\",\n    standalone: true,\n    imports: [DockingContentComponent],\n    template: `\n        <ng-content select=\"nu-docking-panel\"></ng-content>\n\n        @if (!contentComponent) {\n            <nu-docking-content>\n                <ng-content></ng-content>\n            </nu-docking-content>\n        } @else {\n            <ng-content select=\"nu-docking-content\"></ng-content>\n        }\n    `,\n    styleUrl: \"./docking-layout.component.scss\",\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DockingLayoutComponent extends Destructible implements AfterViewInit, OnChanges {\n    readonly #el = inject(ElementRef<HTMLElement>)\n\n    @Input() contentOnly = false\n    @Input() positionMode: DockingPositionMode = \"absolute\"\n\n    @ContentChild(DockingContentComponent) contentComponent?: DockingContentComponent\n    @ContentChildren(DockingPanelComponent) dockingPanels!: QueryList<DockingPanelComponent>\n\n    // readonly panels = new BehaviorSubject<PanelRef[]>([])\n    readonly panels!: Observable<Array<DockingPanelComponent>>\n\n    #reflow = new Subject<void>()\n\n    ngAfterViewInit(): void {\n        // eslint-disable-next-line prettier/prettier\n        (this as { panels: Observable<Array<DockingPanelComponent>> }).panels = this.dockingPanels.changes.pipe(\n            startWith(null),\n            map(() => this.dockingPanels.toArray()),\n            shareReplay(1)\n        )\n\n        // this.panels.subscribe(panels => console.log({ panels }))\n\n        this.d\n            .sub(combineLatest({ panels: this.panels, reflow: this.#reflow.pipe(startWith(null)) }))\n            .pipe(\n                switchMap(({ panels }) =>\n                    combineLatest(\n                        panels.map(panel =>\n                            panel.changes.pipe(\n                                map(changes => {\n                                    return { panel, changes }\n                                })\n                            )\n                        )\n                    )\n                )\n            )\n            .subscribe(this.#layout.bind(this))\n\n        // this.d\n        //     .sub(merge(this.dockingPanels.changes, this.#reflow))\n        //     .pipe(\n        //         startWith(null),\n        //         map(() => this.dockingPanels.map(panel => new PanelRef(panel))),\n        //         switchMap(refs => combineLatest(refs.map(ref => ref.changes))),\n        //         map(changes => {\n        //             this.#layout(changes)\n        //             return changes.map(c => c.ref)\n        //         })\n        //     )\n        //     .subscribe(this.panels)\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (\"contentOnly\" in changes || \"positionMode\" in changes) {\n            this.#reflow.next()\n        }\n    }\n\n    #layout(entries: PanelsChanges) {\n        let paddingTop = 0\n        let paddingRight = 0\n        let paddingBottom = 0\n        let paddingLeft = 0\n        let embeddedZIndex = EMBEDDED_ZINDEX\n        let overlayZIndex = OVERLAY_ZINDEX\n\n        if (this.contentOnly) {\n            // TODO:...\n        } else {\n            for (const entry of entries) {\n                const panelState = entry.changes\n                const panelSize =\n                    panelState.state === \"full\"\n                        ? panelState.fullSize.value\n                        : panelState.state === \"mini\"\n                          ? panelState.miniSize.value\n                          : 0\n\n                const isHorizontal = panelState.position.orient === \"horizontal\"\n                const isEmbedded = panelState.mode === \"embedded\"\n\n                let panelTop = null\n                let panelRight = null\n                let panelBottom = null\n                let panelLeft = null\n\n                if (isHorizontal) {\n                    panelLeft = 0\n                    panelRight = 0\n                    if (panelState.position.cells[0].v === \"top\") {\n                        if (isEmbedded) {\n                            paddingTop = Math.max(paddingTop, panelSize)\n                        }\n                        panelTop = 0\n                    } else if (panelState.position.cells[0].v === \"bottom\") {\n                        if (isEmbedded) {\n                            paddingBottom = Math.max(paddingBottom, panelSize)\n                        }\n                        panelBottom = 0\n                    }\n                } else {\n                    panelTop = 0\n                    panelBottom = 0\n\n                    if (panelState.position.cells[0].h === \"left\") {\n                        if (isEmbedded) {\n                            paddingLeft = Math.max(paddingLeft, panelSize)\n                        }\n                        panelLeft = 0\n                    } else if (panelState.position.cells[0].h === \"right\") {\n                        if (isEmbedded) {\n                            paddingRight = Math.max(paddingRight, panelSize)\n                        }\n                        panelRight = 0\n                    }\n                }\n\n                const panelGivenSize =\n                    panelState.state === \"full\"\n                        ? panelState.fullSize\n                        : panelState.state === \"mini\"\n                          ? panelState.miniSize\n                          : new NumberWithUnit(0, \"px\")\n\n                FastDOM.setStyle(entry.panel.el.nativeElement, {\n                    \"z-index\": `${isEmbedded ? embeddedZIndex++ : overlayZIndex++}`,\n                    \"--docking-panel-t\": panelTop != null ? `${panelTop}px` : null,\n                    \"--docking-panel-r\": panelRight != null ? `${panelRight}px` : null,\n                    \"--docking-panel-b\": panelBottom != null ? `${panelBottom}px` : null,\n                    \"--docking-panel-l\": panelLeft != null ? `${panelLeft}px` : null,\n                    \"--docking-panel-w\": !isHorizontal\n                        ? `${panelGivenSize.unit === \"auto\" ? \"auto\" : panelGivenSize}`\n                        : null,\n                    \"--docking-panel-h\": isHorizontal\n                        ? `${panelGivenSize.unit === \"auto\" ? \"auto\" : panelGivenSize}`\n                        : null,\n                    \"--docking-panel-real-w\": !isHorizontal ? `${panelSize}px` : null,\n                    \"--docking-panel-real-h\": isHorizontal ? `${panelSize}px` : null\n                })\n            }\n\n            FastDOM.setStyle(this.#el.nativeElement, {\n                \"--docking-layout-top\": `${paddingTop}px`,\n                \"--docking-layout-right\": `${paddingRight}px`,\n                \"--docking-layout-bottom\": `${paddingBottom}px`,\n                \"--docking-layout-left\": `${paddingLeft}px`\n            })\n        }\n    }\n}\n"]}
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docking-layout.component.js","sourceRoot":"","sources":["../../../../../packages/layout/src/docking/docking-layout.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    inject,\n    Input,\n    OnChanges,\n    QueryList,\n    SimpleChanges,\n    ViewChild\n} from \"@angular/core\"\n\nimport { combineLatest, map, Observable, shareReplay, startWith, Subject, switchMap } from \"rxjs\"\n\nimport { Destructible, FastDOM } from \"@ngutil/common\"\n\nimport { DockingBackdropComponent } from \"./docking-backdrop.component\"\nimport { DockingContentComponent } from \"./docking-content.component\"\nimport { type DockingPanelChanges, DockingPanelComponent } from \"./docking-panel.component\"\n\ntype DockingVerticalPosition = \"top\" | \"middle\" | \"bottom\"\ntype DockingHorizontalPositon = \"left\" | \"center\" | \"right\"\ntype DockingPosition = `${DockingVerticalPosition}:${DockingHorizontalPositon}`\nexport type DockingRange =\n    | DockingVerticalPosition\n    | DockingHorizontalPositon\n    | DockingPosition\n    | `${DockingPosition}-${DockingPosition}`\n\nconst RIGID_ZINDEX = 100\nconst OVER_ZINDEX = RIGID_ZINDEX * 2\nconst BACKDROP_ZINDEX = 10000\n\ntype PanelsChanges = Array<{ panel: DockingPanelComponent; changes: DockingPanelChanges }>\n\n@Component({\n    selector: \"nu-docking\",\n    standalone: true,\n    imports: [DockingContentComponent, DockingBackdropComponent],\n    template: `\n        <ng-content select=\"nu-docking-panel\"></ng-content>\n\n        @if (!contentComponent) {\n            <nu-docking-content>\n                <ng-content></ng-content>\n            </nu-docking-content>\n        } @else {\n            <ng-content select=\"nu-docking-content\"></ng-content>\n        }\n\n        <nu-docking-backdrop #backdrop (click)=\"onHideBackdropPanel($event)\" />\n    `,\n    styleUrl: \"./docking-layout.component.scss\",\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DockingLayoutComponent extends Destructible implements AfterViewInit, OnChanges {\n    readonly #el = inject(ElementRef<HTMLElement>)\n\n    @Input() contentOnly = false\n\n    @ContentChild(DockingContentComponent) contentComponent?: DockingContentComponent\n    @ViewChild(\"backdrop\", { read: ElementRef, static: true })\n    backdropEl?: ElementRef<HTMLElement>\n    @ContentChildren(DockingPanelComponent) dockingPanels!: QueryList<DockingPanelComponent>\n\n    // readonly panels = new BehaviorSubject<PanelRef[]>([])\n    readonly panels!: Observable<Array<DockingPanelComponent>>\n\n    #reflow = new Subject<void>()\n    #backdropPanel: DockingPanelComponent | null = null\n\n    ngAfterViewInit(): void {\n        // eslint-disable-next-line prettier/prettier\n        (this as { panels: Observable<Array<DockingPanelComponent>> }).panels = this.dockingPanels.changes.pipe(\n            startWith(null),\n            map(() => this.dockingPanels.toArray()),\n            shareReplay(1)\n        )\n\n        this.d\n            .sub(combineLatest({ panels: this.panels, reflow: this.#reflow.pipe(startWith(null)) }))\n            .pipe(\n                switchMap(({ panels }) =>\n                    combineLatest(\n                        panels.map(panel =>\n                            panel.changes.pipe(\n                                map(changes => {\n                                    return { panel, changes }\n                                })\n                            )\n                        )\n                    )\n                )\n            )\n            .subscribe(this.#layout.bind(this))\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (\"contentOnly\" in changes || \"positionMode\" in changes) {\n            this.#reflow.next()\n        }\n    }\n\n    #layout(entries: PanelsChanges) {\n        let paddingTop = 0\n        let paddingRight = 0\n        let paddingBottom = 0\n        let paddingLeft = 0\n        let rigidZIndex = RIGID_ZINDEX\n        let overZIndex = OVER_ZINDEX\n        let backdropZIndex = -1\n\n        this.#backdropPanel = null\n\n        if (this.contentOnly) {\n            // TODO:...\n        } else {\n            for (const entry of entries) {\n                const panelState = entry.changes\n                const panelSize =\n                    panelState.state === \"full\"\n                        ? panelState.fullSize.value\n                        : panelState.state === \"mini\"\n                          ? panelState.miniSize.value\n                          : 0\n\n                const isHorizontal = panelState.position.orient === \"horizontal\"\n                const isRigid = panelState.mode === \"rigid\"\n\n                let panelTop = null\n                let panelRight = null\n                let panelBottom = null\n                let panelLeft = null\n\n                if (isHorizontal) {\n                    panelLeft = 0\n                    panelRight = 0\n                    if (panelState.position.cells[0].v === \"top\") {\n                        if (isRigid) {\n                            paddingTop = Math.max(paddingTop, panelSize)\n                        }\n                        panelTop = 0\n                    } else if (panelState.position.cells[0].v === \"bottom\") {\n                        if (isRigid) {\n                            paddingBottom = Math.max(paddingBottom, panelSize)\n                        }\n                        panelBottom = 0\n                    }\n                } else {\n                    panelTop = 0\n                    panelBottom = 0\n\n                    if (panelState.position.cells[0].h === \"left\") {\n                        if (isRigid) {\n                            paddingLeft = Math.max(paddingLeft, panelSize)\n                        }\n                        panelLeft = 0\n                    } else if (panelState.position.cells[0].h === \"right\") {\n                        if (isRigid) {\n                            paddingRight = Math.max(paddingRight, panelSize)\n                        }\n                        panelRight = 0\n                    }\n                }\n\n                let panelZIndex = isRigid ? (rigidZIndex += 2) : (overZIndex += 2)\n                if (panelState.state !== \"hidden\" && entry.panel.backdrop) {\n                    backdropZIndex = BACKDROP_ZINDEX\n                    panelZIndex = backdropZIndex + 1\n                    this.#backdropPanel = entry.panel\n                }\n\n                FastDOM.setStyle(entry.panel.el.nativeElement, {\n                    \"z-index\": `${panelZIndex}`,\n                    \"--docking-panel-t\": panelTop != null ? `${panelTop}px` : null,\n                    \"--docking-panel-r\": panelRight != null ? `${panelRight}px` : null,\n                    \"--docking-panel-b\": panelBottom != null ? `${panelBottom}px` : null,\n                    \"--docking-panel-l\": panelLeft != null ? `${panelLeft}px` : null\n                })\n            }\n\n            FastDOM.setStyle(this.#el.nativeElement, {\n                \"--docking-layout-top\": `${paddingTop}px`,\n                \"--docking-layout-right\": `${paddingRight}px`,\n                \"--docking-layout-bottom\": `${paddingBottom}px`,\n                \"--docking-layout-left\": `${paddingLeft}px`\n            })\n\n            if (this.backdropEl) {\n                FastDOM.setAttributes(this.backdropEl.nativeElement, {\n                    state: backdropZIndex < 0 ? \"hidden\" : \"visible\"\n                })\n                FastDOM.setStyle(this.backdropEl.nativeElement, { \"z-index\": `${backdropZIndex}` })\n            }\n        }\n    }\n\n    onHideBackdropPanel(event: Event) {\n        event.preventDefault()\n        if (this.#backdropPanel) {\n            this.#backdropPanel.close()\n        }\n    }\n}\n"]}