@ngutil/layout 0.0.3-dev.6 → 0.0.3-dev.7

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,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", never, {}, {}, never, ["*"], true, never>;
5
+ }
@@ -0,0 +1,24 @@
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 type DockingPositionMode = "absolute" | "fixed";
12
+ export declare class DockingLayoutComponent extends Destructible implements AfterViewInit, OnChanges {
13
+ #private;
14
+ contentOnly: boolean;
15
+ positionMode: DockingPositionMode;
16
+ contentComponent?: DockingContentComponent;
17
+ dockingPanels: QueryList<DockingPanelComponent>;
18
+ readonly panels: Observable<Array<DockingPanelComponent>>;
19
+ ngAfterViewInit(): void;
20
+ ngOnChanges(changes: SimpleChanges): void;
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>;
23
+ }
24
+ export {};
@@ -0,0 +1,39 @@
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 = "overlay" | "embedded";
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
+ }>;
30
+ constructor();
31
+ open(): void;
32
+ close(): void;
33
+ minimize(): void;
34
+ 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>;
36
+ }
37
+ type ChangesObservable = typeof DockingPanelComponent.prototype.changes;
38
+ export type DockingPanelChanges = ChangesObservable extends Observable<infer T> ? T : never;
39
+ 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", 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", 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xheW91dC9zcmMvZG9ja2luZy9kb2NraW5nLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBUXpDLE1BQU0sT0FBTyx1QkFBdUI7OEdBQXZCLHVCQUF1QjtrR0FBdkIsdUJBQXVCLDhFQUZ0QiwyQkFBMkI7OzJGQUU1Qix1QkFBdUI7a0JBTm5DLFNBQVM7aUNBQ00sSUFBSSxZQUNOLG9CQUFvQixZQUVwQiwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6IFwibnUtZG9ja2luZy1jb250ZW50XCIsXG4gICAgc3R5bGVVcmw6IFwiLi9kb2NraW5nLWNvbnRlbnQuY29tcG9uZW50LnNjc3NcIixcbiAgICB0ZW1wbGF0ZTogYDxuZy1jb250ZW50PjwvbmctY29udGVudD5gXG59KVxuZXhwb3J0IGNsYXNzIERvY2tpbmdDb250ZW50Q29tcG9uZW50IHt9XG4iXX0=
@@ -0,0 +1,265 @@
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, NumberWithUnit } from "@ngutil/common";
4
+ import { FastDOM } from "../util";
5
+ import { DockingContentComponent } from "./docking-content.component";
6
+ import { DockingPanelComponent } from "./docking-panel.component";
7
+ import * as i0 from "@angular/core";
8
+ const EMBEDDED_ZINDEX = 20;
9
+ const OVERLAY_ZINDEX = EMBEDDED_ZINDEX * 2;
10
+ // interface PanelRefChanges {
11
+ // ref: PanelRef
12
+ // changes: DockingPanelChanges
13
+ // }
14
+ // class PanelRef {
15
+ // style: Partial<CSSStyleDeclaration> = {}
16
+ // readonly changes: Observable<PanelRefChanges>
17
+ // constructor(public readonly panel: DockingPanelDirective) {
18
+ // this.changes = panel.changes.pipe(
19
+ // map(changes => {
20
+ // return { ref: this, changes }
21
+ // })
22
+ // )
23
+ // }
24
+ // }
25
+ export class DockingLayoutComponent extends Destructible {
26
+ constructor() {
27
+ super(...arguments);
28
+ this.#el = inject((ElementRef));
29
+ this.contentOnly = false;
30
+ this.positionMode = "absolute";
31
+ this.#reflow = new Subject();
32
+ }
33
+ #el;
34
+ #reflow;
35
+ ngAfterViewInit() {
36
+ // eslint-disable-next-line prettier/prettier
37
+ this.panels = this.dockingPanels.changes.pipe(startWith(null), map(() => this.dockingPanels.toArray()), shareReplay(1));
38
+ // this.panels.subscribe(panels => console.log({ panels }))
39
+ this.d
40
+ .sub(combineLatest({ panels: this.panels, reflow: this.#reflow.pipe(startWith(null)) }))
41
+ .pipe(switchMap(({ panels }) => combineLatest(panels.map(panel => panel.changes.pipe(map(changes => {
42
+ return { panel, changes };
43
+ }))))))
44
+ .subscribe(this.#layout.bind(this));
45
+ // this.d
46
+ // .sub(merge(this.dockingPanels.changes, this.#reflow))
47
+ // .pipe(
48
+ // startWith(null),
49
+ // map(() => this.dockingPanels.map(panel => new PanelRef(panel))),
50
+ // switchMap(refs => combineLatest(refs.map(ref => ref.changes))),
51
+ // map(changes => {
52
+ // this.#layout(changes)
53
+ // return changes.map(c => c.ref)
54
+ // })
55
+ // )
56
+ // .subscribe(this.panels)
57
+ }
58
+ ngOnChanges(changes) {
59
+ if ("contentOnly" in changes || "positionMode" in changes) {
60
+ this.#reflow.next();
61
+ }
62
+ }
63
+ #layout(entries) {
64
+ console.log("layout", entries);
65
+ let paddingTop = 0;
66
+ let paddingRight = 0;
67
+ let paddingBottom = 0;
68
+ let paddingLeft = 0;
69
+ let embeddedZIndex = EMBEDDED_ZINDEX;
70
+ let overlayZIndex = OVERLAY_ZINDEX;
71
+ if (this.contentOnly) {
72
+ // TODO:...
73
+ }
74
+ else {
75
+ for (const entry of entries) {
76
+ const panelState = entry.changes;
77
+ const panelSize = panelState.state === "full"
78
+ ? panelState.fullSize.value
79
+ : panelState.state === "mini"
80
+ ? panelState.miniSize.value
81
+ : 0;
82
+ const isHorizontal = panelState.position.orient === "horizontal";
83
+ const isEmbedded = panelState.mode === "embedded";
84
+ let panelTop = null;
85
+ let panelRight = null;
86
+ let panelBottom = null;
87
+ let panelLeft = null;
88
+ if (isHorizontal) {
89
+ panelLeft = 0;
90
+ panelRight = 0;
91
+ if (panelState.position.cells[0].v === "top") {
92
+ if (isEmbedded) {
93
+ paddingTop = Math.max(paddingTop, panelSize);
94
+ }
95
+ panelTop = 0;
96
+ }
97
+ else if (panelState.position.cells[0].v === "bottom") {
98
+ if (isEmbedded) {
99
+ paddingBottom = Math.max(paddingBottom, panelSize);
100
+ }
101
+ panelBottom = 0;
102
+ }
103
+ }
104
+ else {
105
+ panelTop = 0;
106
+ panelBottom = 0;
107
+ if (panelState.position.cells[0].h === "left") {
108
+ if (isEmbedded) {
109
+ paddingLeft = Math.max(paddingLeft, panelSize);
110
+ }
111
+ panelLeft = 0;
112
+ }
113
+ else if (panelState.position.cells[0].h === "right") {
114
+ if (isEmbedded) {
115
+ paddingRight = Math.max(paddingRight, panelSize);
116
+ }
117
+ panelRight = 0;
118
+ }
119
+ }
120
+ const panelGivenSize = panelState.state === "full"
121
+ ? panelState.fullSize
122
+ : panelState.state === "mini"
123
+ ? panelState.miniSize
124
+ : new NumberWithUnit(0, "px");
125
+ FastDOM.setStyle(entry.panel.el.nativeElement, {
126
+ "z-index": `${isEmbedded ? embeddedZIndex++ : overlayZIndex++}`,
127
+ "--docking-panel-t": panelTop != null ? `${panelTop}px` : null,
128
+ "--docking-panel-r": panelRight != null ? `${panelRight}px` : null,
129
+ "--docking-panel-b": panelBottom != null ? `${panelBottom}px` : null,
130
+ "--docking-panel-l": panelLeft != null ? `${panelLeft}px` : null,
131
+ "--docking-panel-w": !isHorizontal
132
+ ? `${panelGivenSize.unit === "auto" ? "auto" : panelGivenSize}`
133
+ : null,
134
+ "--docking-panel-h": isHorizontal
135
+ ? `${panelGivenSize.unit === "auto" ? "auto" : panelGivenSize}`
136
+ : null,
137
+ "--docking-panel-real-w": !isHorizontal ? `${panelSize}px` : null,
138
+ "--docking-panel-real-h": isHorizontal ? `${panelSize}px` : null
139
+ });
140
+ }
141
+ console.log({ paddingTop, paddingRight, paddingBottom, paddingLeft });
142
+ FastDOM.setStyle(this.#el.nativeElement, {
143
+ "--docking-layout-top": `${paddingTop}px`,
144
+ "--docking-layout-right": `${paddingRight}px`,
145
+ "--docking-layout-bottom": `${paddingBottom}px`,
146
+ "--docking-layout-left": `${paddingLeft}px`
147
+ });
148
+ }
149
+ }
150
+ #layoutOld(entries) {
151
+ // let paddingTop = 0
152
+ // let paddingRight = 0
153
+ // let paddingBottom = 0
154
+ // let paddingLeft = 0
155
+ // if (!this.contentOnly) {
156
+ // let embeddedZIndex = EMBEDDED_ZINDEX
157
+ // let overlayZIndex = OVERLAY_ZINDEX
158
+ // const leftRight: PanelRefChanges[] = entries.filter(v =>
159
+ // ["left", "right"].includes(v.changes.position.side)
160
+ // )
161
+ // const topBottom: PanelRefChanges[] = entries.filter(v =>
162
+ // ["top", "bottom"].includes(v.changes.position.side)
163
+ // )
164
+ // for (const entry of entries) {
165
+ // const changes = entry.changes
166
+ // const ref = entry.ref
167
+ // if (changes.mode === "embedded") {
168
+ // ref.style.zIndex = `${embeddedZIndex++}`
169
+ // } else if (changes.mode === "overlay") {
170
+ // ref.style.zIndex = `${overlayZIndex++}`
171
+ // }
172
+ // }
173
+ // for (const entry of leftRight) {
174
+ // const changes = entry.changes
175
+ // const ref = entry.ref
176
+ // const padding =
177
+ // changes.mode === "embedded"
178
+ // ? changes.state === "full"
179
+ // ? changes.fullSize
180
+ // : changes.state === "mini"
181
+ // ? changes.miniSize
182
+ // : 0
183
+ // : 0
184
+ // ref.style.top = "0"
185
+ // ref.style.bottom = "0"
186
+ // if (changes.position.side === "left") {
187
+ // paddingLeft = Math.max(paddingLeft, padding)
188
+ // ref.style.left = "0"
189
+ // ref.style.right = ""
190
+ // } else {
191
+ // paddingRight = Math.max(paddingRight, padding)
192
+ // ref.style.right = "0"
193
+ // ref.style.left = ""
194
+ // }
195
+ // }
196
+ // for (const entry of topBottom) {
197
+ // const changes = entry.changes
198
+ // const ref = entry.ref
199
+ // const padding =
200
+ // changes.mode === "embedded"
201
+ // ? changes.state === "full"
202
+ // ? changes.fullSize
203
+ // : changes.state === "mini"
204
+ // ? changes.miniSize
205
+ // : 0
206
+ // : 0
207
+ // if (changes.mode === "embedded") {
208
+ // ref.style.left = `${paddingLeft}px`
209
+ // ref.style.right = `${paddingRight}px`
210
+ // } else {
211
+ // ref.style.left = "0"
212
+ // ref.style.right = "0"
213
+ // }
214
+ // if (changes.position?.cells[0].v === "top") {
215
+ // paddingTop = Math.max(paddingTop, padding)
216
+ // ref.style.top = "0"
217
+ // ref.style.bottom = ""
218
+ // } else {
219
+ // paddingBottom = Math.max(paddingBottom, padding)
220
+ // ref.style.bottom = `0`
221
+ // ref.style.top = ""
222
+ // }
223
+ // }
224
+ // }
225
+ // const cel = this.contentEl.nativeElement
226
+ // cel.style.padding = `${paddingTop}px ${paddingRight}px ${paddingBottom}px ${paddingLeft}px`
227
+ }
228
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingLayoutComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
229
+ 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: `
230
+ <ng-content select="nu-docking-panel"></ng-content>
231
+
232
+ @if (!contentComponent) {
233
+ <nu-docking-content>
234
+ <ng-content></ng-content>
235
+ </nu-docking-content>
236
+ } @else {
237
+ <ng-content select="nu-docking-content"></ng-content>
238
+ }
239
+ `, 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 }); }
240
+ }
241
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingLayoutComponent, decorators: [{
242
+ type: Component,
243
+ args: [{ selector: "nu-docking", standalone: true, imports: [DockingContentComponent], template: `
244
+ <ng-content select="nu-docking-panel"></ng-content>
245
+
246
+ @if (!contentComponent) {
247
+ <nu-docking-content>
248
+ <ng-content></ng-content>
249
+ </nu-docking-content>
250
+ } @else {
251
+ <ng-content select="nu-docking-content"></ng-content>
252
+ }
253
+ `, 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"] }]
254
+ }], propDecorators: { contentOnly: [{
255
+ type: Input
256
+ }], positionMode: [{
257
+ type: Input
258
+ }], contentComponent: [{
259
+ type: ContentChild,
260
+ args: [DockingContentComponent]
261
+ }], dockingPanels: [{
262
+ type: ContentChildren,
263
+ args: [DockingPanelComponent]
264
+ }] } });
265
+ //# 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, NumberWithUnit } from \"@ngutil/common\"\n\nimport { FastDOM } from \"../util\"\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        console.log(\"layout\", entries)\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            console.log({ paddingTop, paddingRight, paddingBottom, paddingLeft })\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    #layoutOld(entries: PanelsChanges) {\n        // let paddingTop = 0\n        // let paddingRight = 0\n        // let paddingBottom = 0\n        // let paddingLeft = 0\n        // if (!this.contentOnly) {\n        //     let embeddedZIndex = EMBEDDED_ZINDEX\n        //     let overlayZIndex = OVERLAY_ZINDEX\n        //     const leftRight: PanelRefChanges[] = entries.filter(v =>\n        //         [\"left\", \"right\"].includes(v.changes.position.side)\n        //     )\n        //     const topBottom: PanelRefChanges[] = entries.filter(v =>\n        //         [\"top\", \"bottom\"].includes(v.changes.position.side)\n        //     )\n        //     for (const entry of entries) {\n        //         const changes = entry.changes\n        //         const ref = entry.ref\n        //         if (changes.mode === \"embedded\") {\n        //             ref.style.zIndex = `${embeddedZIndex++}`\n        //         } else if (changes.mode === \"overlay\") {\n        //             ref.style.zIndex = `${overlayZIndex++}`\n        //         }\n        //     }\n        //     for (const entry of leftRight) {\n        //         const changes = entry.changes\n        //         const ref = entry.ref\n        //         const padding =\n        //             changes.mode === \"embedded\"\n        //                 ? changes.state === \"full\"\n        //                     ? changes.fullSize\n        //                     : changes.state === \"mini\"\n        //                       ? changes.miniSize\n        //                       : 0\n        //                 : 0\n        //         ref.style.top = \"0\"\n        //         ref.style.bottom = \"0\"\n        //         if (changes.position.side === \"left\") {\n        //             paddingLeft = Math.max(paddingLeft, padding)\n        //             ref.style.left = \"0\"\n        //             ref.style.right = \"\"\n        //         } else {\n        //             paddingRight = Math.max(paddingRight, padding)\n        //             ref.style.right = \"0\"\n        //             ref.style.left = \"\"\n        //         }\n        //     }\n        //     for (const entry of topBottom) {\n        //         const changes = entry.changes\n        //         const ref = entry.ref\n        //         const padding =\n        //             changes.mode === \"embedded\"\n        //                 ? changes.state === \"full\"\n        //                     ? changes.fullSize\n        //                     : changes.state === \"mini\"\n        //                       ? changes.miniSize\n        //                       : 0\n        //                 : 0\n        //         if (changes.mode === \"embedded\") {\n        //             ref.style.left = `${paddingLeft}px`\n        //             ref.style.right = `${paddingRight}px`\n        //         } else {\n        //             ref.style.left = \"0\"\n        //             ref.style.right = \"0\"\n        //         }\n        //         if (changes.position?.cells[0].v === \"top\") {\n        //             paddingTop = Math.max(paddingTop, padding)\n        //             ref.style.top = \"0\"\n        //             ref.style.bottom = \"\"\n        //         } else {\n        //             paddingBottom = Math.max(paddingBottom, padding)\n        //             ref.style.bottom = `0`\n        //             ref.style.top = \"\"\n        //         }\n        //     }\n        // }\n        // const cel = this.contentEl.nativeElement\n        // cel.style.padding = `${paddingTop}px ${paddingRight}px ${paddingBottom}px ${paddingLeft}px`\n    }\n}\n"]}
@@ -0,0 +1,148 @@
1
+ import { Component, ElementRef, inject, Input, Output } from "@angular/core";
2
+ import { BehaviorSubject, combineLatest, map, of, shareReplay, switchMap } from "rxjs";
3
+ import { coerceBoolAttr, Destructible, NumberWithUnit } from "@ngutil/common";
4
+ import { L9Range } from "../l9/range";
5
+ import { FastDOM, watchDimension } from "../util";
6
+ import * as i0 from "@angular/core";
7
+ const DEFAULT_POSITION = L9Range.coerce("left");
8
+ export class DockingPanelComponent extends Destructible {
9
+ set positionInput(val) {
10
+ const coerced = L9Range.coerce(val);
11
+ console.log("SET POSITION", coerced, this.position.value.isEq(coerced));
12
+ if (coerced.orient === "rect") {
13
+ throw new Error(`Invalid position value: ${val}`);
14
+ }
15
+ if (!this.position.value.isEq(coerced)) {
16
+ this.position.next(coerced);
17
+ }
18
+ }
19
+ set stateInput(val) {
20
+ if (this.state.value !== val) {
21
+ this.state.next(val);
22
+ }
23
+ }
24
+ set modeInput(val) {
25
+ if (this.mode.value !== val) {
26
+ this.mode.next(val);
27
+ }
28
+ }
29
+ set fullSizeInput(val) {
30
+ const coerced = NumberWithUnit.coerce(val, "px");
31
+ if (this.#fullSize.value !== coerced) {
32
+ this.#fullSize.next(coerced);
33
+ }
34
+ }
35
+ #fullSize;
36
+ set miniSizeInput(val) {
37
+ const coerced = NumberWithUnit.coerce(val, "px");
38
+ if (this.#miniSize.value !== coerced) {
39
+ this.#miniSize.next(coerced);
40
+ }
41
+ }
42
+ #miniSize;
43
+ set minimizable(val) {
44
+ this.#minimizable = coerceBoolAttr(val);
45
+ this.#minimizableAuto = false;
46
+ }
47
+ get minimizable() {
48
+ return this.#minimizable;
49
+ }
50
+ #minimizable;
51
+ #minimizableAuto;
52
+ #autoSize;
53
+ constructor() {
54
+ super();
55
+ this.el = inject((ElementRef));
56
+ this.position = new BehaviorSubject(DEFAULT_POSITION);
57
+ this.state = new BehaviorSubject("invisible");
58
+ this.mode = new BehaviorSubject("overlay");
59
+ this.#fullSize = new BehaviorSubject(NumberWithUnit.coerce(0));
60
+ this.#miniSize = new BehaviorSubject(NumberWithUnit.coerce(0));
61
+ this.#minimizable = false;
62
+ this.#minimizableAuto = true;
63
+ this.#autoSize = combineLatest({
64
+ dim: watchDimension(this.el.nativeElement, "scroll-box"),
65
+ pos: this.position
66
+ }).pipe(map(({ dim, pos }) => {
67
+ if (pos.orient === "horizontal") {
68
+ return dim.height;
69
+ }
70
+ else {
71
+ return dim.width;
72
+ }
73
+ }), shareReplay(1));
74
+ this.fullSize = this.#fullSize.pipe(switchMap(size => {
75
+ if (size.unit === "auto") {
76
+ return this.#autoSize;
77
+ }
78
+ else {
79
+ return of(size);
80
+ }
81
+ }), shareReplay(1));
82
+ this.miniSize = this.#miniSize.pipe(switchMap(size => {
83
+ if (size.unit === "auto") {
84
+ return this.#autoSize;
85
+ }
86
+ else {
87
+ return of(size);
88
+ }
89
+ }), shareReplay(1));
90
+ this.changes = combineLatest({
91
+ position: this.position,
92
+ state: this.state,
93
+ mode: this.mode,
94
+ fullSize: this.fullSize,
95
+ miniSize: this.miniSize
96
+ });
97
+ this.d.sub(this.changes).subscribe(changes => {
98
+ if (this.#minimizableAuto) {
99
+ this.#minimizable = this.#miniSize.value.value !== 0;
100
+ }
101
+ FastDOM.setAttributes(this.el.nativeElement, {
102
+ state: changes.state,
103
+ orient: changes.position.orient,
104
+ mode: changes.mode,
105
+ side: changes.position.orient === "horizontal" ? changes.position.cells[0].v : changes.position.cells[0].h
106
+ });
107
+ });
108
+ }
109
+ open() {
110
+ this.state.next("full");
111
+ }
112
+ close() {
113
+ this.state.next("invisible");
114
+ }
115
+ minimize() {
116
+ if (this.minimizable) {
117
+ this.state.next("mini");
118
+ }
119
+ }
120
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingPanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
121
+ 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-real-w: var(--docking-panel-real-w, var(---docking-panel-w));---docking-panel-real-h: var(--docking-panel-real-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);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"] }); }
122
+ }
123
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DockingPanelComponent, decorators: [{
124
+ type: Component,
125
+ 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-real-w: var(--docking-panel-real-w, var(---docking-panel-w));---docking-panel-real-h: var(--docking-panel-real-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);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"] }]
126
+ }], ctorParameters: () => [], propDecorators: { positionInput: [{
127
+ type: Input,
128
+ args: ["position"]
129
+ }], stateInput: [{
130
+ type: Input,
131
+ args: ["state"]
132
+ }], state: [{
133
+ type: Output,
134
+ args: ["stateChanges"]
135
+ }], modeInput: [{
136
+ type: Input,
137
+ args: ["mode"]
138
+ }], fullSizeInput: [{
139
+ type: Input,
140
+ args: ["fullSize"]
141
+ }], miniSizeInput: [{
142
+ type: Input,
143
+ args: ["miniSize"]
144
+ }], minimizable: [{
145
+ type: Input,
146
+ args: ["minimizable"]
147
+ }] } });
148
+ //# 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 { BooleanInput, coerceBoolAttr, Destructible, NumberWithUnit, NumberWithUnitInput } from \"@ngutil/common\"\n\nimport { L9Range, L9RangeName } from \"../l9/range\"\nimport { FastDOM, watchDimension } from \"../util\"\n\nexport type DockingPanelState = \"full\" | \"mini\" | \"invisible\"\nexport type DockingPanelMode = \"overlay\" | \"embedded\"\n\nconst DEFAULT_POSITION = L9Range.coerce(\"left\")\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\n        console.log(\"SET POSITION\", coerced, this.position.value.isEq(coerced))\n\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>(\"overlay\")\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>(NumberWithUnit.coerce(0))\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>(NumberWithUnit.coerce(0))\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 #autoSize = combineLatest({\n        dim: watchDimension(this.el.nativeElement, \"scroll-box\"),\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    })\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    }\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
package/esm2022/index.mjs CHANGED
@@ -1,2 +1,4 @@
1
- export * from "./lib/layout/layout.component";
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9sYXlvdXQvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsK0JBQStCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9saWIvbGF5b3V0L2xheW91dC5jb21wb25lbnRcIlxuIl19
1
+ export * from "./util";
2
+ export * from "./l9";
3
+ export * from "./docking";
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9sYXlvdXQvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsUUFBUSxDQUFBO0FBQ3RCLGNBQWMsTUFBTSxDQUFBO0FBQ3BCLGNBQWMsV0FBVyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vdXRpbFwiXG5leHBvcnQgKiBmcm9tIFwiLi9sOVwiXG5leHBvcnQgKiBmcm9tIFwiLi9kb2NraW5nXCJcbiJdfQ==