@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.
- package/docking/docking-backdrop.component.d.ts +6 -0
- package/docking/docking-content.component.d.ts +1 -1
- package/docking/docking-layout.component.d.ts +4 -4
- package/docking/docking-panel.component.d.ts +13 -5
- package/esm2022/docking/docking-backdrop.component.mjs +17 -0
- package/esm2022/docking/docking-content.component.mjs +3 -3
- package/esm2022/docking/docking-layout.component.mjs +49 -62
- package/esm2022/docking/docking-panel.component.mjs +82 -14
- package/esm2022/index.mjs +1 -2
- package/esm2022/l9/state.mjs +1 -9
- package/fesm2022/ngutil-layout.mjs +144 -189
- package/fesm2022/ngutil-layout.mjs.map +1 -1
- package/index.d.ts +0 -1
- package/l9/state.d.ts +1 -3
- package/package.json +4 -2
- package/esm2022/util/dimension-watcher.mjs +0 -84
- package/esm2022/util/dimension.mjs +0 -2
- package/esm2022/util/index.mjs +0 -3
- package/esm2022/util/media-watcher.mjs +0 -29
- package/esm2022/util/rect.mjs +0 -2
- package/util/dimension-watcher.d.ts +0 -4
- package/util/dimension.d.ts +0 -5
- package/util/index.d.ts +0 -4
- package/util/media-watcher.d.ts +0 -5
- package/util/rect.d.ts +0 -5
|
@@ -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",
|
|
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; };
|
|
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" | "
|
|
7
|
-
export type DockingPanelMode = "
|
|
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
|
|
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
|
|
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,
|
|
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
|
|
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
|
|
8
|
-
const
|
|
9
|
-
|
|
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
|
|
68
|
-
let
|
|
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
|
|
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 (
|
|
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 (
|
|
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 (
|
|
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 (
|
|
89
|
+
if (isRigid) {
|
|
113
90
|
paddingRight = Math.max(paddingRight, panelSize);
|
|
114
91
|
}
|
|
115
92
|
panelRight = 0;
|
|
116
93
|
}
|
|
117
94
|
}
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
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": `${
|
|
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"
|
|
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
|
-
|
|
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
|
-
|
|
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"]}
|