@ngutil/layout 0.0.3-dev.0 → 0.0.3-dev.10
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-content.component.d.ts +5 -0
- package/docking/docking-layout.component.d.ts +22 -0
- package/docking/docking-panel.component.d.ts +40 -0
- package/docking/index.d.ts +13 -0
- package/esm2022/docking/docking-content.component.mjs +11 -0
- package/esm2022/docking/docking-layout.component.mjs +140 -0
- package/esm2022/docking/docking-panel.component.mjs +179 -0
- package/esm2022/docking/index.mjs +20 -0
- package/esm2022/index.mjs +5 -0
- package/esm2022/l9/index.mjs +3 -0
- package/esm2022/l9/range.mjs +109 -0
- package/esm2022/l9/state.mjs +29 -0
- package/esm2022/ngutil-layout.mjs +5 -0
- package/esm2022/services/slots.service.mjs +240 -0
- package/esm2022/util/dimension-watcher.mjs +85 -0
- package/esm2022/util/dimension.mjs +2 -0
- package/esm2022/util/index.mjs +3 -0
- package/esm2022/util/media-watcher.mjs +29 -0
- package/esm2022/util/rect.mjs +2 -0
- package/fesm2022/ngutil-layout.mjs +822 -0
- package/fesm2022/ngutil-layout.mjs.map +1 -0
- package/index.d.ts +4 -0
- package/l9/index.d.ts +2 -0
- package/l9/range.d.ts +28 -0
- package/l9/state.d.ts +14 -0
- package/package.json +19 -5
- package/services/slots.service.d.ts +69 -0
- package/util/dimension-watcher.d.ts +4 -0
- package/util/dimension.d.ts +5 -0
- package/util/index.d.ts +4 -0
- package/util/media-watcher.d.ts +5 -0
- package/util/rect.d.ts +5 -0
- package/.eslintrc.json +0 -25
- package/.storybook/main.ts +0 -16
- package/.storybook/preview.ts +0 -0
- package/.storybook/tsconfig.json +0 -16
- package/jest.config.ts +0 -22
- package/ng-package.json +0 -7
- package/project.json +0 -73
- package/src/index.ts +0 -1
- package/src/lib/layout/layout.component.scss +0 -0
- package/src/lib/layout/layout.component.spec.ts +0 -22
- package/src/lib/layout/layout.component.stories.ts +0 -24
- package/src/lib/layout/layout.component.ts +0 -11
- package/src/test-setup.ts +0 -9
- package/tsconfig.json +0 -32
- package/tsconfig.lib.json +0 -19
- package/tsconfig.lib.prod.json +0 -9
- package/tsconfig.spec.json +0 -11
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class DockingContentComponent {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DockingContentComponent, never>;
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DockingContentComponent, "nu-docking-content", ["nuDockingContent"], {}, {}, never, ["*"], true, never>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { AfterViewInit, OnChanges, QueryList, SimpleChanges } from "@angular/core";
|
|
2
|
+
import { Observable } from "rxjs";
|
|
3
|
+
import { Destructible } from "@ngutil/common";
|
|
4
|
+
import { DockingContentComponent } from "./docking-content.component";
|
|
5
|
+
import { DockingPanelComponent } from "./docking-panel.component";
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
type DockingVerticalPosition = "top" | "middle" | "bottom";
|
|
8
|
+
type DockingHorizontalPositon = "left" | "center" | "right";
|
|
9
|
+
type DockingPosition = `${DockingVerticalPosition}:${DockingHorizontalPositon}`;
|
|
10
|
+
export type DockingRange = DockingVerticalPosition | DockingHorizontalPositon | DockingPosition | `${DockingPosition}-${DockingPosition}`;
|
|
11
|
+
export declare class DockingLayoutComponent extends Destructible implements AfterViewInit, OnChanges {
|
|
12
|
+
#private;
|
|
13
|
+
contentOnly: boolean;
|
|
14
|
+
contentComponent?: DockingContentComponent;
|
|
15
|
+
dockingPanels: QueryList<DockingPanelComponent>;
|
|
16
|
+
readonly panels: Observable<Array<DockingPanelComponent>>;
|
|
17
|
+
ngAfterViewInit(): void;
|
|
18
|
+
ngOnChanges(changes: SimpleChanges): void;
|
|
19
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DockingLayoutComponent, never>;
|
|
20
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DockingLayoutComponent, "nu-docking", never, { "contentOnly": { "alias": "contentOnly"; "required": false; }; }, {}, ["contentComponent", "dockingPanels"], ["nu-docking-panel", "*", "nu-docking-content"], true, never>;
|
|
21
|
+
}
|
|
22
|
+
export {};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { ElementRef } from "@angular/core";
|
|
2
|
+
import { BehaviorSubject, Observable } from "rxjs";
|
|
3
|
+
import { BooleanInput, Destructible, NumberWithUnit, NumberWithUnitInput } from "@ngutil/common";
|
|
4
|
+
import { L9Range, L9RangeName } from "../l9/range";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export type DockingPanelState = "full" | "mini" | "invisible";
|
|
7
|
+
export type DockingPanelMode = "over" | "push" | "rigid";
|
|
8
|
+
export declare class DockingPanelComponent extends Destructible {
|
|
9
|
+
#private;
|
|
10
|
+
readonly el: ElementRef<any>;
|
|
11
|
+
set positionInput(val: L9Range | L9RangeName);
|
|
12
|
+
readonly position: BehaviorSubject<L9Range>;
|
|
13
|
+
set stateInput(val: DockingPanelState);
|
|
14
|
+
readonly state: BehaviorSubject<DockingPanelState>;
|
|
15
|
+
set modeInput(val: DockingPanelMode);
|
|
16
|
+
readonly mode: BehaviorSubject<DockingPanelMode>;
|
|
17
|
+
set fullSizeInput(val: NumberWithUnitInput);
|
|
18
|
+
set miniSizeInput(val: NumberWithUnitInput);
|
|
19
|
+
set minimizable(val: BooleanInput);
|
|
20
|
+
get minimizable(): boolean;
|
|
21
|
+
readonly fullSize: Observable<NumberWithUnit>;
|
|
22
|
+
readonly miniSize: Observable<NumberWithUnit>;
|
|
23
|
+
readonly changes: Observable<{
|
|
24
|
+
position: L9Range;
|
|
25
|
+
state: DockingPanelState;
|
|
26
|
+
mode: DockingPanelMode;
|
|
27
|
+
fullSize: NumberWithUnit;
|
|
28
|
+
miniSize: NumberWithUnit;
|
|
29
|
+
contentSize: import("../util").Dimension;
|
|
30
|
+
}>;
|
|
31
|
+
constructor();
|
|
32
|
+
open(): void;
|
|
33
|
+
close(): void;
|
|
34
|
+
minimize(): void;
|
|
35
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DockingPanelComponent, never>;
|
|
36
|
+
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>;
|
|
37
|
+
}
|
|
38
|
+
type ChangesObservable = typeof DockingPanelComponent.prototype.changes;
|
|
39
|
+
export type DockingPanelChanges = ChangesObservable extends Observable<infer T> ? T : never;
|
|
40
|
+
export {};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { DockingContentComponent } from "./docking-content.component";
|
|
2
|
+
import { DockingLayoutComponent } from "./docking-layout.component";
|
|
3
|
+
import { DockingPanelComponent } from "./docking-panel.component";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./docking-layout.component";
|
|
6
|
+
import * as i2 from "./docking-panel.component";
|
|
7
|
+
import * as i3 from "./docking-content.component";
|
|
8
|
+
export { DockingLayoutComponent, DockingPanelComponent, DockingContentComponent };
|
|
9
|
+
export declare class NuDockingLayout {
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NuDockingLayout, never>;
|
|
11
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<NuDockingLayout, never, [typeof i1.DockingLayoutComponent, typeof i2.DockingPanelComponent, typeof i3.DockingContentComponent], [typeof i1.DockingLayoutComponent, typeof i2.DockingPanelComponent, typeof i3.DockingContentComponent]>;
|
|
12
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<NuDockingLayout>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Component } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class DockingContentComponent {
|
|
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", 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;overflow:auto}\n"] }); }
|
|
6
|
+
}
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingContentComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
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;overflow:auto}\n"] }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xheW91dC9zcmMvZG9ja2luZy9kb2NraW5nLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBU3pDLE1BQU0sT0FBTyx1QkFBdUI7OEdBQXZCLHVCQUF1QjtrR0FBdkIsdUJBQXVCLDhHQUZ0QiwyQkFBMkI7OzJGQUU1Qix1QkFBdUI7a0JBUG5DLFNBQVM7aUNBQ00sSUFBSSxZQUNOLG9CQUFvQixZQUNwQixrQkFBa0IsWUFFbEIsMkJBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiBcIm51LWRvY2tpbmctY29udGVudFwiLFxuICAgIGV4cG9ydEFzOiBcIm51RG9ja2luZ0NvbnRlbnRcIixcbiAgICBzdHlsZVVybDogXCIuL2RvY2tpbmctY29udGVudC5jb21wb25lbnQuc2Nzc1wiLFxuICAgIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PmBcbn0pXG5leHBvcnQgY2xhc3MgRG9ja2luZ0NvbnRlbnRDb21wb25lbnQge31cbiJdfQ==
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, ElementRef, inject, Input, QueryList } from "@angular/core";
|
|
2
|
+
import { combineLatest, map, shareReplay, startWith, Subject, switchMap } from "rxjs";
|
|
3
|
+
import { Destructible, FastDOM } from "@ngutil/common";
|
|
4
|
+
import { DockingContentComponent } from "./docking-content.component";
|
|
5
|
+
import { DockingPanelComponent } from "./docking-panel.component";
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
const RIGID_ZINDEX = 20;
|
|
8
|
+
const OVER_ZINDEX = RIGID_ZINDEX * 2;
|
|
9
|
+
export class DockingLayoutComponent extends Destructible {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
this.#el = inject((ElementRef));
|
|
13
|
+
this.contentOnly = false;
|
|
14
|
+
this.#reflow = new Subject();
|
|
15
|
+
}
|
|
16
|
+
#el;
|
|
17
|
+
#reflow;
|
|
18
|
+
ngAfterViewInit() {
|
|
19
|
+
// eslint-disable-next-line prettier/prettier
|
|
20
|
+
this.panels = this.dockingPanels.changes.pipe(startWith(null), map(() => this.dockingPanels.toArray()), shareReplay(1));
|
|
21
|
+
this.d
|
|
22
|
+
.sub(combineLatest({ panels: this.panels, reflow: this.#reflow.pipe(startWith(null)) }))
|
|
23
|
+
.pipe(switchMap(({ panels }) => combineLatest(panels.map(panel => panel.changes.pipe(map(changes => {
|
|
24
|
+
return { panel, changes };
|
|
25
|
+
}))))))
|
|
26
|
+
.subscribe(this.#layout.bind(this));
|
|
27
|
+
}
|
|
28
|
+
ngOnChanges(changes) {
|
|
29
|
+
if ("contentOnly" in changes || "positionMode" in changes) {
|
|
30
|
+
this.#reflow.next();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
#layout(entries) {
|
|
34
|
+
let paddingTop = 0;
|
|
35
|
+
let paddingRight = 0;
|
|
36
|
+
let paddingBottom = 0;
|
|
37
|
+
let paddingLeft = 0;
|
|
38
|
+
let rigidZIndex = RIGID_ZINDEX;
|
|
39
|
+
let overZIndex = OVER_ZINDEX;
|
|
40
|
+
if (this.contentOnly) {
|
|
41
|
+
// TODO:...
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
for (const entry of entries) {
|
|
45
|
+
const panelState = entry.changes;
|
|
46
|
+
const panelSize = panelState.state === "full"
|
|
47
|
+
? panelState.fullSize.value
|
|
48
|
+
: panelState.state === "mini"
|
|
49
|
+
? panelState.miniSize.value
|
|
50
|
+
: 0;
|
|
51
|
+
const isHorizontal = panelState.position.orient === "horizontal";
|
|
52
|
+
const isRigid = panelState.mode === "rigid";
|
|
53
|
+
let panelTop = null;
|
|
54
|
+
let panelRight = null;
|
|
55
|
+
let panelBottom = null;
|
|
56
|
+
let panelLeft = null;
|
|
57
|
+
if (isHorizontal) {
|
|
58
|
+
panelLeft = 0;
|
|
59
|
+
panelRight = 0;
|
|
60
|
+
if (panelState.position.cells[0].v === "top") {
|
|
61
|
+
if (isRigid) {
|
|
62
|
+
paddingTop = Math.max(paddingTop, panelSize);
|
|
63
|
+
}
|
|
64
|
+
panelTop = 0;
|
|
65
|
+
}
|
|
66
|
+
else if (panelState.position.cells[0].v === "bottom") {
|
|
67
|
+
if (isRigid) {
|
|
68
|
+
paddingBottom = Math.max(paddingBottom, panelSize);
|
|
69
|
+
}
|
|
70
|
+
panelBottom = 0;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
panelTop = 0;
|
|
75
|
+
panelBottom = 0;
|
|
76
|
+
if (panelState.position.cells[0].h === "left") {
|
|
77
|
+
if (isRigid) {
|
|
78
|
+
paddingLeft = Math.max(paddingLeft, panelSize);
|
|
79
|
+
}
|
|
80
|
+
panelLeft = 0;
|
|
81
|
+
}
|
|
82
|
+
else if (panelState.position.cells[0].h === "right") {
|
|
83
|
+
if (isRigid) {
|
|
84
|
+
paddingRight = Math.max(paddingRight, panelSize);
|
|
85
|
+
}
|
|
86
|
+
panelRight = 0;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
FastDOM.setStyle(entry.panel.el.nativeElement, {
|
|
90
|
+
"z-index": `${isRigid ? rigidZIndex++ : overZIndex++}`,
|
|
91
|
+
"--docking-panel-t": panelTop != null ? `${panelTop}px` : null,
|
|
92
|
+
"--docking-panel-r": panelRight != null ? `${panelRight}px` : null,
|
|
93
|
+
"--docking-panel-b": panelBottom != null ? `${panelBottom}px` : null,
|
|
94
|
+
"--docking-panel-l": panelLeft != null ? `${panelLeft}px` : null
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
FastDOM.setStyle(this.#el.nativeElement, {
|
|
98
|
+
"--docking-layout-top": `${paddingTop}px`,
|
|
99
|
+
"--docking-layout-right": `${paddingRight}px`,
|
|
100
|
+
"--docking-layout-bottom": `${paddingBottom}px`,
|
|
101
|
+
"--docking-layout-left": `${paddingLeft}px`
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingLayoutComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
106
|
+
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 }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: `
|
|
107
|
+
<ng-content select="nu-docking-panel"></ng-content>
|
|
108
|
+
|
|
109
|
+
@if (!contentComponent) {
|
|
110
|
+
<nu-docking-content>
|
|
111
|
+
<ng-content></ng-content>
|
|
112
|
+
</nu-docking-content>
|
|
113
|
+
} @else {
|
|
114
|
+
<ng-content select="nu-docking-content"></ng-content>
|
|
115
|
+
}
|
|
116
|
+
`, 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", exportAs: ["nuDockingContent"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
117
|
+
}
|
|
118
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingLayoutComponent, decorators: [{
|
|
119
|
+
type: Component,
|
|
120
|
+
args: [{ selector: "nu-docking", standalone: true, imports: [DockingContentComponent], template: `
|
|
121
|
+
<ng-content select="nu-docking-panel"></ng-content>
|
|
122
|
+
|
|
123
|
+
@if (!contentComponent) {
|
|
124
|
+
<nu-docking-content>
|
|
125
|
+
<ng-content></ng-content>
|
|
126
|
+
</nu-docking-content>
|
|
127
|
+
} @else {
|
|
128
|
+
<ng-content select="nu-docking-content"></ng-content>
|
|
129
|
+
}
|
|
130
|
+
`, 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"] }]
|
|
131
|
+
}], propDecorators: { contentOnly: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], contentComponent: [{
|
|
134
|
+
type: ContentChild,
|
|
135
|
+
args: [DockingContentComponent]
|
|
136
|
+
}], dockingPanels: [{
|
|
137
|
+
type: ContentChildren,
|
|
138
|
+
args: [DockingPanelComponent]
|
|
139
|
+
}] } });
|
|
140
|
+
//# 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 } 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\nconst RIGID_ZINDEX = 20\nconst OVER_ZINDEX = RIGID_ZINDEX * 2\n\ntype PanelsChanges = Array<{ panel: DockingPanelComponent; changes: DockingPanelChanges }>\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\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.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\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                FastDOM.setStyle(entry.panel.el.nativeElement, {\n                    \"z-index\": `${isRigid ? rigidZIndex++ : overZIndex++}`,\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    }\n}\n"]}
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
import { Component, ElementRef, inject, Input, Output } from "@angular/core";
|
|
2
|
+
import { BehaviorSubject, combineLatest, map, of, shareReplay, switchMap } from "rxjs";
|
|
3
|
+
import { coerceBoolAttr, Destructible, FastDOM, NumberWithUnit } from "@ngutil/common";
|
|
4
|
+
import { L9Range } from "../l9/range";
|
|
5
|
+
import { watchDimension } from "../util";
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
const DEFAULT_POSITION = L9Range.coerce("left");
|
|
8
|
+
const INVISIBLE_SIZE = new NumberWithUnit(0, "px");
|
|
9
|
+
const AUTO_SIZE = NumberWithUnit.coerce("auto");
|
|
10
|
+
export class DockingPanelComponent extends Destructible {
|
|
11
|
+
set positionInput(val) {
|
|
12
|
+
const coerced = L9Range.coerce(val);
|
|
13
|
+
if (coerced.orient === "rect") {
|
|
14
|
+
throw new Error(`Invalid position value: ${val}`);
|
|
15
|
+
}
|
|
16
|
+
if (!this.position.value.isEq(coerced)) {
|
|
17
|
+
this.position.next(coerced);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
set stateInput(val) {
|
|
21
|
+
if (this.state.value !== val) {
|
|
22
|
+
this.state.next(val);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
set modeInput(val) {
|
|
26
|
+
if (this.mode.value !== val) {
|
|
27
|
+
this.mode.next(val);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
set fullSizeInput(val) {
|
|
31
|
+
const coerced = NumberWithUnit.coerce(val, "px");
|
|
32
|
+
if (this.#fullSize.value !== coerced) {
|
|
33
|
+
this.#fullSize.next(coerced);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
#fullSize;
|
|
37
|
+
set miniSizeInput(val) {
|
|
38
|
+
const coerced = NumberWithUnit.coerce(val, "px");
|
|
39
|
+
if (this.#miniSize.value !== coerced) {
|
|
40
|
+
this.#miniSize.next(coerced);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
#miniSize;
|
|
44
|
+
set minimizable(val) {
|
|
45
|
+
this.#minimizable = coerceBoolAttr(val);
|
|
46
|
+
this.#minimizableAuto = false;
|
|
47
|
+
}
|
|
48
|
+
get minimizable() {
|
|
49
|
+
return this.#minimizable;
|
|
50
|
+
}
|
|
51
|
+
#minimizable;
|
|
52
|
+
#minimizableAuto;
|
|
53
|
+
#contentSize;
|
|
54
|
+
#autoSize;
|
|
55
|
+
constructor() {
|
|
56
|
+
super();
|
|
57
|
+
this.el = inject((ElementRef));
|
|
58
|
+
this.position = new BehaviorSubject(DEFAULT_POSITION);
|
|
59
|
+
this.state = new BehaviorSubject("invisible");
|
|
60
|
+
this.mode = new BehaviorSubject("rigid");
|
|
61
|
+
this.#fullSize = new BehaviorSubject(AUTO_SIZE);
|
|
62
|
+
this.#miniSize = new BehaviorSubject(INVISIBLE_SIZE);
|
|
63
|
+
this.#minimizable = false;
|
|
64
|
+
this.#minimizableAuto = true;
|
|
65
|
+
this.#contentSize = watchDimension(this.el.nativeElement, "scroll-box").pipe(shareReplay(1));
|
|
66
|
+
this.#autoSize = combineLatest({
|
|
67
|
+
dim: this.#contentSize,
|
|
68
|
+
pos: this.position
|
|
69
|
+
}).pipe(map(({ dim, pos }) => {
|
|
70
|
+
if (pos.orient === "horizontal") {
|
|
71
|
+
return dim.height;
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
return dim.width;
|
|
75
|
+
}
|
|
76
|
+
}), shareReplay(1));
|
|
77
|
+
this.fullSize = this.#fullSize.pipe(switchMap(size => {
|
|
78
|
+
if (size.unit === "auto") {
|
|
79
|
+
return this.#autoSize;
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
return of(size);
|
|
83
|
+
}
|
|
84
|
+
}), shareReplay(1));
|
|
85
|
+
this.miniSize = this.#miniSize.pipe(switchMap(size => {
|
|
86
|
+
if (size.unit === "auto") {
|
|
87
|
+
return this.#autoSize;
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
return of(size);
|
|
91
|
+
}
|
|
92
|
+
}), shareReplay(1));
|
|
93
|
+
this.changes = combineLatest({
|
|
94
|
+
position: this.position,
|
|
95
|
+
state: this.state,
|
|
96
|
+
mode: this.mode,
|
|
97
|
+
fullSize: this.fullSize,
|
|
98
|
+
miniSize: this.miniSize,
|
|
99
|
+
contentSize: this.#contentSize
|
|
100
|
+
});
|
|
101
|
+
this.d.sub(this.changes).subscribe(changes => {
|
|
102
|
+
if (this.#minimizableAuto) {
|
|
103
|
+
this.#minimizable = this.#miniSize.value.value !== 0;
|
|
104
|
+
}
|
|
105
|
+
FastDOM.setAttributes(this.el.nativeElement, {
|
|
106
|
+
state: changes.state,
|
|
107
|
+
orient: changes.position.orient,
|
|
108
|
+
mode: changes.mode,
|
|
109
|
+
side: changes.position.orient === "horizontal" ? changes.position.cells[0].v : changes.position.cells[0].h
|
|
110
|
+
});
|
|
111
|
+
const isHorizontal = changes.position.orient === "horizontal";
|
|
112
|
+
let w = null;
|
|
113
|
+
let h = null;
|
|
114
|
+
// TODO: when change state from mini -> invisible, currently wrong behavior
|
|
115
|
+
// the good behavior is to not gain fullSize ang go to invisible
|
|
116
|
+
if (changes.state === "mini") {
|
|
117
|
+
if (isHorizontal) {
|
|
118
|
+
h = changes.miniSize.unit === "auto" ? changes.contentSize.height : changes.miniSize;
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
w = changes.miniSize.unit === "auto" ? changes.contentSize.width : changes.miniSize;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
if (isHorizontal) {
|
|
126
|
+
h = changes.fullSize.unit === "auto" ? changes.contentSize.height : changes.fullSize;
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
w = changes.fullSize.unit === "auto" ? changes.contentSize.width : changes.fullSize;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
FastDOM.setStyle(this.el.nativeElement, {
|
|
133
|
+
"--docking-panel-w": w != null ? `${w}` : null,
|
|
134
|
+
"--docking-panel-h": h != null ? `${h}` : null,
|
|
135
|
+
"--docking-panel-content-w": changes.contentSize.width,
|
|
136
|
+
"--docking-panel-content-h": changes.contentSize.height
|
|
137
|
+
}, () => FastDOM.setAttributes(this.el.nativeElement, { animate: "" }));
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
open() {
|
|
141
|
+
this.state.next("full");
|
|
142
|
+
}
|
|
143
|
+
close() {
|
|
144
|
+
this.state.next("invisible");
|
|
145
|
+
}
|
|
146
|
+
minimize() {
|
|
147
|
+
if (this.minimizable) {
|
|
148
|
+
this.state.next("mini");
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingPanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
152
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: DockingPanelComponent, isStandalone: true, selector: "nu-docking-panel", inputs: { positionInput: ["position", "positionInput"], stateInput: ["state", "stateInput"], modeInput: ["mode", "modeInput"], fullSizeInput: ["fullSize", "fullSizeInput"], miniSizeInput: ["miniSize", "miniSizeInput"], minimizable: "minimizable" }, outputs: { state: "stateChanges" }, exportAs: ["nuDockingPanel"], usesInheritance: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [":host{---docking-panel-t: var(--docking-panel-t, auto);---docking-panel-r: var(--docking-panel-r, auto);---docking-panel-b: var(--docking-panel-b, auto);---docking-panel-l: var(--docking-panel-l, auto);---docking-panel-w: var(--docking-panel-w, auto);---docking-panel-h: var(--docking-panel-h, auto);---docking-panel-content-w: var(--docking-panel-content-w, var(---docking-panel-w));---docking-panel-content-h: var(--docking-panel-content-h, var(---docking-panel-h));display:flex;flex-flow:column nowrap;align-items:stretch;position:absolute;box-sizing:border-box;top:var(---docking-panel-t);right:var(---docking-panel-r);bottom:var(---docking-panel-b);left:var(---docking-panel-l);width:var(---docking-panel-w);height:var(---docking-panel-h)}:host[animate]{transition:transform var(---docking-layout-anim-duration) var(---docking-layout-anim-ease),width var(---docking-layout-anim-duration) var(---docking-layout-anim-ease),height var(---docking-layout-anim-duration) var(---docking-layout-anim-ease)}:host[side=top],:host[side=left]{---docking-panel-t-hide: -100%;---docking-panel-t-visible: 0%}:host[side=bottom],:host[side=right]{---docking-panel-t-hide: 100%;---docking-panel-t-visible: 0%}:host[state=invisible][orient=horizontal]{transform:translateY(var(---docking-panel-t-hide))}:host[state=invisible][orient=vertical]{transform:translate(var(---docking-panel-t-hide))}:host:not([state=invisible])[orient=horizontal]{transform:translateY(var(---docking-panel-t-visible))}:host:not([state=invisible])[orient=vertical]{transform:translate(var(---docking-panel-t-visible))}\n"] }); }
|
|
153
|
+
}
|
|
154
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingPanelComponent, decorators: [{
|
|
155
|
+
type: Component,
|
|
156
|
+
args: [{ standalone: true, selector: "nu-docking-panel", exportAs: "nuDockingPanel", template: `<ng-content></ng-content>`, styles: [":host{---docking-panel-t: var(--docking-panel-t, auto);---docking-panel-r: var(--docking-panel-r, auto);---docking-panel-b: var(--docking-panel-b, auto);---docking-panel-l: var(--docking-panel-l, auto);---docking-panel-w: var(--docking-panel-w, auto);---docking-panel-h: var(--docking-panel-h, auto);---docking-panel-content-w: var(--docking-panel-content-w, var(---docking-panel-w));---docking-panel-content-h: var(--docking-panel-content-h, var(---docking-panel-h));display:flex;flex-flow:column nowrap;align-items:stretch;position:absolute;box-sizing:border-box;top:var(---docking-panel-t);right:var(---docking-panel-r);bottom:var(---docking-panel-b);left:var(---docking-panel-l);width:var(---docking-panel-w);height:var(---docking-panel-h)}:host[animate]{transition:transform var(---docking-layout-anim-duration) var(---docking-layout-anim-ease),width var(---docking-layout-anim-duration) var(---docking-layout-anim-ease),height var(---docking-layout-anim-duration) var(---docking-layout-anim-ease)}:host[side=top],:host[side=left]{---docking-panel-t-hide: -100%;---docking-panel-t-visible: 0%}:host[side=bottom],:host[side=right]{---docking-panel-t-hide: 100%;---docking-panel-t-visible: 0%}:host[state=invisible][orient=horizontal]{transform:translateY(var(---docking-panel-t-hide))}:host[state=invisible][orient=vertical]{transform:translate(var(---docking-panel-t-hide))}:host:not([state=invisible])[orient=horizontal]{transform:translateY(var(---docking-panel-t-visible))}:host:not([state=invisible])[orient=vertical]{transform:translate(var(---docking-panel-t-visible))}\n"] }]
|
|
157
|
+
}], ctorParameters: () => [], propDecorators: { positionInput: [{
|
|
158
|
+
type: Input,
|
|
159
|
+
args: ["position"]
|
|
160
|
+
}], stateInput: [{
|
|
161
|
+
type: Input,
|
|
162
|
+
args: ["state"]
|
|
163
|
+
}], state: [{
|
|
164
|
+
type: Output,
|
|
165
|
+
args: ["stateChanges"]
|
|
166
|
+
}], modeInput: [{
|
|
167
|
+
type: Input,
|
|
168
|
+
args: ["mode"]
|
|
169
|
+
}], fullSizeInput: [{
|
|
170
|
+
type: Input,
|
|
171
|
+
args: ["fullSize"]
|
|
172
|
+
}], miniSizeInput: [{
|
|
173
|
+
type: Input,
|
|
174
|
+
args: ["miniSize"]
|
|
175
|
+
}], minimizable: [{
|
|
176
|
+
type: Input,
|
|
177
|
+
args: ["minimizable"]
|
|
178
|
+
}] } });
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docking-panel.component.js","sourceRoot":"","sources":["../../../../../packages/layout/src/docking/docking-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, inject, Input, Output } from \"@angular/core\"\n\nimport { BehaviorSubject, combineLatest, map, Observable, of, shareReplay, switchMap } from \"rxjs\"\n\nimport {\n    BooleanInput,\n    coerceBoolAttr,\n    Destructible,\n    FastDOM,\n    NumberWithUnit,\n    NumberWithUnitInput\n} from \"@ngutil/common\"\n\nimport { L9Range, L9RangeName } from \"../l9/range\"\nimport { watchDimension } from \"../util\"\n\nexport type DockingPanelState = \"full\" | \"mini\" | \"invisible\"\nexport type DockingPanelMode = \"over\" | \"push\" | \"rigid\"\n\nconst DEFAULT_POSITION = L9Range.coerce(\"left\")\nconst INVISIBLE_SIZE = new NumberWithUnit(0, \"px\")\nconst AUTO_SIZE = NumberWithUnit.coerce(\"auto\")\n\n@Component({\n    standalone: true,\n    selector: \"nu-docking-panel\",\n    exportAs: \"nuDockingPanel\",\n    styleUrl: \"./docking-panel.component.scss\",\n    template: `<ng-content></ng-content>`\n})\nexport class DockingPanelComponent extends Destructible {\n    readonly el = inject(ElementRef<HTMLElement>)\n\n    @Input(\"position\")\n    set positionInput(val: L9Range | L9RangeName) {\n        const coerced = L9Range.coerce(val)\n        if (coerced.orient === \"rect\") {\n            throw new Error(`Invalid position value: ${val}`)\n        }\n\n        if (!this.position.value.isEq(coerced)) {\n            this.position.next(coerced)\n        }\n    }\n    readonly position = new BehaviorSubject<L9Range>(DEFAULT_POSITION)\n\n    @Input(\"state\")\n    set stateInput(val: DockingPanelState) {\n        if (this.state.value !== val) {\n            this.state.next(val)\n        }\n    }\n    @Output(\"stateChanges\")\n    readonly state = new BehaviorSubject<DockingPanelState>(\"invisible\")\n\n    @Input(\"mode\")\n    set modeInput(val: DockingPanelMode) {\n        if (this.mode.value !== val) {\n            this.mode.next(val)\n        }\n    }\n    readonly mode = new BehaviorSubject<DockingPanelMode>(\"rigid\")\n\n    @Input(\"fullSize\")\n    set fullSizeInput(val: NumberWithUnitInput) {\n        const coerced = NumberWithUnit.coerce(val, \"px\")\n        if (this.#fullSize.value !== coerced) {\n            this.#fullSize.next(coerced)\n        }\n    }\n    readonly #fullSize = new BehaviorSubject<NumberWithUnit>(AUTO_SIZE)\n\n    @Input(\"miniSize\")\n    set miniSizeInput(val: NumberWithUnitInput) {\n        const coerced = NumberWithUnit.coerce(val, \"px\")\n        if (this.#miniSize.value !== coerced) {\n            this.#miniSize.next(coerced)\n        }\n    }\n    readonly #miniSize = new BehaviorSubject<NumberWithUnit>(INVISIBLE_SIZE)\n\n    @Input(\"minimizable\")\n    set minimizable(val: BooleanInput) {\n        this.#minimizable = coerceBoolAttr(val)\n        this.#minimizableAuto = false\n    }\n    get minimizable(): boolean {\n        return this.#minimizable\n    }\n    #minimizable: boolean = false\n    #minimizableAuto: boolean = true\n\n    readonly #contentSize = watchDimension(this.el.nativeElement, \"scroll-box\").pipe(shareReplay(1))\n\n    readonly #autoSize = combineLatest({\n        dim: this.#contentSize,\n        pos: this.position\n    }).pipe(\n        map(({ dim, pos }) => {\n            if (pos.orient === \"horizontal\") {\n                return dim.height\n            } else {\n                return dim.width\n            }\n        }),\n        shareReplay(1)\n    )\n\n    readonly fullSize = this.#fullSize.pipe(\n        switchMap(size => {\n            if (size.unit === \"auto\") {\n                return this.#autoSize\n            } else {\n                return of(size)\n            }\n        }),\n        shareReplay(1)\n    )\n\n    readonly miniSize = this.#miniSize.pipe(\n        switchMap(size => {\n            if (size.unit === \"auto\") {\n                return this.#autoSize\n            } else {\n                return of(size)\n            }\n        }),\n        shareReplay(1)\n    )\n\n    readonly changes = combineLatest({\n        position: this.position,\n        state: this.state,\n        mode: this.mode,\n        fullSize: this.fullSize,\n        miniSize: this.miniSize,\n        contentSize: this.#contentSize\n    })\n\n    constructor() {\n        super()\n\n        this.d.sub(this.changes).subscribe(changes => {\n            if (this.#minimizableAuto) {\n                this.#minimizable = this.#miniSize.value.value !== 0\n            }\n\n            FastDOM.setAttributes(this.el.nativeElement, {\n                state: changes.state,\n                orient: changes.position.orient,\n                mode: changes.mode,\n                side:\n                    changes.position.orient === \"horizontal\" ? changes.position.cells[0].v : changes.position.cells[0].h\n            })\n\n            const isHorizontal = changes.position.orient === \"horizontal\"\n            let w = null\n            let h = null\n\n            // TODO: when change state from mini -> invisible, currently wrong behavior\n            // the good behavior is to not gain fullSize ang go to invisible\n            if (changes.state === \"mini\") {\n                if (isHorizontal) {\n                    h = changes.miniSize.unit === \"auto\" ? changes.contentSize.height : changes.miniSize\n                } else {\n                    w = changes.miniSize.unit === \"auto\" ? changes.contentSize.width : changes.miniSize\n                }\n            } else {\n                if (isHorizontal) {\n                    h = changes.fullSize.unit === \"auto\" ? changes.contentSize.height : changes.fullSize\n                } else {\n                    w = changes.fullSize.unit === \"auto\" ? changes.contentSize.width : changes.fullSize\n                }\n            }\n\n            FastDOM.setStyle(\n                this.el.nativeElement,\n                {\n                    \"--docking-panel-w\": w != null ? `${w}` : null,\n                    \"--docking-panel-h\": h != null ? `${h}` : null,\n                    \"--docking-panel-content-w\": changes.contentSize.width,\n                    \"--docking-panel-content-h\": changes.contentSize.height\n                },\n                () => FastDOM.setAttributes(this.el.nativeElement, { animate: \"\" })\n            )\n        })\n    }\n\n    open() {\n        this.state.next(\"full\")\n    }\n\n    close() {\n        this.state.next(\"invisible\")\n    }\n\n    minimize() {\n        if (this.minimizable) {\n            this.state.next(\"mini\")\n        }\n    }\n}\n\ntype ChangesObservable = typeof DockingPanelComponent.prototype.changes\nexport type DockingPanelChanges = ChangesObservable extends Observable<infer T> ? T : never\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { DockingContentComponent } from "./docking-content.component";
|
|
3
|
+
import { DockingLayoutComponent } from "./docking-layout.component";
|
|
4
|
+
import { DockingPanelComponent } from "./docking-panel.component";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export { DockingLayoutComponent, DockingPanelComponent, DockingContentComponent };
|
|
7
|
+
const members = [DockingLayoutComponent, DockingPanelComponent, DockingContentComponent];
|
|
8
|
+
export class NuDockingLayout {
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: NuDockingLayout, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.1.3", ngImport: i0, type: NuDockingLayout, imports: [DockingLayoutComponent, DockingPanelComponent, DockingContentComponent], exports: [DockingLayoutComponent, DockingPanelComponent, DockingContentComponent] }); }
|
|
11
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: NuDockingLayout }); }
|
|
12
|
+
}
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: NuDockingLayout, decorators: [{
|
|
14
|
+
type: NgModule,
|
|
15
|
+
args: [{
|
|
16
|
+
imports: members,
|
|
17
|
+
exports: members
|
|
18
|
+
}]
|
|
19
|
+
}] });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sYXlvdXQvc3JjL2RvY2tpbmcvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUV4QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQTtBQUNyRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQTtBQUNuRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQTs7QUFFakUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLHFCQUFxQixFQUFFLHVCQUF1QixFQUFFLENBQUE7QUFFakYsTUFBTSxPQUFPLEdBQUcsQ0FBQyxzQkFBc0IsRUFBRSxxQkFBcUIsRUFBRSx1QkFBdUIsQ0FBQyxDQUFBO0FBTXhGLE1BQU0sT0FBTyxlQUFlOzhHQUFmLGVBQWU7K0dBQWYsZUFBZSxZQU5YLHNCQUFzQixFQUFFLHFCQUFxQixFQUFFLHVCQUF1QixhQUF0RSxzQkFBc0IsRUFBRSxxQkFBcUIsRUFBRSx1QkFBdUI7K0dBTTFFLGVBQWU7OzJGQUFmLGVBQWU7a0JBSjNCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLE9BQU87b0JBQ2hCLE9BQU8sRUFBRSxPQUFPO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxuXG5pbXBvcnQgeyBEb2NraW5nQ29udGVudENvbXBvbmVudCB9IGZyb20gXCIuL2RvY2tpbmctY29udGVudC5jb21wb25lbnRcIlxuaW1wb3J0IHsgRG9ja2luZ0xheW91dENvbXBvbmVudCB9IGZyb20gXCIuL2RvY2tpbmctbGF5b3V0LmNvbXBvbmVudFwiXG5pbXBvcnQgeyBEb2NraW5nUGFuZWxDb21wb25lbnQgfSBmcm9tIFwiLi9kb2NraW5nLXBhbmVsLmNvbXBvbmVudFwiXG5cbmV4cG9ydCB7IERvY2tpbmdMYXlvdXRDb21wb25lbnQsIERvY2tpbmdQYW5lbENvbXBvbmVudCwgRG9ja2luZ0NvbnRlbnRDb21wb25lbnQgfVxuXG5jb25zdCBtZW1iZXJzID0gW0RvY2tpbmdMYXlvdXRDb21wb25lbnQsIERvY2tpbmdQYW5lbENvbXBvbmVudCwgRG9ja2luZ0NvbnRlbnRDb21wb25lbnRdXG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogbWVtYmVycyxcbiAgICBleHBvcnRzOiBtZW1iZXJzXG59KVxuZXhwb3J0IGNsYXNzIE51RG9ja2luZ0xheW91dCB7fVxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from "./util";
|
|
2
|
+
export * from "./l9";
|
|
3
|
+
export * from "./docking";
|
|
4
|
+
export * from "./services/slots.service";
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9sYXlvdXQvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsUUFBUSxDQUFBO0FBQ3RCLGNBQWMsTUFBTSxDQUFBO0FBQ3BCLGNBQWMsV0FBVyxDQUFBO0FBQ3pCLGNBQWMsMEJBQTBCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi91dGlsXCJcbmV4cG9ydCAqIGZyb20gXCIuL2w5XCJcbmV4cG9ydCAqIGZyb20gXCIuL2RvY2tpbmdcIlxuZXhwb3J0ICogZnJvbSBcIi4vc2VydmljZXMvc2xvdHMuc2VydmljZVwiXG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from "./range";
|
|
2
|
+
export * from "./state";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sYXlvdXQvc3JjL2w5L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsU0FBUyxDQUFBO0FBQ3ZCLGNBQWMsU0FBUyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vcmFuZ2VcIlxuZXhwb3J0ICogZnJvbSBcIi4vc3RhdGVcIlxuIl19
|