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.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
|
*/
|
|
@@ -10,26 +10,6 @@
|
|
|
10
10
|
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.dockview = {}, global.React, global.ReactDOM));
|
|
11
11
|
})(this, (function (exports, React, ReactDOM) { 'use strict';
|
|
12
12
|
|
|
13
|
-
function _interopNamespaceDefault(e) {
|
|
14
|
-
var n = Object.create(null);
|
|
15
|
-
if (e) {
|
|
16
|
-
Object.keys(e).forEach(function (k) {
|
|
17
|
-
if (k !== 'default') {
|
|
18
|
-
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
19
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
20
|
-
enumerable: true,
|
|
21
|
-
get: function () { return e[k]; }
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
n.default = e;
|
|
27
|
-
return Object.freeze(n);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
|
|
31
|
-
var ReactDOM__namespace = /*#__PURE__*/_interopNamespaceDefault(ReactDOM);
|
|
32
|
-
|
|
33
13
|
function styleInject(css, ref) {
|
|
34
14
|
if ( ref === void 0 ) ref = {};
|
|
35
15
|
var insertAt = ref.insertAt;
|
|
@@ -57,7 +37,7 @@
|
|
|
57
37
|
}
|
|
58
38
|
}
|
|
59
39
|
|
|
60
|
-
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}";
|
|
40
|
+
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}";
|
|
61
41
|
styleInject(css_248z);
|
|
62
42
|
|
|
63
43
|
class TransferObject {
|
|
@@ -4289,6 +4269,7 @@
|
|
|
4289
4269
|
this._width = 0;
|
|
4290
4270
|
this._height = 0;
|
|
4291
4271
|
this._panels = [];
|
|
4272
|
+
this._panelDisposables = new Map();
|
|
4292
4273
|
this._onMove = new Emitter();
|
|
4293
4274
|
this.onMove = this._onMove.event;
|
|
4294
4275
|
this._onDidDrop = new Emitter();
|
|
@@ -4303,6 +4284,10 @@
|
|
|
4303
4284
|
this.onGroupDragStart = this._onGroupDragStart.event;
|
|
4304
4285
|
this._onDidAddPanel = new Emitter();
|
|
4305
4286
|
this.onDidAddPanel = this._onDidAddPanel.event;
|
|
4287
|
+
this._onDidPanelTitleChange = new Emitter();
|
|
4288
|
+
this.onDidPanelTitleChange = this._onDidPanelTitleChange.event;
|
|
4289
|
+
this._onDidPanelParametersChange = new Emitter();
|
|
4290
|
+
this.onDidPanelParametersChange = this._onDidPanelParametersChange.event;
|
|
4306
4291
|
this._onDidRemovePanel = new Emitter();
|
|
4307
4292
|
this.onDidRemovePanel = this._onDidRemovePanel.event;
|
|
4308
4293
|
this._onDidActivePanelChange = new Emitter();
|
|
@@ -4591,6 +4576,11 @@
|
|
|
4591
4576
|
if (this.mostRecentlyUsed.includes(panel)) {
|
|
4592
4577
|
this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(panel), 1);
|
|
4593
4578
|
}
|
|
4579
|
+
const disposable = this._panelDisposables.get(panel.id);
|
|
4580
|
+
if (disposable) {
|
|
4581
|
+
disposable.dispose();
|
|
4582
|
+
this._panelDisposables.delete(panel.id);
|
|
4583
|
+
}
|
|
4594
4584
|
this._onDidRemovePanel.fire({ panel });
|
|
4595
4585
|
}
|
|
4596
4586
|
doAddPanel(panel, index = this.panels.length, options = { skipSetActive: false }) {
|
|
@@ -4608,6 +4598,7 @@
|
|
|
4608
4598
|
}
|
|
4609
4599
|
this.updateMru(panel);
|
|
4610
4600
|
this.panels.splice(index, 0, panel);
|
|
4601
|
+
this._panelDisposables.set(panel.id, new CompositeDisposable(panel.api.onDidTitleChange((event) => this._onDidPanelTitleChange.fire(event)), panel.api.onDidParametersChange((event) => this._onDidPanelParametersChange.fire(event))));
|
|
4611
4602
|
this._onDidAddPanel.fire({ panel });
|
|
4612
4603
|
}
|
|
4613
4604
|
doSetActivePanel(panel) {
|
|
@@ -5031,14 +5022,16 @@
|
|
|
5031
5022
|
get height() {
|
|
5032
5023
|
return this._height;
|
|
5033
5024
|
}
|
|
5034
|
-
constructor(id) {
|
|
5025
|
+
constructor(id, component) {
|
|
5035
5026
|
super();
|
|
5036
5027
|
this.id = id;
|
|
5028
|
+
this.component = component;
|
|
5037
5029
|
this._isFocused = false;
|
|
5038
5030
|
this._isActive = false;
|
|
5039
5031
|
this._isVisible = true;
|
|
5040
5032
|
this._width = 0;
|
|
5041
5033
|
this._height = 0;
|
|
5034
|
+
this._parameters = {};
|
|
5042
5035
|
this.panelUpdatesDisposable = new MutableDisposable();
|
|
5043
5036
|
this._onDidDimensionChange = new Emitter();
|
|
5044
5037
|
this.onDidDimensionsChange = this._onDidDimensionChange.event;
|
|
@@ -5056,8 +5049,8 @@
|
|
|
5056
5049
|
this.onDidActiveChange = this._onDidActiveChange.event;
|
|
5057
5050
|
this._onActiveChange = new Emitter();
|
|
5058
5051
|
this.onActiveChange = this._onActiveChange.event;
|
|
5059
|
-
this.
|
|
5060
|
-
this.
|
|
5052
|
+
this._onDidParametersChange = new Emitter();
|
|
5053
|
+
this.onDidParametersChange = this._onDidParametersChange.event;
|
|
5061
5054
|
this.addDisposables(this.onDidFocusChange((event) => {
|
|
5062
5055
|
this._isFocused = event.isFocused;
|
|
5063
5056
|
}), this.onDidActiveChange((event) => {
|
|
@@ -5067,10 +5060,14 @@
|
|
|
5067
5060
|
}), this.onDidDimensionsChange((event) => {
|
|
5068
5061
|
this._width = event.width;
|
|
5069
5062
|
this._height = event.height;
|
|
5070
|
-
}), this.panelUpdatesDisposable, this._onDidDimensionChange, this._onDidChangeFocus, this._onDidVisibilityChange, this._onDidActiveChange, this._onWillFocus, this._onActiveChange, this.
|
|
5063
|
+
}), this.panelUpdatesDisposable, this._onDidDimensionChange, this._onDidChangeFocus, this._onDidVisibilityChange, this._onDidActiveChange, this._onWillFocus, this._onActiveChange, this._onWillFocus, this._onWillVisibilityChange, this._onDidParametersChange);
|
|
5064
|
+
}
|
|
5065
|
+
getParameters() {
|
|
5066
|
+
return this._parameters;
|
|
5071
5067
|
}
|
|
5072
5068
|
initialize(panel) {
|
|
5073
|
-
this.panelUpdatesDisposable.value = this.
|
|
5069
|
+
this.panelUpdatesDisposable.value = this._onDidParametersChange.event((parameters) => {
|
|
5070
|
+
this._parameters = parameters;
|
|
5074
5071
|
panel.update({
|
|
5075
5072
|
params: parameters,
|
|
5076
5073
|
});
|
|
@@ -5083,14 +5080,14 @@
|
|
|
5083
5080
|
this._onActiveChange.fire();
|
|
5084
5081
|
}
|
|
5085
5082
|
updateParameters(parameters) {
|
|
5086
|
-
this.
|
|
5083
|
+
this._onDidParametersChange.fire(parameters);
|
|
5087
5084
|
}
|
|
5088
5085
|
}
|
|
5089
5086
|
|
|
5090
5087
|
class SplitviewPanelApiImpl extends PanelApiImpl {
|
|
5091
5088
|
//
|
|
5092
|
-
constructor(id) {
|
|
5093
|
-
super(id);
|
|
5089
|
+
constructor(id, component) {
|
|
5090
|
+
super(id, component);
|
|
5094
5091
|
this._onDidConstraintsChangeInternal = new Emitter();
|
|
5095
5092
|
this.onDidConstraintsChangeInternal = this._onDidConstraintsChangeInternal.event;
|
|
5096
5093
|
//
|
|
@@ -5115,8 +5112,8 @@
|
|
|
5115
5112
|
set pane(pane) {
|
|
5116
5113
|
this._pane = pane;
|
|
5117
5114
|
}
|
|
5118
|
-
constructor(id) {
|
|
5119
|
-
super(id);
|
|
5115
|
+
constructor(id, component) {
|
|
5116
|
+
super(id, component);
|
|
5120
5117
|
this._onDidExpansionChange = new Emitter({
|
|
5121
5118
|
replay: true,
|
|
5122
5119
|
});
|
|
@@ -5275,7 +5272,7 @@
|
|
|
5275
5272
|
this.header.style.display = value ? '' : 'none';
|
|
5276
5273
|
}
|
|
5277
5274
|
constructor(id, component, headerComponent, orientation, isExpanded, isHeaderVisible) {
|
|
5278
|
-
super(id, component, new PaneviewPanelApiImpl(id));
|
|
5275
|
+
super(id, component, new PaneviewPanelApiImpl(id, component));
|
|
5279
5276
|
this.headerComponent = headerComponent;
|
|
5280
5277
|
this._onDidChangeExpansionState = new Emitter({ replay: true });
|
|
5281
5278
|
this.onDidChangeExpansionState = this._onDidChangeExpansionState.event;
|
|
@@ -5506,8 +5503,8 @@
|
|
|
5506
5503
|
}
|
|
5507
5504
|
|
|
5508
5505
|
class GridviewPanelApiImpl extends PanelApiImpl {
|
|
5509
|
-
constructor(id, panel) {
|
|
5510
|
-
super(id);
|
|
5506
|
+
constructor(id, component, panel) {
|
|
5507
|
+
super(id, component);
|
|
5511
5508
|
this._onDidConstraintsChangeInternal = new Emitter();
|
|
5512
5509
|
this.onDidConstraintsChangeInternal = this._onDidConstraintsChangeInternal.event;
|
|
5513
5510
|
this._onDidConstraintsChange = new Emitter();
|
|
@@ -5578,7 +5575,7 @@
|
|
|
5578
5575
|
return this.api.isActive;
|
|
5579
5576
|
}
|
|
5580
5577
|
constructor(id, component, options, api) {
|
|
5581
|
-
super(id, component, api !== null && api !== void 0 ? api : new GridviewPanelApiImpl(id));
|
|
5578
|
+
super(id, component, api !== null && api !== void 0 ? api : new GridviewPanelApiImpl(id, component));
|
|
5582
5579
|
this._evaluatedMinimumWidth = 0;
|
|
5583
5580
|
this._evaluatedMaximumWidth = Number.MAX_SAFE_INTEGER;
|
|
5584
5581
|
this._evaluatedMinimumHeight = 0;
|
|
@@ -5686,7 +5683,7 @@
|
|
|
5686
5683
|
return this._group.model.location;
|
|
5687
5684
|
}
|
|
5688
5685
|
constructor(id, accessor) {
|
|
5689
|
-
super(id);
|
|
5686
|
+
super(id, '__dockviewgroup__');
|
|
5690
5687
|
this.accessor = accessor;
|
|
5691
5688
|
this._onDidLocationChange = new Emitter();
|
|
5692
5689
|
this.onDidLocationChange = this._onDidLocationChange.event;
|
|
@@ -5860,8 +5857,11 @@
|
|
|
5860
5857
|
get group() {
|
|
5861
5858
|
return this._group;
|
|
5862
5859
|
}
|
|
5863
|
-
|
|
5864
|
-
|
|
5860
|
+
get tabComponent() {
|
|
5861
|
+
return this._tabComponent;
|
|
5862
|
+
}
|
|
5863
|
+
constructor(panel, group, accessor, component, tabComponent) {
|
|
5864
|
+
super(panel.id, component);
|
|
5865
5865
|
this.panel = panel;
|
|
5866
5866
|
this.accessor = accessor;
|
|
5867
5867
|
this._onDidTitleChange = new Emitter();
|
|
@@ -5875,6 +5875,7 @@
|
|
|
5875
5875
|
this._onDidLocationChange = new Emitter();
|
|
5876
5876
|
this.onDidLocationChange = this._onDidLocationChange.event;
|
|
5877
5877
|
this.groupEventsDisposable = new MutableDisposable();
|
|
5878
|
+
this._tabComponent = tabComponent;
|
|
5878
5879
|
this.initialize(panel);
|
|
5879
5880
|
this._group = group;
|
|
5880
5881
|
this.setupGroupEventListeners();
|
|
@@ -5957,7 +5958,7 @@
|
|
|
5957
5958
|
var _a;
|
|
5958
5959
|
return (_a = this._renderer) !== null && _a !== void 0 ? _a : this.accessor.renderer;
|
|
5959
5960
|
}
|
|
5960
|
-
constructor(id, accessor, containerApi, group, view, options) {
|
|
5961
|
+
constructor(id, component, tabComponent, accessor, containerApi, group, view, options) {
|
|
5961
5962
|
super();
|
|
5962
5963
|
this.id = id;
|
|
5963
5964
|
this.accessor = accessor;
|
|
@@ -5965,7 +5966,7 @@
|
|
|
5965
5966
|
this.view = view;
|
|
5966
5967
|
this._renderer = options.renderer;
|
|
5967
5968
|
this._group = group;
|
|
5968
|
-
this.api = new DockviewPanelApiImpl(this, this._group, accessor);
|
|
5969
|
+
this.api = new DockviewPanelApiImpl(this, this._group, accessor, component, tabComponent);
|
|
5969
5970
|
this.addDisposables(this.api.onActiveChange(() => {
|
|
5970
5971
|
accessor.setActivePanel(this);
|
|
5971
5972
|
}), this.api.onDidSizeChange((event) => {
|
|
@@ -6133,27 +6134,18 @@
|
|
|
6133
6134
|
//
|
|
6134
6135
|
this.params = {};
|
|
6135
6136
|
this._element = document.createElement('div');
|
|
6136
|
-
this._element.className = 'default-tab';
|
|
6137
|
+
this._element.className = 'dv-default-tab';
|
|
6137
6138
|
//
|
|
6138
6139
|
this._content = document.createElement('div');
|
|
6139
|
-
this._content.className = 'tab-content';
|
|
6140
|
-
//
|
|
6141
|
-
this._actionContainer = document.createElement('div');
|
|
6142
|
-
this._actionContainer.className = 'action-container';
|
|
6143
|
-
//
|
|
6144
|
-
this._list = document.createElement('ul');
|
|
6145
|
-
this._list.className = 'tab-list';
|
|
6146
|
-
//
|
|
6140
|
+
this._content.className = 'dv-default-tab-content';
|
|
6147
6141
|
this.action = document.createElement('div');
|
|
6148
|
-
this.action.className = 'tab-action';
|
|
6142
|
+
this.action.className = 'dv-default-tab-action';
|
|
6149
6143
|
this.action.appendChild(createCloseButton());
|
|
6150
6144
|
//
|
|
6151
6145
|
this._element.appendChild(this._content);
|
|
6152
|
-
this._element.appendChild(this.
|
|
6153
|
-
this._actionContainer.appendChild(this._list);
|
|
6154
|
-
this._list.appendChild(this.action);
|
|
6146
|
+
this._element.appendChild(this.action);
|
|
6155
6147
|
//
|
|
6156
|
-
this.addDisposables(addDisposableListener(this.
|
|
6148
|
+
this.addDisposables(addDisposableListener(this.action, 'mousedown', (ev) => {
|
|
6157
6149
|
ev.preventDefault();
|
|
6158
6150
|
}));
|
|
6159
6151
|
this.render();
|
|
@@ -6260,7 +6252,7 @@
|
|
|
6260
6252
|
? (_b = viewData.tab) === null || _b === void 0 ? void 0 : _b.id
|
|
6261
6253
|
: panelData.tabComponent;
|
|
6262
6254
|
const view = new DockviewPanelModel(this.accessor, panelId, contentComponent, tabComponent);
|
|
6263
|
-
const panel = new DockviewPanel(panelId, this.accessor, new DockviewApi(this.accessor), group, view, {
|
|
6255
|
+
const panel = new DockviewPanel(panelId, contentComponent, tabComponent, this.accessor, new DockviewApi(this.accessor), group, view, {
|
|
6264
6256
|
renderer: panelData.renderer,
|
|
6265
6257
|
});
|
|
6266
6258
|
panel.init({
|
|
@@ -8247,6 +8239,8 @@
|
|
|
8247
8239
|
if (this._onDidActivePanelChange.value !== event.panel) {
|
|
8248
8240
|
this._onDidActivePanelChange.fire(event.panel);
|
|
8249
8241
|
}
|
|
8242
|
+
}), exports.DockviewEvent.any(view.model.onDidPanelTitleChange, view.model.onDidPanelParametersChange)(() => {
|
|
8243
|
+
this._bufferOnDidLayoutChange.fire();
|
|
8250
8244
|
}));
|
|
8251
8245
|
this._groups.set(view.id, { value: view, disposable });
|
|
8252
8246
|
}
|
|
@@ -8259,7 +8253,7 @@
|
|
|
8259
8253
|
const contentComponent = options.component;
|
|
8260
8254
|
const tabComponent = (_a = options.tabComponent) !== null && _a !== void 0 ? _a : this.options.defaultTabComponent;
|
|
8261
8255
|
const view = new DockviewPanelModel(this, options.id, contentComponent, tabComponent);
|
|
8262
|
-
const panel = new DockviewPanel(options.id, this, this._api, group, view, { renderer: options.renderer });
|
|
8256
|
+
const panel = new DockviewPanel(options.id, contentComponent, tabComponent, this, this._api, group, view, { renderer: options.renderer });
|
|
8263
8257
|
panel.init({
|
|
8264
8258
|
title: (_b = options.title) !== null && _b !== void 0 ? _b : options.id,
|
|
8265
8259
|
params: (_c = options === null || options === void 0 ? void 0 : options.params) !== null && _c !== void 0 ? _c : {},
|
|
@@ -9174,7 +9168,7 @@
|
|
|
9174
9168
|
return this._snap;
|
|
9175
9169
|
}
|
|
9176
9170
|
constructor(id, componentName) {
|
|
9177
|
-
super(id, componentName, new SplitviewPanelApiImpl(id));
|
|
9171
|
+
super(id, componentName, new SplitviewPanelApiImpl(id, componentName));
|
|
9178
9172
|
this._evaluatedMinimumSize = 0;
|
|
9179
9173
|
this._evaluatedMaximumSize = Number.POSITIVE_INFINITY;
|
|
9180
9174
|
this._minimumSize = 0;
|
|
@@ -9254,9 +9248,9 @@
|
|
|
9254
9248
|
* component
|
|
9255
9249
|
*/
|
|
9256
9250
|
const ReactComponentBridge = (props, ref) => {
|
|
9257
|
-
const [_, triggerRender] =
|
|
9258
|
-
const _props =
|
|
9259
|
-
|
|
9251
|
+
const [_, triggerRender] = React.useState();
|
|
9252
|
+
const _props = React.useRef(props.componentProps);
|
|
9253
|
+
React.useImperativeHandle(ref, () => ({
|
|
9260
9254
|
update: (componentProps) => {
|
|
9261
9255
|
_props.current = Object.assign(Object.assign({}, _props.current), componentProps);
|
|
9262
9256
|
/**
|
|
@@ -9268,7 +9262,7 @@
|
|
|
9268
9262
|
triggerRender(Date.now());
|
|
9269
9263
|
},
|
|
9270
9264
|
}), []);
|
|
9271
|
-
return
|
|
9265
|
+
return React.createElement(props.component, _props.current);
|
|
9272
9266
|
};
|
|
9273
9267
|
ReactComponentBridge.displayName = 'DockviewReactJsBridge';
|
|
9274
9268
|
/**
|
|
@@ -9280,7 +9274,7 @@
|
|
|
9280
9274
|
let value = 1;
|
|
9281
9275
|
return { next: () => `dockview_react_portal_key_${(value++).toString()}` };
|
|
9282
9276
|
})();
|
|
9283
|
-
const ReactPartContext =
|
|
9277
|
+
const ReactPartContext = React.createContext({});
|
|
9284
9278
|
class ReactPart {
|
|
9285
9279
|
constructor(parent, portalStore, component, parameters, context) {
|
|
9286
9280
|
this.parent = parent;
|
|
@@ -9316,7 +9310,7 @@
|
|
|
9316
9310
|
*/
|
|
9317
9311
|
throw new Error('Dockview: Only React.memo(...), React.ForwardRef(...) and functional components are accepted as components');
|
|
9318
9312
|
}
|
|
9319
|
-
const bridgeComponent =
|
|
9313
|
+
const bridgeComponent = React.createElement(React.forwardRef(ReactComponentBridge), {
|
|
9320
9314
|
component: this
|
|
9321
9315
|
.component,
|
|
9322
9316
|
componentProps: this.parameters,
|
|
@@ -9329,9 +9323,9 @@
|
|
|
9329
9323
|
},
|
|
9330
9324
|
});
|
|
9331
9325
|
const node = this.context
|
|
9332
|
-
?
|
|
9326
|
+
? React.createElement(ReactPartContext.Provider, { value: this.context }, bridgeComponent)
|
|
9333
9327
|
: bridgeComponent;
|
|
9334
|
-
const portal =
|
|
9328
|
+
const portal = ReactDOM.createPortal(node, this.parent, uniquePortalKeyGenerator.next());
|
|
9335
9329
|
this.ref = {
|
|
9336
9330
|
portal,
|
|
9337
9331
|
disposable: this.portalStore.addPortal(portal),
|
|
@@ -9349,9 +9343,9 @@
|
|
|
9349
9343
|
* portal array
|
|
9350
9344
|
*/
|
|
9351
9345
|
const usePortalsLifecycle = () => {
|
|
9352
|
-
const [portals, setPortals] =
|
|
9353
|
-
|
|
9354
|
-
const addPortal =
|
|
9346
|
+
const [portals, setPortals] = React.useState([]);
|
|
9347
|
+
React.useDebugValue(`Portal count: ${portals.length}`);
|
|
9348
|
+
const addPortal = React.useCallback((portal) => {
|
|
9355
9349
|
setPortals((existingPortals) => [...existingPortals, portal]);
|
|
9356
9350
|
let disposed = false;
|
|
9357
9351
|
return {
|
|
@@ -9389,6 +9383,8 @@
|
|
|
9389
9383
|
this.onDidBlur = this._onDidBlur.event;
|
|
9390
9384
|
this._element = document.createElement('div');
|
|
9391
9385
|
this._element.className = 'dockview-react-part';
|
|
9386
|
+
this._element.style.height = '100%';
|
|
9387
|
+
this._element.style.width = '100%';
|
|
9392
9388
|
}
|
|
9393
9389
|
focus() {
|
|
9394
9390
|
// TODO
|
|
@@ -9425,6 +9421,8 @@
|
|
|
9425
9421
|
this.reactPortalStore = reactPortalStore;
|
|
9426
9422
|
this._element = document.createElement('div');
|
|
9427
9423
|
this._element.className = 'dockview-react-part';
|
|
9424
|
+
this._element.style.height = '100%';
|
|
9425
|
+
this._element.style.width = '100%';
|
|
9428
9426
|
}
|
|
9429
9427
|
focus() {
|
|
9430
9428
|
//noop
|
|
@@ -9459,6 +9457,8 @@
|
|
|
9459
9457
|
this.reactPortalStore = reactPortalStore;
|
|
9460
9458
|
this._element = document.createElement('div');
|
|
9461
9459
|
this._element.className = 'dockview-react-part';
|
|
9460
|
+
this._element.style.height = '100%';
|
|
9461
|
+
this._element.style.width = '100%';
|
|
9462
9462
|
}
|
|
9463
9463
|
init(parameters) {
|
|
9464
9464
|
this.part = new ReactPart(this.element, this.reactPortalStore, this.component, {
|
|
@@ -9510,6 +9510,8 @@
|
|
|
9510
9510
|
this.mutableDisposable = new MutableDisposable();
|
|
9511
9511
|
this._element = document.createElement('div');
|
|
9512
9512
|
this._element.className = 'dockview-react-part';
|
|
9513
|
+
this._element.style.height = '100%';
|
|
9514
|
+
this._element.style.width = '100%';
|
|
9513
9515
|
}
|
|
9514
9516
|
focus() {
|
|
9515
9517
|
// TODO
|
|
@@ -9569,12 +9571,12 @@
|
|
|
9569
9571
|
: undefined;
|
|
9570
9572
|
}
|
|
9571
9573
|
const DEFAULT_REACT_TAB = 'props.defaultTabComponent';
|
|
9572
|
-
const DockviewReact =
|
|
9573
|
-
const domRef =
|
|
9574
|
-
const dockviewRef =
|
|
9574
|
+
const DockviewReact = React.forwardRef((props, ref) => {
|
|
9575
|
+
const domRef = React.useRef(null);
|
|
9576
|
+
const dockviewRef = React.useRef();
|
|
9575
9577
|
const [portals, addPortal] = usePortalsLifecycle();
|
|
9576
|
-
|
|
9577
|
-
|
|
9578
|
+
React.useImperativeHandle(ref, () => domRef.current, []);
|
|
9579
|
+
React.useEffect(() => {
|
|
9578
9580
|
var _a;
|
|
9579
9581
|
if (!domRef.current) {
|
|
9580
9582
|
return () => {
|
|
@@ -9645,13 +9647,13 @@
|
|
|
9645
9647
|
dockview.dispose();
|
|
9646
9648
|
};
|
|
9647
9649
|
}, []);
|
|
9648
|
-
|
|
9650
|
+
React.useEffect(() => {
|
|
9649
9651
|
if (!dockviewRef.current) {
|
|
9650
9652
|
return;
|
|
9651
9653
|
}
|
|
9652
9654
|
dockviewRef.current.locked = !!props.locked;
|
|
9653
9655
|
}, [props.locked]);
|
|
9654
|
-
|
|
9656
|
+
React.useEffect(() => {
|
|
9655
9657
|
if (!dockviewRef.current) {
|
|
9656
9658
|
return;
|
|
9657
9659
|
}
|
|
@@ -9659,7 +9661,7 @@
|
|
|
9659
9661
|
disableDnd: props.disableDnd,
|
|
9660
9662
|
});
|
|
9661
9663
|
}, [props.disableDnd]);
|
|
9662
|
-
|
|
9664
|
+
React.useEffect(() => {
|
|
9663
9665
|
if (!dockviewRef.current) {
|
|
9664
9666
|
return () => {
|
|
9665
9667
|
// noop
|
|
@@ -9674,7 +9676,7 @@
|
|
|
9674
9676
|
disposable.dispose();
|
|
9675
9677
|
};
|
|
9676
9678
|
}, [props.onDidDrop]);
|
|
9677
|
-
|
|
9679
|
+
React.useEffect(() => {
|
|
9678
9680
|
if (!dockviewRef.current) {
|
|
9679
9681
|
return () => {
|
|
9680
9682
|
// noop
|
|
@@ -9689,7 +9691,7 @@
|
|
|
9689
9691
|
disposable.dispose();
|
|
9690
9692
|
};
|
|
9691
9693
|
}, [props.onWillDrop]);
|
|
9692
|
-
|
|
9694
|
+
React.useEffect(() => {
|
|
9693
9695
|
if (!dockviewRef.current) {
|
|
9694
9696
|
return;
|
|
9695
9697
|
}
|
|
@@ -9697,7 +9699,7 @@
|
|
|
9697
9699
|
frameworkComponents: props.components,
|
|
9698
9700
|
});
|
|
9699
9701
|
}, [props.components]);
|
|
9700
|
-
|
|
9702
|
+
React.useEffect(() => {
|
|
9701
9703
|
if (!dockviewRef.current) {
|
|
9702
9704
|
return;
|
|
9703
9705
|
}
|
|
@@ -9705,7 +9707,7 @@
|
|
|
9705
9707
|
floatingGroupBounds: props.floatingGroupBounds,
|
|
9706
9708
|
});
|
|
9707
9709
|
}, [props.floatingGroupBounds]);
|
|
9708
|
-
|
|
9710
|
+
React.useEffect(() => {
|
|
9709
9711
|
if (!dockviewRef.current) {
|
|
9710
9712
|
return;
|
|
9711
9713
|
}
|
|
@@ -9713,7 +9715,7 @@
|
|
|
9713
9715
|
watermarkFrameworkComponent: props.watermarkComponent,
|
|
9714
9716
|
});
|
|
9715
9717
|
}, [props.watermarkComponent]);
|
|
9716
|
-
|
|
9718
|
+
React.useEffect(() => {
|
|
9717
9719
|
if (!dockviewRef.current) {
|
|
9718
9720
|
return;
|
|
9719
9721
|
}
|
|
@@ -9721,7 +9723,7 @@
|
|
|
9721
9723
|
showDndOverlay: props.showDndOverlay,
|
|
9722
9724
|
});
|
|
9723
9725
|
}, [props.showDndOverlay]);
|
|
9724
|
-
|
|
9726
|
+
React.useEffect(() => {
|
|
9725
9727
|
if (!dockviewRef.current) {
|
|
9726
9728
|
return;
|
|
9727
9729
|
}
|
|
@@ -9729,7 +9731,7 @@
|
|
|
9729
9731
|
frameworkTabComponents: props.tabComponents,
|
|
9730
9732
|
});
|
|
9731
9733
|
}, [props.tabComponents]);
|
|
9732
|
-
|
|
9734
|
+
React.useEffect(() => {
|
|
9733
9735
|
if (!dockviewRef.current) {
|
|
9734
9736
|
return;
|
|
9735
9737
|
}
|
|
@@ -9737,7 +9739,7 @@
|
|
|
9737
9739
|
disableFloatingGroups: props.disableFloatingGroups,
|
|
9738
9740
|
});
|
|
9739
9741
|
}, [props.disableFloatingGroups]);
|
|
9740
|
-
|
|
9742
|
+
React.useEffect(() => {
|
|
9741
9743
|
var _a;
|
|
9742
9744
|
if (!dockviewRef.current) {
|
|
9743
9745
|
return;
|
|
@@ -9754,7 +9756,7 @@
|
|
|
9754
9756
|
frameworkTabComponents,
|
|
9755
9757
|
});
|
|
9756
9758
|
}, [props.defaultTabComponent]);
|
|
9757
|
-
|
|
9759
|
+
React.useEffect(() => {
|
|
9758
9760
|
if (!dockviewRef.current) {
|
|
9759
9761
|
return;
|
|
9760
9762
|
}
|
|
@@ -9762,7 +9764,7 @@
|
|
|
9762
9764
|
createRightHeaderActionsElement: createGroupControlElement(props.rightHeaderActionsComponent, { addPortal }),
|
|
9763
9765
|
});
|
|
9764
9766
|
}, [props.rightHeaderActionsComponent]);
|
|
9765
|
-
|
|
9767
|
+
React.useEffect(() => {
|
|
9766
9768
|
if (!dockviewRef.current) {
|
|
9767
9769
|
return;
|
|
9768
9770
|
}
|
|
@@ -9770,7 +9772,7 @@
|
|
|
9770
9772
|
createLeftHeaderActionsElement: createGroupControlElement(props.leftHeaderActionsComponent, { addPortal }),
|
|
9771
9773
|
});
|
|
9772
9774
|
}, [props.leftHeaderActionsComponent]);
|
|
9773
|
-
|
|
9775
|
+
React.useEffect(() => {
|
|
9774
9776
|
if (!dockviewRef.current) {
|
|
9775
9777
|
return;
|
|
9776
9778
|
}
|
|
@@ -9778,7 +9780,7 @@
|
|
|
9778
9780
|
rootOverlayModel: props.rootOverlayModel,
|
|
9779
9781
|
});
|
|
9780
9782
|
}, [props.rootOverlayModel]);
|
|
9781
|
-
|
|
9783
|
+
React.useEffect(() => {
|
|
9782
9784
|
if (!dockviewRef.current) {
|
|
9783
9785
|
return;
|
|
9784
9786
|
}
|
|
@@ -9786,7 +9788,7 @@
|
|
|
9786
9788
|
createPrefixHeaderActionsElement: createGroupControlElement(props.prefixHeaderActionsComponent, { addPortal }),
|
|
9787
9789
|
});
|
|
9788
9790
|
}, [props.prefixHeaderActionsComponent]);
|
|
9789
|
-
return (
|
|
9791
|
+
return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
|
|
9790
9792
|
});
|
|
9791
9793
|
DockviewReact.displayName = 'DockviewComponent';
|
|
9792
9794
|
|
|
@@ -9824,12 +9826,12 @@
|
|
|
9824
9826
|
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
|
|
9825
9827
|
};
|
|
9826
9828
|
|
|
9827
|
-
const CloseButton = () => (
|
|
9828
|
-
|
|
9829
|
+
const CloseButton = () => (React.createElement("svg", { height: "11", width: "11", viewBox: "0 0 28 28", "aria-hidden": 'false', focusable: false, className: "dockview-svg" },
|
|
9830
|
+
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" })));
|
|
9829
9831
|
|
|
9830
9832
|
const DockviewDefaultTab = (_a) => {
|
|
9831
9833
|
var { api, containerApi: _containerApi, params: _params, hideClose, closeActionOverride } = _a, rest = __rest(_a, ["api", "containerApi", "params", "hideClose", "closeActionOverride"]);
|
|
9832
|
-
const onClose =
|
|
9834
|
+
const onClose = React.useCallback((event) => {
|
|
9833
9835
|
event.preventDefault();
|
|
9834
9836
|
if (closeActionOverride) {
|
|
9835
9837
|
closeActionOverride();
|
|
@@ -9838,10 +9840,10 @@
|
|
|
9838
9840
|
api.close();
|
|
9839
9841
|
}
|
|
9840
9842
|
}, [api, closeActionOverride]);
|
|
9841
|
-
const onMouseDown =
|
|
9843
|
+
const onMouseDown = React.useCallback((e) => {
|
|
9842
9844
|
e.preventDefault();
|
|
9843
9845
|
}, []);
|
|
9844
|
-
const onClick =
|
|
9846
|
+
const onClick = React.useCallback((event) => {
|
|
9845
9847
|
if (event.defaultPrevented) {
|
|
9846
9848
|
return;
|
|
9847
9849
|
}
|
|
@@ -9850,10 +9852,10 @@
|
|
|
9850
9852
|
rest.onClick(event);
|
|
9851
9853
|
}
|
|
9852
9854
|
}, [api, rest.onClick]);
|
|
9853
|
-
return (
|
|
9854
|
-
|
|
9855
|
-
!hideClose && (
|
|
9856
|
-
|
|
9855
|
+
return (React.createElement("div", Object.assign({ "data-testid": "dockview-dv-default-tab" }, rest, { onClick: onClick, className: "dv-default-tab" }),
|
|
9856
|
+
React.createElement("span", { className: "dv-default-tab-content" }, api.title),
|
|
9857
|
+
!hideClose && (React.createElement("div", { className: "dv-default-tab-action", onMouseDown: onMouseDown, onClick: onClose },
|
|
9858
|
+
React.createElement(CloseButton, null)))));
|
|
9857
9859
|
};
|
|
9858
9860
|
|
|
9859
9861
|
class ReactPanelView extends SplitviewPanel {
|
|
@@ -9872,12 +9874,12 @@
|
|
|
9872
9874
|
}
|
|
9873
9875
|
}
|
|
9874
9876
|
|
|
9875
|
-
const SplitviewReact =
|
|
9876
|
-
const domRef =
|
|
9877
|
-
const splitviewRef =
|
|
9877
|
+
const SplitviewReact = React.forwardRef((props, ref) => {
|
|
9878
|
+
const domRef = React.useRef(null);
|
|
9879
|
+
const splitviewRef = React.useRef();
|
|
9878
9880
|
const [portals, addPortal] = usePortalsLifecycle();
|
|
9879
|
-
|
|
9880
|
-
|
|
9881
|
+
React.useImperativeHandle(ref, () => domRef.current, []);
|
|
9882
|
+
React.useEffect(() => {
|
|
9881
9883
|
var _a;
|
|
9882
9884
|
const splitview = new SplitviewComponent({
|
|
9883
9885
|
parentElement: domRef.current,
|
|
@@ -9908,7 +9910,7 @@
|
|
|
9908
9910
|
splitview.dispose();
|
|
9909
9911
|
};
|
|
9910
9912
|
}, []);
|
|
9911
|
-
|
|
9913
|
+
React.useEffect(() => {
|
|
9912
9914
|
if (!splitviewRef.current) {
|
|
9913
9915
|
return;
|
|
9914
9916
|
}
|
|
@@ -9916,7 +9918,7 @@
|
|
|
9916
9918
|
frameworkComponents: props.components,
|
|
9917
9919
|
});
|
|
9918
9920
|
}, [props.components]);
|
|
9919
|
-
return (
|
|
9921
|
+
return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
|
|
9920
9922
|
});
|
|
9921
9923
|
SplitviewReact.displayName = 'SplitviewComponent';
|
|
9922
9924
|
|
|
@@ -9938,12 +9940,12 @@
|
|
|
9938
9940
|
}
|
|
9939
9941
|
}
|
|
9940
9942
|
|
|
9941
|
-
const GridviewReact =
|
|
9942
|
-
const domRef =
|
|
9943
|
-
const gridviewRef =
|
|
9943
|
+
const GridviewReact = React.forwardRef((props, ref) => {
|
|
9944
|
+
const domRef = React.useRef(null);
|
|
9945
|
+
const gridviewRef = React.useRef();
|
|
9944
9946
|
const [portals, addPortal] = usePortalsLifecycle();
|
|
9945
|
-
|
|
9946
|
-
|
|
9947
|
+
React.useImperativeHandle(ref, () => domRef.current, []);
|
|
9948
|
+
React.useEffect(() => {
|
|
9947
9949
|
var _a;
|
|
9948
9950
|
if (!domRef.current) {
|
|
9949
9951
|
return () => {
|
|
@@ -9979,7 +9981,7 @@
|
|
|
9979
9981
|
gridview.dispose();
|
|
9980
9982
|
};
|
|
9981
9983
|
}, []);
|
|
9982
|
-
|
|
9984
|
+
React.useEffect(() => {
|
|
9983
9985
|
if (!gridviewRef.current) {
|
|
9984
9986
|
return;
|
|
9985
9987
|
}
|
|
@@ -9987,7 +9989,7 @@
|
|
|
9987
9989
|
frameworkComponents: props.components,
|
|
9988
9990
|
});
|
|
9989
9991
|
}, [props.components]);
|
|
9990
|
-
return (
|
|
9992
|
+
return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
|
|
9991
9993
|
});
|
|
9992
9994
|
GridviewReact.displayName = 'GridviewComponent';
|
|
9993
9995
|
|
|
@@ -10026,12 +10028,12 @@
|
|
|
10026
10028
|
}
|
|
10027
10029
|
}
|
|
10028
10030
|
|
|
10029
|
-
const PaneviewReact =
|
|
10030
|
-
const domRef =
|
|
10031
|
-
const paneviewRef =
|
|
10031
|
+
const PaneviewReact = React.forwardRef((props, ref) => {
|
|
10032
|
+
const domRef = React.useRef(null);
|
|
10033
|
+
const paneviewRef = React.useRef();
|
|
10032
10034
|
const [portals, addPortal] = usePortalsLifecycle();
|
|
10033
|
-
|
|
10034
|
-
|
|
10035
|
+
React.useImperativeHandle(ref, () => domRef.current, []);
|
|
10036
|
+
React.useEffect(() => {
|
|
10035
10037
|
const createComponent = (id, _componentId, component) => new PanePanelSection(id, component, {
|
|
10036
10038
|
addPortal,
|
|
10037
10039
|
});
|
|
@@ -10064,7 +10066,7 @@
|
|
|
10064
10066
|
paneview.dispose();
|
|
10065
10067
|
};
|
|
10066
10068
|
}, []);
|
|
10067
|
-
|
|
10069
|
+
React.useEffect(() => {
|
|
10068
10070
|
if (!paneviewRef.current) {
|
|
10069
10071
|
return;
|
|
10070
10072
|
}
|
|
@@ -10072,7 +10074,7 @@
|
|
|
10072
10074
|
frameworkComponents: props.components,
|
|
10073
10075
|
});
|
|
10074
10076
|
}, [props.components]);
|
|
10075
|
-
|
|
10077
|
+
React.useEffect(() => {
|
|
10076
10078
|
if (!paneviewRef.current) {
|
|
10077
10079
|
return;
|
|
10078
10080
|
}
|
|
@@ -10080,7 +10082,7 @@
|
|
|
10080
10082
|
headerframeworkComponents: props.headerComponents,
|
|
10081
10083
|
});
|
|
10082
10084
|
}, [props.headerComponents]);
|
|
10083
|
-
|
|
10085
|
+
React.useEffect(() => {
|
|
10084
10086
|
if (!paneviewRef.current) {
|
|
10085
10087
|
return () => {
|
|
10086
10088
|
//
|
|
@@ -10096,7 +10098,7 @@
|
|
|
10096
10098
|
disposable.dispose();
|
|
10097
10099
|
};
|
|
10098
10100
|
}, [props.onDidDrop]);
|
|
10099
|
-
|
|
10101
|
+
React.useEffect(() => {
|
|
10100
10102
|
if (!paneviewRef.current) {
|
|
10101
10103
|
return;
|
|
10102
10104
|
}
|
|
@@ -10104,7 +10106,7 @@
|
|
|
10104
10106
|
showDndOverlay: props.showDndOverlay,
|
|
10105
10107
|
});
|
|
10106
10108
|
}, [props.showDndOverlay]);
|
|
10107
|
-
return (
|
|
10109
|
+
return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
|
|
10108
10110
|
});
|
|
10109
10111
|
PaneviewReact.displayName = 'PaneviewComponent';
|
|
10110
10112
|
|