@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.
@@ -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,{"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      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"]}
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((layout) => {
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(layout);
36
- console.log('traces', { layout, 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
- // this.removeFromPane(layout.rootPane, this.dockPanel);
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 = layout.floatingPanes.indexOf(trace[0]);
77
+ const floatingIndex = parentifiedLayout.floatingPanes.indexOf(trace[0]);
78
78
  if (trace[0].isEmpty && (floatingIndex > -1)) {
79
- layout.floatingPanes.splice(floatingIndex, 1);
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
- layout.floatingPanes.push(floatingPane);
107
- setTimeout(() => this.dock.layout$.next(layout), 5);
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
- // removeFromPane(host: BsDockPane, panel: BsDockPanelComponent /*, parents: BsDockPane[] */): RemoveFromPaneResult {
195
- // if (host instanceof BsContentPane) {
196
- // return { paneRemoved: false, hostIsEmpty: false };
197
- // } else if (host instanceof BsDocumentHost) {
198
- // // Actually documentHost should never be removed
199
- // if (!host.rootPane) {
200
- // return { paneRemoved: false, hostIsEmpty: true };
201
- // }
202
- // const result = this.removeFromPane(host.rootPane, panel);
203
- // return { paneRemoved: result.paneRemoved, hostIsEmpty: result.hostIsEmpty };
204
- // } else if (host instanceof BsTabGroupPane) {
205
- // const matching = host.panes.filter(p => p.dockPanel === panel);
206
- // if (matching.length > 0) {
207
- // host.panes.splice(host.panes.findIndex(p => p.dockPanel === panel), 1);
208
- // return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
209
- // } else {
210
- // // ATM. all panes are ContentPanes anyway.
211
- // // So unless you'd want to have splitters inside the tabs,
212
- // // This code will not be hit.
213
- // // const result = host.panes
214
- // // .map(parentPane => this.removeFromPane(parentPane, panel))
215
- // // .filter(r => r.paneRemoved);
216
- // //
217
- // // if (result.length > 0) {
218
- // // return { paneRemoved: true, hostIsEmpty: }
219
- // // }
220
- // return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
221
- // }
222
- // } else if (host instanceof BsSplitPane) {
223
- // const matching = host.panes
224
- // .filter(p => p instanceof BsContentPane)
225
- // .map(p => <BsContentPane>p)
226
- // .filter(p => p.dockPanel === panel);
227
- // if (matching.length > 0) {
228
- // host.panes.splice(host.panes.findIndex(p => (p instanceof BsContentPane) && matching.includes(p)), 1);
229
- // // TODO: Remove splitter if only 1 pane left?
230
- // return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
231
- // } else {
232
- // for (let splitPane of host.panes) {
233
- // const result = this.removeFromPane(splitPane, panel);
234
- // if (result.paneRemoved && result.hostIsEmpty) {
235
- // // splitPane is empty now, so we can remove it from this splitter
236
- // host.panes.splice(host.panes.indexOf(splitPane), 1);
237
- // return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
238
- // }
239
- // }
240
- // }
241
- // return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
242
- // } else {
243
- // throw 'unknown host type';
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((layout) => {
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(layout);
303
- console.log('traces', { layout, 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
- // this.removeFromPane(layout.rootPane, this.dockPanel);
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 = layout.floatingPanes.indexOf(trace[0]);
345
+ const floatingIndex = parentifiedLayout.floatingPanes.indexOf(trace[0]);
345
346
  if (trace[0].isEmpty && (floatingIndex > -1)) {
346
- layout.floatingPanes.splice(floatingIndex, 1);
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
- layout.floatingPanes.push(floatingPane);
374
- setTimeout(() => this.dock.layout$.next(layout), 5);
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
- // removeFromPane(host: BsDockPane, panel: BsDockPanelComponent /*, parents: BsDockPane[] */): RemoveFromPaneResult {
462
- // if (host instanceof BsContentPane) {
463
- // return { paneRemoved: false, hostIsEmpty: false };
464
- // } else if (host instanceof BsDocumentHost) {
465
- // // Actually documentHost should never be removed
466
- // if (!host.rootPane) {
467
- // return { paneRemoved: false, hostIsEmpty: true };
468
- // }
469
- // const result = this.removeFromPane(host.rootPane, panel);
470
- // return { paneRemoved: result.paneRemoved, hostIsEmpty: result.hostIsEmpty };
471
- // } else if (host instanceof BsTabGroupPane) {
472
- // const matching = host.panes.filter(p => p.dockPanel === panel);
473
- // if (matching.length > 0) {
474
- // host.panes.splice(host.panes.findIndex(p => p.dockPanel === panel), 1);
475
- // return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
476
- // } else {
477
- // // ATM. all panes are ContentPanes anyway.
478
- // // So unless you'd want to have splitters inside the tabs,
479
- // // This code will not be hit.
480
- // // const result = host.panes
481
- // // .map(parentPane => this.removeFromPane(parentPane, panel))
482
- // // .filter(r => r.paneRemoved);
483
- // //
484
- // // if (result.length > 0) {
485
- // // return { paneRemoved: true, hostIsEmpty: }
486
- // // }
487
- // return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
488
- // }
489
- // } else if (host instanceof BsSplitPane) {
490
- // const matching = host.panes
491
- // .filter(p => p instanceof BsContentPane)
492
- // .map(p => <BsContentPane>p)
493
- // .filter(p => p.dockPanel === panel);
494
- // if (matching.length > 0) {
495
- // host.panes.splice(host.panes.findIndex(p => (p instanceof BsContentPane) && matching.includes(p)), 1);
496
- // // TODO: Remove splitter if only 1 pane left?
497
- // return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
498
- // } else {
499
- // for (let splitPane of host.panes) {
500
- // const result = this.removeFromPane(splitPane, panel);
501
- // if (result.paneRemoved && result.hostIsEmpty) {
502
- // // splitPane is empty now, so we can remove it from this splitter
503
- // host.panes.splice(host.panes.indexOf(splitPane), 1);
504
- // return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
505
- // }
506
- // }
507
- // }
508
- // return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
509
- // } else {
510
- // throw 'unknown host type';
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;