@mintplayer/ng-bootstrap 15.25.0 → 15.25.1
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/dock.component.d.ts +3 -1
- package/dock/src/dock-panel-header/dock-panel-header.component.d.ts +5 -4
- package/dock/src/index.d.ts +1 -0
- package/dock/src/panes/content-pane.d.ts +1 -0
- package/dock/src/panes/dock-pane.d.ts +1 -0
- package/dock/src/panes/document-host-pane.d.ts +1 -0
- package/dock/src/panes/floating-pane.d.ts +2 -1
- package/dock/src/panes/split-pane.d.ts +1 -0
- package/dock/src/panes/tab-group-pane.d.ts +1 -0
- package/dock/src/services/dock/dock.service.d.ts +14 -0
- package/dock/src/services/index.d.ts +1 -0
- package/esm2020/dock/src/dock/dock.component.mjs +10 -2
- package/esm2020/dock/src/dock-panel-header/dock-panel-header.component.mjs +202 -96
- package/esm2020/dock/src/index.mjs +2 -1
- package/esm2020/dock/src/panes/content-pane.mjs +4 -1
- package/esm2020/dock/src/panes/dock-pane.mjs +1 -1
- package/esm2020/dock/src/panes/document-host-pane.mjs +4 -1
- package/esm2020/dock/src/panes/floating-pane.mjs +7 -2
- package/esm2020/dock/src/panes/split-pane.mjs +4 -1
- package/esm2020/dock/src/panes/tab-group-pane.mjs +4 -1
- package/esm2020/dock/src/services/dock/dock.service.mjs +56 -0
- package/esm2020/dock/src/services/index.mjs +2 -0
- package/esm2020/resizable/src/resize-glyph/resize-glyph.directive.mjs +1 -1
- package/fesm2015/mintplayer-ng-bootstrap-dock.mjs +287 -111
- package/fesm2015/mintplayer-ng-bootstrap-dock.mjs.map +1 -1
- package/fesm2015/mintplayer-ng-bootstrap-resizable.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap-dock.mjs +285 -111
- package/fesm2020/mintplayer-ng-bootstrap-dock.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap-resizable.mjs.map +1 -1
- package/package.json +2 -2
- package/resizable/src/resize-glyph/resize-glyph.directive.d.ts +1 -1
|
@@ -216,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
216
216
|
type: HostListener,
|
|
217
217
|
args: ['touchend', ['$event']]
|
|
218
218
|
}] } });
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize-glyph.directive.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/resizable/src/resize-glyph/resize-glyph.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, HostBinding, HostListener, Inject, Input, forwardRef, Optional } from '@angular/core';\nimport { Position } from '@mintplayer/ng-bootstrap';\nimport type { BsResizableComponent } from '../resizable/resizable.component';\nimport { ResizeAction } from '../interfaces/resize-action';\nimport { PointerData } from '../interfaces/pointer-data';\nimport { RESIZABLE } from '../providers/resizable.provider';\n\n@Directive({\n  selector: '[bsResizeGlyph]'\n})\nexport class BsResizeGlyphDirective {\n\n  // Can't use typed DI because of the `import type`\n  private resizable: BsResizableComponent;\n  constructor(@Inject(RESIZABLE) resizable: any) {\n    this.resizable = resizable;\n  }\n\n  @HostBinding('class') positions = '';\n  @HostBinding('class.glyph') glyphClass = true;\n  @HostBinding('class.active') activeClass = false;\n\n  @Input() set bsResizeGlyph(value: Position[]) {\n    this.positions = value.join(' ');\n  }\n\n  @HostListener('mousedown', ['$event']) onMouseDown(ev: MouseEvent) {\n    ev.preventDefault();\n    this.onPointerDown()\n  }\n\n  @HostListener('touchstart', ['$event']) onTouchStart(ev: TouchEvent) {\n    ev.preventDefault();\n    this.onPointerDown();\n  }\n\n  @HostListener('document:mousemove', ['$event']) onMouseMove(ev: MouseEvent) {\n    this.onPointerMove({ clientX: ev.clientX, clientY: ev.clientY, preventDefault: () => ev.preventDefault() });\n  }\n\n  @HostListener('touchmove', ['$event']) onTouchMove(ev: TouchEvent) {\n    if (ev.touches.length === 1) {\n      this.onPointerMove({ clientX: ev.touches[0].clientX, clientY: ev.touches[0].clientY, preventDefault: () => ev.preventDefault() });\n    }\n  }\n\n  @HostListener('document:mouseup', ['$event']) onMouseUp(ev: Event) {\n    this.onPointerUp();\n  }\n\n  @HostListener('touchend', ['$event']) onTouchEnd(ev: Event) {\n    this.onPointerUp();\n  }\n\n  onPointerDown() {\n    let action: ResizeAction = {\n      positioning: this.resizable.positioning\n    };\n    const rect = this.resizable.element.nativeElement.getBoundingClientRect();\n    const styles = window.getComputedStyle(this.resizable.element.nativeElement);\n\n    const marginLeft = (this.resizable.positioning === 'absolute') ? undefined : parseFloat(styles.marginLeft.slice(0, -2));\n    const marginRight = (this.resizable.positioning === 'absolute') ? undefined : parseFloat(styles.marginRight.slice(0, -2));\n    const marginTop = (this.resizable.positioning === 'absolute') ? undefined : parseFloat(styles.marginTop.slice(0, -2));\n    const marginBottom = (this.resizable.positioning === 'absolute') ? undefined : parseFloat(styles.marginBottom.slice(0, -2));\n\n    if (this.positions?.includes('start')) {\n      action = {\n        ...action,\n        end: {\n          edge: rect.right,\n          size: rect.width,\n          margin: marginRight,\n          dragMargin: marginLeft\n        },\n      };\n    }\n    if (this.positions?.includes('end')) {\n      action = {\n        ...action,\n        start: {\n          edge: rect.left,\n          size: rect.width,\n          margin: marginLeft,\n          dragMargin: marginRight\n        },\n      };\n    }\n    if (this.positions?.includes('top')) {\n      action = {\n        ...action,\n        bottom: {\n          edge: rect.bottom,\n          size: rect.height,\n          margin: marginBottom,\n          dragMargin: marginTop\n        },\n      };\n    }\n    if (this.positions?.includes('bottom')) {\n      action = {\n        ...action,\n        top: {\n          edge: rect.top,\n          size: rect.height,\n          margin: marginTop,\n          dragMargin: marginBottom\n        },\n      };\n    }\n\n    this.resizable.resizeAction = action;\n    this.activeClass = true;\n  }\n\n  private isBusy = false;\n  onPointerMove(ev: PointerData) {\n    if (this.resizable.resizeAction && !this.isBusy) {\n      ev.preventDefault();\n      this.isBusy = true;\n      const rct = this.resizable.element.nativeElement.getBoundingClientRect();\n      if (this.resizable.resizeAction.start && this.positions?.includes('end')) {\n        // Right glyph\n        const x = (ev.clientX < rct.left + 10) ? rct.left + 10 : ev.clientX;\n        switch (this.resizable.positioning) {\n          case 'inline': {\n            const initalMargin = this.resizable.marginRight ?? 0;\n            this.resizable.marginRight = initalMargin - (x - rct.right);\n          } break;\n          case 'absolute': {\n            this.resizable.width = x - rct.left;\n          } break;\n        }\n      } else if (this.resizable.resizeAction.end && this.positions?.includes('start')) {\n        // Left glyph\n        const x = (ev.clientX > rct.right - 10) ? rct.right - 10 : ev.clientX;\n        switch (this.resizable.positioning) {\n          case 'inline': {\n            const initalMargin = this.resizable.marginLeft ?? 0;\n            this.resizable.marginLeft = initalMargin + x - rct.left;\n          } break;\n          case 'absolute': {\n            this.resizable.left = x;\n            this.resizable.width = this.resizable.resizeAction.end.edge - x;\n          } break;\n        }\n      }\n\n      if (this.resizable.resizeAction.top && this.positions?.includes('bottom')) {\n        // Bottom glyph\n        const y = (ev.clientY < rct.top + 10) ? rct.top + 10 : ev.clientY;\n        switch (this.resizable.positioning) {\n          case 'inline': {\n            const initalMargin = this.resizable.marginBottom ?? 0;\n            this.resizable.height = y - rct.top;\n            this.resizable.marginBottom = initalMargin - (y - rct.bottom);\n          } break;\n          case 'absolute': {\n            this.resizable.height = y - rct.top;\n          } break;\n        }\n      } else if (this.resizable.resizeAction.bottom && this.positions?.includes('top')) {\n        // Top glyph\n        const y = (ev.clientY > rct.bottom - 10) ? rct.bottom - 10 : ev.clientY;\n        switch (this.resizable.positioning) {\n          case 'inline': {\n            const initalMargin = this.resizable.marginTop ?? 0;\n            this.resizable.height = rct.bottom - y;\n            this.resizable.marginTop = initalMargin + y - rct.top;\n          } break;\n          case 'absolute': {\n            this.resizable.top = y;\n            this.resizable.height = this.resizable.resizeAction.bottom.edge - y;\n          } break;\n        }\n      }\n      this.isBusy = false;\n    }\n  }\n  \n  onPointerUp() {\n    this.resizable.resizeAction = undefined;\n    this.activeClass = false;\n  }\n}\n"]}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize-glyph.directive.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/resizable/src/resize-glyph/resize-glyph.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, HostBinding, HostListener, Inject, Input, forwardRef, Optional } from '@angular/core';\nimport { Position } from '@mintplayer/ng-bootstrap';\nimport type { BsResizableComponent } from '../resizable/resizable.component';\nimport { ResizeAction } from '../interfaces/resize-action';\nimport { PointerData } from '../interfaces/pointer-data';\nimport { RESIZABLE } from '../providers/resizable.provider';\n\n@Directive({\n  selector: '[bsResizeGlyph]'\n})\nexport class BsResizeGlyphDirective {\n\n  // Can't use typed DI because of the `import type`\n  private readonly resizable: BsResizableComponent;\n  constructor(@Inject(RESIZABLE) resizable: any) {\n    this.resizable = resizable;\n  }\n\n  @HostBinding('class') positions = '';\n  @HostBinding('class.glyph') glyphClass = true;\n  @HostBinding('class.active') activeClass = false;\n\n  @Input() set bsResizeGlyph(value: Position[]) {\n    this.positions = value.join(' ');\n  }\n\n  @HostListener('mousedown', ['$event']) onMouseDown(ev: MouseEvent) {\n    ev.preventDefault();\n    this.onPointerDown()\n  }\n\n  @HostListener('touchstart', ['$event']) onTouchStart(ev: TouchEvent) {\n    ev.preventDefault();\n    this.onPointerDown();\n  }\n\n  @HostListener('document:mousemove', ['$event']) onMouseMove(ev: MouseEvent) {\n    this.onPointerMove({ clientX: ev.clientX, clientY: ev.clientY, preventDefault: () => ev.preventDefault() });\n  }\n\n  @HostListener('touchmove', ['$event']) onTouchMove(ev: TouchEvent) {\n    if (ev.touches.length === 1) {\n      this.onPointerMove({ clientX: ev.touches[0].clientX, clientY: ev.touches[0].clientY, preventDefault: () => ev.preventDefault() });\n    }\n  }\n\n  @HostListener('document:mouseup', ['$event']) onMouseUp(ev: Event) {\n    this.onPointerUp();\n  }\n\n  @HostListener('touchend', ['$event']) onTouchEnd(ev: Event) {\n    this.onPointerUp();\n  }\n\n  onPointerDown() {\n    let action: ResizeAction = {\n      positioning: this.resizable.positioning\n    };\n    const rect = this.resizable.element.nativeElement.getBoundingClientRect();\n    const styles = window.getComputedStyle(this.resizable.element.nativeElement);\n\n    const marginLeft = (this.resizable.positioning === 'absolute') ? undefined : parseFloat(styles.marginLeft.slice(0, -2));\n    const marginRight = (this.resizable.positioning === 'absolute') ? undefined : parseFloat(styles.marginRight.slice(0, -2));\n    const marginTop = (this.resizable.positioning === 'absolute') ? undefined : parseFloat(styles.marginTop.slice(0, -2));\n    const marginBottom = (this.resizable.positioning === 'absolute') ? undefined : parseFloat(styles.marginBottom.slice(0, -2));\n\n    if (this.positions?.includes('start')) {\n      action = {\n        ...action,\n        end: {\n          edge: rect.right,\n          size: rect.width,\n          margin: marginRight,\n          dragMargin: marginLeft\n        },\n      };\n    }\n    if (this.positions?.includes('end')) {\n      action = {\n        ...action,\n        start: {\n          edge: rect.left,\n          size: rect.width,\n          margin: marginLeft,\n          dragMargin: marginRight\n        },\n      };\n    }\n    if (this.positions?.includes('top')) {\n      action = {\n        ...action,\n        bottom: {\n          edge: rect.bottom,\n          size: rect.height,\n          margin: marginBottom,\n          dragMargin: marginTop\n        },\n      };\n    }\n    if (this.positions?.includes('bottom')) {\n      action = {\n        ...action,\n        top: {\n          edge: rect.top,\n          size: rect.height,\n          margin: marginTop,\n          dragMargin: marginBottom\n        },\n      };\n    }\n\n    this.resizable.resizeAction = action;\n    this.activeClass = true;\n  }\n\n  private isBusy = false;\n  onPointerMove(ev: PointerData) {\n    if (this.resizable.resizeAction && !this.isBusy) {\n      ev.preventDefault();\n      this.isBusy = true;\n      const rct = this.resizable.element.nativeElement.getBoundingClientRect();\n      if (this.resizable.resizeAction.start && this.positions?.includes('end')) {\n        // Right glyph\n        const x = (ev.clientX < rct.left + 10) ? rct.left + 10 : ev.clientX;\n        switch (this.resizable.positioning) {\n          case 'inline': {\n            const initalMargin = this.resizable.marginRight ?? 0;\n            this.resizable.marginRight = initalMargin - (x - rct.right);\n          } break;\n          case 'absolute': {\n            this.resizable.width = x - rct.left;\n          } break;\n        }\n      } else if (this.resizable.resizeAction.end && this.positions?.includes('start')) {\n        // Left glyph\n        const x = (ev.clientX > rct.right - 10) ? rct.right - 10 : ev.clientX;\n        switch (this.resizable.positioning) {\n          case 'inline': {\n            const initalMargin = this.resizable.marginLeft ?? 0;\n            this.resizable.marginLeft = initalMargin + x - rct.left;\n          } break;\n          case 'absolute': {\n            this.resizable.left = x;\n            this.resizable.width = this.resizable.resizeAction.end.edge - x;\n          } break;\n        }\n      }\n\n      if (this.resizable.resizeAction.top && this.positions?.includes('bottom')) {\n        // Bottom glyph\n        const y = (ev.clientY < rct.top + 10) ? rct.top + 10 : ev.clientY;\n        switch (this.resizable.positioning) {\n          case 'inline': {\n            const initalMargin = this.resizable.marginBottom ?? 0;\n            this.resizable.height = y - rct.top;\n            this.resizable.marginBottom = initalMargin - (y - rct.bottom);\n          } break;\n          case 'absolute': {\n            this.resizable.height = y - rct.top;\n          } break;\n        }\n      } else if (this.resizable.resizeAction.bottom && this.positions?.includes('top')) {\n        // Top glyph\n        const y = (ev.clientY > rct.bottom - 10) ? rct.bottom - 10 : ev.clientY;\n        switch (this.resizable.positioning) {\n          case 'inline': {\n            const initalMargin = this.resizable.marginTop ?? 0;\n            this.resizable.height = rct.bottom - y;\n            this.resizable.marginTop = initalMargin + y - rct.top;\n          } break;\n          case 'absolute': {\n            this.resizable.top = y;\n            this.resizable.height = this.resizable.resizeAction.bottom.edge - y;\n          } break;\n        }\n      }\n      this.isBusy = false;\n    }\n  }\n  \n  onPointerUp() {\n    this.resizable.resizeAction = undefined;\n    this.activeClass = false;\n  }\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Component, ViewChild, Input, ContentChildren, ViewChildren, HostBinding, HostListener, NgModule } from '@angular/core';
|
|
2
|
+
import { Component, ViewChild, Input, ContentChildren, ViewChildren, HostBinding, Injectable, HostListener, NgModule } from '@angular/core';
|
|
3
3
|
import * as i2 from '@angular/common';
|
|
4
4
|
import { CommonModule } from '@angular/common';
|
|
5
5
|
import * as i3 from '@angular/cdk/portal';
|
|
@@ -13,7 +13,8 @@ import * as i6 from '@mintplayer/ng-bootstrap/tab-control';
|
|
|
13
13
|
import { BsTabControlModule } from '@mintplayer/ng-bootstrap/tab-control';
|
|
14
14
|
import * as i4 from '@mintplayer/ng-bootstrap/instance-of';
|
|
15
15
|
import { BsInstanceOfModule } from '@mintplayer/ng-bootstrap/instance-of';
|
|
16
|
-
import { BehaviorSubject, Subject, takeUntil, take } from 'rxjs';
|
|
16
|
+
import { BehaviorSubject, Subject, takeUntil, map, take } from 'rxjs';
|
|
17
|
+
import { deepClone } from '@mintplayer/parentify';
|
|
17
18
|
import * as i1 from '@angular/cdk/overlay';
|
|
18
19
|
|
|
19
20
|
class BsDockPanelComponent {
|
|
@@ -49,6 +50,9 @@ class BsTabGroupPane extends BsDockPane {
|
|
|
49
50
|
this.panes = [];
|
|
50
51
|
Object.assign(this, data);
|
|
51
52
|
}
|
|
53
|
+
get isEmpty() {
|
|
54
|
+
return this.panes.length === 0;
|
|
55
|
+
}
|
|
52
56
|
}
|
|
53
57
|
|
|
54
58
|
class BsDocumentHost extends BsDockPane {
|
|
@@ -56,38 +60,53 @@ class BsDocumentHost extends BsDockPane {
|
|
|
56
60
|
super();
|
|
57
61
|
Object.assign(this, data);
|
|
58
62
|
}
|
|
63
|
+
get isEmpty() {
|
|
64
|
+
var _a, _b;
|
|
65
|
+
return (_b = (_a = this.rootPane) === null || _a === void 0 ? void 0 : _a.isEmpty) !== null && _b !== void 0 ? _b : true;
|
|
66
|
+
}
|
|
59
67
|
}
|
|
60
68
|
|
|
61
|
-
|
|
62
|
-
(function (EPaneType) {
|
|
63
|
-
EPaneType[EPaneType["documentHost"] = 1] = "documentHost";
|
|
64
|
-
EPaneType[EPaneType["splitPane"] = 2] = "splitPane";
|
|
65
|
-
EPaneType[EPaneType["contentPane"] = 3] = "contentPane";
|
|
66
|
-
EPaneType[EPaneType["tabGroupPane"] = 4] = "tabGroupPane";
|
|
67
|
-
})(EPaneType || (EPaneType = {}));
|
|
68
|
-
|
|
69
|
-
class BsSplitPane extends BsDockPane {
|
|
69
|
+
class BsContentPane extends BsDockPane {
|
|
70
70
|
constructor(data) {
|
|
71
71
|
super();
|
|
72
|
-
this.orientation = 'horizontal';
|
|
73
|
-
this.panes = [];
|
|
74
72
|
Object.assign(this, data);
|
|
75
73
|
}
|
|
74
|
+
get isEmpty() {
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
76
77
|
}
|
|
77
78
|
|
|
78
|
-
class
|
|
79
|
+
class BsFloatingPane extends BsDockPane {
|
|
79
80
|
constructor(data) {
|
|
80
81
|
super();
|
|
81
82
|
Object.assign(this, data);
|
|
82
83
|
}
|
|
84
|
+
get isEmpty() {
|
|
85
|
+
var _a, _b;
|
|
86
|
+
return (_b = (_a = this.pane) === null || _a === void 0 ? void 0 : _a.isEmpty) !== null && _b !== void 0 ? _b : true;
|
|
87
|
+
}
|
|
83
88
|
}
|
|
84
89
|
|
|
85
|
-
class
|
|
90
|
+
class BsSplitPane extends BsDockPane {
|
|
86
91
|
constructor(data) {
|
|
92
|
+
super();
|
|
93
|
+
this.orientation = 'horizontal';
|
|
94
|
+
this.panes = [];
|
|
87
95
|
Object.assign(this, data);
|
|
88
96
|
}
|
|
97
|
+
get isEmpty() {
|
|
98
|
+
return this.panes.length === 0;
|
|
99
|
+
}
|
|
89
100
|
}
|
|
90
101
|
|
|
102
|
+
var EPaneType;
|
|
103
|
+
(function (EPaneType) {
|
|
104
|
+
EPaneType[EPaneType["documentHost"] = 1] = "documentHost";
|
|
105
|
+
EPaneType[EPaneType["splitPane"] = 2] = "splitPane";
|
|
106
|
+
EPaneType[EPaneType["contentPane"] = 3] = "contentPane";
|
|
107
|
+
EPaneType[EPaneType["tabGroupPane"] = 4] = "tabGroupPane";
|
|
108
|
+
})(EPaneType || (EPaneType = {}));
|
|
109
|
+
|
|
91
110
|
class BsDockPaneRendererComponent {
|
|
92
111
|
constructor(overlay, element) {
|
|
93
112
|
this.overlay = overlay;
|
|
@@ -154,6 +173,10 @@ class BsDockComponent {
|
|
|
154
173
|
.subscribe((floating) => {
|
|
155
174
|
floating.forEach((panel) => panel.moveToOverlay());
|
|
156
175
|
});
|
|
176
|
+
this.parentifiedLayout$ = this.layout$.pipe(map(layout => deepClone(layout, true,
|
|
177
|
+
// []
|
|
178
|
+
[BsContentPane, BsDocumentHost, BsFloatingPane, BsSplitPane, BsTabGroupPane], true)));
|
|
179
|
+
this.parentifiedLayout$.pipe(takeUntil(this.destroyed$)).subscribe(console.log);
|
|
157
180
|
}
|
|
158
181
|
set panels(value) {
|
|
159
182
|
this.panels$.next(value.toArray());
|
|
@@ -202,13 +225,63 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
202
225
|
args: ['style.right']
|
|
203
226
|
}] } });
|
|
204
227
|
|
|
228
|
+
class BsDockService {
|
|
229
|
+
buildTraces(layout) {
|
|
230
|
+
const result = [layout.rootPane, ...layout.floatingPanes].map(pane => this.buildTracesPrivate([pane]));
|
|
231
|
+
// const result = this.buildTracesPrivate([layout.rootPane]);
|
|
232
|
+
return result.flatMap(traceGroup => traceGroup);
|
|
233
|
+
}
|
|
234
|
+
buildTracesPrivate(currentSequence) {
|
|
235
|
+
const children = this.getChildPanes(currentSequence[currentSequence.length - 1]);
|
|
236
|
+
if (children.length === 0) {
|
|
237
|
+
return [{
|
|
238
|
+
finished: true,
|
|
239
|
+
trace: currentSequence
|
|
240
|
+
}];
|
|
241
|
+
}
|
|
242
|
+
else {
|
|
243
|
+
const result = children.map(child => this.buildTracesPrivate([...currentSequence, child]));
|
|
244
|
+
return result.flatMap(r => r);
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
getChildPanes(pane) {
|
|
248
|
+
if (pane instanceof BsContentPane) {
|
|
249
|
+
return [];
|
|
250
|
+
}
|
|
251
|
+
else if (pane instanceof BsTabGroupPane) {
|
|
252
|
+
return pane.panes;
|
|
253
|
+
}
|
|
254
|
+
else if (pane instanceof BsSplitPane) {
|
|
255
|
+
return pane.panes;
|
|
256
|
+
}
|
|
257
|
+
else if (pane instanceof BsFloatingPane) {
|
|
258
|
+
return pane.pane ? [pane.pane] : [];
|
|
259
|
+
}
|
|
260
|
+
else if (pane instanceof BsDocumentHost) {
|
|
261
|
+
return pane.rootPane ? [pane.rootPane] : [];
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
return [];
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
BsDockService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
269
|
+
BsDockService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockService, providedIn: 'root' });
|
|
270
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockService, decorators: [{
|
|
271
|
+
type: Injectable,
|
|
272
|
+
args: [{
|
|
273
|
+
providedIn: 'root'
|
|
274
|
+
}]
|
|
275
|
+
}] });
|
|
276
|
+
|
|
205
277
|
class BsDockPanelHeaderComponent {
|
|
206
|
-
constructor(dockPanel, dock, element) {
|
|
278
|
+
constructor(dockPanel, dock, dockService, element) {
|
|
207
279
|
this.dockPanel = dockPanel;
|
|
208
280
|
this.dock = dock;
|
|
281
|
+
this.dockService = dockService;
|
|
209
282
|
this.element = element;
|
|
210
283
|
this.isMouseDown = false;
|
|
211
|
-
this.
|
|
284
|
+
this.isDragging = false;
|
|
212
285
|
this.dBlock = true;
|
|
213
286
|
}
|
|
214
287
|
onMouseDown(ev) {
|
|
@@ -217,131 +290,234 @@ class BsDockPanelHeaderComponent {
|
|
|
217
290
|
}
|
|
218
291
|
onMouseMove(ev) {
|
|
219
292
|
if (this.isMouseDown) {
|
|
220
|
-
if (!this.
|
|
221
|
-
this.
|
|
222
|
-
this.dock.
|
|
293
|
+
if (!this.isDragging) {
|
|
294
|
+
this.isDragging = true;
|
|
295
|
+
this.dock.parentifiedLayout$.pipe(take(1)).subscribe((layout) => {
|
|
223
296
|
var _a, _b, _c, _d;
|
|
224
|
-
|
|
225
|
-
|
|
297
|
+
// this.dock.layout$.pipe(take(1)).subscribe((layout) => {
|
|
298
|
+
const traces = this.dockService.buildTraces(layout);
|
|
299
|
+
console.log('traces', { layout, traces });
|
|
300
|
+
const matching = traces.filter(t => {
|
|
301
|
+
const lastPane = t.trace[t.trace.length - 1];
|
|
302
|
+
// return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);
|
|
303
|
+
return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);
|
|
304
|
+
});
|
|
305
|
+
console.log('matching', matching);
|
|
306
|
+
if (matching.length !== 1) {
|
|
307
|
+
return;
|
|
308
|
+
}
|
|
309
|
+
// const tabs = matching[0].trace.filter(pane => pane instanceof BsTabGroupPane);
|
|
310
|
+
// const lastTabGroup = tabs[tabs.length - 1];
|
|
311
|
+
// // console.log('last tabgroup', lastTabGroup);
|
|
312
|
+
let tabControlEl = this.element.nativeElement;
|
|
226
313
|
do {
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
314
|
+
if (tabControlEl.parentElement) {
|
|
315
|
+
tabControlEl = tabControlEl.parentElement;
|
|
316
|
+
}
|
|
317
|
+
else {
|
|
318
|
+
throw 'No more parents';
|
|
319
|
+
}
|
|
320
|
+
} while (tabControlEl.tagName.toUpperCase() !== 'BS-TAB-CONTROL');
|
|
321
|
+
const coords = {
|
|
322
|
+
width: tabControlEl.clientWidth,
|
|
323
|
+
height: tabControlEl.clientHeight,
|
|
324
|
+
left: ev.clientX - ev.offsetX,
|
|
325
|
+
top: ev.clientY - ev.offsetY,
|
|
326
|
+
};
|
|
327
|
+
// this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();
|
|
328
|
+
// this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();
|
|
329
|
+
// this.removeFromPane(layout.rootPane, this.dockPanel);
|
|
330
|
+
const trace = [...matching[0].trace];
|
|
331
|
+
((_a = this.dockPanel.headerPortal) === null || _a === void 0 ? void 0 : _a.isAttached) && ((_b = this.dockPanel.headerPortal) === null || _b === void 0 ? void 0 : _b.detach());
|
|
332
|
+
((_c = this.dockPanel.contentPortal) === null || _c === void 0 ? void 0 : _c.isAttached) && ((_d = this.dockPanel.contentPortal) === null || _d === void 0 ? void 0 : _d.detach());
|
|
333
|
+
for (let index = trace.length - 1; index >= 0; index--) {
|
|
334
|
+
if (index > 0) {
|
|
335
|
+
this.removeFromPaneBis(trace[index - 1], trace[index]);
|
|
336
|
+
if (!trace[index - 1].isEmpty)
|
|
337
|
+
break;
|
|
338
|
+
}
|
|
339
|
+
else {
|
|
340
|
+
const floatingIndex = layout.floatingPanes.indexOf(trace[0]);
|
|
341
|
+
if (trace[0].isEmpty && (floatingIndex > -1)) {
|
|
342
|
+
layout.floatingPanes.splice(floatingIndex, 1);
|
|
256
343
|
}
|
|
257
|
-
}
|
|
258
|
-
this.dragOperation = {
|
|
259
|
-
offsetX: ev.offsetX,
|
|
260
|
-
offsetY: ev.offsetY,
|
|
261
|
-
floatingPane
|
|
262
|
-
};
|
|
263
|
-
layout.floatingPanes.push(floatingPane);
|
|
264
|
-
this.dock.layout$.next(layout);
|
|
344
|
+
}
|
|
265
345
|
}
|
|
346
|
+
// this.removeFromPane((<any>matching[0].trace[0])['$original'], this.dockPanel);
|
|
347
|
+
const floatingPane = new BsFloatingPane({
|
|
348
|
+
pane: new BsTabGroupPane({
|
|
349
|
+
panes: [
|
|
350
|
+
new BsContentPane({
|
|
351
|
+
dockPanel: this.dockPanel
|
|
352
|
+
})
|
|
353
|
+
]
|
|
354
|
+
}),
|
|
355
|
+
size: {
|
|
356
|
+
width: coords.width,
|
|
357
|
+
height: coords.height,
|
|
358
|
+
},
|
|
359
|
+
location: {
|
|
360
|
+
x: coords.left,
|
|
361
|
+
y: coords.top,
|
|
362
|
+
}
|
|
363
|
+
});
|
|
364
|
+
this.dragOperation = {
|
|
365
|
+
offsetX: ev.offsetX,
|
|
366
|
+
offsetY: ev.offsetY,
|
|
367
|
+
floatingPane
|
|
368
|
+
};
|
|
369
|
+
layout.floatingPanes.push(floatingPane);
|
|
370
|
+
setTimeout(() => this.dock.layout$.next(layout), 5);
|
|
371
|
+
// console.log('traces', { traces, matching, dockPanel: this.dockPanel, equals: traces[2].trace[3] });
|
|
372
|
+
// let element: HTMLElement | null = this.element.nativeElement;
|
|
373
|
+
// let tree: HTMLElement[] = [];
|
|
374
|
+
// do {
|
|
375
|
+
// tree.push(element!);
|
|
376
|
+
// element = element!.parentElement;
|
|
377
|
+
// } while (element);
|
|
378
|
+
// const tabControls = tree.filter(el => el.tagName.toUpperCase() === 'BS-TAB-CONTROL');
|
|
379
|
+
// if (tabControls.length > 0) {
|
|
380
|
+
// const coords = {
|
|
381
|
+
// width: tabControls[0].clientWidth,
|
|
382
|
+
// height: tabControls[0].clientHeight,
|
|
383
|
+
// left: ev.clientX - ev.offsetX,
|
|
384
|
+
// top: ev.clientY - ev.offsetY,
|
|
385
|
+
// };
|
|
386
|
+
// this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();
|
|
387
|
+
// this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();
|
|
388
|
+
// this.removeFromPane(layout.rootPane, this.dockPanel);
|
|
389
|
+
// const floatingPane = new BsFloatingPane({
|
|
390
|
+
// pane: new BsTabGroupPane({
|
|
391
|
+
// panes: [
|
|
392
|
+
// new BsContentPane({
|
|
393
|
+
// dockPanel: this.dockPanel
|
|
394
|
+
// })
|
|
395
|
+
// ]
|
|
396
|
+
// }),
|
|
397
|
+
// size: {
|
|
398
|
+
// width: coords.width,
|
|
399
|
+
// height: coords.height,
|
|
400
|
+
// },
|
|
401
|
+
// location: {
|
|
402
|
+
// x: coords.left,
|
|
403
|
+
// y: coords.top,
|
|
404
|
+
// }
|
|
405
|
+
// });
|
|
406
|
+
// this.dragOperation = {
|
|
407
|
+
// offsetX: ev.offsetX,
|
|
408
|
+
// offsetY: ev.offsetY,
|
|
409
|
+
// floatingPane
|
|
410
|
+
// };
|
|
411
|
+
// layout.floatingPanes.push(floatingPane);
|
|
412
|
+
// this.dock.layout$.next(layout);
|
|
413
|
+
// }
|
|
266
414
|
});
|
|
267
415
|
}
|
|
268
|
-
else
|
|
269
|
-
if (this.dragOperation
|
|
270
|
-
this.dragOperation.floatingPane.location
|
|
271
|
-
|
|
416
|
+
else {
|
|
417
|
+
if (this.dragOperation) {
|
|
418
|
+
if (this.dragOperation.floatingPane.location) {
|
|
419
|
+
this.dragOperation.floatingPane.location.x = ev.clientX - this.dragOperation.offsetX;
|
|
420
|
+
this.dragOperation.floatingPane.location.y = ev.clientY - this.dragOperation.offsetY;
|
|
421
|
+
}
|
|
422
|
+
// } else {
|
|
423
|
+
// const traces = this.dockService.buildTraces(this.dock.layout);
|
|
424
|
+
// const matchingTrace = traces.filter(trace => {
|
|
425
|
+
// const pane = trace.trace[trace.trace.length - 1];
|
|
426
|
+
// return (pane instanceof BsContentPane) && (pane.dockPanel === this.dockPanel);
|
|
427
|
+
// });
|
|
428
|
+
// console.log('matching', { traces, matchingTrace });
|
|
429
|
+
// // this.dragOperation = {
|
|
430
|
+
// // }
|
|
272
431
|
}
|
|
273
432
|
}
|
|
274
433
|
}
|
|
275
434
|
}
|
|
276
|
-
|
|
435
|
+
removeFromPaneBis(host, pane) {
|
|
277
436
|
if (host instanceof BsContentPane) {
|
|
278
|
-
return { paneRemoved: false, hostIsEmpty: false };
|
|
279
437
|
}
|
|
280
438
|
else if (host instanceof BsDocumentHost) {
|
|
281
439
|
// Actually documentHost should never be removed
|
|
282
|
-
if (!host.rootPane) {
|
|
283
|
-
return { paneRemoved: false, hostIsEmpty: true };
|
|
284
|
-
}
|
|
285
|
-
const result = this.removeFromPane(host.rootPane, panel);
|
|
286
|
-
return { paneRemoved: result.paneRemoved, hostIsEmpty: result.hostIsEmpty };
|
|
287
440
|
}
|
|
288
441
|
else if (host instanceof BsTabGroupPane) {
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
host.panes.splice(
|
|
292
|
-
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
293
|
-
}
|
|
294
|
-
else {
|
|
295
|
-
// ATM. all panes are ContentPanes anyway.
|
|
296
|
-
// So unless you'd want to have splitters inside the tabs,
|
|
297
|
-
// This code will not be hit.
|
|
298
|
-
// const result = host.panes
|
|
299
|
-
// .map(parentPane => this.removeFromPane(parentPane, panel))
|
|
300
|
-
// .filter(r => r.paneRemoved);
|
|
301
|
-
//
|
|
302
|
-
// if (result.length > 0) {
|
|
303
|
-
// return { paneRemoved: true, hostIsEmpty: }
|
|
304
|
-
// }
|
|
305
|
-
return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
442
|
+
if (pane instanceof BsContentPane) {
|
|
443
|
+
const index = host.panes.indexOf(pane);
|
|
444
|
+
host.panes.splice(index, 1);
|
|
306
445
|
}
|
|
307
446
|
}
|
|
308
447
|
else if (host instanceof BsSplitPane) {
|
|
309
|
-
const
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
if (matching.length > 0) {
|
|
314
|
-
host.panes.splice(host.panes.findIndex(p => (p instanceof BsContentPane) && matching.includes(p)), 1);
|
|
315
|
-
// TODO: Remove splitter if only 1 pane left?
|
|
316
|
-
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
317
|
-
}
|
|
318
|
-
else {
|
|
319
|
-
for (let splitPane of host.panes) {
|
|
320
|
-
const result = this.removeFromPane(splitPane, panel);
|
|
321
|
-
if (result.paneRemoved && result.hostIsEmpty) {
|
|
322
|
-
// splitPane is empty now, so we can remove it from this splitter
|
|
323
|
-
host.panes.splice(host.panes.indexOf(splitPane), 1);
|
|
324
|
-
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
448
|
+
const index = host.panes.indexOf(pane);
|
|
449
|
+
host.panes.splice(index, 1);
|
|
450
|
+
}
|
|
451
|
+
else if (host instanceof BsFloatingPane) {
|
|
329
452
|
}
|
|
330
453
|
else {
|
|
331
|
-
throw '
|
|
454
|
+
throw 'Unknown pane type';
|
|
332
455
|
}
|
|
333
456
|
}
|
|
457
|
+
// removeFromPane(host: BsDockPane, panel: BsDockPanelComponent /*, parents: BsDockPane[] */): RemoveFromPaneResult {
|
|
458
|
+
// if (host instanceof BsContentPane) {
|
|
459
|
+
// return { paneRemoved: false, hostIsEmpty: false };
|
|
460
|
+
// } else if (host instanceof BsDocumentHost) {
|
|
461
|
+
// // Actually documentHost should never be removed
|
|
462
|
+
// if (!host.rootPane) {
|
|
463
|
+
// return { paneRemoved: false, hostIsEmpty: true };
|
|
464
|
+
// }
|
|
465
|
+
// const result = this.removeFromPane(host.rootPane, panel);
|
|
466
|
+
// return { paneRemoved: result.paneRemoved, hostIsEmpty: result.hostIsEmpty };
|
|
467
|
+
// } else if (host instanceof BsTabGroupPane) {
|
|
468
|
+
// const matching = host.panes.filter(p => p.dockPanel === panel);
|
|
469
|
+
// if (matching.length > 0) {
|
|
470
|
+
// host.panes.splice(host.panes.findIndex(p => p.dockPanel === panel), 1);
|
|
471
|
+
// return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
472
|
+
// } else {
|
|
473
|
+
// // ATM. all panes are ContentPanes anyway.
|
|
474
|
+
// // So unless you'd want to have splitters inside the tabs,
|
|
475
|
+
// // This code will not be hit.
|
|
476
|
+
// // const result = host.panes
|
|
477
|
+
// // .map(parentPane => this.removeFromPane(parentPane, panel))
|
|
478
|
+
// // .filter(r => r.paneRemoved);
|
|
479
|
+
// //
|
|
480
|
+
// // if (result.length > 0) {
|
|
481
|
+
// // return { paneRemoved: true, hostIsEmpty: }
|
|
482
|
+
// // }
|
|
483
|
+
// return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
484
|
+
// }
|
|
485
|
+
// } else if (host instanceof BsSplitPane) {
|
|
486
|
+
// const matching = host.panes
|
|
487
|
+
// .filter(p => p instanceof BsContentPane)
|
|
488
|
+
// .map(p => <BsContentPane>p)
|
|
489
|
+
// .filter(p => p.dockPanel === panel);
|
|
490
|
+
// if (matching.length > 0) {
|
|
491
|
+
// host.panes.splice(host.panes.findIndex(p => (p instanceof BsContentPane) && matching.includes(p)), 1);
|
|
492
|
+
// // TODO: Remove splitter if only 1 pane left?
|
|
493
|
+
// return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
494
|
+
// } else {
|
|
495
|
+
// for (let splitPane of host.panes) {
|
|
496
|
+
// const result = this.removeFromPane(splitPane, panel);
|
|
497
|
+
// if (result.paneRemoved && result.hostIsEmpty) {
|
|
498
|
+
// // splitPane is empty now, so we can remove it from this splitter
|
|
499
|
+
// host.panes.splice(host.panes.indexOf(splitPane), 1);
|
|
500
|
+
// return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
501
|
+
// }
|
|
502
|
+
// }
|
|
503
|
+
// }
|
|
504
|
+
// return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
505
|
+
// } else {
|
|
506
|
+
// throw 'unknown host type';
|
|
507
|
+
// }
|
|
508
|
+
// }
|
|
334
509
|
onMouseUp(ev) {
|
|
335
510
|
this.isMouseDown = false;
|
|
511
|
+
this.isDragging = false;
|
|
336
512
|
this.dragOperation = undefined;
|
|
337
513
|
}
|
|
338
514
|
}
|
|
339
|
-
BsDockPanelHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockPanelHeaderComponent, deps: [{ token: BsDockPanelComponent }, { token: BsDockComponent }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
515
|
+
BsDockPanelHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockPanelHeaderComponent, deps: [{ token: BsDockPanelComponent }, { token: BsDockComponent }, { token: BsDockService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
340
516
|
BsDockPanelHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: BsDockPanelHeaderComponent, selector: "bs-dock-panel-header", host: { listeners: { "mousedown": "onMouseDown($event)", "document:mousemove": "onMouseMove($event)", "document:mouseup": "onMouseUp($event)" }, properties: { "class.d-block": "this.dBlock" } }, ngImport: i0, template: "<ng-content></ng-content>", styles: [":host{padding:var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);margin:calc(-1 * var(--bs-nav-link-padding-y)) calc(-1 * var(--bs-nav-link-padding-x))}\n"] });
|
|
341
517
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockPanelHeaderComponent, decorators: [{
|
|
342
518
|
type: Component,
|
|
343
519
|
args: [{ selector: 'bs-dock-panel-header', template: "<ng-content></ng-content>", styles: [":host{padding:var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);margin:calc(-1 * var(--bs-nav-link-padding-y)) calc(-1 * var(--bs-nav-link-padding-x))}\n"] }]
|
|
344
|
-
}], ctorParameters: function () { return [{ type: BsDockPanelComponent }, { type: BsDockComponent }, { type: i0.ElementRef }]; }, propDecorators: { onMouseDown: [{
|
|
520
|
+
}], ctorParameters: function () { return [{ type: BsDockPanelComponent }, { type: BsDockComponent }, { type: BsDockService }, { type: i0.ElementRef }]; }, propDecorators: { onMouseDown: [{
|
|
345
521
|
type: HostListener,
|
|
346
522
|
args: ['mousedown', ['$event']]
|
|
347
523
|
}], onMouseMove: [{
|
|
@@ -409,5 +585,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
409
585
|
* Generated bundle index. Do not edit.
|
|
410
586
|
*/
|
|
411
587
|
|
|
412
|
-
export { BsContentPane, BsDockComponent, BsDockModule, BsDockPane, BsDockPaneRendererComponent, BsDockPanelComponent, BsDockPanelHeaderComponent, BsDocumentHost, BsFloatingPane, BsSplitPane, BsTabGroupPane, EPaneType };
|
|
588
|
+
export { BsContentPane, BsDockComponent, BsDockModule, BsDockPane, BsDockPaneRendererComponent, BsDockPanelComponent, BsDockPanelHeaderComponent, BsDockService, BsDocumentHost, BsFloatingPane, BsSplitPane, BsTabGroupPane, EPaneType };
|
|
413
589
|
//# sourceMappingURL=mintplayer-ng-bootstrap-dock.mjs.map
|