dockview 1.10.1 → 1.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/dockview/defaultTab.d.ts +1 -1
- package/dist/cjs/dockview/defaultTab.js +11 -31
- package/dist/cjs/dockview/dockview.d.ts +1 -1
- package/dist/cjs/dockview/dockview.js +27 -47
- package/dist/cjs/dockview/headerActionsRenderer.d.ts +1 -1
- package/dist/cjs/dockview/headerActionsRenderer.js +2 -0
- package/dist/cjs/dockview/reactContentPart.d.ts +1 -1
- package/dist/cjs/dockview/reactContentPart.js +2 -0
- package/dist/cjs/dockview/reactHeaderPart.d.ts +1 -1
- package/dist/cjs/dockview/reactHeaderPart.js +2 -0
- package/dist/cjs/dockview/reactWatermarkPart.d.ts +1 -1
- package/dist/cjs/dockview/reactWatermarkPart.js +2 -0
- package/dist/cjs/gridview/gridview.d.ts +1 -1
- package/dist/cjs/gridview/gridview.js +13 -33
- package/dist/cjs/paneview/paneview.d.ts +1 -1
- package/dist/cjs/paneview/paneview.js +16 -36
- package/dist/cjs/paneview/view.d.ts +1 -1
- package/dist/cjs/react.d.ts +1 -1
- package/dist/cjs/react.js +16 -36
- package/dist/cjs/splitview/splitview.d.ts +1 -1
- package/dist/cjs/splitview/splitview.js +13 -33
- package/dist/cjs/svg.d.ts +1 -1
- package/dist/cjs/svg.js +7 -27
- package/dist/dockview.amd.js +125 -123
- 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 +124 -122
- package/dist/dockview.amd.noStyle.js.map +1 -1
- package/dist/dockview.cjs.js +125 -123
- package/dist/dockview.cjs.js.map +1 -1
- package/dist/dockview.esm.js +65 -43
- 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 +125 -123
- 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 +124 -122
- package/dist/dockview.noStyle.js.map +1 -1
- package/dist/esm/dockview/defaultTab.d.ts +1 -1
- package/dist/esm/dockview/defaultTab.js +4 -4
- package/dist/esm/dockview/dockview.d.ts +1 -1
- package/dist/esm/dockview/dockview.js +1 -1
- package/dist/esm/dockview/headerActionsRenderer.d.ts +1 -1
- package/dist/esm/dockview/headerActionsRenderer.js +2 -0
- package/dist/esm/dockview/reactContentPart.d.ts +1 -1
- package/dist/esm/dockview/reactContentPart.js +2 -0
- package/dist/esm/dockview/reactHeaderPart.d.ts +1 -1
- package/dist/esm/dockview/reactHeaderPart.js +2 -0
- package/dist/esm/dockview/reactWatermarkPart.d.ts +1 -1
- package/dist/esm/dockview/reactWatermarkPart.js +2 -0
- package/dist/esm/gridview/gridview.d.ts +1 -1
- package/dist/esm/gridview/gridview.js +1 -1
- package/dist/esm/paneview/paneview.d.ts +1 -1
- package/dist/esm/paneview/paneview.js +1 -1
- package/dist/esm/paneview/view.d.ts +1 -1
- package/dist/esm/react.d.ts +1 -1
- package/dist/esm/react.js +2 -2
- package/dist/esm/splitview/splitview.d.ts +1 -1
- package/dist/esm/splitview/splitview.js +1 -1
- package/dist/esm/svg.d.ts +1 -1
- package/dist/esm/svg.js +1 -1
- package/dist/styles/dockview.css +849 -8
- package/package.json +3 -3
package/dist/dockview.cjs.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* dockview
|
|
3
|
-
* @version 1.
|
|
3
|
+
* @version 1.11.0
|
|
4
4
|
* @link https://github.com/mathuo/dockview
|
|
5
5
|
* @license MIT
|
|
6
6
|
*/
|
|
@@ -9,26 +9,6 @@
|
|
|
9
9
|
var React = require('react');
|
|
10
10
|
var ReactDOM = require('react-dom');
|
|
11
11
|
|
|
12
|
-
function _interopNamespaceDefault(e) {
|
|
13
|
-
var n = Object.create(null);
|
|
14
|
-
if (e) {
|
|
15
|
-
Object.keys(e).forEach(function (k) {
|
|
16
|
-
if (k !== 'default') {
|
|
17
|
-
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
18
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
19
|
-
enumerable: true,
|
|
20
|
-
get: function () { return e[k]; }
|
|
21
|
-
});
|
|
22
|
-
}
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
n.default = e;
|
|
26
|
-
return Object.freeze(n);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
|
|
30
|
-
var ReactDOM__namespace = /*#__PURE__*/_interopNamespaceDefault(ReactDOM);
|
|
31
|
-
|
|
32
12
|
function styleInject(css, ref) {
|
|
33
13
|
if ( ref === void 0 ) ref = {};
|
|
34
14
|
var insertAt = ref.insertAt;
|
|
@@ -56,7 +36,7 @@ function styleInject(css, ref) {
|
|
|
56
36
|
}
|
|
57
37
|
}
|
|
58
38
|
|
|
59
|
-
var css_248z = "@import \"dockview-core/dist/styles/dockview.css\";\n.tab .dockview-react-tab {\n display: flex;\n padding: 0px 8px;\n align-items: center;\n height: 100%;\n}\n.tab .dockview-react-tab .dockview-react-tab-title {\n padding: 0px 8px;\n flex-grow: 1;\n}\n.tab .dockview-react-tab .dv-react-tab-close-btn {\n padding: 4px;\n display: flex;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n}\n.tab .dockview-react-tab .dv-react-tab-close-btn:hover {\n border-radius: 2px;\n background-color: var(--dv-icon-hover-background-color);\n}\n.tab.inactive-tab:not(:hover) .dv-react-tab-close-btn {\n visibility: hidden;\n}\n.dockview-react-part {\n height: 100%;\n width: 100%;\n}";
|
|
39
|
+
var css_248z = ".dv-render-overlay {\n position: absolute;\n z-index: 1;\n height: 100%;\n}\n.dv-render-overlay.dv-render-overlay-float {\n z-index: 999;\n}\n\n.dv-debug .dv-render-overlay {\n outline: 1px solid red;\n outline-offset: -1;\n}\n.dockview-svg {\n display: inline-block;\n fill: currentcolor;\n line-height: 1;\n stroke: currentcolor;\n stroke-width: 0;\n}\n.dockview-theme-dark {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-floating-box-shadow: 8px 8px 8px 0px rgba(83, 89, 93, 0.5);\n --dv-group-view-background-color: #1e1e1e;\n --dv-tabs-and-actions-container-background-color: #252526;\n --dv-activegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-activegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-inactivegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-tab-divider-color: #1e1e1e;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: #969696;\n --dv-inactivegroup-visiblepanel-tab-color: #8f8f8f;\n --dv-inactivegroup-hiddenpanel-tab-color: #626262;\n --dv-separator-border: rgb(68, 68, 68);\n --dv-paneview-header-border-color: rgba(204, 204, 204, 0.2);\n}\n\n.dockview-theme-light {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-floating-box-shadow: 8px 8px 8px 0px rgba(83, 89, 93, 0.5);\n --dv-group-view-background-color: white;\n --dv-tabs-and-actions-container-background-color: #f3f3f3;\n --dv-activegroup-visiblepanel-tab-background-color: white;\n --dv-activegroup-hiddenpanel-tab-background-color: #ececec;\n --dv-inactivegroup-visiblepanel-tab-background-color: white;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #ececec;\n --dv-tab-divider-color: white;\n --dv-activegroup-visiblepanel-tab-color: rgb(51, 51, 51);\n --dv-activegroup-hiddenpanel-tab-color: rgba(51, 51, 51, 0.7);\n --dv-inactivegroup-visiblepanel-tab-color: rgba(51, 51, 51, 0.7);\n --dv-inactivegroup-hiddenpanel-tab-color: rgba(51, 51, 51, 0.35);\n --dv-separator-border: rgba(128, 128, 128, 0.35);\n --dv-paneview-header-border-color: rgb(51, 51, 51);\n}\n\n.dockview-theme-vs {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-floating-box-shadow: 8px 8px 8px 0px rgba(83, 89, 93, 0.5);\n --dv-group-view-background-color: #1e1e1e;\n --dv-tabs-and-actions-container-background-color: #252526;\n --dv-activegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-activegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-inactivegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-tab-divider-color: #1e1e1e;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: #969696;\n --dv-inactivegroup-visiblepanel-tab-color: #8f8f8f;\n --dv-inactivegroup-hiddenpanel-tab-color: #626262;\n --dv-separator-border: rgb(68, 68, 68);\n --dv-paneview-header-border-color: rgba(204, 204, 204, 0.2);\n --dv-tabs-and-actions-container-background-color: #2d2d30;\n --dv-tabs-and-actions-container-height: 20px;\n --dv-tabs-and-actions-container-font-size: 11px;\n --dv-activegroup-visiblepanel-tab-background-color: #007acc;\n --dv-inactivegroup-visiblepanel-tab-background-color: #3f3f46;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: white;\n --dv-inactivegroup-visiblepanel-tab-color: white;\n --dv-inactivegroup-hiddenpanel-tab-color: white;\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container {\n box-sizing: content-box;\n border-bottom: 2px solid var(--dv-activegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container .tab.active-tab {\n border-top: 2px solid var(--dv-activegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container .tab.inactive-tab {\n border-top: 2px solid var(--dv-activegroup-hiddenpanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container {\n box-sizing: content-box;\n border-bottom: 2px solid var(--dv-inactivegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container .tab.active-tab {\n border-top: 2px solid var(--dv-inactivegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container .tab.inactive-tab {\n border-top: 2px solid var(--dv-inactivegroup-hiddenpanel-tab-background-color);\n}\n\n.dockview-theme-abyss {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-floating-box-shadow: 8px 8px 8px 0px rgba(83, 89, 93, 0.5);\n --dv-group-view-background-color: #000c18;\n --dv-tabs-and-actions-container-background-color: #1c1c2a;\n --dv-activegroup-visiblepanel-tab-background-color: #000c18;\n --dv-activegroup-hiddenpanel-tab-background-color: #10192c;\n --dv-inactivegroup-visiblepanel-tab-background-color: #000c18;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #10192c;\n --dv-tab-divider-color: #2b2b4a;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: rgba(255, 255, 255, 0.5);\n --dv-inactivegroup-visiblepanel-tab-color: rgba(255, 255, 255, 0.5);\n --dv-inactivegroup-hiddenpanel-tab-color: rgba(255, 255, 255, 0.25);\n --dv-separator-border: #2b2b4a;\n --dv-paneview-header-border-color: #2b2b4a;\n --dv-paneview-active-outline-color: #596f99;\n}\n\n.dockview-theme-dracula {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-floating-box-shadow: 8px 8px 8px 0px rgba(83, 89, 93, 0.5);\n --dv-group-view-background-color: #282a36;\n --dv-tabs-and-actions-container-background-color: #191a21;\n --dv-activegroup-visiblepanel-tab-background-color: #282a36;\n --dv-activegroup-hiddenpanel-tab-background-color: #21222c;\n --dv-inactivegroup-visiblepanel-tab-background-color: #282a36;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #21222c;\n --dv-tab-divider-color: #191a21;\n --dv-activegroup-visiblepanel-tab-color: rgb(248, 248, 242);\n --dv-activegroup-hiddenpanel-tab-color: rgb(98, 114, 164);\n --dv-inactivegroup-visiblepanel-tab-color: rgba(248, 248, 242, 0.5);\n --dv-inactivegroup-hiddenpanel-tab-color: rgba(98, 114, 164, 0.5);\n --dv-separator-border: #bd93f9;\n --dv-paneview-header-border-color: #bd93f9;\n --dv-paneview-active-outline-color: #6272a4;\n}\n.dockview-theme-dracula .groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n position: relative;\n}\n.dockview-theme-dracula .groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab::after {\n position: absolute;\n left: 0px;\n top: 0px;\n content: \"\";\n width: 100%;\n height: 1px;\n background-color: #94527e;\n z-index: 999;\n}\n.dockview-theme-dracula .groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n position: relative;\n}\n.dockview-theme-dracula .groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab::after {\n position: absolute;\n left: 0px;\n bottom: 0px;\n content: \"\";\n width: 100%;\n height: 1px;\n background-color: #5e3d5a;\n z-index: 999;\n}\n\n.dockview-theme-replit {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-floating-box-shadow: 8px 8px 8px 0px rgba(83, 89, 93, 0.5);\n --dv-group-gap-size: 3px;\n --dv-group-view-background-color: #ebeced;\n --dv-tabs-and-actions-container-background-color: #fcfcfc;\n --dv-activegroup-visiblepanel-tab-background-color: #f0f1f2;\n --dv-activegroup-hiddenpanel-tab-background-color: ##fcfcfc;\n --dv-inactivegroup-visiblepanel-tab-background-color: #f0f1f2;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #fcfcfc;\n --dv-tab-divider-color: transparent;\n --dv-activegroup-visiblepanel-tab-color: rgb(51, 51, 51);\n --dv-activegroup-hiddenpanel-tab-color: rgb(51, 51, 51);\n --dv-inactivegroup-visiblepanel-tab-color: rgb(51, 51, 51);\n --dv-inactivegroup-hiddenpanel-tab-color: rgb(51, 51, 51);\n --dv-separator-border: transparent;\n --dv-paneview-header-border-color: rgb(51, 51, 51);\n --dv-background-color: #ebeced;\n --dv-separator-handle-background-color: #cfd1d3;\n --dv-separator-handle-hover-background-color: #babbbb;\n}\n.dockview-theme-replit .dv-resize-container:has(> .groupview) {\n border-radius: 8px;\n}\n.dockview-theme-replit .groupview {\n overflow: hidden;\n border-radius: 10px;\n}\n.dockview-theme-replit .groupview .tabs-and-actions-container {\n border-bottom: 1px solid rgba(128, 128, 128, 0.35);\n}\n.dockview-theme-replit .groupview .tabs-and-actions-container .tab {\n margin: 4px;\n border-radius: 8px;\n}\n.dockview-theme-replit .groupview .tabs-and-actions-container .tab .dockview-svg {\n height: 8px;\n width: 8px;\n}\n.dockview-theme-replit .groupview .tabs-and-actions-container .tab:hover {\n background-color: #e4e5e6 !important;\n}\n.dockview-theme-replit .groupview .content-container {\n background-color: #fcfcfc;\n}\n.dockview-theme-replit .groupview.active-group {\n border: 1px solid rgba(128, 128, 128, 0.35);\n}\n.dockview-theme-replit .groupview.inactive-group {\n border: 1px solid transparent;\n}\n.dockview-theme-replit .vertical > .sash-container > .sash::after {\n content: \"\";\n height: 4px;\n width: 40px;\n border-radius: 2px;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n background-color: var(--dv-separator-handle-background-color);\n position: absolute;\n}\n.dockview-theme-replit .vertical > .sash-container > .sash:hover::after {\n background-color: var(--dv-separator-handle-hover-background-color);\n}\n.dockview-theme-replit .horizontal > .sash-container > .sash::after {\n content: \"\";\n height: 40px;\n width: 4px;\n border-radius: 2px;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n background-color: var(--dv-separator-handle-background-color);\n position: absolute;\n}\n.dockview-theme-replit .horizontal > .sash-container > .sash:hover::after {\n background-color: var(--dv-separator-handle-hover-background-color);\n}\n.drop-target {\n position: relative;\n}\n.drop-target > .drop-target-dropzone {\n position: absolute;\n left: 0px;\n top: 0px;\n height: 100%;\n width: 100%;\n z-index: 1000;\n pointer-events: none;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection {\n position: relative;\n box-sizing: border-box;\n height: 100%;\n width: 100%;\n background-color: var(--dv-drag-over-background-color);\n transition: top 70ms ease-out, left 70ms ease-out, width 70ms ease-out, height 70ms ease-out, opacity 0.15s ease-out;\n will-change: transform;\n pointer-events: none;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.dv-drop-target-top.dv-drop-target-small-vertical {\n border-top: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.dv-drop-target-bottom.dv-drop-target-small-vertical {\n border-bottom: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.dv-drop-target-left.dv-drop-target-small-horizontal {\n border-left: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.dv-drop-target-right.dv-drop-target-small-horizontal {\n border-right: 1px solid var(--dv-drag-over-border-color);\n}\n.dv-debug .dv-resize-container .dv-resize-handle-top {\n background-color: red;\n}\n.dv-debug .dv-resize-container .dv-resize-handle-bottom {\n background-color: green;\n}\n.dv-debug .dv-resize-container .dv-resize-handle-left {\n background-color: yellow;\n}\n.dv-debug .dv-resize-container .dv-resize-handle-right {\n background-color: blue;\n}\n.dv-debug .dv-resize-container .dv-resize-handle-topleft,\n.dv-debug .dv-resize-container .dv-resize-handle-topright,\n.dv-debug .dv-resize-container .dv-resize-handle-bottomleft,\n.dv-debug .dv-resize-container .dv-resize-handle-bottomright {\n background-color: cyan;\n}\n\n.dv-resize-container {\n position: absolute;\n z-index: 997;\n border: 1px solid var(--dv-tab-divider-color);\n box-shadow: var(--dv-floating-box-shadow);\n}\n.dv-resize-container.dv-bring-to-front {\n z-index: 998;\n}\n.dv-resize-container.dv-resize-container-dragging {\n opacity: 0.5;\n}\n.dv-resize-container .dv-resize-handle-top {\n height: 4px;\n width: calc(100% - 8px);\n left: 4px;\n top: -2px;\n z-index: 999;\n position: absolute;\n cursor: ns-resize;\n}\n.dv-resize-container .dv-resize-handle-bottom {\n height: 4px;\n width: calc(100% - 8px);\n left: 4px;\n bottom: -2px;\n z-index: 999;\n position: absolute;\n cursor: ns-resize;\n}\n.dv-resize-container .dv-resize-handle-left {\n height: calc(100% - 8px);\n width: 4px;\n left: -2px;\n top: 4px;\n z-index: 999;\n position: absolute;\n cursor: ew-resize;\n}\n.dv-resize-container .dv-resize-handle-right {\n height: calc(100% - 8px);\n width: 4px;\n right: -2px;\n top: 4px;\n z-index: 999;\n position: absolute;\n cursor: ew-resize;\n}\n.dv-resize-container .dv-resize-handle-topleft {\n height: 4px;\n width: 4px;\n top: -2px;\n left: -2px;\n z-index: 999;\n position: absolute;\n cursor: nw-resize;\n}\n.dv-resize-container .dv-resize-handle-topright {\n height: 4px;\n width: 4px;\n right: -2px;\n top: -2px;\n z-index: 999;\n position: absolute;\n cursor: ne-resize;\n}\n.dv-resize-container .dv-resize-handle-bottomleft {\n height: 4px;\n width: 4px;\n left: -2px;\n bottom: -2px;\n z-index: 999;\n position: absolute;\n cursor: sw-resize;\n}\n.dv-resize-container .dv-resize-handle-bottomright {\n height: 4px;\n width: 4px;\n right: -2px;\n bottom: -2px;\n z-index: 999;\n position: absolute;\n cursor: se-resize;\n}\n.dv-dockview {\n position: relative;\n background-color: var(--dv-group-view-background-color);\n}\n.dv-dockview .dv-watermark-container {\n position: absolute;\n top: 0px;\n left: 0px;\n height: 100%;\n width: 100%;\n z-index: 1;\n}\n.dv-dockview .dv-overlay-render-container {\n position: relative;\n}\n.dv-dockview .split-view-container.horizontal > .view-container > .view:not(:last-child) {\n border-right: var(--dv-group-gap-size) solid transparent;\n}\n.dv-dockview .split-view-container.horizontal > .view-container > .view:not(:first-child) {\n border-left: var(--dv-group-gap-size) solid transparent;\n}\n.dv-dockview .split-view-container.vertical > .view-container > .view:not(:last-child) {\n border-bottom: var(--dv-group-gap-size) solid transparent;\n}\n.dv-dockview .split-view-container.vertical > .view-container > .view:not(:first-child) {\n border-top: var(--dv-group-gap-size) solid transparent;\n}\n\n.groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n background-color: var(--dv-activegroup-visiblepanel-tab-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab {\n background-color: var(--dv-activegroup-hiddenpanel-tab-background-color);\n color: var(--dv-activegroup-hiddenpanel-tab-color);\n}\n.groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n background-color: var(--dv-inactivegroup-visiblepanel-tab-background-color);\n color: var(--dv-inactivegroup-visiblepanel-tab-color);\n}\n.groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab {\n background-color: var(--dv-inactivegroup-hiddenpanel-tab-background-color);\n color: var(--dv-inactivegroup-hiddenpanel-tab-color);\n}\n\n/**\n * when a tab is dragged we lose the above stylings because they are conditional on parent elements\n * therefore we also set some stylings for the dragging event\n **/\n.tab.dv-tab-dragging {\n background-color: var(--dv-activegroup-visiblepanel-tab-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.groupview {\n display: flex;\n flex-direction: column;\n height: 100%;\n background-color: var(--dv-group-view-background-color);\n overflow: hidden;\n}\n.groupview:focus {\n outline: none;\n}\n.groupview.empty > .tabs-and-actions-container {\n display: none;\n}\n.groupview > .content-container {\n flex-grow: 1;\n min-height: 0;\n outline: none;\n}\n.dv-root-wrapper {\n height: 100%;\n width: 100%;\n}\n.grid-view,\n.branch-node {\n height: 100%;\n width: 100%;\n}\n.pane-container {\n height: 100%;\n width: 100%;\n}\n.pane-container.animated .view {\n transition-duration: 0.15s;\n transition-timing-function: ease-out;\n}\n.pane-container .view {\n overflow: hidden;\n display: flex;\n flex-direction: column;\n padding: 0px !important;\n}\n.pane-container .view:not(:first-child)::before {\n background-color: transparent !important;\n}\n.pane-container .view:not(:first-child) .pane > .pane-header {\n border-top: 1px solid var(--dv-paneview-header-border-color);\n}\n.pane-container .view .default-header {\n background-color: var(--dv-group-view-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n display: flex;\n padding: 0px 8px;\n cursor: pointer;\n}\n.pane-container .view .default-header .dockview-pane-header-icon {\n display: flex;\n justify-content: center;\n align-items: center;\n}\n.pane-container .view .default-header > span {\n padding-left: 8px;\n flex-grow: 1;\n}\n.pane-container:first-of-type > .pane > .pane-header {\n border-top: none !important;\n}\n.pane-container .pane {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n height: 100%;\n}\n.pane-container .pane .pane-header {\n box-sizing: border-box;\n user-select: none;\n position: relative;\n outline: none;\n}\n.pane-container .pane .pane-header.pane-draggable {\n cursor: pointer;\n}\n.pane-container .pane .pane-header:focus:before, .pane-container .pane .pane-header:focus-within:before {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 5;\n content: \"\";\n pointer-events: none;\n outline: 1px solid;\n outline-width: -1px;\n outline-style: solid;\n outline-offset: -1px;\n outline-color: var(--dv-paneview-active-outline-color);\n}\n.pane-container .pane .pane-body {\n overflow-y: auto;\n overflow-x: hidden;\n flex-grow: 1;\n position: relative;\n outline: none;\n}\n.pane-container .pane .pane-body:focus:before, .pane-container .pane .pane-body:focus-within:before {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 5;\n content: \"\";\n pointer-events: none;\n outline: 1px solid;\n outline-width: -1px;\n outline-style: solid;\n outline-offset: -1px;\n outline-color: var(--dv-paneview-active-outline-color);\n}\n.dv-debug .split-view-container .sash-container .sash.enabled {\n background-color: black;\n}\n.dv-debug .split-view-container .sash-container .sash.disabled {\n background-color: orange;\n}\n.dv-debug .split-view-container .sash-container .sash.maximum {\n background-color: green;\n}\n.dv-debug .split-view-container .sash-container .sash.minimum {\n background-color: red;\n}\n\n.split-view-container {\n position: relative;\n overflow: hidden;\n height: 100%;\n width: 100%;\n}\n.split-view-container.dv-splitview-disabled > .sash-container > .sash {\n pointer-events: none;\n}\n.split-view-container.animation .view,\n.split-view-container.animation .sash {\n transition-duration: 0.15s;\n transition-timing-function: ease-out;\n}\n.split-view-container.horizontal {\n height: 100%;\n}\n.split-view-container.horizontal > .sash-container > .sash {\n height: 100%;\n width: 4px;\n}\n.split-view-container.horizontal > .sash-container > .sash.enabled {\n cursor: ew-resize;\n}\n.split-view-container.horizontal > .sash-container > .sash.disabled {\n cursor: default;\n}\n.split-view-container.horizontal > .sash-container > .sash.maximum {\n cursor: w-resize;\n}\n.split-view-container.horizontal > .sash-container > .sash.minimum {\n cursor: e-resize;\n}\n.split-view-container.horizontal > .view-container > .view:not(:first-child)::before {\n height: 100%;\n width: 1px;\n}\n.split-view-container.vertical {\n width: 100%;\n}\n.split-view-container.vertical > .sash-container > .sash {\n width: 100%;\n height: 4px;\n}\n.split-view-container.vertical > .sash-container > .sash.enabled {\n cursor: ns-resize;\n}\n.split-view-container.vertical > .sash-container > .sash.disabled {\n cursor: default;\n}\n.split-view-container.vertical > .sash-container > .sash.maximum {\n cursor: n-resize;\n}\n.split-view-container.vertical > .sash-container > .sash.minimum {\n cursor: s-resize;\n}\n.split-view-container.vertical > .view-container > .view {\n width: 100%;\n}\n.split-view-container.vertical > .view-container > .view:not(:first-child)::before {\n height: 1px;\n width: 100%;\n}\n.split-view-container .sash-container {\n height: 100%;\n width: 100%;\n position: absolute;\n}\n.split-view-container .sash-container .sash {\n position: absolute;\n z-index: 99;\n outline: none;\n user-select: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n touch-action: none;\n}\n.split-view-container .sash-container .sash:not(.disabled):active {\n transition: background-color 0.1s ease-in-out;\n background-color: var(--dv-active-sash-color, transparent);\n}\n.split-view-container .sash-container .sash:not(.disabled):hover {\n background-color: var(--dv-active-sash-color, transparent);\n transition: background-color 0.1s ease-in-out;\n transition-delay: 0.5s;\n}\n.split-view-container .view-container {\n position: relative;\n height: 100%;\n width: 100%;\n background-color: var(--dv-background-color);\n}\n.split-view-container .view-container .view {\n height: 100%;\n box-sizing: border-box;\n overflow: auto;\n position: absolute;\n}\n.split-view-container.separator-border .view:not(:first-child)::before {\n content: \" \";\n position: absolute;\n top: 0;\n left: 0;\n z-index: 5;\n pointer-events: none;\n background-color: var(--dv-separator-border);\n}\n.dv-dragged {\n transform: translate3d(0px, 0px, 0px); /* forces tab to be drawn on a separate layer (see https://github.com/microsoft/vscode/issues/18733) */\n}\n\n.tab {\n flex-shrink: 0;\n}\n.tab:focus-within, .tab:focus {\n position: relative;\n}\n.tab:focus-within::after, .tab:focus::after {\n position: absolute;\n content: \"\";\n height: 100%;\n width: 100%;\n top: 0px;\n left: 0px;\n pointer-events: none;\n outline: 1px solid var(--dv-tab-divider-color) !important;\n outline-offset: -1px;\n z-index: 5;\n}\n.tab.dv-tab-dragging .dv-default-tab-action {\n background-color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.tab.active-tab .dv-default-tab .dv-default-tab-action {\n visibility: visible;\n}\n.tab.inactive-tab .dv-default-tab .dv-default-tab-action {\n visibility: hidden;\n}\n.tab.inactive-tab .dv-default-tab:hover .dv-default-tab-action {\n visibility: visible;\n}\n.tab .dv-default-tab {\n position: relative;\n height: 100%;\n display: flex;\n min-width: 80px;\n align-items: center;\n padding: 0px 8px;\n white-space: nowrap;\n text-overflow: elipsis;\n}\n.tab .dv-default-tab .dv-default-tab-content {\n padding: 0px 8px;\n flex-grow: 1;\n}\n.tab .dv-default-tab .dv-default-tab-action {\n padding: 4px;\n display: flex;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n}\n.tab .dv-default-tab .dv-default-tab-action:hover {\n border-radius: 2px;\n background-color: var(--dv-icon-hover-background-color);\n}\n.tabs-and-actions-container {\n display: flex;\n background-color: var(--dv-tabs-and-actions-container-background-color);\n flex-shrink: 0;\n box-sizing: border-box;\n height: var(--dv-tabs-and-actions-container-height);\n font-size: var(--dv-tabs-and-actions-container-font-size);\n}\n.tabs-and-actions-container.hidden {\n display: none;\n}\n.tabs-and-actions-container.dv-single-tab.dv-full-width-single-tab .tabs-container {\n flex-grow: 1;\n}\n.tabs-and-actions-container.dv-single-tab.dv-full-width-single-tab .tabs-container .tab {\n flex-grow: 1;\n}\n.tabs-and-actions-container.dv-single-tab.dv-full-width-single-tab .void-container {\n flex-grow: 0;\n}\n.tabs-and-actions-container .void-container {\n display: flex;\n flex-grow: 1;\n cursor: grab;\n}\n.tabs-and-actions-container .tabs-container {\n display: flex;\n overflow-x: overlay;\n overflow-y: hidden;\n scrollbar-width: thin;\n /* Track */\n /* Handle */\n}\n.tabs-and-actions-container .tabs-container::-webkit-scrollbar {\n height: 3px;\n}\n.tabs-and-actions-container .tabs-container::-webkit-scrollbar-track {\n background: transparent;\n}\n.tabs-and-actions-container .tabs-container::-webkit-scrollbar-thumb {\n background: var(--dv-tabs-container-scrollbar-color);\n}\n.tabs-and-actions-container .tabs-container .tab {\n -webkit-user-drag: element;\n outline: none;\n min-width: 75px;\n cursor: pointer;\n position: relative;\n box-sizing: border-box;\n}\n.tabs-and-actions-container .tabs-container .tab:not(:first-child)::before {\n content: \" \";\n position: absolute;\n top: 0;\n left: 0;\n z-index: 5;\n pointer-events: none;\n background-color: var(--dv-tab-divider-color);\n width: 1px;\n height: 100%;\n}\n.watermark {\n display: flex;\n width: 100%;\n}\n.watermark.has-actions .watermark-title .actions-container {\n display: none;\n}\n.watermark .watermark-title {\n height: 35px;\n width: 100%;\n display: flex;\n}\n.watermark .watermark-content {\n flex-grow: 1;\n}\n.watermark .actions-container {\n display: flex;\n align-items: center;\n padding: 0px 8px;\n}\n.watermark .actions-container .close-action {\n padding: 4px;\n display: flex;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n cursor: pointer;\n color: var(--dv-activegroup-hiddenpanel-tab-color);\n}\n.watermark .actions-container .close-action:hover {\n border-radius: 2px;\n background-color: var(--dv-icon-hover-background-color);\n}";
|
|
60
40
|
styleInject(css_248z);
|
|
61
41
|
|
|
62
42
|
class TransferObject {
|
|
@@ -4288,6 +4268,7 @@ class DockviewGroupPanelModel extends CompositeDisposable {
|
|
|
4288
4268
|
this._width = 0;
|
|
4289
4269
|
this._height = 0;
|
|
4290
4270
|
this._panels = [];
|
|
4271
|
+
this._panelDisposables = new Map();
|
|
4291
4272
|
this._onMove = new Emitter();
|
|
4292
4273
|
this.onMove = this._onMove.event;
|
|
4293
4274
|
this._onDidDrop = new Emitter();
|
|
@@ -4302,6 +4283,10 @@ class DockviewGroupPanelModel extends CompositeDisposable {
|
|
|
4302
4283
|
this.onGroupDragStart = this._onGroupDragStart.event;
|
|
4303
4284
|
this._onDidAddPanel = new Emitter();
|
|
4304
4285
|
this.onDidAddPanel = this._onDidAddPanel.event;
|
|
4286
|
+
this._onDidPanelTitleChange = new Emitter();
|
|
4287
|
+
this.onDidPanelTitleChange = this._onDidPanelTitleChange.event;
|
|
4288
|
+
this._onDidPanelParametersChange = new Emitter();
|
|
4289
|
+
this.onDidPanelParametersChange = this._onDidPanelParametersChange.event;
|
|
4305
4290
|
this._onDidRemovePanel = new Emitter();
|
|
4306
4291
|
this.onDidRemovePanel = this._onDidRemovePanel.event;
|
|
4307
4292
|
this._onDidActivePanelChange = new Emitter();
|
|
@@ -4590,6 +4575,11 @@ class DockviewGroupPanelModel extends CompositeDisposable {
|
|
|
4590
4575
|
if (this.mostRecentlyUsed.includes(panel)) {
|
|
4591
4576
|
this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(panel), 1);
|
|
4592
4577
|
}
|
|
4578
|
+
const disposable = this._panelDisposables.get(panel.id);
|
|
4579
|
+
if (disposable) {
|
|
4580
|
+
disposable.dispose();
|
|
4581
|
+
this._panelDisposables.delete(panel.id);
|
|
4582
|
+
}
|
|
4593
4583
|
this._onDidRemovePanel.fire({ panel });
|
|
4594
4584
|
}
|
|
4595
4585
|
doAddPanel(panel, index = this.panels.length, options = { skipSetActive: false }) {
|
|
@@ -4607,6 +4597,7 @@ class DockviewGroupPanelModel extends CompositeDisposable {
|
|
|
4607
4597
|
}
|
|
4608
4598
|
this.updateMru(panel);
|
|
4609
4599
|
this.panels.splice(index, 0, panel);
|
|
4600
|
+
this._panelDisposables.set(panel.id, new CompositeDisposable(panel.api.onDidTitleChange((event) => this._onDidPanelTitleChange.fire(event)), panel.api.onDidParametersChange((event) => this._onDidPanelParametersChange.fire(event))));
|
|
4610
4601
|
this._onDidAddPanel.fire({ panel });
|
|
4611
4602
|
}
|
|
4612
4603
|
doSetActivePanel(panel) {
|
|
@@ -5030,14 +5021,16 @@ class PanelApiImpl extends CompositeDisposable {
|
|
|
5030
5021
|
get height() {
|
|
5031
5022
|
return this._height;
|
|
5032
5023
|
}
|
|
5033
|
-
constructor(id) {
|
|
5024
|
+
constructor(id, component) {
|
|
5034
5025
|
super();
|
|
5035
5026
|
this.id = id;
|
|
5027
|
+
this.component = component;
|
|
5036
5028
|
this._isFocused = false;
|
|
5037
5029
|
this._isActive = false;
|
|
5038
5030
|
this._isVisible = true;
|
|
5039
5031
|
this._width = 0;
|
|
5040
5032
|
this._height = 0;
|
|
5033
|
+
this._parameters = {};
|
|
5041
5034
|
this.panelUpdatesDisposable = new MutableDisposable();
|
|
5042
5035
|
this._onDidDimensionChange = new Emitter();
|
|
5043
5036
|
this.onDidDimensionsChange = this._onDidDimensionChange.event;
|
|
@@ -5055,8 +5048,8 @@ class PanelApiImpl extends CompositeDisposable {
|
|
|
5055
5048
|
this.onDidActiveChange = this._onDidActiveChange.event;
|
|
5056
5049
|
this._onActiveChange = new Emitter();
|
|
5057
5050
|
this.onActiveChange = this._onActiveChange.event;
|
|
5058
|
-
this.
|
|
5059
|
-
this.
|
|
5051
|
+
this._onDidParametersChange = new Emitter();
|
|
5052
|
+
this.onDidParametersChange = this._onDidParametersChange.event;
|
|
5060
5053
|
this.addDisposables(this.onDidFocusChange((event) => {
|
|
5061
5054
|
this._isFocused = event.isFocused;
|
|
5062
5055
|
}), this.onDidActiveChange((event) => {
|
|
@@ -5066,10 +5059,14 @@ class PanelApiImpl extends CompositeDisposable {
|
|
|
5066
5059
|
}), this.onDidDimensionsChange((event) => {
|
|
5067
5060
|
this._width = event.width;
|
|
5068
5061
|
this._height = event.height;
|
|
5069
|
-
}), this.panelUpdatesDisposable, this._onDidDimensionChange, this._onDidChangeFocus, this._onDidVisibilityChange, this._onDidActiveChange, this._onWillFocus, this._onActiveChange, this.
|
|
5062
|
+
}), this.panelUpdatesDisposable, this._onDidDimensionChange, this._onDidChangeFocus, this._onDidVisibilityChange, this._onDidActiveChange, this._onWillFocus, this._onActiveChange, this._onWillFocus, this._onWillVisibilityChange, this._onDidParametersChange);
|
|
5063
|
+
}
|
|
5064
|
+
getParameters() {
|
|
5065
|
+
return this._parameters;
|
|
5070
5066
|
}
|
|
5071
5067
|
initialize(panel) {
|
|
5072
|
-
this.panelUpdatesDisposable.value = this.
|
|
5068
|
+
this.panelUpdatesDisposable.value = this._onDidParametersChange.event((parameters) => {
|
|
5069
|
+
this._parameters = parameters;
|
|
5073
5070
|
panel.update({
|
|
5074
5071
|
params: parameters,
|
|
5075
5072
|
});
|
|
@@ -5082,14 +5079,14 @@ class PanelApiImpl extends CompositeDisposable {
|
|
|
5082
5079
|
this._onActiveChange.fire();
|
|
5083
5080
|
}
|
|
5084
5081
|
updateParameters(parameters) {
|
|
5085
|
-
this.
|
|
5082
|
+
this._onDidParametersChange.fire(parameters);
|
|
5086
5083
|
}
|
|
5087
5084
|
}
|
|
5088
5085
|
|
|
5089
5086
|
class SplitviewPanelApiImpl extends PanelApiImpl {
|
|
5090
5087
|
//
|
|
5091
|
-
constructor(id) {
|
|
5092
|
-
super(id);
|
|
5088
|
+
constructor(id, component) {
|
|
5089
|
+
super(id, component);
|
|
5093
5090
|
this._onDidConstraintsChangeInternal = new Emitter();
|
|
5094
5091
|
this.onDidConstraintsChangeInternal = this._onDidConstraintsChangeInternal.event;
|
|
5095
5092
|
//
|
|
@@ -5114,8 +5111,8 @@ class PaneviewPanelApiImpl extends SplitviewPanelApiImpl {
|
|
|
5114
5111
|
set pane(pane) {
|
|
5115
5112
|
this._pane = pane;
|
|
5116
5113
|
}
|
|
5117
|
-
constructor(id) {
|
|
5118
|
-
super(id);
|
|
5114
|
+
constructor(id, component) {
|
|
5115
|
+
super(id, component);
|
|
5119
5116
|
this._onDidExpansionChange = new Emitter({
|
|
5120
5117
|
replay: true,
|
|
5121
5118
|
});
|
|
@@ -5274,7 +5271,7 @@ class PaneviewPanel extends BasePanelView {
|
|
|
5274
5271
|
this.header.style.display = value ? '' : 'none';
|
|
5275
5272
|
}
|
|
5276
5273
|
constructor(id, component, headerComponent, orientation, isExpanded, isHeaderVisible) {
|
|
5277
|
-
super(id, component, new PaneviewPanelApiImpl(id));
|
|
5274
|
+
super(id, component, new PaneviewPanelApiImpl(id, component));
|
|
5278
5275
|
this.headerComponent = headerComponent;
|
|
5279
5276
|
this._onDidChangeExpansionState = new Emitter({ replay: true });
|
|
5280
5277
|
this.onDidChangeExpansionState = this._onDidChangeExpansionState.event;
|
|
@@ -5505,8 +5502,8 @@ class DraggablePaneviewPanel extends PaneviewPanel {
|
|
|
5505
5502
|
}
|
|
5506
5503
|
|
|
5507
5504
|
class GridviewPanelApiImpl extends PanelApiImpl {
|
|
5508
|
-
constructor(id, panel) {
|
|
5509
|
-
super(id);
|
|
5505
|
+
constructor(id, component, panel) {
|
|
5506
|
+
super(id, component);
|
|
5510
5507
|
this._onDidConstraintsChangeInternal = new Emitter();
|
|
5511
5508
|
this.onDidConstraintsChangeInternal = this._onDidConstraintsChangeInternal.event;
|
|
5512
5509
|
this._onDidConstraintsChange = new Emitter();
|
|
@@ -5577,7 +5574,7 @@ class GridviewPanel extends BasePanelView {
|
|
|
5577
5574
|
return this.api.isActive;
|
|
5578
5575
|
}
|
|
5579
5576
|
constructor(id, component, options, api) {
|
|
5580
|
-
super(id, component, api !== null && api !== void 0 ? api : new GridviewPanelApiImpl(id));
|
|
5577
|
+
super(id, component, api !== null && api !== void 0 ? api : new GridviewPanelApiImpl(id, component));
|
|
5581
5578
|
this._evaluatedMinimumWidth = 0;
|
|
5582
5579
|
this._evaluatedMaximumWidth = Number.MAX_SAFE_INTEGER;
|
|
5583
5580
|
this._evaluatedMinimumHeight = 0;
|
|
@@ -5685,7 +5682,7 @@ class DockviewGroupPanelApiImpl extends GridviewPanelApiImpl {
|
|
|
5685
5682
|
return this._group.model.location;
|
|
5686
5683
|
}
|
|
5687
5684
|
constructor(id, accessor) {
|
|
5688
|
-
super(id);
|
|
5685
|
+
super(id, '__dockviewgroup__');
|
|
5689
5686
|
this.accessor = accessor;
|
|
5690
5687
|
this._onDidLocationChange = new Emitter();
|
|
5691
5688
|
this.onDidLocationChange = this._onDidLocationChange.event;
|
|
@@ -5859,8 +5856,11 @@ class DockviewPanelApiImpl extends GridviewPanelApiImpl {
|
|
|
5859
5856
|
get group() {
|
|
5860
5857
|
return this._group;
|
|
5861
5858
|
}
|
|
5862
|
-
|
|
5863
|
-
|
|
5859
|
+
get tabComponent() {
|
|
5860
|
+
return this._tabComponent;
|
|
5861
|
+
}
|
|
5862
|
+
constructor(panel, group, accessor, component, tabComponent) {
|
|
5863
|
+
super(panel.id, component);
|
|
5864
5864
|
this.panel = panel;
|
|
5865
5865
|
this.accessor = accessor;
|
|
5866
5866
|
this._onDidTitleChange = new Emitter();
|
|
@@ -5874,6 +5874,7 @@ class DockviewPanelApiImpl extends GridviewPanelApiImpl {
|
|
|
5874
5874
|
this._onDidLocationChange = new Emitter();
|
|
5875
5875
|
this.onDidLocationChange = this._onDidLocationChange.event;
|
|
5876
5876
|
this.groupEventsDisposable = new MutableDisposable();
|
|
5877
|
+
this._tabComponent = tabComponent;
|
|
5877
5878
|
this.initialize(panel);
|
|
5878
5879
|
this._group = group;
|
|
5879
5880
|
this.setupGroupEventListeners();
|
|
@@ -5956,7 +5957,7 @@ class DockviewPanel extends CompositeDisposable {
|
|
|
5956
5957
|
var _a;
|
|
5957
5958
|
return (_a = this._renderer) !== null && _a !== void 0 ? _a : this.accessor.renderer;
|
|
5958
5959
|
}
|
|
5959
|
-
constructor(id, accessor, containerApi, group, view, options) {
|
|
5960
|
+
constructor(id, component, tabComponent, accessor, containerApi, group, view, options) {
|
|
5960
5961
|
super();
|
|
5961
5962
|
this.id = id;
|
|
5962
5963
|
this.accessor = accessor;
|
|
@@ -5964,7 +5965,7 @@ class DockviewPanel extends CompositeDisposable {
|
|
|
5964
5965
|
this.view = view;
|
|
5965
5966
|
this._renderer = options.renderer;
|
|
5966
5967
|
this._group = group;
|
|
5967
|
-
this.api = new DockviewPanelApiImpl(this, this._group, accessor);
|
|
5968
|
+
this.api = new DockviewPanelApiImpl(this, this._group, accessor, component, tabComponent);
|
|
5968
5969
|
this.addDisposables(this.api.onActiveChange(() => {
|
|
5969
5970
|
accessor.setActivePanel(this);
|
|
5970
5971
|
}), this.api.onDidSizeChange((event) => {
|
|
@@ -6132,27 +6133,18 @@ class DefaultTab extends CompositeDisposable {
|
|
|
6132
6133
|
//
|
|
6133
6134
|
this.params = {};
|
|
6134
6135
|
this._element = document.createElement('div');
|
|
6135
|
-
this._element.className = 'default-tab';
|
|
6136
|
+
this._element.className = 'dv-default-tab';
|
|
6136
6137
|
//
|
|
6137
6138
|
this._content = document.createElement('div');
|
|
6138
|
-
this._content.className = 'tab-content';
|
|
6139
|
-
//
|
|
6140
|
-
this._actionContainer = document.createElement('div');
|
|
6141
|
-
this._actionContainer.className = 'action-container';
|
|
6142
|
-
//
|
|
6143
|
-
this._list = document.createElement('ul');
|
|
6144
|
-
this._list.className = 'tab-list';
|
|
6145
|
-
//
|
|
6139
|
+
this._content.className = 'dv-default-tab-content';
|
|
6146
6140
|
this.action = document.createElement('div');
|
|
6147
|
-
this.action.className = 'tab-action';
|
|
6141
|
+
this.action.className = 'dv-default-tab-action';
|
|
6148
6142
|
this.action.appendChild(createCloseButton());
|
|
6149
6143
|
//
|
|
6150
6144
|
this._element.appendChild(this._content);
|
|
6151
|
-
this._element.appendChild(this.
|
|
6152
|
-
this._actionContainer.appendChild(this._list);
|
|
6153
|
-
this._list.appendChild(this.action);
|
|
6145
|
+
this._element.appendChild(this.action);
|
|
6154
6146
|
//
|
|
6155
|
-
this.addDisposables(addDisposableListener(this.
|
|
6147
|
+
this.addDisposables(addDisposableListener(this.action, 'mousedown', (ev) => {
|
|
6156
6148
|
ev.preventDefault();
|
|
6157
6149
|
}));
|
|
6158
6150
|
this.render();
|
|
@@ -6259,7 +6251,7 @@ class DefaultDockviewDeserialzier {
|
|
|
6259
6251
|
? (_b = viewData.tab) === null || _b === void 0 ? void 0 : _b.id
|
|
6260
6252
|
: panelData.tabComponent;
|
|
6261
6253
|
const view = new DockviewPanelModel(this.accessor, panelId, contentComponent, tabComponent);
|
|
6262
|
-
const panel = new DockviewPanel(panelId, this.accessor, new DockviewApi(this.accessor), group, view, {
|
|
6254
|
+
const panel = new DockviewPanel(panelId, contentComponent, tabComponent, this.accessor, new DockviewApi(this.accessor), group, view, {
|
|
6263
6255
|
renderer: panelData.renderer,
|
|
6264
6256
|
});
|
|
6265
6257
|
panel.init({
|
|
@@ -8246,6 +8238,8 @@ class DockviewComponent extends BaseGrid {
|
|
|
8246
8238
|
if (this._onDidActivePanelChange.value !== event.panel) {
|
|
8247
8239
|
this._onDidActivePanelChange.fire(event.panel);
|
|
8248
8240
|
}
|
|
8241
|
+
}), exports.DockviewEvent.any(view.model.onDidPanelTitleChange, view.model.onDidPanelParametersChange)(() => {
|
|
8242
|
+
this._bufferOnDidLayoutChange.fire();
|
|
8249
8243
|
}));
|
|
8250
8244
|
this._groups.set(view.id, { value: view, disposable });
|
|
8251
8245
|
}
|
|
@@ -8258,7 +8252,7 @@ class DockviewComponent extends BaseGrid {
|
|
|
8258
8252
|
const contentComponent = options.component;
|
|
8259
8253
|
const tabComponent = (_a = options.tabComponent) !== null && _a !== void 0 ? _a : this.options.defaultTabComponent;
|
|
8260
8254
|
const view = new DockviewPanelModel(this, options.id, contentComponent, tabComponent);
|
|
8261
|
-
const panel = new DockviewPanel(options.id, this, this._api, group, view, { renderer: options.renderer });
|
|
8255
|
+
const panel = new DockviewPanel(options.id, contentComponent, tabComponent, this, this._api, group, view, { renderer: options.renderer });
|
|
8262
8256
|
panel.init({
|
|
8263
8257
|
title: (_b = options.title) !== null && _b !== void 0 ? _b : options.id,
|
|
8264
8258
|
params: (_c = options === null || options === void 0 ? void 0 : options.params) !== null && _c !== void 0 ? _c : {},
|
|
@@ -9173,7 +9167,7 @@ class SplitviewPanel extends BasePanelView {
|
|
|
9173
9167
|
return this._snap;
|
|
9174
9168
|
}
|
|
9175
9169
|
constructor(id, componentName) {
|
|
9176
|
-
super(id, componentName, new SplitviewPanelApiImpl(id));
|
|
9170
|
+
super(id, componentName, new SplitviewPanelApiImpl(id, componentName));
|
|
9177
9171
|
this._evaluatedMinimumSize = 0;
|
|
9178
9172
|
this._evaluatedMaximumSize = Number.POSITIVE_INFINITY;
|
|
9179
9173
|
this._minimumSize = 0;
|
|
@@ -9253,9 +9247,9 @@ class SplitviewPanel extends BasePanelView {
|
|
|
9253
9247
|
* component
|
|
9254
9248
|
*/
|
|
9255
9249
|
const ReactComponentBridge = (props, ref) => {
|
|
9256
|
-
const [_, triggerRender] =
|
|
9257
|
-
const _props =
|
|
9258
|
-
|
|
9250
|
+
const [_, triggerRender] = React.useState();
|
|
9251
|
+
const _props = React.useRef(props.componentProps);
|
|
9252
|
+
React.useImperativeHandle(ref, () => ({
|
|
9259
9253
|
update: (componentProps) => {
|
|
9260
9254
|
_props.current = Object.assign(Object.assign({}, _props.current), componentProps);
|
|
9261
9255
|
/**
|
|
@@ -9267,7 +9261,7 @@ const ReactComponentBridge = (props, ref) => {
|
|
|
9267
9261
|
triggerRender(Date.now());
|
|
9268
9262
|
},
|
|
9269
9263
|
}), []);
|
|
9270
|
-
return
|
|
9264
|
+
return React.createElement(props.component, _props.current);
|
|
9271
9265
|
};
|
|
9272
9266
|
ReactComponentBridge.displayName = 'DockviewReactJsBridge';
|
|
9273
9267
|
/**
|
|
@@ -9279,7 +9273,7 @@ const uniquePortalKeyGenerator = (() => {
|
|
|
9279
9273
|
let value = 1;
|
|
9280
9274
|
return { next: () => `dockview_react_portal_key_${(value++).toString()}` };
|
|
9281
9275
|
})();
|
|
9282
|
-
const ReactPartContext =
|
|
9276
|
+
const ReactPartContext = React.createContext({});
|
|
9283
9277
|
class ReactPart {
|
|
9284
9278
|
constructor(parent, portalStore, component, parameters, context) {
|
|
9285
9279
|
this.parent = parent;
|
|
@@ -9315,7 +9309,7 @@ class ReactPart {
|
|
|
9315
9309
|
*/
|
|
9316
9310
|
throw new Error('Dockview: Only React.memo(...), React.ForwardRef(...) and functional components are accepted as components');
|
|
9317
9311
|
}
|
|
9318
|
-
const bridgeComponent =
|
|
9312
|
+
const bridgeComponent = React.createElement(React.forwardRef(ReactComponentBridge), {
|
|
9319
9313
|
component: this
|
|
9320
9314
|
.component,
|
|
9321
9315
|
componentProps: this.parameters,
|
|
@@ -9328,9 +9322,9 @@ class ReactPart {
|
|
|
9328
9322
|
},
|
|
9329
9323
|
});
|
|
9330
9324
|
const node = this.context
|
|
9331
|
-
?
|
|
9325
|
+
? React.createElement(ReactPartContext.Provider, { value: this.context }, bridgeComponent)
|
|
9332
9326
|
: bridgeComponent;
|
|
9333
|
-
const portal =
|
|
9327
|
+
const portal = ReactDOM.createPortal(node, this.parent, uniquePortalKeyGenerator.next());
|
|
9334
9328
|
this.ref = {
|
|
9335
9329
|
portal,
|
|
9336
9330
|
disposable: this.portalStore.addPortal(portal),
|
|
@@ -9348,9 +9342,9 @@ class ReactPart {
|
|
|
9348
9342
|
* portal array
|
|
9349
9343
|
*/
|
|
9350
9344
|
const usePortalsLifecycle = () => {
|
|
9351
|
-
const [portals, setPortals] =
|
|
9352
|
-
|
|
9353
|
-
const addPortal =
|
|
9345
|
+
const [portals, setPortals] = React.useState([]);
|
|
9346
|
+
React.useDebugValue(`Portal count: ${portals.length}`);
|
|
9347
|
+
const addPortal = React.useCallback((portal) => {
|
|
9354
9348
|
setPortals((existingPortals) => [...existingPortals, portal]);
|
|
9355
9349
|
let disposed = false;
|
|
9356
9350
|
return {
|
|
@@ -9388,6 +9382,8 @@ class ReactPanelContentPart {
|
|
|
9388
9382
|
this.onDidBlur = this._onDidBlur.event;
|
|
9389
9383
|
this._element = document.createElement('div');
|
|
9390
9384
|
this._element.className = 'dockview-react-part';
|
|
9385
|
+
this._element.style.height = '100%';
|
|
9386
|
+
this._element.style.width = '100%';
|
|
9391
9387
|
}
|
|
9392
9388
|
focus() {
|
|
9393
9389
|
// TODO
|
|
@@ -9424,6 +9420,8 @@ class ReactPanelHeaderPart {
|
|
|
9424
9420
|
this.reactPortalStore = reactPortalStore;
|
|
9425
9421
|
this._element = document.createElement('div');
|
|
9426
9422
|
this._element.className = 'dockview-react-part';
|
|
9423
|
+
this._element.style.height = '100%';
|
|
9424
|
+
this._element.style.width = '100%';
|
|
9427
9425
|
}
|
|
9428
9426
|
focus() {
|
|
9429
9427
|
//noop
|
|
@@ -9458,6 +9456,8 @@ class ReactWatermarkPart {
|
|
|
9458
9456
|
this.reactPortalStore = reactPortalStore;
|
|
9459
9457
|
this._element = document.createElement('div');
|
|
9460
9458
|
this._element.className = 'dockview-react-part';
|
|
9459
|
+
this._element.style.height = '100%';
|
|
9460
|
+
this._element.style.width = '100%';
|
|
9461
9461
|
}
|
|
9462
9462
|
init(parameters) {
|
|
9463
9463
|
this.part = new ReactPart(this.element, this.reactPortalStore, this.component, {
|
|
@@ -9509,6 +9509,8 @@ class ReactHeaderActionsRendererPart {
|
|
|
9509
9509
|
this.mutableDisposable = new MutableDisposable();
|
|
9510
9510
|
this._element = document.createElement('div');
|
|
9511
9511
|
this._element.className = 'dockview-react-part';
|
|
9512
|
+
this._element.style.height = '100%';
|
|
9513
|
+
this._element.style.width = '100%';
|
|
9512
9514
|
}
|
|
9513
9515
|
focus() {
|
|
9514
9516
|
// TODO
|
|
@@ -9568,12 +9570,12 @@ function createGroupControlElement(component, store) {
|
|
|
9568
9570
|
: undefined;
|
|
9569
9571
|
}
|
|
9570
9572
|
const DEFAULT_REACT_TAB = 'props.defaultTabComponent';
|
|
9571
|
-
const DockviewReact =
|
|
9572
|
-
const domRef =
|
|
9573
|
-
const dockviewRef =
|
|
9573
|
+
const DockviewReact = React.forwardRef((props, ref) => {
|
|
9574
|
+
const domRef = React.useRef(null);
|
|
9575
|
+
const dockviewRef = React.useRef();
|
|
9574
9576
|
const [portals, addPortal] = usePortalsLifecycle();
|
|
9575
|
-
|
|
9576
|
-
|
|
9577
|
+
React.useImperativeHandle(ref, () => domRef.current, []);
|
|
9578
|
+
React.useEffect(() => {
|
|
9577
9579
|
var _a;
|
|
9578
9580
|
if (!domRef.current) {
|
|
9579
9581
|
return () => {
|
|
@@ -9644,13 +9646,13 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9644
9646
|
dockview.dispose();
|
|
9645
9647
|
};
|
|
9646
9648
|
}, []);
|
|
9647
|
-
|
|
9649
|
+
React.useEffect(() => {
|
|
9648
9650
|
if (!dockviewRef.current) {
|
|
9649
9651
|
return;
|
|
9650
9652
|
}
|
|
9651
9653
|
dockviewRef.current.locked = !!props.locked;
|
|
9652
9654
|
}, [props.locked]);
|
|
9653
|
-
|
|
9655
|
+
React.useEffect(() => {
|
|
9654
9656
|
if (!dockviewRef.current) {
|
|
9655
9657
|
return;
|
|
9656
9658
|
}
|
|
@@ -9658,7 +9660,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9658
9660
|
disableDnd: props.disableDnd,
|
|
9659
9661
|
});
|
|
9660
9662
|
}, [props.disableDnd]);
|
|
9661
|
-
|
|
9663
|
+
React.useEffect(() => {
|
|
9662
9664
|
if (!dockviewRef.current) {
|
|
9663
9665
|
return () => {
|
|
9664
9666
|
// noop
|
|
@@ -9673,7 +9675,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9673
9675
|
disposable.dispose();
|
|
9674
9676
|
};
|
|
9675
9677
|
}, [props.onDidDrop]);
|
|
9676
|
-
|
|
9678
|
+
React.useEffect(() => {
|
|
9677
9679
|
if (!dockviewRef.current) {
|
|
9678
9680
|
return () => {
|
|
9679
9681
|
// noop
|
|
@@ -9688,7 +9690,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9688
9690
|
disposable.dispose();
|
|
9689
9691
|
};
|
|
9690
9692
|
}, [props.onWillDrop]);
|
|
9691
|
-
|
|
9693
|
+
React.useEffect(() => {
|
|
9692
9694
|
if (!dockviewRef.current) {
|
|
9693
9695
|
return;
|
|
9694
9696
|
}
|
|
@@ -9696,7 +9698,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9696
9698
|
frameworkComponents: props.components,
|
|
9697
9699
|
});
|
|
9698
9700
|
}, [props.components]);
|
|
9699
|
-
|
|
9701
|
+
React.useEffect(() => {
|
|
9700
9702
|
if (!dockviewRef.current) {
|
|
9701
9703
|
return;
|
|
9702
9704
|
}
|
|
@@ -9704,7 +9706,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9704
9706
|
floatingGroupBounds: props.floatingGroupBounds,
|
|
9705
9707
|
});
|
|
9706
9708
|
}, [props.floatingGroupBounds]);
|
|
9707
|
-
|
|
9709
|
+
React.useEffect(() => {
|
|
9708
9710
|
if (!dockviewRef.current) {
|
|
9709
9711
|
return;
|
|
9710
9712
|
}
|
|
@@ -9712,7 +9714,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9712
9714
|
watermarkFrameworkComponent: props.watermarkComponent,
|
|
9713
9715
|
});
|
|
9714
9716
|
}, [props.watermarkComponent]);
|
|
9715
|
-
|
|
9717
|
+
React.useEffect(() => {
|
|
9716
9718
|
if (!dockviewRef.current) {
|
|
9717
9719
|
return;
|
|
9718
9720
|
}
|
|
@@ -9720,7 +9722,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9720
9722
|
showDndOverlay: props.showDndOverlay,
|
|
9721
9723
|
});
|
|
9722
9724
|
}, [props.showDndOverlay]);
|
|
9723
|
-
|
|
9725
|
+
React.useEffect(() => {
|
|
9724
9726
|
if (!dockviewRef.current) {
|
|
9725
9727
|
return;
|
|
9726
9728
|
}
|
|
@@ -9728,7 +9730,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9728
9730
|
frameworkTabComponents: props.tabComponents,
|
|
9729
9731
|
});
|
|
9730
9732
|
}, [props.tabComponents]);
|
|
9731
|
-
|
|
9733
|
+
React.useEffect(() => {
|
|
9732
9734
|
if (!dockviewRef.current) {
|
|
9733
9735
|
return;
|
|
9734
9736
|
}
|
|
@@ -9736,7 +9738,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9736
9738
|
disableFloatingGroups: props.disableFloatingGroups,
|
|
9737
9739
|
});
|
|
9738
9740
|
}, [props.disableFloatingGroups]);
|
|
9739
|
-
|
|
9741
|
+
React.useEffect(() => {
|
|
9740
9742
|
var _a;
|
|
9741
9743
|
if (!dockviewRef.current) {
|
|
9742
9744
|
return;
|
|
@@ -9753,7 +9755,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9753
9755
|
frameworkTabComponents,
|
|
9754
9756
|
});
|
|
9755
9757
|
}, [props.defaultTabComponent]);
|
|
9756
|
-
|
|
9758
|
+
React.useEffect(() => {
|
|
9757
9759
|
if (!dockviewRef.current) {
|
|
9758
9760
|
return;
|
|
9759
9761
|
}
|
|
@@ -9761,7 +9763,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9761
9763
|
createRightHeaderActionsElement: createGroupControlElement(props.rightHeaderActionsComponent, { addPortal }),
|
|
9762
9764
|
});
|
|
9763
9765
|
}, [props.rightHeaderActionsComponent]);
|
|
9764
|
-
|
|
9766
|
+
React.useEffect(() => {
|
|
9765
9767
|
if (!dockviewRef.current) {
|
|
9766
9768
|
return;
|
|
9767
9769
|
}
|
|
@@ -9769,7 +9771,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9769
9771
|
createLeftHeaderActionsElement: createGroupControlElement(props.leftHeaderActionsComponent, { addPortal }),
|
|
9770
9772
|
});
|
|
9771
9773
|
}, [props.leftHeaderActionsComponent]);
|
|
9772
|
-
|
|
9774
|
+
React.useEffect(() => {
|
|
9773
9775
|
if (!dockviewRef.current) {
|
|
9774
9776
|
return;
|
|
9775
9777
|
}
|
|
@@ -9777,7 +9779,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9777
9779
|
rootOverlayModel: props.rootOverlayModel,
|
|
9778
9780
|
});
|
|
9779
9781
|
}, [props.rootOverlayModel]);
|
|
9780
|
-
|
|
9782
|
+
React.useEffect(() => {
|
|
9781
9783
|
if (!dockviewRef.current) {
|
|
9782
9784
|
return;
|
|
9783
9785
|
}
|
|
@@ -9785,7 +9787,7 @@ const DockviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9785
9787
|
createPrefixHeaderActionsElement: createGroupControlElement(props.prefixHeaderActionsComponent, { addPortal }),
|
|
9786
9788
|
});
|
|
9787
9789
|
}, [props.prefixHeaderActionsComponent]);
|
|
9788
|
-
return (
|
|
9790
|
+
return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
|
|
9789
9791
|
});
|
|
9790
9792
|
DockviewReact.displayName = 'DockviewComponent';
|
|
9791
9793
|
|
|
@@ -9823,12 +9825,12 @@ typeof SuppressedError === "function" ? SuppressedError : function (error, suppr
|
|
|
9823
9825
|
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
|
|
9824
9826
|
};
|
|
9825
9827
|
|
|
9826
|
-
const CloseButton = () => (
|
|
9827
|
-
|
|
9828
|
+
const CloseButton = () => (React.createElement("svg", { height: "11", width: "11", viewBox: "0 0 28 28", "aria-hidden": 'false', focusable: false, className: "dockview-svg" },
|
|
9829
|
+
React.createElement("path", { d: "M2.1 27.3L0 25.2L11.55 13.65L0 2.1L2.1 0L13.65 11.55L25.2 0L27.3 2.1L15.75 13.65L27.3 25.2L25.2 27.3L13.65 15.75L2.1 27.3Z" })));
|
|
9828
9830
|
|
|
9829
9831
|
const DockviewDefaultTab = (_a) => {
|
|
9830
9832
|
var { api, containerApi: _containerApi, params: _params, hideClose, closeActionOverride } = _a, rest = __rest(_a, ["api", "containerApi", "params", "hideClose", "closeActionOverride"]);
|
|
9831
|
-
const onClose =
|
|
9833
|
+
const onClose = React.useCallback((event) => {
|
|
9832
9834
|
event.preventDefault();
|
|
9833
9835
|
if (closeActionOverride) {
|
|
9834
9836
|
closeActionOverride();
|
|
@@ -9837,10 +9839,10 @@ const DockviewDefaultTab = (_a) => {
|
|
|
9837
9839
|
api.close();
|
|
9838
9840
|
}
|
|
9839
9841
|
}, [api, closeActionOverride]);
|
|
9840
|
-
const onMouseDown =
|
|
9842
|
+
const onMouseDown = React.useCallback((e) => {
|
|
9841
9843
|
e.preventDefault();
|
|
9842
9844
|
}, []);
|
|
9843
|
-
const onClick =
|
|
9845
|
+
const onClick = React.useCallback((event) => {
|
|
9844
9846
|
if (event.defaultPrevented) {
|
|
9845
9847
|
return;
|
|
9846
9848
|
}
|
|
@@ -9849,10 +9851,10 @@ const DockviewDefaultTab = (_a) => {
|
|
|
9849
9851
|
rest.onClick(event);
|
|
9850
9852
|
}
|
|
9851
9853
|
}, [api, rest.onClick]);
|
|
9852
|
-
return (
|
|
9853
|
-
|
|
9854
|
-
!hideClose && (
|
|
9855
|
-
|
|
9854
|
+
return (React.createElement("div", Object.assign({ "data-testid": "dockview-dv-default-tab" }, rest, { onClick: onClick, className: "dv-default-tab" }),
|
|
9855
|
+
React.createElement("span", { className: "dv-default-tab-content" }, api.title),
|
|
9856
|
+
!hideClose && (React.createElement("div", { className: "dv-default-tab-action", onMouseDown: onMouseDown, onClick: onClose },
|
|
9857
|
+
React.createElement(CloseButton, null)))));
|
|
9856
9858
|
};
|
|
9857
9859
|
|
|
9858
9860
|
class ReactPanelView extends SplitviewPanel {
|
|
@@ -9871,12 +9873,12 @@ class ReactPanelView extends SplitviewPanel {
|
|
|
9871
9873
|
}
|
|
9872
9874
|
}
|
|
9873
9875
|
|
|
9874
|
-
const SplitviewReact =
|
|
9875
|
-
const domRef =
|
|
9876
|
-
const splitviewRef =
|
|
9876
|
+
const SplitviewReact = React.forwardRef((props, ref) => {
|
|
9877
|
+
const domRef = React.useRef(null);
|
|
9878
|
+
const splitviewRef = React.useRef();
|
|
9877
9879
|
const [portals, addPortal] = usePortalsLifecycle();
|
|
9878
|
-
|
|
9879
|
-
|
|
9880
|
+
React.useImperativeHandle(ref, () => domRef.current, []);
|
|
9881
|
+
React.useEffect(() => {
|
|
9880
9882
|
var _a;
|
|
9881
9883
|
const splitview = new SplitviewComponent({
|
|
9882
9884
|
parentElement: domRef.current,
|
|
@@ -9907,7 +9909,7 @@ const SplitviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9907
9909
|
splitview.dispose();
|
|
9908
9910
|
};
|
|
9909
9911
|
}, []);
|
|
9910
|
-
|
|
9912
|
+
React.useEffect(() => {
|
|
9911
9913
|
if (!splitviewRef.current) {
|
|
9912
9914
|
return;
|
|
9913
9915
|
}
|
|
@@ -9915,7 +9917,7 @@ const SplitviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9915
9917
|
frameworkComponents: props.components,
|
|
9916
9918
|
});
|
|
9917
9919
|
}, [props.components]);
|
|
9918
|
-
return (
|
|
9920
|
+
return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
|
|
9919
9921
|
});
|
|
9920
9922
|
SplitviewReact.displayName = 'SplitviewComponent';
|
|
9921
9923
|
|
|
@@ -9937,12 +9939,12 @@ class ReactGridPanelView extends GridviewPanel {
|
|
|
9937
9939
|
}
|
|
9938
9940
|
}
|
|
9939
9941
|
|
|
9940
|
-
const GridviewReact =
|
|
9941
|
-
const domRef =
|
|
9942
|
-
const gridviewRef =
|
|
9942
|
+
const GridviewReact = React.forwardRef((props, ref) => {
|
|
9943
|
+
const domRef = React.useRef(null);
|
|
9944
|
+
const gridviewRef = React.useRef();
|
|
9943
9945
|
const [portals, addPortal] = usePortalsLifecycle();
|
|
9944
|
-
|
|
9945
|
-
|
|
9946
|
+
React.useImperativeHandle(ref, () => domRef.current, []);
|
|
9947
|
+
React.useEffect(() => {
|
|
9946
9948
|
var _a;
|
|
9947
9949
|
if (!domRef.current) {
|
|
9948
9950
|
return () => {
|
|
@@ -9978,7 +9980,7 @@ const GridviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9978
9980
|
gridview.dispose();
|
|
9979
9981
|
};
|
|
9980
9982
|
}, []);
|
|
9981
|
-
|
|
9983
|
+
React.useEffect(() => {
|
|
9982
9984
|
if (!gridviewRef.current) {
|
|
9983
9985
|
return;
|
|
9984
9986
|
}
|
|
@@ -9986,7 +9988,7 @@ const GridviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
9986
9988
|
frameworkComponents: props.components,
|
|
9987
9989
|
});
|
|
9988
9990
|
}, [props.components]);
|
|
9989
|
-
return (
|
|
9991
|
+
return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
|
|
9990
9992
|
});
|
|
9991
9993
|
GridviewReact.displayName = 'GridviewComponent';
|
|
9992
9994
|
|
|
@@ -10025,12 +10027,12 @@ class PanePanelSection {
|
|
|
10025
10027
|
}
|
|
10026
10028
|
}
|
|
10027
10029
|
|
|
10028
|
-
const PaneviewReact =
|
|
10029
|
-
const domRef =
|
|
10030
|
-
const paneviewRef =
|
|
10030
|
+
const PaneviewReact = React.forwardRef((props, ref) => {
|
|
10031
|
+
const domRef = React.useRef(null);
|
|
10032
|
+
const paneviewRef = React.useRef();
|
|
10031
10033
|
const [portals, addPortal] = usePortalsLifecycle();
|
|
10032
|
-
|
|
10033
|
-
|
|
10034
|
+
React.useImperativeHandle(ref, () => domRef.current, []);
|
|
10035
|
+
React.useEffect(() => {
|
|
10034
10036
|
const createComponent = (id, _componentId, component) => new PanePanelSection(id, component, {
|
|
10035
10037
|
addPortal,
|
|
10036
10038
|
});
|
|
@@ -10063,7 +10065,7 @@ const PaneviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
10063
10065
|
paneview.dispose();
|
|
10064
10066
|
};
|
|
10065
10067
|
}, []);
|
|
10066
|
-
|
|
10068
|
+
React.useEffect(() => {
|
|
10067
10069
|
if (!paneviewRef.current) {
|
|
10068
10070
|
return;
|
|
10069
10071
|
}
|
|
@@ -10071,7 +10073,7 @@ const PaneviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
10071
10073
|
frameworkComponents: props.components,
|
|
10072
10074
|
});
|
|
10073
10075
|
}, [props.components]);
|
|
10074
|
-
|
|
10076
|
+
React.useEffect(() => {
|
|
10075
10077
|
if (!paneviewRef.current) {
|
|
10076
10078
|
return;
|
|
10077
10079
|
}
|
|
@@ -10079,7 +10081,7 @@ const PaneviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
10079
10081
|
headerframeworkComponents: props.headerComponents,
|
|
10080
10082
|
});
|
|
10081
10083
|
}, [props.headerComponents]);
|
|
10082
|
-
|
|
10084
|
+
React.useEffect(() => {
|
|
10083
10085
|
if (!paneviewRef.current) {
|
|
10084
10086
|
return () => {
|
|
10085
10087
|
//
|
|
@@ -10095,7 +10097,7 @@ const PaneviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
10095
10097
|
disposable.dispose();
|
|
10096
10098
|
};
|
|
10097
10099
|
}, [props.onDidDrop]);
|
|
10098
|
-
|
|
10100
|
+
React.useEffect(() => {
|
|
10099
10101
|
if (!paneviewRef.current) {
|
|
10100
10102
|
return;
|
|
10101
10103
|
}
|
|
@@ -10103,7 +10105,7 @@ const PaneviewReact = React__namespace.forwardRef((props, ref) => {
|
|
|
10103
10105
|
showDndOverlay: props.showDndOverlay,
|
|
10104
10106
|
});
|
|
10105
10107
|
}, [props.showDndOverlay]);
|
|
10106
|
-
return (
|
|
10108
|
+
return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
|
|
10107
10109
|
});
|
|
10108
10110
|
PaneviewReact.displayName = 'PaneviewComponent';
|
|
10109
10111
|
|