@mintplayer/ng-bootstrap 15.24.1 → 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/list-group/src/list-group-item/list-group-item.component.mjs +9 -7
- package/esm2020/resizable/src/resize-glyph/resize-glyph.directive.mjs +1 -1
- package/esm2020/treeview/index.mjs +2 -0
- package/esm2020/treeview/mintplayer-ng-bootstrap-treeview.mjs +5 -0
- package/esm2020/treeview/src/index.mjs +4 -0
- package/esm2020/treeview/src/treeview/treeview.component.mjs +46 -0
- package/esm2020/treeview/src/treeview-item/treeview-item.component.mjs +27 -0
- package/esm2020/treeview/src/treeview.module.mjs +21 -0
- package/fesm2015/mintplayer-ng-bootstrap-dock.mjs +287 -111
- package/fesm2015/mintplayer-ng-bootstrap-dock.mjs.map +1 -1
- package/fesm2015/mintplayer-ng-bootstrap-list-group.mjs +8 -6
- package/fesm2015/mintplayer-ng-bootstrap-list-group.mjs.map +1 -1
- package/fesm2015/mintplayer-ng-bootstrap-resizable.mjs.map +1 -1
- package/fesm2015/mintplayer-ng-bootstrap-treeview.mjs +93 -0
- package/fesm2015/mintplayer-ng-bootstrap-treeview.mjs.map +1 -0
- package/fesm2020/mintplayer-ng-bootstrap-dock.mjs +285 -111
- package/fesm2020/mintplayer-ng-bootstrap-dock.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap-list-group.mjs +8 -6
- package/fesm2020/mintplayer-ng-bootstrap-list-group.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap-resizable.mjs.map +1 -1
- package/fesm2020/mintplayer-ng-bootstrap-treeview.mjs +91 -0
- package/fesm2020/mintplayer-ng-bootstrap-treeview.mjs.map +1 -0
- package/list-group/src/list-group-item/list-group-item.component.d.ts +2 -4
- package/package.json +10 -2
- package/resizable/src/resize-glyph/resize-glyph.directive.d.ts +1 -1
- package/treeview/index.d.ts +1 -0
- package/treeview/src/index.d.ts +3 -0
- package/treeview/src/treeview/treeview.component.d.ts +16 -0
- package/treeview/src/treeview-item/treeview-item.component.d.ts +10 -0
- package/treeview/src/treeview.module.d.ts +11 -0
|
@@ -7,16 +7,19 @@ import { BsContentPane } from '../panes/content-pane';
|
|
|
7
7
|
import { BsFloatingPane } from '../panes/floating-pane';
|
|
8
8
|
import { BsTabGroupPane } from '../panes/tab-group-pane';
|
|
9
9
|
import { BsDocumentHost } from '../panes/document-host-pane';
|
|
10
|
+
import { BsDockService } from '../services/dock/dock.service';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
12
|
import * as i1 from "../dock-panel/dock-panel.component";
|
|
12
13
|
import * as i2 from "../dock/dock.component";
|
|
14
|
+
import * as i3 from "../services/dock/dock.service";
|
|
13
15
|
export class BsDockPanelHeaderComponent {
|
|
14
|
-
constructor(dockPanel, dock, element) {
|
|
16
|
+
constructor(dockPanel, dock, dockService, element) {
|
|
15
17
|
this.dockPanel = dockPanel;
|
|
16
18
|
this.dock = dock;
|
|
19
|
+
this.dockService = dockService;
|
|
17
20
|
this.element = element;
|
|
18
21
|
this.isMouseDown = false;
|
|
19
|
-
this.
|
|
22
|
+
this.isDragging = false;
|
|
20
23
|
this.dBlock = true;
|
|
21
24
|
}
|
|
22
25
|
onMouseDown(ev) {
|
|
@@ -25,130 +28,233 @@ export class BsDockPanelHeaderComponent {
|
|
|
25
28
|
}
|
|
26
29
|
onMouseMove(ev) {
|
|
27
30
|
if (this.isMouseDown) {
|
|
28
|
-
if (!this.
|
|
29
|
-
this.
|
|
30
|
-
this.dock.
|
|
31
|
-
|
|
32
|
-
|
|
31
|
+
if (!this.isDragging) {
|
|
32
|
+
this.isDragging = true;
|
|
33
|
+
this.dock.parentifiedLayout$.pipe(take(1)).subscribe((layout) => {
|
|
34
|
+
// this.dock.layout$.pipe(take(1)).subscribe((layout) => {
|
|
35
|
+
const traces = this.dockService.buildTraces(layout);
|
|
36
|
+
console.log('traces', { layout, traces });
|
|
37
|
+
const matching = traces.filter(t => {
|
|
38
|
+
const lastPane = t.trace[t.trace.length - 1];
|
|
39
|
+
// return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);
|
|
40
|
+
return (lastPane instanceof BsContentPane) && (lastPane.dockPanel === this.dockPanel);
|
|
41
|
+
});
|
|
42
|
+
console.log('matching', matching);
|
|
43
|
+
if (matching.length !== 1) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
// const tabs = matching[0].trace.filter(pane => pane instanceof BsTabGroupPane);
|
|
47
|
+
// const lastTabGroup = tabs[tabs.length - 1];
|
|
48
|
+
// // console.log('last tabgroup', lastTabGroup);
|
|
49
|
+
let tabControlEl = this.element.nativeElement;
|
|
33
50
|
do {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
51
|
+
if (tabControlEl.parentElement) {
|
|
52
|
+
tabControlEl = tabControlEl.parentElement;
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
throw 'No more parents';
|
|
56
|
+
}
|
|
57
|
+
} while (tabControlEl.tagName.toUpperCase() !== 'BS-TAB-CONTROL');
|
|
58
|
+
const coords = {
|
|
59
|
+
width: tabControlEl.clientWidth,
|
|
60
|
+
height: tabControlEl.clientHeight,
|
|
61
|
+
left: ev.clientX - ev.offsetX,
|
|
62
|
+
top: ev.clientY - ev.offsetY,
|
|
63
|
+
};
|
|
64
|
+
// this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();
|
|
65
|
+
// this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();
|
|
66
|
+
// this.removeFromPane(layout.rootPane, this.dockPanel);
|
|
67
|
+
const trace = [...matching[0].trace];
|
|
68
|
+
this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();
|
|
69
|
+
this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();
|
|
70
|
+
for (let index = trace.length - 1; index >= 0; index--) {
|
|
71
|
+
if (index > 0) {
|
|
72
|
+
this.removeFromPaneBis(trace[index - 1], trace[index]);
|
|
73
|
+
if (!trace[index - 1].isEmpty)
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
const floatingIndex = layout.floatingPanes.indexOf(trace[0]);
|
|
78
|
+
if (trace[0].isEmpty && (floatingIndex > -1)) {
|
|
79
|
+
layout.floatingPanes.splice(floatingIndex, 1);
|
|
63
80
|
}
|
|
64
|
-
}
|
|
65
|
-
this.dragOperation = {
|
|
66
|
-
offsetX: ev.offsetX,
|
|
67
|
-
offsetY: ev.offsetY,
|
|
68
|
-
floatingPane
|
|
69
|
-
};
|
|
70
|
-
layout.floatingPanes.push(floatingPane);
|
|
71
|
-
this.dock.layout$.next(layout);
|
|
81
|
+
}
|
|
72
82
|
}
|
|
83
|
+
// this.removeFromPane((<any>matching[0].trace[0])['$original'], this.dockPanel);
|
|
84
|
+
const floatingPane = new BsFloatingPane({
|
|
85
|
+
pane: new BsTabGroupPane({
|
|
86
|
+
panes: [
|
|
87
|
+
new BsContentPane({
|
|
88
|
+
dockPanel: this.dockPanel
|
|
89
|
+
})
|
|
90
|
+
]
|
|
91
|
+
}),
|
|
92
|
+
size: {
|
|
93
|
+
width: coords.width,
|
|
94
|
+
height: coords.height,
|
|
95
|
+
},
|
|
96
|
+
location: {
|
|
97
|
+
x: coords.left,
|
|
98
|
+
y: coords.top,
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
this.dragOperation = {
|
|
102
|
+
offsetX: ev.offsetX,
|
|
103
|
+
offsetY: ev.offsetY,
|
|
104
|
+
floatingPane
|
|
105
|
+
};
|
|
106
|
+
layout.floatingPanes.push(floatingPane);
|
|
107
|
+
setTimeout(() => this.dock.layout$.next(layout), 5);
|
|
108
|
+
// console.log('traces', { traces, matching, dockPanel: this.dockPanel, equals: traces[2].trace[3] });
|
|
109
|
+
// let element: HTMLElement | null = this.element.nativeElement;
|
|
110
|
+
// let tree: HTMLElement[] = [];
|
|
111
|
+
// do {
|
|
112
|
+
// tree.push(element!);
|
|
113
|
+
// element = element!.parentElement;
|
|
114
|
+
// } while (element);
|
|
115
|
+
// const tabControls = tree.filter(el => el.tagName.toUpperCase() === 'BS-TAB-CONTROL');
|
|
116
|
+
// if (tabControls.length > 0) {
|
|
117
|
+
// const coords = {
|
|
118
|
+
// width: tabControls[0].clientWidth,
|
|
119
|
+
// height: tabControls[0].clientHeight,
|
|
120
|
+
// left: ev.clientX - ev.offsetX,
|
|
121
|
+
// top: ev.clientY - ev.offsetY,
|
|
122
|
+
// };
|
|
123
|
+
// this.dockPanel.headerPortal?.isAttached && this.dockPanel.headerPortal?.detach();
|
|
124
|
+
// this.dockPanel.contentPortal?.isAttached && this.dockPanel.contentPortal?.detach();
|
|
125
|
+
// this.removeFromPane(layout.rootPane, this.dockPanel);
|
|
126
|
+
// const floatingPane = new BsFloatingPane({
|
|
127
|
+
// pane: new BsTabGroupPane({
|
|
128
|
+
// panes: [
|
|
129
|
+
// new BsContentPane({
|
|
130
|
+
// dockPanel: this.dockPanel
|
|
131
|
+
// })
|
|
132
|
+
// ]
|
|
133
|
+
// }),
|
|
134
|
+
// size: {
|
|
135
|
+
// width: coords.width,
|
|
136
|
+
// height: coords.height,
|
|
137
|
+
// },
|
|
138
|
+
// location: {
|
|
139
|
+
// x: coords.left,
|
|
140
|
+
// y: coords.top,
|
|
141
|
+
// }
|
|
142
|
+
// });
|
|
143
|
+
// this.dragOperation = {
|
|
144
|
+
// offsetX: ev.offsetX,
|
|
145
|
+
// offsetY: ev.offsetY,
|
|
146
|
+
// floatingPane
|
|
147
|
+
// };
|
|
148
|
+
// layout.floatingPanes.push(floatingPane);
|
|
149
|
+
// this.dock.layout$.next(layout);
|
|
150
|
+
// }
|
|
73
151
|
});
|
|
74
152
|
}
|
|
75
|
-
else
|
|
76
|
-
if (this.dragOperation
|
|
77
|
-
this.dragOperation.floatingPane.location
|
|
78
|
-
|
|
153
|
+
else {
|
|
154
|
+
if (this.dragOperation) {
|
|
155
|
+
if (this.dragOperation.floatingPane.location) {
|
|
156
|
+
this.dragOperation.floatingPane.location.x = ev.clientX - this.dragOperation.offsetX;
|
|
157
|
+
this.dragOperation.floatingPane.location.y = ev.clientY - this.dragOperation.offsetY;
|
|
158
|
+
}
|
|
159
|
+
// } else {
|
|
160
|
+
// const traces = this.dockService.buildTraces(this.dock.layout);
|
|
161
|
+
// const matchingTrace = traces.filter(trace => {
|
|
162
|
+
// const pane = trace.trace[trace.trace.length - 1];
|
|
163
|
+
// return (pane instanceof BsContentPane) && (pane.dockPanel === this.dockPanel);
|
|
164
|
+
// });
|
|
165
|
+
// console.log('matching', { traces, matchingTrace });
|
|
166
|
+
// // this.dragOperation = {
|
|
167
|
+
// // }
|
|
79
168
|
}
|
|
80
169
|
}
|
|
81
170
|
}
|
|
82
171
|
}
|
|
83
|
-
|
|
172
|
+
removeFromPaneBis(host, pane) {
|
|
84
173
|
if (host instanceof BsContentPane) {
|
|
85
|
-
return { paneRemoved: false, hostIsEmpty: false };
|
|
86
174
|
}
|
|
87
175
|
else if (host instanceof BsDocumentHost) {
|
|
88
176
|
// Actually documentHost should never be removed
|
|
89
|
-
if (!host.rootPane) {
|
|
90
|
-
return { paneRemoved: false, hostIsEmpty: true };
|
|
91
|
-
}
|
|
92
|
-
const result = this.removeFromPane(host.rootPane, panel);
|
|
93
|
-
return { paneRemoved: result.paneRemoved, hostIsEmpty: result.hostIsEmpty };
|
|
94
177
|
}
|
|
95
178
|
else if (host instanceof BsTabGroupPane) {
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
host.panes.splice(
|
|
99
|
-
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
100
|
-
}
|
|
101
|
-
else {
|
|
102
|
-
// ATM. all panes are ContentPanes anyway.
|
|
103
|
-
// So unless you'd want to have splitters inside the tabs,
|
|
104
|
-
// This code will not be hit.
|
|
105
|
-
// const result = host.panes
|
|
106
|
-
// .map(parentPane => this.removeFromPane(parentPane, panel))
|
|
107
|
-
// .filter(r => r.paneRemoved);
|
|
108
|
-
//
|
|
109
|
-
// if (result.length > 0) {
|
|
110
|
-
// return { paneRemoved: true, hostIsEmpty: }
|
|
111
|
-
// }
|
|
112
|
-
return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
179
|
+
if (pane instanceof BsContentPane) {
|
|
180
|
+
const index = host.panes.indexOf(pane);
|
|
181
|
+
host.panes.splice(index, 1);
|
|
113
182
|
}
|
|
114
183
|
}
|
|
115
184
|
else if (host instanceof BsSplitPane) {
|
|
116
|
-
const
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
if (matching.length > 0) {
|
|
121
|
-
host.panes.splice(host.panes.findIndex(p => (p instanceof BsContentPane) && matching.includes(p)), 1);
|
|
122
|
-
// TODO: Remove splitter if only 1 pane left?
|
|
123
|
-
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
for (let splitPane of host.panes) {
|
|
127
|
-
const result = this.removeFromPane(splitPane, panel);
|
|
128
|
-
if (result.paneRemoved && result.hostIsEmpty) {
|
|
129
|
-
// splitPane is empty now, so we can remove it from this splitter
|
|
130
|
-
host.panes.splice(host.panes.indexOf(splitPane), 1);
|
|
131
|
-
return { paneRemoved: true, hostIsEmpty: host.panes.length === 0 };
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
return { paneRemoved: false, hostIsEmpty: host.panes.length === 0 };
|
|
185
|
+
const index = host.panes.indexOf(pane);
|
|
186
|
+
host.panes.splice(index, 1);
|
|
187
|
+
}
|
|
188
|
+
else if (host instanceof BsFloatingPane) {
|
|
136
189
|
}
|
|
137
190
|
else {
|
|
138
|
-
throw '
|
|
191
|
+
throw 'Unknown pane type';
|
|
139
192
|
}
|
|
140
193
|
}
|
|
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
|
+
// }
|
|
141
246
|
onMouseUp(ev) {
|
|
142
247
|
this.isMouseDown = false;
|
|
248
|
+
this.isDragging = false;
|
|
143
249
|
this.dragOperation = undefined;
|
|
144
250
|
}
|
|
145
251
|
}
|
|
146
|
-
BsDockPanelHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockPanelHeaderComponent, deps: [{ token: i1.BsDockPanelComponent }, { token: i2.BsDockComponent }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
252
|
+
BsDockPanelHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockPanelHeaderComponent, deps: [{ token: i1.BsDockPanelComponent }, { token: i2.BsDockComponent }, { token: i3.BsDockService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
147
253
|
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"] });
|
|
148
254
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockPanelHeaderComponent, decorators: [{
|
|
149
255
|
type: Component,
|
|
150
256
|
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"] }]
|
|
151
|
-
}], ctorParameters: function () { return [{ type: i1.BsDockPanelComponent }, { type: i2.BsDockComponent }, { type: i0.ElementRef }]; }, propDecorators: { onMouseDown: [{
|
|
257
|
+
}], ctorParameters: function () { return [{ type: i1.BsDockPanelComponent }, { type: i2.BsDockComponent }, { type: i3.BsDockService }, { type: i0.ElementRef }]; }, propDecorators: { onMouseDown: [{
|
|
152
258
|
type: HostListener,
|
|
153
259
|
args: ['mousedown', ['$event']]
|
|
154
260
|
}], onMouseMove: [{
|
|
@@ -161,4 +267,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
161
267
|
type: HostBinding,
|
|
162
268
|
args: ['class.d-block']
|
|
163
269
|
}] } });
|
|
164
|
-
//# 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 { 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';\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 element: ElementRef<HTMLElement>) {}\n\n  isMouseDown = false;\n  dragOperation?: DragOperation;\n  isLayoutDetached = 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.isLayoutDetached) {\n        this.isLayoutDetached = true;\n        this.dock.layout$.pipe(take(1)).subscribe((layout) => {\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 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      }\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.dragOperation = undefined;\n  }\n\n  @HostBinding('class.d-block') dBlock = true;\n}\n","<ng-content></ng-content>"]}
|
|
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":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,YAAY,EAAgC,MAAM,eAAe,CAAC;AAC/G,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAG7D,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;;;;;AAO9D,MAAM,OAAO,0BAA0B;IACrC,YAAoB,SAA+B,EAAU,IAAqB,EAAU,WAA0B,EAAU,OAAgC;QAA5I,cAAS,GAAT,SAAS,CAAsB;QAAU,SAAI,GAAJ,IAAI,CAAiB;QAAU,gBAAW,GAAX,WAAW,CAAe;QAAU,YAAO,GAAP,OAAO,CAAyB;QAEhK,gBAAW,GAAG,KAAK,CAAC;QAEpB,eAAU,GAAG,KAAK,CAAC;QAoQW,WAAM,GAAG,IAAI,CAAC;IAxQuH,CAAC;IAK7H,WAAW,CAAC,EAAc;QAC/D,EAAE,CAAC,cAAc,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAE+C,WAAW,CAAC,EAAc;QACxE,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;gBACpB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBAEvB,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;oBAChE,0DAA0D;oBACxD,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;oBACpD,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAC,MAAM,EAAE,MAAM,EAAC,CAAC,CAAC;oBACxC,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE;wBACjC,MAAM,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;wBAC7C,yFAAyF;wBACzF,OAAO,CAAC,QAAQ,YAAY,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC;oBACxF,CAAC,CAAC,CAAC;oBACH,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;oBAClC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;wBACzB,OAAO;qBACR;oBAED,iFAAiF;oBACjF,8CAA8C;oBAC9C,iDAAiD;oBAEjD,IAAI,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;oBAC9C,GAAG;wBACD,IAAI,YAAY,CAAC,aAAa,EAAE;4BAC9B,YAAY,GAAG,YAAa,CAAC,aAAa,CAAC;yBAC5C;6BAAM;4BACL,MAAM,iBAAiB,CAAC;yBACzB;qBACF,QAAQ,YAAY,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,gBAAgB,EAAE;oBAElE,MAAM,MAAM,GAAG;wBACb,KAAK,EAAE,YAAY,CAAC,WAAW;wBAC/B,MAAM,EAAE,YAAY,CAAC,YAAY;wBACjC,IAAI,EAAE,EAAE,CAAC,OAAO,GAAG,EAAE,CAAC,OAAO;wBAC7B,GAAG,EAAE,EAAE,CAAC,OAAO,GAAG,EAAE,CAAC,OAAO;qBAC7B,CAAC;oBAEF,oFAAoF;oBACpF,sFAAsF;oBACtF,wDAAwD;oBAExD,MAAM,KAAK,GAAG,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;oBAErC,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,UAAU,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,MAAM,EAAE,CAAC;oBACjF,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,UAAU,IAAI,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC;oBAGnF,KAAK,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE;wBACtD,IAAI,KAAK,GAAG,CAAC,EAAE;4BACb,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;4BACvD,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,OAAO;gCAAE,MAAM;yBACtC;6BAAM;4BACL,MAAM,aAAa,GAAG,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;4BAC7D,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,EAAE;gCAC5C,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;6BAC/C;yBACF;qBACF;oBAID,iFAAiF;oBAEjF,MAAM,YAAY,GAAG,IAAI,cAAc,CAAC;wBACtC,IAAI,EAAE,IAAI,cAAc,CAAC;4BACvB,KAAK,EAAE;gCACL,IAAI,aAAa,CAAC;oCAChB,SAAS,EAAE,IAAI,CAAC,SAAS;iCAC1B,CAAC;6BACH;yBACF,CAAC;wBACF,IAAI,EAAE;4BACJ,KAAK,EAAE,MAAM,CAAC,KAAK;4BACnB,MAAM,EAAE,MAAM,CAAC,MAAM;yBACtB;wBACD,QAAQ,EAAE;4BACR,CAAC,EAAE,MAAM,CAAC,IAAI;4BACd,CAAC,EAAE,MAAM,CAAC,GAAG;yBACd;qBACF,CAAC,CAAC;oBACH,IAAI,CAAC,aAAa,GAAG;wBACnB,OAAO,EAAE,EAAE,CAAC,OAAO;wBACnB,OAAO,EAAE,EAAE,CAAC,OAAO;wBACnB,YAAY;qBACb,CAAC;oBACF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;oBACxC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;oBACpD,sGAAsG;oBAEtG,oEAAoE;oBACpE,oCAAoC;oBACpC,WAAW;oBACX,6BAA6B;oBAC7B,0CAA0C;oBAC1C,yBAAyB;oBAEzB,4FAA4F;oBAC5F,oCAAoC;oBACpC,yBAAyB;oBACzB,6CAA6C;oBAC7C,+CAA+C;oBAC/C,yCAAyC;oBACzC,wCAAwC;oBACxC,WAAW;oBAEX,0FAA0F;oBAC1F,4FAA4F;oBAC5F,8DAA8D;oBAE9D,kDAAkD;oBAClD,qCAAqC;oBACrC,qBAAqB;oBACrB,kCAAkC;oBAClC,0CAA0C;oBAC1C,iBAAiB;oBACjB,cAAc;oBACd,cAAc;oBACd,kBAAkB;oBAClB,iCAAiC;oBACjC,mCAAmC;oBACnC,aAAa;oBACb,sBAAsB;oBACtB,4BAA4B;oBAC5B,2BAA2B;oBAC3B,YAAY;oBACZ,YAAY;oBAEZ,+BAA+B;oBAC/B,+BAA+B;oBAC/B,+BAA+B;oBAC/B,uBAAuB;oBACvB,WAAW;oBAEX,iDAAiD;oBACjD,wCAAwC;oBACxC,QAAQ;gBACV,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,IAAI,IAAI,CAAC,aAAa,EAAE;oBACtB,IAAI,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,QAAQ,EAAE;wBAC5C,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC;wBACrF,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC;qBACtF;oBACL,aAAa;oBACb,qEAAqE;oBACrE,qDAAqD;oBACrD,0DAA0D;oBAC1D,uFAAuF;oBACvF,UAAU;oBAEV,0DAA0D;oBAC1D,gCAAgC;oBAEhC,WAAW;iBACR;aACF;SACF;IACH,CAAC;IAED,iBAAiB,CAAC,IAAgB,EAAE,IAAgB;QAClD,IAAI,IAAI,YAAY,aAAa,EAAE;SAClC;aAAM,IAAI,IAAI,YAAY,cAAc,EAAE;YACzC,gDAAgD;SACjD;aAAM,IAAI,IAAI,YAAY,cAAc,EAAE;YACzC,IAAI,IAAI,YAAY,aAAa,EAAE;gBACjC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;gBACvC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;aAC7B;SACF;aAAM,IAAI,IAAI,YAAY,WAAW,EAAE;YACtC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACvC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;SAC7B;aAAM,IAAI,IAAI,YAAY,cAAc,EAAE;SAC1C;aAAM;YACL,MAAM,mBAAmB,CAAC;SAC3B;IACH,CAAC;IAED,qHAAqH;IACrH,yCAAyC;IACzC,yDAAyD;IACzD,iDAAiD;IACjD,uDAAuD;IAEvD,4BAA4B;IAC5B,0DAA0D;IAC1D,QAAQ;IAER,gEAAgE;IAChE,mFAAmF;IAEnF,iDAAiD;IAIjD,sEAAsE;IACtE,iCAAiC;IACjC,gFAAgF;IAChF,4EAA4E;IAC5E,eAAe;IACf,mDAAmD;IACnD,mEAAmE;IACnE,sCAAsC;IAEtC,qCAAqC;IACrC,wEAAwE;IACxE,0CAA0C;IAC1C,WAAW;IACX,oCAAoC;IACpC,wDAAwD;IACxD,aAAa;IACb,6EAA6E;IAC7E,QAAQ;IAKR,8CAA8C;IAC9C,kCAAkC;IAClC,iDAAiD;IACjD,oCAAoC;IACpC,6CAA6C;IAE7C,iCAAiC;IACjC,+GAA+G;IAE/G,sDAAsD;IACtD,4EAA4E;IAC5E,eAAe;IAGf,4CAA4C;IAC5C,gEAAgE;IAChE,0DAA0D;IAC1D,8EAA8E;IAC9E,iEAAiE;IACjE,gFAAgF;IAChF,YAAY;IACZ,UAAU;IACV,QAAQ;IAER,2EAA2E;IAC3E,aAAa;IACb,iCAAiC;IACjC,MAAM;IACN,IAAI;IAE0C,SAAS,CAAC,EAAS;QAC/D,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;IACjC,CAAC;;uHAvQU,0BAA0B;2GAA1B,0BAA0B,+PCrBvC,2BAAyB;2FDqBZ,0BAA0B;kBALtC,SAAS;+BACE,sBAAsB;8LAUO,WAAW;sBAAjD,YAAY;uBAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;gBAKW,WAAW;sBAA1D,YAAY;uBAAC,oBAAoB,EAAE,CAAC,QAAQ,CAAC;gBAwPA,SAAS;sBAAtD,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC;gBAMd,MAAM;sBAAnC,WAAW;uBAAC,eAAe","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>"]}
|
|
@@ -6,4 +6,5 @@ export * from './dock-pane-renderer/dock-pane-renderer.component';
|
|
|
6
6
|
export * from './enums';
|
|
7
7
|
export * from './interfaces';
|
|
8
8
|
export * from './panes';
|
|
9
|
-
|
|
9
|
+
export * from './services';
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL2RvY2svc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2RvY2subW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vZG9jay9kb2NrLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RvY2stcGFuZWwvZG9jay1wYW5lbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9kb2NrLXBhbmVsLWhlYWRlci9kb2NrLXBhbmVsLWhlYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9kb2NrLXBhbmUtcmVuZGVyZXIvZG9jay1wYW5lLXJlbmRlcmVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2VudW1zJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL3BhbmVzJztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMnOyJdfQ==
|
|
@@ -4,5 +4,8 @@ export class BsContentPane extends BsDockPane {
|
|
|
4
4
|
super();
|
|
5
5
|
Object.assign(this, data);
|
|
6
6
|
}
|
|
7
|
+
get isEmpty() {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
7
10
|
}
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC1wYW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9kb2NrL3NyYy9wYW5lcy9jb250ZW50LXBhbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUV6QyxNQUFNLE9BQU8sYUFBYyxTQUFRLFVBQVU7SUFDekMsWUFBWSxJQUE2QjtRQUNyQyxLQUFLLEVBQUUsQ0FBQztRQUNSLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFLRCxJQUFhLE9BQU87UUFDaEIsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQnNEb2NrUGFuZWxDb21wb25lbnQgfSBmcm9tIFwiLi4vZG9jay1wYW5lbC9kb2NrLXBhbmVsLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgQnNEb2NrUGFuZSB9IGZyb20gXCIuL2RvY2stcGFuZVwiO1xuXG5leHBvcnQgY2xhc3MgQnNDb250ZW50UGFuZSBleHRlbmRzIEJzRG9ja1BhbmUge1xuICAgIGNvbnN0cnVjdG9yKGRhdGE/OiBQYXJ0aWFsPEJzQ29udGVudFBhbmU+KSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIE9iamVjdC5hc3NpZ24odGhpcywgZGF0YSk7XG4gICAgfVxuXG4gICAgZG9ja1BhbmVsITogQnNEb2NrUGFuZWxDb21wb25lbnQ7XG4gICAgaXNQaW5uZWQ/OiBib29sZWFuO1xuXG4gICAgb3ZlcnJpZGUgZ2V0IGlzRW1wdHkoKSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59Il19
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export class BsDockPane {
|
|
2
2
|
}
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jay1wYW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9kb2NrL3NyYy9wYW5lcy9kb2NrLXBhbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFnQixVQUFVO0NBRS9CIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJzRG9ja1BhbmUge1xuICAgIGFic3RyYWN0IGdldCBpc0VtcHR5KCk6IGJvb2xlYW47XG59Il19
|
|
@@ -4,5 +4,8 @@ export class BsDocumentHost extends BsDockPane {
|
|
|
4
4
|
super();
|
|
5
5
|
Object.assign(this, data);
|
|
6
6
|
}
|
|
7
|
+
get isEmpty() {
|
|
8
|
+
return this.rootPane?.isEmpty ?? true;
|
|
9
|
+
}
|
|
7
10
|
}
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jdW1lbnQtaG9zdC1wYW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9kb2NrL3NyYy9wYW5lcy9kb2N1bWVudC1ob3N0LXBhbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUd6QyxNQUFNLE9BQU8sY0FBZSxTQUFRLFVBQVU7SUFDMUMsWUFBWSxJQUE4QjtRQUN0QyxLQUFLLEVBQUUsQ0FBQztRQUNSLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFJRCxJQUFhLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsUUFBUSxFQUFFLE9BQU8sSUFBSSxJQUFJLENBQUM7SUFDMUMsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQnNEb2NrUGFuZSB9IGZyb20gXCIuL2RvY2stcGFuZVwiO1xuaW1wb3J0IHsgQnNUYWJHcm91cFBhbmUgfSBmcm9tIFwiLi90YWItZ3JvdXAtcGFuZVwiO1xuXG5leHBvcnQgY2xhc3MgQnNEb2N1bWVudEhvc3QgZXh0ZW5kcyBCc0RvY2tQYW5lIHtcbiAgICBjb25zdHJ1Y3RvcihkYXRhPzogUGFydGlhbDxCc0RvY3VtZW50SG9zdD4pIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICAgICAgT2JqZWN0LmFzc2lnbih0aGlzLCBkYXRhKTtcbiAgICB9XG5cbiAgICByb290UGFuZT86IEJzVGFiR3JvdXBQYW5lXG5cbiAgICBvdmVycmlkZSBnZXQgaXNFbXB0eSgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMucm9vdFBhbmU/LmlzRW1wdHkgPz8gdHJ1ZTtcbiAgICB9XG59Il19
|
|
@@ -1,6 +1,11 @@
|
|
|
1
|
-
|
|
1
|
+
import { BsDockPane } from "./dock-pane";
|
|
2
|
+
export class BsFloatingPane extends BsDockPane {
|
|
2
3
|
constructor(data) {
|
|
4
|
+
super();
|
|
3
5
|
Object.assign(this, data);
|
|
4
6
|
}
|
|
7
|
+
get isEmpty() {
|
|
8
|
+
return this.pane?.isEmpty ?? true;
|
|
9
|
+
}
|
|
5
10
|
}
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvYXRpbmctcGFuZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvZG9jay9zcmMvcGFuZXMvZmxvYXRpbmctcGFuZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBSXpDLE1BQU0sT0FBTyxjQUFlLFNBQVEsVUFBVTtJQUMxQyxZQUFZLElBQThCO1FBQ3RDLEtBQUssRUFBRSxDQUFDO1FBQ1IsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQU1ELElBQWEsT0FBTztRQUNoQixPQUFPLElBQUksQ0FBQyxJQUFJLEVBQUUsT0FBTyxJQUFJLElBQUksQ0FBQztJQUN0QyxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCc0RvY2tQYW5lIH0gZnJvbSBcIi4vZG9jay1wYW5lXCI7XG5pbXBvcnQgeyBQb2ludCB9IGZyb20gXCIuLi9pbnRlcmZhY2VzL3BvaW50XCI7XG5pbXBvcnQgeyBTaXplIH0gZnJvbSBcIi4uL2ludGVyZmFjZXMvc2l6ZVwiO1xuXG5leHBvcnQgY2xhc3MgQnNGbG9hdGluZ1BhbmUgZXh0ZW5kcyBCc0RvY2tQYW5lIHtcbiAgICBjb25zdHJ1Y3RvcihkYXRhPzogUGFydGlhbDxCc0Zsb2F0aW5nUGFuZT4pIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICAgICAgT2JqZWN0LmFzc2lnbih0aGlzLCBkYXRhKTtcbiAgICB9XG4gICAgXG4gICAgcGFuZT86IEJzRG9ja1BhbmU7XG4gICAgc2l6ZT86IFNpemU7XG4gICAgbG9jYXRpb24/OiBQb2ludDtcblxuICAgIG92ZXJyaWRlIGdldCBpc0VtcHR5KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5wYW5lPy5pc0VtcHR5ID8/IHRydWU7XG4gICAgfVxufSJdfQ==
|
|
@@ -6,5 +6,8 @@ export class BsSplitPane extends BsDockPane {
|
|
|
6
6
|
this.panes = [];
|
|
7
7
|
Object.assign(this, data);
|
|
8
8
|
}
|
|
9
|
+
get isEmpty() {
|
|
10
|
+
return this.panes.length === 0;
|
|
11
|
+
}
|
|
9
12
|
}
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BsaXQtcGFuZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvZG9jay9zcmMvcGFuZXMvc3BsaXQtcGFuZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXpDLE1BQU0sT0FBTyxXQUFZLFNBQVEsVUFBVTtJQUN2QyxZQUFZLElBQTJCO1FBQ25DLEtBQUssRUFBRSxDQUFDO1FBSVosZ0JBQVcsR0FBeUIsWUFBWSxDQUFDO1FBQ2pELFVBQUssR0FBaUIsRUFBRSxDQUFDO1FBSnJCLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFLRCxJQUFhLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUM7SUFDbkMsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3BsaXRQYW5lT3JpZW50YXRpb24gfSBmcm9tIFwiLi4vdHlwZXMvc3BsaXQtcGFuZS1vcmllbnRhdGlvbi50eXBlXCI7XG5pbXBvcnQgeyBCc0RvY2tQYW5lIH0gZnJvbSBcIi4vZG9jay1wYW5lXCI7XG5cbmV4cG9ydCBjbGFzcyBCc1NwbGl0UGFuZSBleHRlbmRzIEJzRG9ja1BhbmUge1xuICAgIGNvbnN0cnVjdG9yKGRhdGE/OiBQYXJ0aWFsPEJzU3BsaXRQYW5lPikge1xuICAgICAgICBzdXBlcigpO1xuICAgICAgICBPYmplY3QuYXNzaWduKHRoaXMsIGRhdGEpO1xuICAgIH1cblxuICAgIG9yaWVudGF0aW9uOiBTcGxpdFBhbmVPcmllbnRhdGlvbiA9ICdob3Jpem9udGFsJztcbiAgICBwYW5lczogQnNEb2NrUGFuZVtdID0gW107XG5cbiAgICBvdmVycmlkZSBnZXQgaXNFbXB0eSgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMucGFuZXMubGVuZ3RoID09PSAwO1xuICAgIH1cbn0iXX0=
|
|
@@ -5,5 +5,8 @@ export class BsTabGroupPane extends BsDockPane {
|
|
|
5
5
|
this.panes = [];
|
|
6
6
|
Object.assign(this, data);
|
|
7
7
|
}
|
|
8
|
+
get isEmpty() {
|
|
9
|
+
return this.panes.length === 0;
|
|
10
|
+
}
|
|
8
11
|
}
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWdyb3VwLXBhbmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL2RvY2svc3JjL3BhbmVzL3RhYi1ncm91cC1wYW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFekMsTUFBTSxPQUFPLGNBQWUsU0FBUSxVQUFVO0lBQzFDLFlBQVksSUFBOEI7UUFDdEMsS0FBSyxFQUFFLENBQUM7UUFJWixVQUFLLEdBQW9CLEVBQUUsQ0FBQztRQUh4QixNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBSUQsSUFBYSxPQUFPO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDO0lBQ25DLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJzQ29udGVudFBhbmUgfSBmcm9tIFwiLi9jb250ZW50LXBhbmVcIjtcbmltcG9ydCB7IEJzRG9ja1BhbmUgfSBmcm9tIFwiLi9kb2NrLXBhbmVcIjtcblxuZXhwb3J0IGNsYXNzIEJzVGFiR3JvdXBQYW5lIGV4dGVuZHMgQnNEb2NrUGFuZSB7XG4gICAgY29uc3RydWN0b3IoZGF0YT86IFBhcnRpYWw8QnNUYWJHcm91cFBhbmU+KSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIE9iamVjdC5hc3NpZ24odGhpcywgZGF0YSk7XG4gICAgfVxuXG4gICAgcGFuZXM6IEJzQ29udGVudFBhbmVbXSA9IFtdO1xuICAgIFxuICAgIG92ZXJyaWRlIGdldCBpc0VtcHR5KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5wYW5lcy5sZW5ndGggPT09IDA7XG4gICAgfVxufSJdfQ==
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BsSplitPane } from '../../panes/split-pane';
|
|
3
|
+
import { BsContentPane } from '../../panes/content-pane';
|
|
4
|
+
import { BsTabGroupPane } from '../../panes/tab-group-pane';
|
|
5
|
+
import { BsFloatingPane } from '../../panes/floating-pane';
|
|
6
|
+
import { BsDocumentHost } from '../../panes/document-host-pane';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class BsDockService {
|
|
9
|
+
buildTraces(layout) {
|
|
10
|
+
const result = [layout.rootPane, ...layout.floatingPanes].map(pane => this.buildTracesPrivate([pane]));
|
|
11
|
+
// const result = this.buildTracesPrivate([layout.rootPane]);
|
|
12
|
+
return result.flatMap(traceGroup => traceGroup);
|
|
13
|
+
}
|
|
14
|
+
buildTracesPrivate(currentSequence) {
|
|
15
|
+
const children = this.getChildPanes(currentSequence[currentSequence.length - 1]);
|
|
16
|
+
if (children.length === 0) {
|
|
17
|
+
return [{
|
|
18
|
+
finished: true,
|
|
19
|
+
trace: currentSequence
|
|
20
|
+
}];
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
const result = children.map(child => this.buildTracesPrivate([...currentSequence, child]));
|
|
24
|
+
return result.flatMap(r => r);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
getChildPanes(pane) {
|
|
28
|
+
if (pane instanceof BsContentPane) {
|
|
29
|
+
return [];
|
|
30
|
+
}
|
|
31
|
+
else if (pane instanceof BsTabGroupPane) {
|
|
32
|
+
return pane.panes;
|
|
33
|
+
}
|
|
34
|
+
else if (pane instanceof BsSplitPane) {
|
|
35
|
+
return pane.panes;
|
|
36
|
+
}
|
|
37
|
+
else if (pane instanceof BsFloatingPane) {
|
|
38
|
+
return pane.pane ? [pane.pane] : [];
|
|
39
|
+
}
|
|
40
|
+
else if (pane instanceof BsDocumentHost) {
|
|
41
|
+
return pane.rootPane ? [pane.rootPane] : [];
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
return [];
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
BsDockService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
49
|
+
BsDockService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockService, providedIn: 'root' });
|
|
50
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: BsDockService, decorators: [{
|
|
51
|
+
type: Injectable,
|
|
52
|
+
args: [{
|
|
53
|
+
providedIn: 'root'
|
|
54
|
+
}]
|
|
55
|
+
}] });
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jay5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9kb2NrL3NyYy9zZXJ2aWNlcy9kb2NrL2RvY2suc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzVELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7O0FBTWhFLE1BQU0sT0FBTyxhQUFhO0lBQ2pCLFdBQVcsQ0FBQyxNQUFvQjtRQUNyQyxNQUFNLE1BQU0sR0FBRyxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsR0FBRyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3ZHLDZEQUE2RDtRQUM3RCxPQUFPLE1BQU0sQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRU8sa0JBQWtCLENBQUMsZUFBNkI7UUFDdEQsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxlQUFlLENBQUMsZUFBZSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pGLElBQUksUUFBUSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDekIsT0FBTyxDQUFDO29CQUNOLFFBQVEsRUFBRSxJQUFJO29CQUNkLEtBQUssRUFBRSxlQUFlO2lCQUN2QixDQUFDLENBQUM7U0FDSjthQUFNO1lBQ0wsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLEdBQUcsZUFBZSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUMzRixPQUFPLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUMvQjtJQUNILENBQUM7SUFFTyxhQUFhLENBQUMsSUFBZ0I7UUFDcEMsSUFBSSxJQUFJLFlBQVksYUFBYSxFQUFFO1lBQ2pDLE9BQU8sRUFBRSxDQUFDO1NBQ1g7YUFBTSxJQUFJLElBQUksWUFBWSxjQUFjLEVBQUU7WUFDekMsT0FBc0IsSUFBSSxDQUFDLEtBQU0sQ0FBQztTQUNuQzthQUFNLElBQUksSUFBSSxZQUFZLFdBQVcsRUFBRTtZQUN0QyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7U0FDbkI7YUFBTSxJQUFJLElBQUksWUFBWSxjQUFjLEVBQUU7WUFDekMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1NBQ3JDO2FBQU0sSUFBSSxJQUFJLFlBQVksY0FBYyxFQUFFO1lBQ3pDLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztTQUM3QzthQUFNO1lBQ0wsT0FBTyxFQUFFLENBQUM7U0FDWDtJQUNILENBQUM7OzBHQWxDVSxhQUFhOzhHQUFiLGFBQWEsY0FGWixNQUFNOzJGQUVQLGFBQWE7a0JBSHpCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQnNEb2NrUGFuZSB9IGZyb20gJy4uLy4uL3BhbmVzL2RvY2stcGFuZSc7XG5pbXBvcnQgeyBCc1NwbGl0UGFuZSB9IGZyb20gJy4uLy4uL3BhbmVzL3NwbGl0LXBhbmUnO1xuaW1wb3J0IHsgQnNDb250ZW50UGFuZSB9IGZyb20gJy4uLy4uL3BhbmVzL2NvbnRlbnQtcGFuZSc7XG5pbXBvcnQgeyBCc1RhYkdyb3VwUGFuZSB9IGZyb20gJy4uLy4uL3BhbmVzL3RhYi1ncm91cC1wYW5lJztcbmltcG9ydCB7IEJzRmxvYXRpbmdQYW5lIH0gZnJvbSAnLi4vLi4vcGFuZXMvZmxvYXRpbmctcGFuZSc7XG5pbXBvcnQgeyBCc0RvY3VtZW50SG9zdCB9IGZyb20gJy4uLy4uL3BhbmVzL2RvY3VtZW50LWhvc3QtcGFuZSc7XG5pbXBvcnQgeyBCc0RvY2tMYXlvdXQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL2RvY2stbGF5b3V0JztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgQnNEb2NrU2VydmljZSB7XG4gIHB1YmxpYyBidWlsZFRyYWNlcyhsYXlvdXQ6IEJzRG9ja0xheW91dCkge1xuICAgIGNvbnN0IHJlc3VsdCA9IFtsYXlvdXQucm9vdFBhbmUsIC4uLmxheW91dC5mbG9hdGluZ1BhbmVzXS5tYXAocGFuZSA9PiB0aGlzLmJ1aWxkVHJhY2VzUHJpdmF0ZShbcGFuZV0pKTtcbiAgICAvLyBjb25zdCByZXN1bHQgPSB0aGlzLmJ1aWxkVHJhY2VzUHJpdmF0ZShbbGF5b3V0LnJvb3RQYW5lXSk7XG4gICAgcmV0dXJuIHJlc3VsdC5mbGF0TWFwKHRyYWNlR3JvdXAgPT4gdHJhY2VHcm91cCk7XG4gIH1cblxuICBwcml2YXRlIGJ1aWxkVHJhY2VzUHJpdmF0ZShjdXJyZW50U2VxdWVuY2U6IEJzRG9ja1BhbmVbXSk6IFBhbmVUcmFjZVJlc3VsdFtdIHtcbiAgICBjb25zdCBjaGlsZHJlbiA9IHRoaXMuZ2V0Q2hpbGRQYW5lcyhjdXJyZW50U2VxdWVuY2VbY3VycmVudFNlcXVlbmNlLmxlbmd0aCAtIDFdKTtcbiAgICBpZiAoY2hpbGRyZW4ubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gW3tcbiAgICAgICAgZmluaXNoZWQ6IHRydWUsXG4gICAgICAgIHRyYWNlOiBjdXJyZW50U2VxdWVuY2VcbiAgICAgIH1dO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCByZXN1bHQgPSBjaGlsZHJlbi5tYXAoY2hpbGQgPT4gdGhpcy5idWlsZFRyYWNlc1ByaXZhdGUoWy4uLmN1cnJlbnRTZXF1ZW5jZSwgY2hpbGRdKSk7XG4gICAgICByZXR1cm4gcmVzdWx0LmZsYXRNYXAociA9PiByKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGdldENoaWxkUGFuZXMocGFuZTogQnNEb2NrUGFuZSk6IEJzRG9ja1BhbmVbXSB7XG4gICAgaWYgKHBhbmUgaW5zdGFuY2VvZiBCc0NvbnRlbnRQYW5lKSB7XG4gICAgICByZXR1cm4gW107XG4gICAgfSBlbHNlIGlmIChwYW5lIGluc3RhbmNlb2YgQnNUYWJHcm91cFBhbmUpIHtcbiAgICAgIHJldHVybiAoPEJzRG9ja1BhbmVbXT5wYW5lLnBhbmVzKTtcbiAgICB9IGVsc2UgaWYgKHBhbmUgaW5zdGFuY2VvZiBCc1NwbGl0UGFuZSkge1xuICAgICAgcmV0dXJuIHBhbmUucGFuZXM7XG4gICAgfSBlbHNlIGlmIChwYW5lIGluc3RhbmNlb2YgQnNGbG9hdGluZ1BhbmUpIHtcbiAgICAgIHJldHVybiBwYW5lLnBhbmUgPyBbcGFuZS5wYW5lXSA6IFtdO1xuICAgIH0gZWxzZSBpZiAocGFuZSBpbnN0YW5jZW9mIEJzRG9jdW1lbnRIb3N0KSB7XG4gICAgICByZXR1cm4gcGFuZS5yb290UGFuZSA/IFtwYW5lLnJvb3RQYW5lXSA6IFtdO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gW107XG4gICAgfVxuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFuZVRyYWNlUmVzdWx0IHtcbiAgdHJhY2U6IEJzRG9ja1BhbmVbXTtcbiAgZmluaXNoZWQ6IGJvb2xlYW47XG59Il19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './dock/dock.service';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL2RvY2svc3JjL3NlcnZpY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMscUJBQXFCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2RvY2svZG9jay5zZXJ2aWNlJzsiXX0=
|