dockview 4.2.1 → 4.2.4
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/dist/cjs/dockview/dockview.js +1 -0
- package/dist/cjs/gridview/gridview.js +1 -0
- package/dist/cjs/paneview/paneview.js +1 -0
- package/dist/cjs/splitview/splitview.js +1 -0
- package/dist/dockview.amd.js +72 -20
- package/dist/dockview.amd.js.map +1 -1
- package/dist/dockview.amd.min.js +2 -2
- package/dist/dockview.amd.min.js.map +1 -1
- package/dist/dockview.amd.min.noStyle.js +2 -2
- package/dist/dockview.amd.min.noStyle.js.map +1 -1
- package/dist/dockview.amd.noStyle.js +72 -20
- package/dist/dockview.amd.noStyle.js.map +1 -1
- package/dist/dockview.cjs.js +72 -20
- package/dist/dockview.cjs.js.map +1 -1
- package/dist/dockview.esm.js +72 -20
- package/dist/dockview.esm.js.map +1 -1
- package/dist/dockview.esm.min.js +2 -2
- package/dist/dockview.esm.min.js.map +1 -1
- package/dist/dockview.js +72 -20
- package/dist/dockview.js.map +1 -1
- package/dist/dockview.min.js +2 -2
- package/dist/dockview.min.js.map +1 -1
- package/dist/dockview.min.noStyle.js +2 -2
- package/dist/dockview.min.noStyle.js.map +1 -1
- package/dist/dockview.noStyle.js +72 -20
- package/dist/dockview.noStyle.js.map +1 -1
- package/dist/esm/dockview/dockview.js +1 -0
- package/dist/esm/gridview/gridview.js +1 -0
- package/dist/esm/paneview/paneview.js +1 -0
- package/dist/esm/splitview/splitview.js +1 -0
- package/package.json +2 -2
package/dist/dockview.noStyle.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* dockview
|
|
3
|
-
* @version 4.2.
|
|
3
|
+
* @version 4.2.4
|
|
4
4
|
* @link https://github.com/mathuo/dockview
|
|
5
5
|
* @license MIT
|
|
6
6
|
*/
|
|
@@ -642,6 +642,44 @@
|
|
|
642
642
|
}));
|
|
643
643
|
return disposable;
|
|
644
644
|
}
|
|
645
|
+
function shiftAbsoluteElementIntoView(element, root, options = { buffer: 10 }) {
|
|
646
|
+
const buffer = options.buffer;
|
|
647
|
+
const rect = element.getBoundingClientRect();
|
|
648
|
+
const rootRect = element.getBoundingClientRect();
|
|
649
|
+
const viewportWidth = root.clientWidth;
|
|
650
|
+
const viewportHeight = root.clientHeight;
|
|
651
|
+
let translateX = 0;
|
|
652
|
+
let translateY = 0;
|
|
653
|
+
const left = rect.left - rootRect.left;
|
|
654
|
+
const top = rect.top - rootRect.top;
|
|
655
|
+
const bottom = rect.bottom - rootRect.bottom;
|
|
656
|
+
const right = rect.right - rootRect.right;
|
|
657
|
+
// Check horizontal overflow
|
|
658
|
+
if (left < buffer) {
|
|
659
|
+
translateX = buffer - left;
|
|
660
|
+
}
|
|
661
|
+
else if (right > viewportWidth - buffer) {
|
|
662
|
+
translateX = viewportWidth - right - buffer;
|
|
663
|
+
}
|
|
664
|
+
// Check vertical overflow
|
|
665
|
+
if (top < buffer) {
|
|
666
|
+
translateY = buffer - top;
|
|
667
|
+
}
|
|
668
|
+
else if (bottom > viewportHeight - buffer) {
|
|
669
|
+
translateY = viewportHeight - bottom - buffer;
|
|
670
|
+
}
|
|
671
|
+
// Apply the translation if needed
|
|
672
|
+
if (translateX !== 0 || translateY !== 0) {
|
|
673
|
+
element.style.transform = `translate(${translateX}px, ${translateY}px)`;
|
|
674
|
+
}
|
|
675
|
+
}
|
|
676
|
+
function findRelativeZIndexParent(el) {
|
|
677
|
+
let tmp = el;
|
|
678
|
+
while (tmp && (tmp.style.zIndex === 'auto' || tmp.style.zIndex === '')) {
|
|
679
|
+
tmp = tmp.parentElement;
|
|
680
|
+
}
|
|
681
|
+
return tmp;
|
|
682
|
+
}
|
|
645
683
|
|
|
646
684
|
function tail(arr) {
|
|
647
685
|
if (arr.length === 0) {
|
|
@@ -5609,7 +5647,7 @@
|
|
|
5609
5647
|
toggleClass(wrapper, 'dv-tab', true);
|
|
5610
5648
|
toggleClass(wrapper, 'dv-active-tab', panelObject.api.isActive);
|
|
5611
5649
|
toggleClass(wrapper, 'dv-inactive-tab', !panelObject.api.isActive);
|
|
5612
|
-
wrapper.addEventListener('
|
|
5650
|
+
wrapper.addEventListener('pointerdown', () => {
|
|
5613
5651
|
this.accessor.popupService.close();
|
|
5614
5652
|
tab.element.scrollIntoView();
|
|
5615
5653
|
tab.panel.api.setActive();
|
|
@@ -5617,9 +5655,13 @@
|
|
|
5617
5655
|
wrapper.appendChild(child);
|
|
5618
5656
|
el.appendChild(wrapper);
|
|
5619
5657
|
}
|
|
5658
|
+
const relativeParent = findRelativeZIndexParent(root);
|
|
5620
5659
|
this.accessor.popupService.openPopover(el, {
|
|
5621
5660
|
x: event.clientX,
|
|
5622
5661
|
y: event.clientY,
|
|
5662
|
+
zIndex: (relativeParent === null || relativeParent === void 0 ? void 0 : relativeParent.style.zIndex)
|
|
5663
|
+
? `calc(${relativeParent.style.zIndex} * 2)`
|
|
5664
|
+
: undefined,
|
|
5623
5665
|
});
|
|
5624
5666
|
}));
|
|
5625
5667
|
}
|
|
@@ -7961,10 +8003,11 @@
|
|
|
7961
8003
|
}), this._activeDisposable);
|
|
7962
8004
|
}
|
|
7963
8005
|
openPopover(element, position) {
|
|
8006
|
+
var _a;
|
|
7964
8007
|
this.close();
|
|
7965
8008
|
const wrapper = document.createElement('div');
|
|
7966
8009
|
wrapper.style.position = 'absolute';
|
|
7967
|
-
wrapper.style.zIndex = '
|
|
8010
|
+
wrapper.style.zIndex = (_a = position.zIndex) !== null && _a !== void 0 ? _a : 'var(--dv-overlay-z-index)';
|
|
7968
8011
|
wrapper.appendChild(element);
|
|
7969
8012
|
const anchorBox = this._element.getBoundingClientRect();
|
|
7970
8013
|
const offsetX = anchorBox.left;
|
|
@@ -7988,6 +8031,9 @@
|
|
|
7988
8031
|
}
|
|
7989
8032
|
this.close();
|
|
7990
8033
|
}));
|
|
8034
|
+
requestAnimationFrame(() => {
|
|
8035
|
+
shiftAbsoluteElementIntoView(wrapper, this.root);
|
|
8036
|
+
});
|
|
7991
8037
|
}
|
|
7992
8038
|
close() {
|
|
7993
8039
|
if (this._active) {
|
|
@@ -9521,24 +9567,26 @@
|
|
|
9521
9567
|
selectedPopoutGroup.disposable.dispose();
|
|
9522
9568
|
}
|
|
9523
9569
|
}
|
|
9524
|
-
|
|
9525
|
-
|
|
9526
|
-
|
|
9527
|
-
|
|
9528
|
-
|
|
9529
|
-
|
|
9530
|
-
|
|
9531
|
-
|
|
9532
|
-
|
|
9533
|
-
|
|
9534
|
-
|
|
9535
|
-
|
|
9536
|
-
|
|
9537
|
-
|
|
9538
|
-
|
|
9539
|
-
|
|
9570
|
+
if (from.api.location.type !== 'popout') {
|
|
9571
|
+
const referenceLocation = getGridLocation(to.element);
|
|
9572
|
+
const dropLocation = getRelativeLocation(this.gridview.orientation, referenceLocation, target);
|
|
9573
|
+
let size;
|
|
9574
|
+
switch (this.gridview.orientation) {
|
|
9575
|
+
case exports.Orientation.VERTICAL:
|
|
9576
|
+
size =
|
|
9577
|
+
referenceLocation.length % 2 == 0
|
|
9578
|
+
? from.api.width
|
|
9579
|
+
: from.api.height;
|
|
9580
|
+
break;
|
|
9581
|
+
case exports.Orientation.HORIZONTAL:
|
|
9582
|
+
size =
|
|
9583
|
+
referenceLocation.length % 2 == 0
|
|
9584
|
+
? from.api.height
|
|
9585
|
+
: from.api.width;
|
|
9586
|
+
break;
|
|
9587
|
+
}
|
|
9588
|
+
this.gridview.addView(from, size, dropLocation);
|
|
9540
9589
|
}
|
|
9541
|
-
this.gridview.addView(from, size, dropLocation);
|
|
9542
9590
|
}
|
|
9543
9591
|
from.panels.forEach((panel) => {
|
|
9544
9592
|
this._onDidMovePanel.fire({ panel, from });
|
|
@@ -11115,6 +11163,7 @@
|
|
|
11115
11163
|
}
|
|
11116
11164
|
dockviewRef.current = api;
|
|
11117
11165
|
return () => {
|
|
11166
|
+
dockviewRef.current = undefined;
|
|
11118
11167
|
api.dispose();
|
|
11119
11168
|
};
|
|
11120
11169
|
}, []);
|
|
@@ -11373,6 +11422,7 @@
|
|
|
11373
11422
|
}
|
|
11374
11423
|
splitviewRef.current = api;
|
|
11375
11424
|
return () => {
|
|
11425
|
+
splitviewRef.current = undefined;
|
|
11376
11426
|
api.dispose();
|
|
11377
11427
|
};
|
|
11378
11428
|
}, []);
|
|
@@ -11456,6 +11506,7 @@
|
|
|
11456
11506
|
}
|
|
11457
11507
|
gridviewRef.current = api;
|
|
11458
11508
|
return () => {
|
|
11509
|
+
gridviewRef.current = undefined;
|
|
11459
11510
|
api.dispose();
|
|
11460
11511
|
};
|
|
11461
11512
|
}, []);
|
|
@@ -11561,6 +11612,7 @@
|
|
|
11561
11612
|
}
|
|
11562
11613
|
paneviewRef.current = api;
|
|
11563
11614
|
return () => {
|
|
11615
|
+
paneviewRef.current = undefined;
|
|
11564
11616
|
api.dispose();
|
|
11565
11617
|
};
|
|
11566
11618
|
}, []);
|