@mintplayer/ng-bootstrap 15.26.2 → 15.27.0
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/dock/src/dock-panel-header/dock-panel-header.component.d.ts +2 -0
- package/esm2020/dock/src/dock/dock.component.mjs +3 -2
- package/esm2020/dock/src/dock-panel-header/dock-panel-header.component.mjs +68 -61
- package/fesm2015/mintplayer-ng-bootstrap-dock.mjs +69 -61
- package/fesm2015/mintplayer-ng-bootstrap-dock.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap-dock.mjs +69 -61
- package/fesm2020/mintplayer-ng-bootstrap-dock.mjs.map +1 -1
- package/package.json +2 -2
|
@@ -2,6 +2,7 @@ import { ElementRef } from '@angular/core';
|
|
|
2
2
|
import { BsDockPanelComponent } from '../dock-panel/dock-panel.component';
|
|
3
3
|
import { BsDockComponent } from '../dock/dock.component';
|
|
4
4
|
import { BsDockPane } from '../panes/dock-pane';
|
|
5
|
+
import { RemoveFromPaneResult } from '../interfaces/remove-from-pane-result';
|
|
5
6
|
import { DragOperation } from '../interfaces/drag-operation';
|
|
6
7
|
import { BsDockService } from '../services/dock/dock.service';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
@@ -17,6 +18,7 @@ export declare class BsDockPanelHeaderComponent {
|
|
|
17
18
|
onMouseDown(ev: MouseEvent): void;
|
|
18
19
|
onMouseMove(ev: MouseEvent): void;
|
|
19
20
|
removeFromPaneBis(host: BsDockPane, pane: BsDockPane): void;
|
|
21
|
+
removeFromPane(host: BsDockPane, panel: BsDockPanelComponent): RemoveFromPaneResult;
|
|
20
22
|
onMouseUp(ev: Event): void;
|
|
21
23
|
dBlock: boolean;
|
|
22
24
|
static ɵfac: i0.ɵɵFactoryDeclaration<BsDockPanelHeaderComponent, never>;
|
|
@@ -38,7 +38,8 @@ export class BsDockComponent {
|
|
|
38
38
|
const clone = deepClone(layout, true,
|
|
39
39
|
// []
|
|
40
40
|
[BsContentPane, BsDocumentHost, BsFloatingPane, BsSplitPane, BsTabGroupPane], true, this.paneCache);
|
|
41
|
-
this.paneCache = clone.cache;
|
|
41
|
+
// this.paneCache = clone.cache;
|
|
42
|
+
console.log('parentify', { layout, result: clone.result });
|
|
42
43
|
return clone.result;
|
|
43
44
|
}));
|
|
44
45
|
this.parentifiedLayout$.pipe(takeUntil(this.destroyed$)).subscribe(console.log);
|
|
@@ -89,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
89
90
|
type: HostBinding,
|
|
90
91
|
args: ['style.right']
|
|
91
92
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dock.component.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/dock/src/dock/dock.component.ts","../../../../../../../libs/mintplayer-ng-bootstrap/dock/src/dock/dock.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChildren, ViewChildren, Input, OnDestroy, QueryList, HostBinding } from '@angular/core';\nimport { BehaviorSubject, combineLatest, combineLatestAll, map, Observable, Subject, takeUntil } from 'rxjs';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { Parentified, deepClone } from '@mintplayer/parentify';\nimport { BsDockPanelComponent } from '../dock-panel/dock-panel.component';\nimport { EPaneType } from '../enums/pane-type.enum';\nimport { BsDockLayout } from '../interfaces/dock-layout';\nimport { BsTabGroupPane } from '../panes/tab-group-pane';\nimport { BsDocumentHost } from '../panes/document-host-pane';\nimport { BsContentPane } from '../panes/content-pane';\nimport { BsFloatingPane } from '../panes/floating-pane';\nimport { BsSplitPane } from '../panes/split-pane';\nimport { BsDockPaneRendererComponent } from '../dock-pane-renderer/dock-pane-renderer.component';\n\n@Component({\n  selector: 'bs-dock',\n  templateUrl: './dock.component.html',\n  styleUrls: ['./dock.component.scss']\n})\nexport class BsDockComponent implements OnDestroy {\n  constructor() {\n    const tabs = new BsTabGroupPane();\n    const docHost = new BsDocumentHost();\n    docHost.rootPane = tabs;\n\n    this.layout$ = new BehaviorSubject<BsDockLayout>({\n      rootPane: docHost,\n      floatingPanes: []\n    });\n\n    // combineLatest([this.layout$, this.panels$])\n    //   .pipe(takeUntil(this.destroyed$))\n    //   .subscribe(([layout, panels]) => {\n        \n    //   })\n\n    this.floating$.pipe(takeUntil(this.destroyed$))\n      .subscribe((floating) => {\n        floating.forEach((panel) => panel.moveToOverlay());\n      });\n      \n    this.parentifiedLayout$ = this.layout$.pipe(map(layout => {\n      const clone = deepClone(\n        layout, true,\n        // []\n        [BsContentPane, BsDocumentHost, BsFloatingPane, BsSplitPane, BsTabGroupPane],\n        true,\n        this.paneCache);\n\n      // this.paneCache = clone.cache;\n\n      console.log('parentify', { layout, result: clone.result });\n\n      return clone.result;\n    }));\n\n    this.parentifiedLayout$.pipe(takeUntil(this.destroyed$)).subscribe(console.log);\n  }\n\n  private paneCache?: Map<any, any>;\n\n  //#region Panels\n  panels$ = new BehaviorSubject<BsDockPanelComponent[]>([]);\n  @ContentChildren(BsDockPanelComponent) set panels(value: QueryList<BsDockPanelComponent>) {\n    this.panels$.next(value.toArray());\n  }\n  //#endregion\n  //#region Layout\n  layout$: BehaviorSubject<BsDockLayout>;\n  public get layout() {\n    return this.layout$.value;\n  }\n  @Input() public set layout(value: BsDockLayout) {\n    this.layout$.next(value);\n  }\n  //#endregion\n\n  floating$ = new BehaviorSubject<BsDockPaneRendererComponent[]>([]);\n  @ViewChildren('floating') set floatingPanes(value: QueryList<BsDockPaneRendererComponent>) {\n    this.floating$.next(value.toArray());\n  }\n\n  @HostBinding('class.position-absolute')\n  positionAbsolute = true;\n\n  @HostBinding('style.top')\n  @HostBinding('style.left')\n  @HostBinding('style.bottom')\n  @HostBinding('style.right')\n  positionPx = 0;\n\n  parentifiedLayout$: Observable<Parentified<BsDockLayout>>;\n\n  destroyed$ = new Subject();\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n    this.floating$.value.forEach(panel => panel.disposeOverlay());\n  }\n}\n","<ng-content></ng-content>\n<ng-container *ngIf=\"(layout$ | async) as layout\">\n    <bs-dock-pane-renderer [layout]=\"layout.rootPane\"></bs-dock-pane-renderer>\n\n    <ng-container *ngFor=\"let pane of layout.floatingPanes\">\n        <bs-dock-pane-renderer #floating *ngIf=\"pane.pane\" [layout]=\"pane\"></bs-dock-pane-renderer>\n    </ng-container>\n</ng-container>\n<!-- <bs-splitter>\n    <ng-content></ng-content>\n    <ng-container *ngFor=\"let panel of (panels$ | async)\">\n        <bs-split-panel>\n            <ng-template [cdkPortalOutlet]=\"panel.portal\"></ng-template>\n        </bs-split-panel>\n    </ng-container>\n</bs-splitter> -->\n"]}
|
|
@@ -30,10 +30,10 @@ export class BsDockPanelHeaderComponent {
|
|
|
30
30
|
if (this.isMouseDown) {
|
|
31
31
|
if (!this.isDragging) {
|
|
32
32
|
this.isDragging = true;
|
|
33
|
-
this.dock.parentifiedLayout$.pipe(take(1)).subscribe((
|
|
33
|
+
this.dock.parentifiedLayout$.pipe(take(1)).subscribe((parentifiedLayout) => {
|
|
34
34
|
// this.dock.layout$.pipe(take(1)).subscribe((layout) => {
|
|
35
|
-
const traces = this.dockService.buildTraces(
|
|
36
|
-
console.log('traces', {
|
|
35
|
+
const traces = this.dockService.buildTraces(parentifiedLayout);
|
|
36
|
+
console.log('traces', { parentifiedLayout, traces });
|
|
37
37
|
const matching = traces.filter(t => {
|
|
38
38
|
const lastPane = t.trace[t.trace.length - 1];
|
|
39
39
|
// return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);
|
|
@@ -63,7 +63,7 @@ export class BsDockPanelHeaderComponent {
|
|
|
63
63
|
};
|
|
64
64
|
// this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();
|
|
65
65
|
// this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();
|
|
66
|
-
|
|
66
|
+
this.removeFromPane(parentifiedLayout.$original.rootPane, this.dockPanel);
|
|
67
67
|
const trace = [...matching[0].trace];
|
|
68
68
|
this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();
|
|
69
69
|
this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();
|
|
@@ -74,9 +74,9 @@ export class BsDockPanelHeaderComponent {
|
|
|
74
74
|
break;
|
|
75
75
|
}
|
|
76
76
|
else {
|
|
77
|
-
const floatingIndex =
|
|
77
|
+
const floatingIndex = parentifiedLayout.floatingPanes.indexOf(trace[0]);
|
|
78
78
|
if (trace[0].isEmpty && (floatingIndex > -1)) {
|
|
79
|
-
|
|
79
|
+
parentifiedLayout.$original.floatingPanes.splice(floatingIndex, 1);
|
|
80
80
|
}
|
|
81
81
|
}
|
|
82
82
|
}
|
|
@@ -103,8 +103,9 @@ export class BsDockPanelHeaderComponent {
|
|
|
103
103
|
offsetY: ev.offsetY,
|
|
104
104
|
floatingPane
|
|
105
105
|
};
|
|
106
|
-
|
|
107
|
-
|
|
106
|
+
parentifiedLayout.$original.floatingPanes.push(floatingPane);
|
|
107
|
+
// debugger;
|
|
108
|
+
setTimeout(() => this.dock.layout$.next(parentifiedLayout.$original), 5);
|
|
108
109
|
// console.log('traces', { traces, matching, dockPanel: this.dockPanel, equals: traces[2].trace[3] });
|
|
109
110
|
// let element: HTMLElement | null = this.element.nativeElement;
|
|
110
111
|
// let tree: HTMLElement[] = [];
|
|
@@ -191,58 +192,64 @@ export class BsDockPanelHeaderComponent {
|
|
|
191
192
|
throw 'Unknown pane type';
|
|
192
193
|
}
|
|
193
194
|
}
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
195
|
+
removeFromPane(host, panel /*, parents: BsDockPane[] */) {
|
|
196
|
+
if (host instanceof BsContentPane) {
|
|
197
|
+
return { paneRemoved: false, hostIsEmpty: false };
|
|
198
|
+
}
|
|
199
|
+
else if (host instanceof BsDocumentHost) {
|
|
200
|
+
// Actually documentHost should never be removed
|
|
201
|
+
if (!host.rootPane) {
|
|
202
|
+
return { paneRemoved: false, hostIsEmpty: true };
|
|
203
|
+
}
|
|
204
|
+
const result = this.removeFromPane(host.rootPane, panel);
|
|
205
|
+
return { paneRemoved: result.paneRemoved, hostIsEmpty: result.hostIsEmpty };
|
|
206
|
+
}
|
|
207
|
+
else if (host instanceof BsTabGroupPane) {
|
|
208
|
+
const matching = host.panes.filter(p => p.dockPanel === panel);
|
|
209
|
+
if (matching.length > 0) {
|
|
210
|
+
host.panes.splice(host.panes.findIndex(p => p.dockPanel === panel), 1);
|
|
211
|
+
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
// ATM. all panes are ContentPanes anyway.
|
|
215
|
+
// So unless you'd want to have splitters inside the tabs,
|
|
216
|
+
// This code will not be hit.
|
|
217
|
+
// const result = host.panes
|
|
218
|
+
// .map(parentPane => this.removeFromPane(parentPane, panel))
|
|
219
|
+
// .filter(r => r.paneRemoved);
|
|
220
|
+
//
|
|
221
|
+
// if (result.length > 0) {
|
|
222
|
+
// return { paneRemoved: true, hostIsEmpty: }
|
|
223
|
+
// }
|
|
224
|
+
return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
else if (host instanceof BsSplitPane) {
|
|
228
|
+
const matching = host.panes
|
|
229
|
+
.filter(p => p instanceof BsContentPane)
|
|
230
|
+
.map(p => p)
|
|
231
|
+
.filter(p => p.dockPanel === panel);
|
|
232
|
+
if (matching.length > 0) {
|
|
233
|
+
host.panes.splice(host.panes.findIndex(p => (p instanceof BsContentPane) && matching.includes(p)), 1);
|
|
234
|
+
// TODO: Remove splitter if only 1 pane left?
|
|
235
|
+
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
236
|
+
}
|
|
237
|
+
else {
|
|
238
|
+
for (let splitPane of host.panes) {
|
|
239
|
+
const result = this.removeFromPane(splitPane, panel);
|
|
240
|
+
if (result.paneRemoved && result.hostIsEmpty) {
|
|
241
|
+
// splitPane is empty now, so we can remove it from this splitter
|
|
242
|
+
host.panes.splice(host.panes.indexOf(splitPane), 1);
|
|
243
|
+
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
248
|
+
}
|
|
249
|
+
else {
|
|
250
|
+
throw 'unknown host type';
|
|
251
|
+
}
|
|
252
|
+
}
|
|
246
253
|
onMouseUp(ev) {
|
|
247
254
|
this.isMouseDown = false;
|
|
248
255
|
this.isDragging = false;
|
|
@@ -267,4 +274,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
267
274
|
type: HostBinding,
|
|
268
275
|
args: ['class.d-block']
|
|
269
276
|
}] } });
|
|
270
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dock-panel-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/dock/src/dock-panel-header/dock-panel-header.component.ts","../../../../../../../libs/mintplayer-ng-bootstrap/dock/src/dock-panel-header/dock-panel-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, HostListener, Inject, Optional, forwardRef } from '@angular/core';\nimport { take } from 'rxjs';\nimport { BsTabControlComponent } from '@mintplayer/ng-bootstrap/tab-control';\nimport { Parentified } from '@mintplayer/parentify';\nimport { BsDockPanelComponent } from '../dock-panel/dock-panel.component';\nimport { BsDockComponent } from '../dock/dock.component';\nimport { BsDockPane } from '../panes/dock-pane';\nimport { BsSplitPane } from '../panes/split-pane';\nimport { BsContentPane } from '../panes/content-pane';\nimport { BsFloatingPane } from '../panes/floating-pane';\nimport { BsTabGroupPane } from '../panes/tab-group-pane';\nimport { BsDocumentHost } from '../panes/document-host-pane';\nimport { RemoveFromPaneResult } from '../interfaces/remove-from-pane-result';\nimport { DragOperation } from '../interfaces/drag-operation';\nimport { BsDockService } from '../services/dock/dock.service';\n\n@Component({\n  selector: 'bs-dock-panel-header',\n  templateUrl: './dock-panel-header.component.html',\n  styleUrls: ['./dock-panel-header.component.scss']\n})\nexport class BsDockPanelHeaderComponent {\n  constructor(private dockPanel: BsDockPanelComponent, private dock: BsDockComponent, private dockService: BsDockService, private element: ElementRef<HTMLElement>) {}\n\n  isMouseDown = false;\n  dragOperation?: DragOperation;\n  isDragging = false;\n  @HostListener('mousedown', ['$event']) onMouseDown(ev: MouseEvent) {\n    ev.preventDefault();\n    this.isMouseDown = true;\n  }\n\n  @HostListener('document:mousemove', ['$event']) onMouseMove(ev: MouseEvent) {\n    if (this.isMouseDown) {\n      if (!this.isDragging) {\n        this.isDragging = true;\n          \n        this.dock.parentifiedLayout$.pipe(take(1)).subscribe((layout) => {\n        // this.dock.layout$.pipe(take(1)).subscribe((layout) => {\n          const traces = this.dockService.buildTraces(layout);\n          console.log('traces', {layout, traces});\n          const matching = traces.filter(t => {\n            const lastPane = t.trace[t.trace.length - 1];\n            // return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);\n            return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);\n          });\n          console.log('matching', matching);\n          if (matching.length !== 1) {\n            return;\n          }\n\n          // const tabs = matching[0].trace.filter(pane => pane instanceof BsTabGroupPane);\n          // const lastTabGroup = tabs[tabs.length - 1];\n          // // console.log('last tabgroup', lastTabGroup);\n\n          let tabControlEl = this.element.nativeElement;\n          do {\n            if (tabControlEl.parentElement) {\n              tabControlEl = tabControlEl!.parentElement;\n            } else {\n              throw 'No more parents';\n            }\n          } while (tabControlEl.tagName.toUpperCase() !== 'BS-TAB-CONTROL');\n\n          const coords = {\n            width: tabControlEl.clientWidth,\n            height: tabControlEl.clientHeight,\n            left: ev.clientX - ev.offsetX,\n            top: ev.clientY - ev.offsetY,\n          };\n\n          // this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();\n          // this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();\n          // this.removeFromPane(layout.rootPane, this.dockPanel);\n\n          const trace = [...matching[0].trace];\n\n          this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();\n          this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();\n          \n          \n          for (let index = trace.length - 1; index >= 0; index--) {\n            if (index > 0) {\n              this.removeFromPaneBis(trace[index - 1], trace[index]);\n              if (!trace[index - 1].isEmpty) break;\n            } else {\n              const floatingIndex = layout.floatingPanes.indexOf(trace[0]);\n              if (trace[0].isEmpty && (floatingIndex > -1)) {\n                layout.floatingPanes.splice(floatingIndex, 1);\n              }\n            }\n          }\n\n\n\n          // this.removeFromPane((<any>matching[0].trace[0])['$original'], this.dockPanel);\n\n          const floatingPane = new BsFloatingPane({\n            pane: new BsTabGroupPane({\n              panes: [\n                new BsContentPane({\n                  dockPanel: this.dockPanel\n                })\n              ]\n            }),\n            size: {\n              width: coords.width,\n              height: coords.height,\n            },\n            location: {\n              x: coords.left,\n              y: coords.top,\n            }\n          });\n          this.dragOperation = {\n            offsetX: ev.offsetX,\n            offsetY: ev.offsetY,\n            floatingPane\n          };\n          layout.floatingPanes.push(floatingPane);\n          setTimeout(() => this.dock.layout$.next(layout), 5);\n          // console.log('traces', { traces, matching, dockPanel: this.dockPanel, equals: traces[2].trace[3] });\n\n          //     let element: HTMLElement | null = this.element.nativeElement;\n          //     let tree: HTMLElement[] = [];\n          //     do {\n          //       tree.push(element!);\n          //       element = element!.parentElement;\n          //     } while (element);\n\n          //     const tabControls = tree.filter(el => el.tagName.toUpperCase() === 'BS-TAB-CONTROL');\n          //     if (tabControls.length > 0) {\n          //       const coords = {\n          //         width: tabControls[0].clientWidth,\n          //         height: tabControls[0].clientHeight,\n          //         left: ev.clientX - ev.offsetX,\n          //         top: ev.clientY - ev.offsetY,\n          //       };\n\n          //       this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();\n          //       this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();\n          //       this.removeFromPane(layout.rootPane, this.dockPanel);\n\n          //       const floatingPane = new BsFloatingPane({\n          //         pane: new BsTabGroupPane({\n          //           panes: [\n          //             new BsContentPane({\n          //               dockPanel: this.dockPanel\n          //             })\n          //           ]\n          //         }),\n          //         size: {\n          //           width: coords.width,\n          //           height: coords.height,\n          //         },\n          //         location: {\n          //           x: coords.left,\n          //           y: coords.top,\n          //         }\n          //       });\n                \n          //       this.dragOperation = {\n          //         offsetX: ev.offsetX,\n          //         offsetY: ev.offsetY,\n          //         floatingPane\n          //       };\n\n          //       layout.floatingPanes.push(floatingPane);\n          //       this.dock.layout$.next(layout);\n          //     }\n        });\n      } else {\n        if (this.dragOperation) {\n          if (this.dragOperation.floatingPane.location) {\n            this.dragOperation.floatingPane.location.x = ev.clientX - this.dragOperation.offsetX;\n            this.dragOperation.floatingPane.location.y = ev.clientY - this.dragOperation.offsetY;\n          }\n      //   } else {\n      //     const traces = this.dockService.buildTraces(this.dock.layout);\n      //     const matchingTrace = traces.filter(trace => {\n      //       const pane = trace.trace[trace.trace.length - 1];\n      //       return (pane instanceof BsContentPane) && (pane.dockPanel === this.dockPanel);\n      //     });\n\n      //     console.log('matching', { traces, matchingTrace });\n      //     // this.dragOperation = {\n            \n      //     // }\n        }\n      }\n    }\n  }\n\n  removeFromPaneBis(host: BsDockPane, pane: BsDockPane) {\n    if (host instanceof BsContentPane) {\n    } else if (host instanceof BsDocumentHost) {\n      // Actually documentHost should never be removed\n    } else if (host instanceof BsTabGroupPane) {\n      if (pane instanceof BsContentPane) {\n        const index = host.panes.indexOf(pane);\n        host.panes.splice(index, 1);\n      }\n    } else if (host instanceof BsSplitPane) {\n      const index = host.panes.indexOf(pane);\n      host.panes.splice(index, 1);\n    } else if (host instanceof BsFloatingPane) {\n    } else {\n      throw 'Unknown pane type';\n    }\n  }\n\n  // removeFromPane(host: BsDockPane, panel: BsDockPanelComponent /*, parents: BsDockPane[] */): RemoveFromPaneResult {\n  //   if (host instanceof BsContentPane) {\n  //     return { paneRemoved: false, hostIsEmpty: false };\n  //   } else if (host instanceof BsDocumentHost) {\n  //     // Actually documentHost should never be removed\n\n  //     if (!host.rootPane) {\n  //       return { paneRemoved: false, hostIsEmpty: true };\n  //     }\n\n  //     const result = this.removeFromPane(host.rootPane, panel);\n  //     return { paneRemoved: result.paneRemoved, hostIsEmpty: result.hostIsEmpty };\n\n  //   } else if (host instanceof BsTabGroupPane) {\n\n\n\n  //     const matching = host.panes.filter(p => p.dockPanel === panel);\n  //     if (matching.length > 0) {\n  //       host.panes.splice(host.panes.findIndex(p => p.dockPanel === panel), 1);\n  //       return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };\n  //     } else {\n  //       // ATM. all panes are ContentPanes anyway.\n  //       // So unless you'd want to have splitters inside the tabs,\n  //       // This code will not be hit.\n\n  //       // const result = host.panes\n  //       //   .map(parentPane => this.removeFromPane(parentPane, panel))\n  //       //   .filter(r => r.paneRemoved);\n  //       //\n  //       // if (result.length > 0) {\n  //       //   return { paneRemoved: true, hostIsEmpty: }\n  //       // }\n  //       return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };\n  //     }\n\n\n\n\n  //   } else if (host instanceof BsSplitPane) {\n  //     const matching = host.panes\n  //       .filter(p => p instanceof BsContentPane)\n  //       .map(p => <BsContentPane>p)\n  //       .filter(p => p.dockPanel === panel);\n      \n  //     if (matching.length > 0) {\n  //       host.panes.splice(host.panes.findIndex(p => (p instanceof BsContentPane) && matching.includes(p)), 1);\n\n  //       // TODO: Remove splitter if only 1 pane left?\n  //       return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };\n  //     } else {\n\n\n  //       for (let splitPane of host.panes) {\n  //         const result = this.removeFromPane(splitPane, panel);\n  //         if (result.paneRemoved && result.hostIsEmpty) {\n  //           // splitPane is empty now, so we can remove it from this splitter\n  //           host.panes.splice(host.panes.indexOf(splitPane), 1);\n  //           return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };\n  //         }\n  //       }\n  //     }\n\n  //     return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };\n  //   } else {\n  //     throw 'unknown host type';\n  //   }\n  // }\n\n  @HostListener('document:mouseup', ['$event']) onMouseUp(ev: Event) {\n    this.isMouseDown = false;\n    this.isDragging = false;\n    this.dragOperation = undefined;\n  }\n\n  @HostBinding('class.d-block') dBlock = true;\n}\n","<ng-content></ng-content>"]}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dock-panel-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/dock/src/dock-panel-header/dock-panel-header.component.ts","../../../../../../../libs/mintplayer-ng-bootstrap/dock/src/dock-panel-header/dock-panel-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, HostListener, Inject, Optional, forwardRef } from '@angular/core';\nimport { take } from 'rxjs';\nimport { BsTabControlComponent } from '@mintplayer/ng-bootstrap/tab-control';\nimport { Parentified } from '@mintplayer/parentify';\nimport { BsDockPanelComponent } from '../dock-panel/dock-panel.component';\nimport { BsDockComponent } from '../dock/dock.component';\nimport { BsDockPane } from '../panes/dock-pane';\nimport { BsSplitPane } from '../panes/split-pane';\nimport { BsContentPane } from '../panes/content-pane';\nimport { BsFloatingPane } from '../panes/floating-pane';\nimport { BsTabGroupPane } from '../panes/tab-group-pane';\nimport { BsDocumentHost } from '../panes/document-host-pane';\nimport { RemoveFromPaneResult } from '../interfaces/remove-from-pane-result';\nimport { DragOperation } from '../interfaces/drag-operation';\nimport { BsDockService } from '../services/dock/dock.service';\n\n@Component({\n  selector: 'bs-dock-panel-header',\n  templateUrl: './dock-panel-header.component.html',\n  styleUrls: ['./dock-panel-header.component.scss']\n})\nexport class BsDockPanelHeaderComponent {\n  constructor(private dockPanel: BsDockPanelComponent, private dock: BsDockComponent, private dockService: BsDockService, private element: ElementRef<HTMLElement>) {}\n\n  isMouseDown = false;\n  dragOperation?: DragOperation;\n  isDragging = false;\n  @HostListener('mousedown', ['$event']) onMouseDown(ev: MouseEvent) {\n    ev.preventDefault();\n    this.isMouseDown = true;\n  }\n\n  @HostListener('document:mousemove', ['$event']) onMouseMove(ev: MouseEvent) {\n    if (this.isMouseDown) {\n      if (!this.isDragging) {\n        this.isDragging = true;\n          \n        this.dock.parentifiedLayout$.pipe(take(1)).subscribe((parentifiedLayout) => {\n        // this.dock.layout$.pipe(take(1)).subscribe((layout) => {\n          const traces = this.dockService.buildTraces(parentifiedLayout);\n          console.log('traces', {parentifiedLayout, traces});\n          const matching = traces.filter(t => {\n            const lastPane = t.trace[t.trace.length - 1];\n            // return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);\n            return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);\n          });\n          console.log('matching', matching);\n          if (matching.length !== 1) {\n            return;\n          }\n\n          // const tabs = matching[0].trace.filter(pane => pane instanceof BsTabGroupPane);\n          // const lastTabGroup = tabs[tabs.length - 1];\n          // // console.log('last tabgroup', lastTabGroup);\n\n          let tabControlEl = this.element.nativeElement;\n          do {\n            if (tabControlEl.parentElement) {\n              tabControlEl = tabControlEl!.parentElement;\n            } else {\n              throw 'No more parents';\n            }\n          } while (tabControlEl.tagName.toUpperCase() !== 'BS-TAB-CONTROL');\n\n          const coords = {\n            width: tabControlEl.clientWidth,\n            height: tabControlEl.clientHeight,\n            left: ev.clientX - ev.offsetX,\n            top: ev.clientY - ev.offsetY,\n          };\n\n          // this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();\n          // this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();\n          this.removeFromPane(parentifiedLayout.$original.rootPane, this.dockPanel);\n\n          const trace = [...matching[0].trace];\n\n          this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();\n          this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();\n          \n          \n          for (let index = trace.length - 1; index >= 0; index--) {\n            if (index > 0) {\n              this.removeFromPaneBis(trace[index - 1], trace[index]);\n              if (!trace[index - 1].isEmpty) break;\n            } else {\n              const floatingIndex = parentifiedLayout.floatingPanes.indexOf(trace[0]);\n              if (trace[0].isEmpty && (floatingIndex > -1)) {\n                parentifiedLayout.$original.floatingPanes.splice(floatingIndex, 1);\n              }\n            }\n          }\n\n\n\n          // this.removeFromPane((<any>matching[0].trace[0])['$original'], this.dockPanel);\n\n          const floatingPane = new BsFloatingPane({\n            pane: new BsTabGroupPane({\n              panes: [\n                new BsContentPane({\n                  dockPanel: this.dockPanel\n                })\n              ]\n            }),\n            size: {\n              width: coords.width,\n              height: coords.height,\n            },\n            location: {\n              x: coords.left,\n              y: coords.top,\n            }\n          });\n          this.dragOperation = {\n            offsetX: ev.offsetX,\n            offsetY: ev.offsetY,\n            floatingPane\n          };\n          parentifiedLayout.$original.floatingPanes.push(floatingPane);\n          // debugger;\n          setTimeout(() => this.dock.layout$.next(parentifiedLayout.$original), 5);\n          // console.log('traces', { traces, matching, dockPanel: this.dockPanel, equals: traces[2].trace[3] });\n\n          //     let element: HTMLElement | null = this.element.nativeElement;\n          //     let tree: HTMLElement[] = [];\n          //     do {\n          //       tree.push(element!);\n          //       element = element!.parentElement;\n          //     } while (element);\n\n          //     const tabControls = tree.filter(el => el.tagName.toUpperCase() === 'BS-TAB-CONTROL');\n          //     if (tabControls.length > 0) {\n          //       const coords = {\n          //         width: tabControls[0].clientWidth,\n          //         height: tabControls[0].clientHeight,\n          //         left: ev.clientX - ev.offsetX,\n          //         top: ev.clientY - ev.offsetY,\n          //       };\n\n          //       this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();\n          //       this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();\n          //       this.removeFromPane(layout.rootPane, this.dockPanel);\n\n          //       const floatingPane = new BsFloatingPane({\n          //         pane: new BsTabGroupPane({\n          //           panes: [\n          //             new BsContentPane({\n          //               dockPanel: this.dockPanel\n          //             })\n          //           ]\n          //         }),\n          //         size: {\n          //           width: coords.width,\n          //           height: coords.height,\n          //         },\n          //         location: {\n          //           x: coords.left,\n          //           y: coords.top,\n          //         }\n          //       });\n                \n          //       this.dragOperation = {\n          //         offsetX: ev.offsetX,\n          //         offsetY: ev.offsetY,\n          //         floatingPane\n          //       };\n\n          //       layout.floatingPanes.push(floatingPane);\n          //       this.dock.layout$.next(layout);\n          //     }\n        });\n      } else {\n        if (this.dragOperation) {\n          if (this.dragOperation.floatingPane.location) {\n            this.dragOperation.floatingPane.location.x = ev.clientX - this.dragOperation.offsetX;\n            this.dragOperation.floatingPane.location.y = ev.clientY - this.dragOperation.offsetY;\n          }\n      //   } else {\n      //     const traces = this.dockService.buildTraces(this.dock.layout);\n      //     const matchingTrace = traces.filter(trace => {\n      //       const pane = trace.trace[trace.trace.length - 1];\n      //       return (pane instanceof BsContentPane) && (pane.dockPanel === this.dockPanel);\n      //     });\n\n      //     console.log('matching', { traces, matchingTrace });\n      //     // this.dragOperation = {\n            \n      //     // }\n        }\n      }\n    }\n  }\n\n  removeFromPaneBis(host: BsDockPane, pane: BsDockPane) {\n    if (host instanceof BsContentPane) {\n    } else if (host instanceof BsDocumentHost) {\n      // Actually documentHost should never be removed\n    } else if (host instanceof BsTabGroupPane) {\n      if (pane instanceof BsContentPane) {\n        const index = host.panes.indexOf(pane);\n        host.panes.splice(index, 1);\n      }\n    } else if (host instanceof BsSplitPane) {\n      const index = host.panes.indexOf(pane);\n      host.panes.splice(index, 1);\n    } else if (host instanceof BsFloatingPane) {\n    } else {\n      throw 'Unknown pane type';\n    }\n  }\n\n  removeFromPane(host: BsDockPane, panel: BsDockPanelComponent /*, parents: BsDockPane[] */): RemoveFromPaneResult {\n    if (host instanceof BsContentPane) {\n      return { paneRemoved: false, hostIsEmpty: false };\n    } else if (host instanceof BsDocumentHost) {\n      // Actually documentHost should never be removed\n\n      if (!host.rootPane) {\n        return { paneRemoved: false, hostIsEmpty: true };\n      }\n\n      const result = this.removeFromPane(host.rootPane, panel);\n      return { paneRemoved: result.paneRemoved, hostIsEmpty: result.hostIsEmpty };\n\n    } else if (host instanceof BsTabGroupPane) {\n\n\n\n      const matching = host.panes.filter(p => p.dockPanel === panel);\n      if (matching.length > 0) {\n        host.panes.splice(host.panes.findIndex(p => p.dockPanel === panel), 1);\n        return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };\n      } else {\n        // ATM. all panes are ContentPanes anyway.\n        // So unless you'd want to have splitters inside the tabs,\n        // This code will not be hit.\n\n        // const result = host.panes\n        //   .map(parentPane => this.removeFromPane(parentPane, panel))\n        //   .filter(r => r.paneRemoved);\n        //\n        // if (result.length > 0) {\n        //   return { paneRemoved: true, hostIsEmpty: }\n        // }\n        return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };\n      }\n\n\n\n\n    } else if (host instanceof BsSplitPane) {\n      const matching = host.panes\n        .filter(p => p instanceof BsContentPane)\n        .map(p => <BsContentPane>p)\n        .filter(p => p.dockPanel === panel);\n      \n      if (matching.length > 0) {\n        host.panes.splice(host.panes.findIndex(p => (p instanceof BsContentPane) && matching.includes(p)), 1);\n\n        // TODO: Remove splitter if only 1 pane left?\n        return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };\n      } else {\n\n\n        for (let splitPane of host.panes) {\n          const result = this.removeFromPane(splitPane, panel);\n          if (result.paneRemoved && result.hostIsEmpty) {\n            // splitPane is empty now, so we can remove it from this splitter\n            host.panes.splice(host.panes.indexOf(splitPane), 1);\n            return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };\n          }\n        }\n      }\n\n      return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };\n    } else {\n      throw 'unknown host type';\n    }\n  }\n\n  @HostListener('document:mouseup', ['$event']) onMouseUp(ev: Event) {\n    this.isMouseDown = false;\n    this.isDragging = false;\n    this.dragOperation = undefined;\n  }\n\n  @HostBinding('class.d-block') dBlock = true;\n}\n","<ng-content></ng-content>"]}
|
|
@@ -177,7 +177,8 @@ class BsDockComponent {
|
|
|
177
177
|
const clone = deepClone(layout, true,
|
|
178
178
|
// []
|
|
179
179
|
[BsContentPane, BsDocumentHost, BsFloatingPane, BsSplitPane, BsTabGroupPane], true, this.paneCache);
|
|
180
|
-
this.paneCache = clone.cache;
|
|
180
|
+
// this.paneCache = clone.cache;
|
|
181
|
+
console.log('parentify', { layout, result: clone.result });
|
|
181
182
|
return clone.result;
|
|
182
183
|
}));
|
|
183
184
|
this.parentifiedLayout$.pipe(takeUntil(this.destroyed$)).subscribe(console.log);
|
|
@@ -296,11 +297,11 @@ class BsDockPanelHeaderComponent {
|
|
|
296
297
|
if (this.isMouseDown) {
|
|
297
298
|
if (!this.isDragging) {
|
|
298
299
|
this.isDragging = true;
|
|
299
|
-
this.dock.parentifiedLayout$.pipe(take(1)).subscribe((
|
|
300
|
+
this.dock.parentifiedLayout$.pipe(take(1)).subscribe((parentifiedLayout) => {
|
|
300
301
|
var _a, _b, _c, _d;
|
|
301
302
|
// this.dock.layout$.pipe(take(1)).subscribe((layout) => {
|
|
302
|
-
const traces = this.dockService.buildTraces(
|
|
303
|
-
console.log('traces', {
|
|
303
|
+
const traces = this.dockService.buildTraces(parentifiedLayout);
|
|
304
|
+
console.log('traces', { parentifiedLayout, traces });
|
|
304
305
|
const matching = traces.filter(t => {
|
|
305
306
|
const lastPane = t.trace[t.trace.length - 1];
|
|
306
307
|
// return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);
|
|
@@ -330,7 +331,7 @@ class BsDockPanelHeaderComponent {
|
|
|
330
331
|
};
|
|
331
332
|
// this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();
|
|
332
333
|
// this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();
|
|
333
|
-
|
|
334
|
+
this.removeFromPane(parentifiedLayout.$original.rootPane, this.dockPanel);
|
|
334
335
|
const trace = [...matching[0].trace];
|
|
335
336
|
((_a = this.dockPanel.headerPortal) === null || _a === void 0 ? void 0 : _a.isAttached) && ((_b = this.dockPanel.headerPortal) === null || _b === void 0 ? void 0 : _b.detach());
|
|
336
337
|
((_c = this.dockPanel.contentPortal) === null || _c === void 0 ? void 0 : _c.isAttached) && ((_d = this.dockPanel.contentPortal) === null || _d === void 0 ? void 0 : _d.detach());
|
|
@@ -341,9 +342,9 @@ class BsDockPanelHeaderComponent {
|
|
|
341
342
|
break;
|
|
342
343
|
}
|
|
343
344
|
else {
|
|
344
|
-
const floatingIndex =
|
|
345
|
+
const floatingIndex = parentifiedLayout.floatingPanes.indexOf(trace[0]);
|
|
345
346
|
if (trace[0].isEmpty && (floatingIndex > -1)) {
|
|
346
|
-
|
|
347
|
+
parentifiedLayout.$original.floatingPanes.splice(floatingIndex, 1);
|
|
347
348
|
}
|
|
348
349
|
}
|
|
349
350
|
}
|
|
@@ -370,8 +371,9 @@ class BsDockPanelHeaderComponent {
|
|
|
370
371
|
offsetY: ev.offsetY,
|
|
371
372
|
floatingPane
|
|
372
373
|
};
|
|
373
|
-
|
|
374
|
-
|
|
374
|
+
parentifiedLayout.$original.floatingPanes.push(floatingPane);
|
|
375
|
+
// debugger;
|
|
376
|
+
setTimeout(() => this.dock.layout$.next(parentifiedLayout.$original), 5);
|
|
375
377
|
// console.log('traces', { traces, matching, dockPanel: this.dockPanel, equals: traces[2].trace[3] });
|
|
376
378
|
// let element: HTMLElement | null = this.element.nativeElement;
|
|
377
379
|
// let tree: HTMLElement[] = [];
|
|
@@ -458,58 +460,64 @@ class BsDockPanelHeaderComponent {
|
|
|
458
460
|
throw 'Unknown pane type';
|
|
459
461
|
}
|
|
460
462
|
}
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
463
|
+
removeFromPane(host, panel /*, parents: BsDockPane[] */) {
|
|
464
|
+
if (host instanceof BsContentPane) {
|
|
465
|
+
return { paneRemoved: false, hostIsEmpty: false };
|
|
466
|
+
}
|
|
467
|
+
else if (host instanceof BsDocumentHost) {
|
|
468
|
+
// Actually documentHost should never be removed
|
|
469
|
+
if (!host.rootPane) {
|
|
470
|
+
return { paneRemoved: false, hostIsEmpty: true };
|
|
471
|
+
}
|
|
472
|
+
const result = this.removeFromPane(host.rootPane, panel);
|
|
473
|
+
return { paneRemoved: result.paneRemoved, hostIsEmpty: result.hostIsEmpty };
|
|
474
|
+
}
|
|
475
|
+
else if (host instanceof BsTabGroupPane) {
|
|
476
|
+
const matching = host.panes.filter(p => p.dockPanel === panel);
|
|
477
|
+
if (matching.length > 0) {
|
|
478
|
+
host.panes.splice(host.panes.findIndex(p => p.dockPanel === panel), 1);
|
|
479
|
+
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
480
|
+
}
|
|
481
|
+
else {
|
|
482
|
+
// ATM. all panes are ContentPanes anyway.
|
|
483
|
+
// So unless you'd want to have splitters inside the tabs,
|
|
484
|
+
// This code will not be hit.
|
|
485
|
+
// const result = host.panes
|
|
486
|
+
// .map(parentPane => this.removeFromPane(parentPane, panel))
|
|
487
|
+
// .filter(r => r.paneRemoved);
|
|
488
|
+
//
|
|
489
|
+
// if (result.length > 0) {
|
|
490
|
+
// return { paneRemoved: true, hostIsEmpty: }
|
|
491
|
+
// }
|
|
492
|
+
return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
else if (host instanceof BsSplitPane) {
|
|
496
|
+
const matching = host.panes
|
|
497
|
+
.filter(p => p instanceof BsContentPane)
|
|
498
|
+
.map(p => p)
|
|
499
|
+
.filter(p => p.dockPanel === panel);
|
|
500
|
+
if (matching.length > 0) {
|
|
501
|
+
host.panes.splice(host.panes.findIndex(p => (p instanceof BsContentPane) && matching.includes(p)), 1);
|
|
502
|
+
// TODO: Remove splitter if only 1 pane left?
|
|
503
|
+
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
504
|
+
}
|
|
505
|
+
else {
|
|
506
|
+
for (let splitPane of host.panes) {
|
|
507
|
+
const result = this.removeFromPane(splitPane, panel);
|
|
508
|
+
if (result.paneRemoved && result.hostIsEmpty) {
|
|
509
|
+
// splitPane is empty now, so we can remove it from this splitter
|
|
510
|
+
host.panes.splice(host.panes.indexOf(splitPane), 1);
|
|
511
|
+
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
512
|
+
}
|
|
513
|
+
}
|
|
514
|
+
}
|
|
515
|
+
return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
516
|
+
}
|
|
517
|
+
else {
|
|
518
|
+
throw 'unknown host type';
|
|
519
|
+
}
|
|
520
|
+
}
|
|
513
521
|
onMouseUp(ev) {
|
|
514
522
|
this.isMouseDown = false;
|
|
515
523
|
this.isDragging = false;
|