dockview 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/gridview/gridviewComponent.d.ts +2 -2
- package/dist/cjs/gridview/gridviewComponent.js.map +1 -1
- package/dist/cjs/index.d.ts +0 -1
- package/dist/cjs/index.js +0 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/react/dockview/dockview.js +16 -0
- package/dist/cjs/react/dockview/dockview.js.map +1 -1
- package/dist/cjs/react/gridview/gridview.js +8 -0
- package/dist/cjs/react/gridview/gridview.js.map +1 -1
- package/dist/cjs/react/paneview/paneview.js +8 -4
- package/dist/cjs/react/paneview/paneview.js.map +1 -1
- package/dist/cjs/react/splitview/splitview.js +8 -0
- package/dist/cjs/react/splitview/splitview.js.map +1 -1
- package/dist/cjs/splitview/splitviewComponent.d.ts +2 -2
- package/dist/cjs/splitview/splitviewComponent.js.map +1 -1
- package/dist/dockview.amd.js +41 -24
- package/dist/dockview.amd.min.js +3 -3
- package/dist/dockview.amd.min.noStyle.js +3 -3
- package/dist/dockview.amd.noStyle.js +41 -24
- package/dist/dockview.cjs.js +41 -24
- package/dist/dockview.esm.js +41 -24
- package/dist/dockview.esm.min.js +3 -3
- package/dist/dockview.js +41 -24
- package/dist/dockview.min.js +3 -3
- package/dist/dockview.min.noStyle.js +3 -3
- package/dist/dockview.noStyle.js +41 -24
- package/dist/esm/gridview/gridviewComponent.d.ts +2 -2
- package/dist/esm/index.d.ts +0 -1
- package/dist/esm/index.js +0 -1
- package/dist/esm/react/dockview/dockview.js +16 -0
- package/dist/esm/react/gridview/gridview.js +8 -0
- package/dist/esm/react/paneview/paneview.js +8 -4
- package/dist/esm/react/splitview/splitview.js +8 -0
- package/dist/esm/splitview/splitviewComponent.d.ts +2 -2
- package/package.json +7 -7
- package/dist/cjs/footnote.d.ts +0 -1
- package/dist/cjs/footnote.js +0 -20
- package/dist/cjs/footnote.js.map +0 -1
- package/dist/esm/footnote.d.ts +0 -1
- package/dist/esm/footnote.js +0 -19
package/dist/dockview.esm.min.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* dockview
|
|
3
|
-
* @version 1.0.
|
|
3
|
+
* @version 1.0.1
|
|
4
4
|
* @link https://github.com/mathuo/dockview
|
|
5
5
|
* @license MIT
|
|
6
6
|
*/
|
|
7
|
-
import*as e from"react";import*as t from"react-dom";var i,n;!function(e,t){void 0===t&&(t={});var i=t.insertAt;if(e&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],s=document.createElement("style");s.type="text/css","top"===i&&n.firstChild?n.insertBefore(s,n.firstChild):n.appendChild(s),s.styleSheet?s.styleSheet.cssText=e:s.appendChild(document.createTextNode(e))}}('.dockview-theme-dark {\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-tab-close-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>\');\n --dv-tab-dirty-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2z"/></svg>\');\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-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-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-tab-close-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>\');\n --dv-tab-dirty-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2z"/></svg>\');\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-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-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-tab-close-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>\');\n --dv-tab-dirty-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2z"/></svg>\');\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-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-activegroup-visiblepanel-tab-background-color: dodgerblue;\n --dv-tabs-and-actions-container-height: 18px;\n --dv-tabs-and-actions-container-font-size: 11px;\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container {\n border-bottom: 2px solid var(--dv-activegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container {\n border-bottom: 2px solid var(--dv-inactivegroup-visiblepanel-tab-background-color);\n}\n.actions-bar {\n text-align: right;\n width: 28px;\n display: flex;\n align-items: center;\n flex-shrink: 0;\n}\n.actions-bar .actions-container {\n display: flex;\n padding: 0px;\n margin: 0px;\n justify-content: flex-end;\n}\n.actions-bar .actions-container a:active {\n -webkit-mask-size: 100% 100% !important;\n mask-size: 100% 100% !important;\n}\n.actions-bar .actions-container .close-action {\n background-color: white;\n height: 16px;\n width: 16px;\n display: block;\n -webkit-mask: var(--dv-tab-close-icon) 50% 50%/90% 90% no-repeat;\n mask: var(--dv-tab-close-icon) 50% 50%/90% 90% no-repeat;\n margin-right: "0.5em";\n cursor: pointer;\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: 10000;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection {\n position: relative;\n pointer-events: none;\n box-sizing: border-box;\n height: 100%;\n width: 100%;\n background-color: var(--dv-drag-over-background-color);\n transition-duration: 0.15s;\n transition-timing-function: ease-out;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.left, .drop-target > .drop-target-dropzone > .drop-target-selection.right {\n width: 50%;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.right {\n transform: translate(100%, 0%);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.bottom {\n transform: translate(0%, 100%);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.top, .drop-target > .drop-target-dropzone > .drop-target-selection.bottom {\n height: 50%;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-top {\n border-top: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-bottom {\n border-bottom: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-left {\n border-left: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-right {\n border-right: 1px solid var(--dv-drag-over-border-color);\n}\n.custom-dragging {\n height: 24px;\n line-height: 24px;\n font-size: 11px;\n width: 100px;\n background-color: dodgerblue;\n color: ghostwhite;\n border-radius: 11px;\n position: absolute;\n padding-left: 10px;\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.active-tab .tab-action {\n background-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.active-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab .tab-action {\n background-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.active-tab .tab-action {\n background-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.groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab .tab-action {\n background-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.dragging {\n background-color: var(--dv-activegroup-visiblepanel-tab-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.grid-view,\n.branch-node {\n height: 100%;\n width: 100%;\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 overflow: hidden;\n outline: none;\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}\n.pane-container .view .default-header > span {\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.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 .void-container {\n display: flex;\n flex-grow: 1;\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.split-view-container {\n position: relative;\n overflow: hidden;\n height: 100%;\n width: 100%;\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}\n.split-view-container .sash-container .sash: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: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}\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.dragged {\n transform: translate3d(0px, 0px, 0px);\n /* 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.dragging .tab-action {\n background-color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.tab.active-tab > .default-tab .tab-action {\n visibility: visible;\n}\n.tab.inactive-tab > .default-tab .tab-action:not(.dirty) {\n visibility: hidden;\n}\n.tab.inactive-tab > .default-tab:hover .tab-action {\n visibility: visible;\n}\n.tab .default-tab {\n position: relative;\n height: 100%;\n display: flex;\n min-width: 80px;\n align-items: center;\n padding-left: 10px;\n white-space: nowrap;\n text-overflow: elipsis;\n}\n.tab .default-tab .tab-content {\n flex-grow: 1;\n}\n.tab .default-tab .action-container {\n text-align: right;\n width: 28px;\n display: flex;\n}\n.tab .default-tab .action-container .tab-list {\n display: flex;\n padding: 0px;\n margin: 0px;\n justify-content: flex-end;\n}\n.tab .default-tab .action-container .tab-list a:active:hover {\n -webkit-mask-size: 100% 100% !important;\n mask-size: 100% 100% !important;\n}\n.tab .default-tab .action-container .tab-list .tab-action {\n height: 16px;\n width: 16px;\n display: block;\n -webkit-mask: var(--dv-tab-close-icon) 50% 50%/90% 90% no-repeat;\n mask: var(--dv-tab-close-icon) 50% 50%/90% 90% no-repeat;\n margin-right: "0.5em";\n}\n.tab .default-tab .action-container .tab-list .tab-action.disable-close {\n display: none;\n}\n.tab .default-tab .action-container .tab-list .tab-action.dirty:not(:hover) {\n display: block;\n -webkit-mask: var(--dv-tab-dirty-icon) 50% 50%/60% 60% no-repeat;\n mask: var(--dv-tab-dirty-icon) 50% 50%/60% 60% no-repeat;\n}\n.watermark {\n display: flex;\n width: 100%;\n}\n.watermark.has-actions .watermark-title .actions-bar {\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}'),function(){var e,t;const i="DOCKVIEW_WATERMARK_SUPPRESSED";if("test"===(null===(t=null===(e=window.process)||void 0===e?void 0:e.env)||void 0===t?void 0:t.NODE_ENV))return;!!window[i]||console.log(["dockview: https://github.com/mathuo/dockview for examples and documentation","dockview: https://www.npmjs.com/package/dockview","dockview: To suppress this message set window.DOCKVIEW_WATERMARK_SUPPRESSED=1 before importing the dockview package",""].join("\n"))}(),function(e){e.any=(...e)=>t=>{const i=e.map((e=>e(t)));return{dispose:()=>{i.forEach((e=>{e.dispose()}))}}}}(i||(i={}));class s{constructor(e){this.options=e,this._listeners=[],this._disposed=!1}get event(){return this._event||(this._event=e=>{var t;return(null===(t=this.options)||void 0===t?void 0:t.replay)&&void 0!==this._last&&e(this._last),this._listeners.length,this._listeners.push(e),{dispose:()=>{const t=this._listeners.indexOf(e);t>-1&&this._listeners.splice(t,1)}}}),this._event}fire(e){this._last=e,this._listeners.forEach((t=>{t(e)}))}dispose(){this._listeners=[],this._disposed=!0}}function o(e,t,i,n){return e.addEventListener(t,i,n),{dispose:()=>{e.removeEventListener(t,i)}}}function a(e,t,i,n){return e.addEventListener(t,i,n),{dispose:()=>{e.removeEventListener(t,i)}}}!function(e){e.NONE={dispose:()=>{}}}(n||(n={}));class r{constructor(...e){this.disposables=e}static from(...e){return new r(...e)}addDisposables(...e){null==e||e.forEach((e=>this.disposables.push(e)))}dispose(){this.disposables.forEach((e=>e.dispose()))}}class h{constructor(){this._disposable=n.NONE}set value(e){this._disposable&&this._disposable.dispose(),this._disposable=e}dispose(){this._disposable&&this._disposable.dispose()}}class d{constructor(){}}class l extends d{constructor(e,t,i){super(),this.viewId=e,this.groupId=t,this.panelId=i}}class p extends d{constructor(e,t){super(),this.viewId=e,this.paneId=t}}const c="splitview/transfer",m=e=>!!e.dataTransfer&&e.dataTransfer.types.includes(c);var u;!function(e){e.DOCKVIEW_TAB="dockview_tab",e.EXTERNAL="external_group_drag"}(u||(u={}));const v=e=>e.type===u.DOCKVIEW_TAB,g=e=>e.type===u.EXTERNAL,w=e=>{if(!e.dataTransfer)return null;const t=function(e,t){try{return JSON.parse(e,t)}catch(e){return void console.warn("failed to parse JSON")}}(e.dataTransfer.getData(c));return t||console.warn(`[dragEvent] ${c} data is missing`),"string"!=typeof t.type&&console.warn(`[dragEvent] invalid type ${t.type}`),t};class b{constructor(){}static getInstance(){return b.INSTANCE}hasData(e){return e&&e===this.proto}clearData(e){this.hasData(e)&&(this.proto=void 0,this.data=void 0)}getData(e){if(this.hasData(e))return this.data}setData(e,t){t&&(this.data=e,this.proto=t)}}function f(){const e=b.getInstance();if(e.hasData(l.prototype))return e.getData(l.prototype)[0]}function _(){const e=b.getInstance();if(e.hasData(p.prototype))return e.getData(p.prototype)[0]}b.INSTANCE=new b;class C{constructor(e){this.component=e}get minimumSize(){return this.component.minimumSize}get maximumSize(){return this.component.maximumSize}get height(){return this.component.height}get width(){return this.component.width}get length(){return this.component.length}get onDidLayoutChange(){return this.component.onDidLayoutChange}get orientation(){return this.component.orientation}updateOptions(e){this.component.updateOptions(e)}removePanel(e,t){this.component.removePanel(e,t)}setVisible(e,t){this.component.setVisible(e,t)}getPanels(){return this.component.getPanels()}focus(){this.component.focus()}getPanel(e){return this.component.getPanel(e)}setActive(e){this.component.setActive(e)}layout(e,t){return this.component.layout(e,t)}addPanel(e){this.component.addPanel(e)}resizeToFit(){this.component.resizeToFit()}movePanel(e,t){this.component.movePanel(e,t)}fromJSON(e,t){this.component.fromJSON(e,t)}toJSON(){return this.component.toJSON()}}class y{constructor(e){this.component=e}get width(){return this.component.width}get height(){return this.component.height}get minimumSize(){return this.component.minimumSize}get maximumSize(){return this.component.maximumSize}get onDidLayoutChange(){return this.component.onDidLayoutChange}getPanels(){return this.component.getPanels()}removePanel(e){this.component.removePanel(e)}getPanel(e){return this.component.getPanel(e)}movePanel(e,t){this.component.movePanel(e,t)}focus(){this.component.focus()}layout(e,t){this.component.layout(e,t)}addPanel(e){return this.component.addPanel(e)}resizeToFit(){this.component.resizeToFit()}fromJSON(e,t){this.component.fromJSON(e,t)}toJSON(){return this.component.toJSON()}}class z{constructor(e){this.component=e}get width(){return this.component.width}get height(){return this.component.height}get minimumHeight(){return this.component.minimumHeight}get maximumHeight(){return this.component.maximumHeight}get minimumWidth(){return this.component.minimumWidth}get maximumWidth(){return this.component.maximumWidth}get onGridEvent(){return this.component.onGridEvent}get onDidLayoutChange(){return this.component.onDidLayoutChange}get panels(){return this.component.groups}get orientation(){return this.component.orientation}set orientation(e){this.component.updateOptions({orientation:e})}focus(){this.component.focus()}layout(e,t,i=!1){this.component.layout(e,t,i)}addPanel(e){this.component.addPanel(e)}removePanel(e,t){this.component.removePanel(e,t)}movePanel(e,t){this.component.movePanel(e,t)}resizeToFit(){this.component.resizeToFit()}getPanel(e){return this.component.getPanel(e)}toggleVisibility(e){this.component.toggleVisibility(e)}setVisible(e,t){this.component.setVisible(e,t)}setActive(e){this.component.setActive(e)}fromJSON(e,t){return this.component.fromJSON(e,t)}toJSON(){return this.component.toJSON()}}class x{constructor(e){this.component=e}get width(){return this.component.width}get height(){return this.component.height}get minimumHeight(){return this.component.minimumHeight}get maximumHeight(){return this.component.maximumHeight}get minimumWidth(){return this.component.minimumWidth}get maximumWidth(){return this.component.maximumWidth}get size(){return this.component.size}get totalPanels(){return this.component.totalPanels}get onGridEvent(){return this.component.onGridEvent}get onDidLayoutChange(){return this.component.onDidLayoutChange}get panels(){return this.component.panels}get groups(){return this.component.groups}get activePanel(){return this.component.activePanel}get activeGroup(){return this.component.activeGroup}getTabHeight(){return this.component.tabHeight}setTabHeight(e){this.component.tabHeight=e}focus(){this.component.focus()}getPanel(e){return this.component.getGroupPanel(e)}setActivePanel(e){this.component.setActivePanel(e)}layout(e,t,i=!1){this.component.layout(e,t,i)}addPanel(e){return this.component.addPanel(e)}removePanel(e){this.component.removePanel(e)}addEmptyGroup(e){this.component.addEmptyGroup(e)}moveToNext(e){this.component.moveToNext(e)}moveToPrevious(e){this.component.moveToPrevious(e)}closeAllGroups(){return this.component.closeAllGroups()}removeGroup(e){this.component.removeGroup(e)}resizeToFit(){return this.component.resizeToFit()}getGroup(e){return this.component.getPanel(e)}fromJSON(e){this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}}function D(e,t){const i=new ResizeObserver((e=>{const i=e[0];t(i)}));return i.observe(e),{dispose:()=>{i.unobserve(e),i.disconnect()}}}const E=(e,...t)=>{for(const i of t)e.classList.contains(i)&&e.classList.remove(i)},S=(e,...t)=>{for(const i of t)e.classList.contains(i)||e.classList.add(i)},A=(e,t,i)=>{const n=e.classList.contains(t);i&&!n&&e.classList.add(t),!i&&n&&e.classList.remove(t)};function P(e,t){for(;e;){if(e===t)return!0;e=e.parentNode}return!1}function O(e){return Array.prototype.slice.call(document.getElementsByTagName(e),0)}function N(e){return new I(e)}class I extends r{constructor(e){super(),this._onDidFocus=new s,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new s,this.onDidBlur=this._onDidBlur.event;let t=P(document.activeElement,e),i=!1;const n=()=>{i=!1,t||(t=!0,this._onDidFocus.fire())},r=()=>{t&&(i=!0,window.setTimeout((()=>{i&&(i=!1,t=!1,this._onDidBlur.fire())}),0))};this._refreshStateHandler=()=>{P(document.activeElement,e)!==t&&(t?r():n())},e instanceof HTMLElement?(this.addDisposables(a(e,"focus",n,!0)),this.addDisposables(a(e,"blur",r,!0))):(this.addDisposables(o(e,"focus",n,!0)),this.addDisposables(o(e,"blur",r,!0)))}refreshState(){this._refreshStateHandler()}dispose(){super.dispose(),this._onDidBlur.dispose(),this._onDidFocus.dispose()}}const k=(e,t,i)=>{if(t>i)throw new Error(`${t} > ${i} is an invalid condition`);return Math.min(i,Math.max(e,t))},V=()=>{let e=1;return{next:()=>(e++).toString()}};function T(e){if(0===e.length)throw new Error("Invalid tail call");return[e.slice(0,e.length-1),e[e.length-1]]}function L(e,t){if(e.length!==t.length)return!1;for(let i=0;i<e.length;i++)if(e[i]!==t[i])return!1;return!0}function R(e,t){const i=e.indexOf(t);i>-1&&(e.splice(i,1),e.unshift(t))}function G(e,t){const i=e.indexOf(t);i>-1&&(e.splice(i,1),e.push(t))}const H=(e,t)=>{const i=[];if("number"!=typeof t&&(t=e,e=0),e<=t)for(let n=e;n<t;n++)i.push(n);else for(let n=e;n>t;n--)i.push(n);return i};class M{constructor(e,t,i,n){this.container=e,this.view=t,this.disposable=n,this._cachedVisibleSize=void 0,"number"==typeof i?(this._size=i,this._cachedVisibleSize=void 0,e.classList.add("visible")):(this._size=0,this._cachedVisibleSize=i.cachedVisibleSize)}set size(e){this._size=e}get size(){return this._size}get cachedVisibleSize(){return this._cachedVisibleSize}get visible(){return void 0===this._cachedVisibleSize}setVisible(e,t){var i;e!==this.visible&&(e?(this.size=k(null!==(i=this._cachedVisibleSize)&&void 0!==i?i:0,this.viewMinimumSize,this.viewMaximumSize),this._cachedVisibleSize=void 0):(this._cachedVisibleSize="number"==typeof t?t:this.size,this.size=0),this.container.classList.toggle("visible",e),this.view.setVisible&&this.view.setVisible(e))}get minimumSize(){return this.visible?this.view.minimumSize:0}get viewMinimumSize(){return this.view.minimumSize}get maximumSize(){return this.visible?this.view.maximumSize:0}get viewMaximumSize(){return this.view.maximumSize}get priority(){return this.view.priority}get snap(){return!!this.view.snap}set enabled(e){this.container.style.pointerEvents=e?"":"none"}dispose(){return this.disposable.dispose(),this.view}}var F,W,B,J,U;!function(e){e.HORIZONTAL="HORIZONTAL",e.VERTICAL="VERTICAL"}(F||(F={})),function(e){e[e.MAXIMUM=0]="MAXIMUM",e[e.MINIMUM=1]="MINIMUM",e[e.DISABLED=2]="DISABLED",e[e.ENABLED=3]="ENABLED"}(W||(W={})),function(e){e.Low="low",e.High="high",e.Normal="normal"}(B||(B={})),function(e){e.Distribute={type:"distribute"},e.Split=function(e){return{type:"split",index:e}},e.Invisible=function(e){return{type:"invisible",cachedVisibleSize:e}}}(J||(J={}));class j{constructor(e,t){this.container=e,this.views=[],this.sashes=[],this._size=0,this._orthogonalSize=0,this.contentSize=0,this._proportions=void 0,this._onDidSashEnd=new s,this.onDidSashEnd=this._onDidSashEnd.event,this._onDidAddView=new s,this.onDidAddView=this._onDidAddView.event,this._onDidRemoveView=new s,this.onDidRemoveView=this._onDidAddView.event,this._startSnappingEnabled=!0,this._endSnappingEnabled=!0,this.resize=(e,t,i=this.views.map((e=>e.size)),n,s,o=Number.NEGATIVE_INFINITY,a=Number.POSITIVE_INFINITY,r,h)=>{if(e<0||e>this.views.length)return 0;const d=H(e,-1),l=H(e+1,this.views.length);if(s)for(const e of s)R(d,e),R(l,e);if(n)for(const e of n)G(d,e),G(l,e);const p=d.map((e=>this.views[e])),c=d.map((e=>i[e])),m=l.map((e=>this.views[e])),u=l.map((e=>i[e])),v=d.reduce(((e,t)=>e+this.views[t].minimumSize-i[t]),0),g=d.reduce(((e,t)=>e+this.views[t].maximumSize-i[t]),0),w=0===l.length?Number.POSITIVE_INFINITY:l.reduce(((e,t)=>e+i[t]-this.views[t].minimumSize),0),b=0===l.length?Number.NEGATIVE_INFINITY:l.reduce(((e,t)=>e+i[t]-this.views[t].maximumSize),0),f=Math.max(v,b),_=Math.min(w,g);let C=!1;if(r){const e=this.views[r.index],i=t>=r.limitDelta;C=i!==e.visible,e.setVisible(i,r.size)}if(!C&&h){const e=this.views[h.index],i=t<h.limitDelta;C=i!==e.visible,e.setVisible(i,h.size)}if(C)return this.resize(e,t,i,n,s,o,a);let y=0,z=k(t,f,_);for(let e=0;e<p.length;e++){const t=p[e],i=k(c[e]+z,t.minimumSize,t.maximumSize),n=i-c[e];y+=n,z-=n,t.size=i}let x=y;for(let e=0;e<m.length;e++){const t=m[e],i=k(u[e]-x,t.minimumSize,t.maximumSize);x+=i-u[e],t.size=i}return t},this._orientation=t.orientation,this.element=this.createContainer(),this.proportionalLayout=void 0===t.proportionalLayout||!!t.proportionalLayout,this.viewContainer=this.createViewContainer(),this.sashContainer=this.createSashContainer(),this.element.appendChild(this.sashContainer),this.element.appendChild(this.viewContainer),this.container.appendChild(this.element),this.style(t.styles),t.descriptor&&(this._size=t.descriptor.size,t.descriptor.views.forEach(((e,t)=>{const i=void 0===e.visible||e.visible?e.size:{type:"invisible",cachedVisibleSize:e.size},n=e.view;this.addView(n,i,t,!0)})),this.contentSize=this.views.reduce(((e,t)=>e+t.size),0),this.saveProportions())}get size(){return this._size}set size(e){this._size=e}get orthogonalSize(){return this._orthogonalSize}set orthogonalSize(e){this._orthogonalSize=e}get length(){return this.views.length}get proportions(){return this._proportions?[...this._proportions]:void 0}get orientation(){return this._orientation}set orientation(e){this._orientation=e;const t=this.size;this.size=this.orthogonalSize,this.orthogonalSize=t,E(this.element,"horizontal","vertical"),this.element.classList.add(this.orientation==F.HORIZONTAL?"horizontal":"vertical")}get minimumSize(){return this.views.reduce(((e,t)=>e+t.minimumSize),0)}get maximumSize(){return 0===this.length?Number.POSITIVE_INFINITY:this.views.reduce(((e,t)=>e+t.maximumSize),0)}get startSnappingEnabled(){return this._startSnappingEnabled}set startSnappingEnabled(e){this._startSnappingEnabled!==e&&(this._startSnappingEnabled=e,this.updateSashEnablement())}get endSnappingEnabled(){return this._endSnappingEnabled}set endSnappingEnabled(e){this._endSnappingEnabled!==e&&(this._endSnappingEnabled=e,this.updateSashEnablement())}style(e){"transparent"===(null==e?void 0:e.separatorBorder)?(E(this.element,"separator-border"),this.element.style.removeProperty("--dv-separator-border")):(S(this.element,"separator-border"),(null==e?void 0:e.separatorBorder)&&this.element.style.setProperty("--dv-separator-border",e.separatorBorder))}isViewVisible(e){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");return this.views[e].visible}setViewVisible(e,t){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");A(this.container,"visible",t);const i=this.views[e];A(this.container,"visible",t),i.setVisible(t,i.size),this.distributeEmptySpace(e),this.layoutViews(),this.saveProportions()}getViewSize(e){return e<0||e>=this.views.length?-1:this.views[e].size}resizeView(e,t){if(e<0||e>=this.views.length)return;const i=H(this.views.length).filter((t=>t!==e)),n=[...i.filter((e=>this.views[e].priority===B.Low)),e],s=i.filter((e=>this.views[e].priority===B.High)),o=this.views[e];t=Math.round(t),t=k(t,o.minimumSize,Math.min(o.maximumSize,this._size)),o.size=t,this.relayout(n,s)}getViews(){return this.views.map((e=>e.view))}onDidChange(e,t){const i=this.views.indexOf(e);i<0||i>=this.views.length||(t="number"==typeof t?t:e.size,t=k(t,e.minimumSize,e.maximumSize),e.size=t,this.relayout([i]))}addView(e,t={type:"distribute"},i=this.views.length,n){const s=document.createElement("div");let o;s.className="view",s.appendChild(e.element),o="number"==typeof t?t:"split"===t.type?this.getViewSize(t.index)/2:"invisible"===t.type?{cachedVisibleSize:t.cachedVisibleSize}:e.minimumSize;const a=e.onDidChange((e=>this.onDidChange(r,e))),r=new M(s,e,o,{dispose:()=>{null==a||a.dispose(),this.viewContainer.removeChild(s)}});if(i===this.views.length?this.viewContainer.appendChild(s):this.viewContainer.insertBefore(s,this.viewContainer.children.item(i)),this.views.splice(i,0,r),this.views.length>1){const e=document.createElement("div");e.className="sash";const t=t=>{for(const e of this.views)e.enabled=!1;const i=[...O("iframe"),...O("webview")];for(const e of i)e.style.pointerEvents="none";const n=this._orientation===F.HORIZONTAL?t.clientX:t.clientY,s=function(e,t){for(let i=0;i<e.length;i++)if(t(e[i]))return i;return-1}(this.sashes,(t=>t.container===e)),o=this.views.map((e=>e.size));let a,r;const h=H(s,-1),d=H(s+1,this.views.length),l=h.reduce(((e,t)=>e+(this.views[t].minimumSize-o[t])),0),p=h.reduce(((e,t)=>e+(this.views[t].viewMaximumSize-o[t])),0),c=0===d.length?Number.POSITIVE_INFINITY:d.reduce(((e,t)=>e+(o[t]-this.views[t].minimumSize)),0),m=0===d.length?Number.NEGATIVE_INFINITY:d.reduce(((e,t)=>e+(o[t]-this.views[t].viewMaximumSize)),0),u=Math.max(l,m),v=Math.min(c,p),g=this.findFirstSnapIndex(h),w=this.findFirstSnapIndex(d);if("number"==typeof g){const e=this.views[g],t=Math.floor(e.viewMinimumSize/2);a={index:g,limitDelta:e.visible?u-t:u+t,size:e.size}}if("number"==typeof w){const e=this.views[w],t=Math.floor(e.viewMinimumSize/2);r={index:w,limitDelta:e.visible?v+t:v-t,size:e.size}}const b=e=>{const t=(this._orientation===F.HORIZONTAL?e.clientX:e.clientY)-n;this.resize(s,t,o,void 0,void 0,u,v,a,r),this.distributeEmptySpace(),this.layoutViews()},f=()=>{for(const e of this.views)e.enabled=!0;for(const e of i)e.style.pointerEvents="auto";this.saveProportions(),document.removeEventListener("mousemove",b),document.removeEventListener("mouseup",f),document.removeEventListener("mouseend",f),this._onDidSashEnd.fire(void 0)};document.addEventListener("mousemove",b),document.addEventListener("mouseup",f),document.addEventListener("mouseend",f)};e.addEventListener("mousedown",t);const i={container:e,disposable:()=>{e.removeEventListener("mousedown",t),this.sashContainer.removeChild(e)}};this.sashContainer.appendChild(e),this.sashes.push(i)}n||this.relayout([i]),n||"number"==typeof t||"distribute"!==t.type||this.distributeViewSizes(),this._onDidAddView.fire(e)}distributeViewSizes(){const e=[];let t=0;for(const i of this.views)i.maximumSize-i.minimumSize>0&&(e.push(i),t+=i.size);const i=Math.floor(t/e.length);for(const t of e)t.size=k(i,t.minimumSize,t.maximumSize);const n=H(this.views.length),s=n.filter((e=>this.views[e].priority===B.Low)),o=n.filter((e=>this.views[e].priority===B.High));this.relayout(s,o)}removeView(e,t,i=!1){const n=this.views.splice(e,1)[0];if(n.dispose(),this.views.length>=1){const t=Math.max(e-1,0);this.sashes.splice(t,1)[0].disposable()}return i||this.relayout(),t&&"distribute"===t.type&&this.distributeViewSizes(),this._onDidRemoveView.fire(n.view),n.view}getViewCachedVisibleSize(e){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");return this.views[e].cachedVisibleSize}moveView(e,t){const i=this.getViewCachedVisibleSize(e),n=void 0===i?this.getViewSize(e):J.Invisible(i),s=this.removeView(e,void 0,!0);this.addView(s,n,t)}layout(e,t){const i=Math.max(this.size,this.contentSize);if(this.size=e,this.orthogonalSize=t,this.proportions)for(let t=0;t<this.views.length;t++){const i=this.views[t];i.size=k(Math.round(this.proportions[t]*e),i.minimumSize,i.maximumSize)}else{const t=H(this.views.length),n=t.filter((e=>this.views[e].priority===B.Low)),s=t.filter((e=>this.views[e].priority===B.High));this.resize(this.views.length-1,e-i,void 0,n,s)}this.distributeEmptySpace(),this.layoutViews()}relayout(e,t){const i=this.views.reduce(((e,t)=>e+t.size),0);this.resize(this.views.length-1,this._size-i,void 0,e,t),this.distributeEmptySpace(),this.layoutViews(),this.saveProportions()}distributeEmptySpace(e){const t=this.views.reduce(((e,t)=>e+t.size),0);let i=this.size-t;const n=H(this.views.length-1,-1),s=n.filter((e=>this.views[e].priority===B.Low)),o=n.filter((e=>this.views[e].priority===B.High));for(const e of o)R(n,e);for(const e of s)G(n,e);"number"==typeof e&&G(n,e);for(let e=0;0!==i&&e<n.length;e++){const t=this.views[n[e]],s=k(t.size+i,t.minimumSize,t.maximumSize);i-=s-t.size,t.size=s}}saveProportions(){this.proportionalLayout&&this.contentSize>0&&(this._proportions=this.views.map((e=>e.size/this.contentSize)))}layoutViews(){this.contentSize=this.views.reduce(((e,t)=>e+t.size),0);let e=0;const t=[];this.updateSashEnablement();for(let i=0;i<this.views.length-1;i++){e+=this.views[i].size,t.push(e);const n=Math.min(Math.max(0,e-2),this.size-4);this._orientation===F.HORIZONTAL&&(this.sashes[i].container.style.left=`${n}px`,this.sashes[i].container.style.top="0px"),this._orientation===F.VERTICAL&&(this.sashes[i].container.style.left="0px",this.sashes[i].container.style.top=`${n}px`)}this.views.forEach(((e,i)=>{this._orientation===F.HORIZONTAL&&(e.container.style.width=`${e.size}px`,e.container.style.left=0==i?"0px":`${t[i-1]}px`,e.container.style.top="",e.container.style.height=""),this._orientation===F.VERTICAL&&(e.container.style.height=`${e.size}px`,e.container.style.top=0==i?"0px":`${t[i-1]}px`,e.container.style.width="",e.container.style.left=""),e.view.layout(e.size,this._orthogonalSize)}))}findFirstSnapIndex(e){for(const t of e){const e=this.views[t];if(e.visible&&e.snap)return t}for(const t of e){const e=this.views[t];if(e.visible&&e.maximumSize-e.minimumSize>0)return;if(!e.visible&&e.snap)return t}}updateSashEnablement(){let e=!1;const t=this.views.map((t=>e=t.size-t.minimumSize>0||e));e=!1;const i=this.views.map((t=>e=t.maximumSize-t.size>0||e)),n=[...this.views].reverse();e=!1;const s=n.map((t=>e=t.size-t.minimumSize>0||e)).reverse();e=!1;const o=n.map((t=>e=t.maximumSize-t.size>0||e)).reverse();let a=0;for(let e=0;e<this.sashes.length;e++){const n=this.sashes[e];a+=this.views[e].size;const r=!(t[e]&&o[e+1]),h=!(i[e]&&s[e+1]);if(r&&h){const i=H(e,-1),o=H(e+1,this.views.length),r=this.findFirstSnapIndex(i),h=this.findFirstSnapIndex(o),d="number"==typeof r&&!this.views[r].visible,l="number"==typeof h&&!this.views[h].visible;d&&s[e]&&(a>0||this.startSnappingEnabled)?this.updateSash(n,W.MINIMUM):l&&t[e]&&(a<this.contentSize||this.endSnappingEnabled)?this.updateSash(n,W.MAXIMUM):this.updateSash(n,W.DISABLED)}else r&&!h?this.updateSash(n,W.MINIMUM):!r&&h?this.updateSash(n,W.MAXIMUM):this.updateSash(n,W.ENABLED)}}updateSash(e,t){A(e.container,"disabled",t===W.DISABLED),A(e.container,"enabled",t===W.ENABLED),A(e.container,"maximum",t===W.MAXIMUM),A(e.container,"minimum",t===W.MINIMUM)}createViewContainer(){const e=document.createElement("div");return e.className="view-container",e}createSashContainer(){const e=document.createElement("div");return e.className="sash-container",e}createContainer(){const e=document.createElement("div"),t=this._orientation===F.HORIZONTAL?"horizontal":"vertical";return e.className=`split-view-container ${t}`,e}dispose(){this._onDidSashEnd.dispose(),this._onDidAddView.dispose(),this._onDidRemoveView.dispose(),this.element.remove();for(let e=0;e<this.element.children.length;e++)if(this.element.children.item(e)===this.element){this.element.removeChild(this.element);break}}}class $ extends r{constructor(e,t){var i;super(),this.paneItems=[],this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.skipAnimation=!1,this._orientation=null!==(i=t.orientation)&&void 0!==i?i:F.VERTICAL,this.element=document.createElement("div"),this.element.className="pane-container",e.appendChild(this.element),this.splitview=new j(this.element,{orientation:this._orientation,proportionalLayout:!1,descriptor:t.descriptor}),this.getPanes().forEach(((e,t)=>{const i=new r(e.onDidChangeExpansionState((()=>{this.setupAnimation(),this._onDidChange.fire(void 0)}))),n={pane:e,disposable:{dispose:()=>{i.dispose()}}};this.paneItems.push(n),e.orthogonalSize=this.splitview.orthogonalSize})),this.addDisposables(this.splitview.onDidSashEnd((()=>{this._onDidChange.fire(void 0)})),this.splitview.onDidAddView((()=>{this._onDidChange.fire()})),this.splitview.onDidRemoveView((()=>{this._onDidChange.fire()})))}get onDidAddView(){return this.splitview.onDidAddView}get onDidRemoveView(){return this.splitview.onDidRemoveView}get minimumSize(){return this.splitview.minimumSize}get maximumSize(){return this.splitview.maximumSize}get orientation(){return this.splitview.orientation}get size(){return this.splitview.size}get orthogonalSize(){return this.splitview.orthogonalSize}addPane(e,t,i=this.splitview.length,n=!1){const s=e.onDidChangeExpansionState((()=>{this.setupAnimation(),this._onDidChange.fire(void 0)})),o={pane:e,disposable:{dispose:()=>{s.dispose()}}};this.paneItems.splice(i,0,o),e.orthogonalSize=this.splitview.orthogonalSize,this.splitview.addView(e,t,i,n)}getViewSize(e){return this.splitview.getViewSize(e)}getPanes(){return this.splitview.getViews()}removePane(e){const t=this.paneItems.splice(e,1)[0];return this.splitview.removeView(e),t.disposable.dispose(),t}moveView(e,t){if(e===t)return;const i=this.removePane(e);this.skipAnimation=!0;try{this.addPane(i.pane,i.pane.size,t,!1)}finally{this.skipAnimation=!1}}layout(e,t){this.splitview.layout(e,t)}setupAnimation(){this.skipAnimation||(this.animationTimer&&(clearTimeout(this.animationTimer),this.animationTimer=void 0),S(this.element,"animated"),this.animationTimer=setTimeout((()=>{this.animationTimer=void 0,E(this.element,"animated")}),200))}dispose(){super.dispose(),this.splitview.dispose(),this.animationTimer&&(clearTimeout(this.animationTimer),this.animationTimer=void 0),this.paneItems.forEach((e=>{e.disposable.dispose()})),this.paneItems=[],this.element.remove()}}class Z extends r{constructor(e,t){super(),this.element=e,this.callbacks=t,this.counter=0,this.registerListeners()}registerListeners(){this.addDisposables(a(this.element,"dragenter",(e=>{this.counter++,this.callbacks.onDragEnter(e)}))),this.addDisposables(a(this.element,"dragover",(e=>{e.preventDefault(),this.callbacks.onDragOver&&this.callbacks.onDragOver(e)}))),this.addDisposables(a(this.element,"dragleave",(e=>{this.counter--,0===this.counter&&this.callbacks.onDragLeave(e)}))),this.addDisposables(a(this.element,"dragend",(e=>{this.counter=0,this.callbacks.onDragEnd(e)}))),this.addDisposables(a(this.element,"drop",(e=>{this.counter=0,this.callbacks.onDrop(e)})))}}!function(e){e.Top="Top",e.Left="Left",e.Bottom="Bottom",e.Right="Right",e.Center="Center"}(U||(U={}));class Y extends r{constructor(e,t){super(),this.element=e,this.options=t,this._onDrop=new s,this.onDrop=this._onDrop.event,this.addDisposables(new Z(this.element,{onDragEnter:e=>{},onDragOver:e=>{if("boolean"==typeof this.options.canDisplayOverlay){if(!this.options.canDisplayOverlay)return}else if(!this.options.canDisplayOverlay(e))return;if(this.target||(this.target=document.createElement("div"),this.target.className="drop-target-dropzone",this.overlay=document.createElement("div"),this.overlay.className="drop-target-selection",this._state=U.Center,this.target.appendChild(this.overlay),this.element.classList.add("drop-target"),this.element.append(this.target)),"none"===this.options.validOverlays)return;if(!this.target||!this.overlay)return;const t=this.target.clientWidth,i=this.target.clientHeight;if(0===t||0===i)return;const n=100*e.offsetX/t,s=100*e.offsetY/i;let o=!1,a=!1,r=!1,h=!1;switch(this.options.validOverlays){case"all":o=n>80,a=n<20,r=!o&&!a&&s<20,h=!o&&!a&&s>80;break;case"vertical":r=s<50,h=s>=50;break;case"horizontal":a=n<50,o=n>=50}const d=t<100,l=i<100;A(this.overlay,"right",!d&&o),A(this.overlay,"left",!d&&a),A(this.overlay,"top",!l&&r),A(this.overlay,"bottom",!l&&h),A(this.overlay,"small-right",d&&o),A(this.overlay,"small-left",d&&a),A(this.overlay,"small-top",l&&r),A(this.overlay,"small-bottom",l&&h),this._state=o?U.Right:a?U.Left:r?U.Top:h?U.Bottom:U.Center},onDragLeave:e=>{this.removeDropTarget()},onDragEnd:e=>{this.removeDropTarget()},onDrop:e=>{e.preventDefault(),e.stopPropagation();const t=this._state;this.removeDropTarget(),t&&this._onDrop.fire({position:t,event:e})}}))}get state(){return this._state}set validOverlays(e){this.options.validOverlays=e}set canDisplayOverlay(e){this.options.canDisplayOverlay=e}dispose(){this._onDrop.dispose(),this.removeDropTarget()}removeDropTarget(){this.target&&(this._state=void 0,this.element.removeChild(this.target),this.target=void 0,this.element.classList.remove("drop-target"))}}class X{constructor(e,t,i,n=0){this.view=e,this.orientation=t,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this._orthogonalSize=i,this._size=n,this._disposable=this.view.onDidChange((e=>{e?this._onDidChange.fire(this.orientation===F.VERTICAL?e.width:e.height):this._onDidChange.fire(void 0)}))}get minimumWidth(){return this.view.minimumWidth}get maximumWidth(){return this.view.maximumWidth}get minimumHeight(){return this.view.minimumHeight}get maximumHeight(){return this.view.maximumHeight}get priority(){return this.view.priority}get snap(){return this.view.snap}get minimumSize(){return this.orientation===F.HORIZONTAL?this.minimumHeight:this.minimumWidth}get maximumSize(){return this.orientation===F.HORIZONTAL?this.maximumHeight:this.maximumWidth}get minimumOrthogonalSize(){return this.orientation===F.HORIZONTAL?this.minimumWidth:this.minimumHeight}get maximumOrthogonalSize(){return this.orientation===F.HORIZONTAL?this.maximumWidth:this.maximumHeight}get orthogonalSize(){return this._orthogonalSize}get size(){return this._size}get element(){return this.view.element}get width(){return this.orientation===F.HORIZONTAL?this.orthogonalSize:this.size}get height(){return this.orientation===F.HORIZONTAL?this.size:this.orthogonalSize}setVisible(e){this.view.setVisible&&(this.view.setVisible(e),this._onDidChange.fire(void 0))}layout(e,t){this._size=e,this._orthogonalSize=t,this.view.layout(this.width,this.height)}dispose(){this._disposable.dispose()}}class K extends r{constructor(e,t,i,o,a,r){if(super(),this.orientation=e,this.proportionalLayout=t,this.styles=i,this.children=[],this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this._childrenDisposable=n.NONE,this._orthogonalSize=a,this._size=o,this.element=document.createElement("div"),this.element.className="branch-node",r){const e={views:r.map((e=>({view:e.node,size:e.node.size,visible:!(e.node instanceof X&&void 0!==e.visible)||e.visible}))),size:this.orthogonalSize};this.children=r.map((e=>e.node)),this.splitview=new j(this.element,{orientation:this.orientation,descriptor:e,proportionalLayout:t})}else this.splitview=new j(this.element,{orientation:this.orientation,proportionalLayout:t,styles:i}),this.splitview.layout(this.size,this.orthogonalSize);this.addDisposables(this.splitview.onDidSashEnd((()=>{this._onDidChange.fire(void 0)}))),this.setupChildrenEvents()}get width(){return this.orientation===F.HORIZONTAL?this.size:this.orthogonalSize}get height(){return this.orientation===F.HORIZONTAL?this.orthogonalSize:this.size}get minimumSize(){return 0===this.children.length?0:Math.max(...this.children.map((e=>e.minimumOrthogonalSize)))}get maximumSize(){return Math.min(...this.children.map((e=>e.maximumOrthogonalSize)))}get minimumOrthogonalSize(){return this.splitview.minimumSize}get maximumOrthogonalSize(){return this.splitview.maximumSize}get orthogonalSize(){return this._orthogonalSize}get size(){return this._size}get minimumWidth(){return this.orientation===F.HORIZONTAL?this.minimumOrthogonalSize:this.minimumSize}get minimumHeight(){return this.orientation===F.HORIZONTAL?this.minimumSize:this.minimumOrthogonalSize}get maximumWidth(){return this.orientation===F.HORIZONTAL?this.maximumOrthogonalSize:this.maximumSize}get maximumHeight(){return this.orientation===F.HORIZONTAL?this.maximumSize:this.maximumOrthogonalSize}get priority(){if(0===this.children.length)return B.Normal;const e=this.children.map((e=>void 0===e.priority?B.Normal:e.priority));return e.some((e=>e===B.High))?B.High:e.some((e=>e===B.Low))?B.Low:B.Normal}setVisible(e){for(const t of this.children)t.setVisible(e)}isChildVisible(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.isViewVisible(e)}setChildVisible(e,t){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.isViewVisible(e)!==t&&this.splitview.setViewVisible(e,t)}moveChild(e,t){if(e===t)return;if(e<0||e>=this.children.length)throw new Error("Invalid from index");e<t&&t--,this.splitview.moveView(e,t);const i=this._removeChild(e);this._addChild(i,t)}getChildSize(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.getViewSize(e)}resizeChild(e,t){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.resizeView(e,t)}layout(e,t){this._size=t,this._orthogonalSize=e,this.splitview.layout(this.size,this.orthogonalSize)}addChild(e,t,i,n){if(i<0||i>this.children.length)throw new Error("Invalid index");this.splitview.addView(e,t,i,n),this._addChild(e,i)}getChildCachedVisibleSize(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.getViewCachedVisibleSize(e)}removeChild(e,t){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.removeView(e,t),this._removeChild(e)}_addChild(e,t){this.children.splice(t,0,e),this.setupChildrenEvents()}_removeChild(e){const[t]=this.children.splice(e,1);return this.setupChildrenEvents(),t}setupChildrenEvents(){this._childrenDisposable.dispose(),this._childrenDisposable=i.any(...this.children.map((e=>e.onDidChange)))((e=>{this._onDidChange.fire(void 0)}))}dispose(){super.dispose(),this._childrenDisposable.dispose(),this.children.forEach((e=>e.dispose())),this.splitview.dispose()}}function q(e,t,i){if(e instanceof K){const n=new K(se(e.orientation),e.proportionalLayout,e.styles,t,i);let s=0;for(let o=e.children.length-1;o>=0;o--){const a=e.children[o],r=a instanceof K?a.orthogonalSize:a.size;let h=0===e.size?0:Math.round(t*r/e.size);s+=h,0===o&&(h+=t-s),n.addChild(q(a,i,h),h,0,!0)}return n}return new X(e.view,se(e.orientation),i)}function Q(e){const t=e.parentElement;if(!t)throw new Error("Invalid grid element");let i=t.firstElementChild,n=0;for(;i!==e&&i!==t.lastElementChild&&i;)i=i.nextElementSibling,n++;return n}function ee(e){const t=e.parentElement;if(!t)throw new Error("Invalid grid element");if(/\bgrid-view\b/.test(t.className))return[];const i=Q(t);return[...ee(t.parentElement.parentElement.parentElement),i]}function te(e,t,i){if(ne(e,t)===ie(i)){const[e,n]=T(t);let s=n;return i!==U.Right&&i!==U.Bottom||(s+=1),[...e,s]}{const e=i===U.Right||i===U.Bottom?1:0;return[...t,e]}}function ie(e){return e===U.Top||e===U.Bottom?F.VERTICAL:F.HORIZONTAL}function ne(e,t){return t.length%2==0?se(e):e}const se=e=>e===F.HORIZONTAL?F.VERTICAL:F.HORIZONTAL;function oe(e){return!!e.children}const ae=(e,t)=>{const i=t===F.VERTICAL?e.box.width:e.box.height;return oe(e)?{type:"branch",data:e.children.map((e=>ae(e,se(t)))),size:i}:"number"==typeof e.cachedVisibleSize?{type:"leaf",data:e.view.toJSON(),size:e.cachedVisibleSize,visible:!1}:{type:"leaf",data:e.view.toJSON(),size:i}};class re{constructor(e,t,i){this.proportionalLayout=e,this.styles=t,this.disposable=new h,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.element=document.createElement("div"),this.element.className="grid-view",this.root=new K(i,e,t,0,0)}serialize(){return{root:ae(this.getView(),this.orientation),width:this.width,height:this.height,orientation:this.orientation}}dispose(){this.disposable.dispose(),this._onDidChange.dispose(),this.root.dispose()}clear(){const e=this.root.orientation;this.root=new K(e,this.proportionalLayout,this.styles,this.root.size,this.root.orthogonalSize)}deserialize(e,t){const i=e.orientation,n=e.height;this._deserialize(e.root,i,t,n)}_deserialize(e,t,i,n){this.root=this._deserializeNode(e,t,i,n)}_deserializeNode(e,t,i,n){let s;if("branch"===e.type){const o=e.data.map((n=>({node:this._deserializeNode(n,se(t),i,e.size),visible:n.visible})));s=new K(t,this.proportionalLayout,this.styles,e.size,n,o)}else s=new X(i.fromJSON(e),t,n,e.size);return s}get orientation(){return this.root.orientation}set orientation(e){if(this.root.orientation===e)return;const{size:t,orthogonalSize:i}=this.root;this.root=q(this.root,i,t),this.root.layout(t,i)}get root(){return this._root}set root(e){const t=this._root;t&&(t.dispose(),this.element.removeChild(t.element)),this._root=e,this.element.appendChild(this._root.element),this.disposable.value=this._root.onDidChange((e=>{this._onDidChange.fire(e)}))}next(e){return this.progmaticSelect(e)}previous(e){return this.progmaticSelect(e,!0)}getView(e){const t=e?this.getNode(e)[1]:this.root;return this._getViews(t,this.orientation)}_getViews(e,t,i){const n={height:e.height,width:e.width};if(e instanceof X)return{box:n,view:e.view,cachedVisibleSize:i};const s=[];for(let i=0;i<e.children.length;i++){const n=e.children[i],o=e.getChildCachedVisibleSize(i);s.push(this._getViews(n,se(t),o))}return{box:n,children:s}}progmaticSelect(e,t=!1){const[i,n]=this.getNode(e);if(!(n instanceof X))throw new Error("invalid location");const s=(e,t)=>{if(e instanceof X)return e;if(e instanceof K)return s(e.children[t?e.children.length-1:0],t);throw new Error("invalid node")};for(let n=i.length-1;n>-1;n--){const o=i[n],a=e[n]||0;if(t?a-1>-1:a+1<o.children.length)return s(o.children[t?a-1:a+1],t)}return s(this.root,t)}get width(){return this.root.width}get height(){return this.root.height}get minimumWidth(){return this.root.minimumWidth}get minimumHeight(){return this.root.minimumHeight}get maximumWidth(){return this.root.maximumHeight}get maximumHeight(){return this.root.maximumHeight}isViewVisible(e){const[t,i]=T(e),[,n]=this.getNode(t);if(!(n instanceof K))throw new Error("Invalid from location");return n.isChildVisible(i)}setViewVisible(e,t){const[i,n]=T(e),[,s]=this.getNode(i);if(!(s instanceof K))throw new Error("Invalid from location");s.setChildVisible(n,t)}moveView(e,t,i){const[,n]=this.getNode(e);if(!(n instanceof K))throw new Error("Invalid location");n.moveChild(t,i)}addView(e,t,i){const[n,s]=T(i),[o,a]=this.getNode(n);if(a instanceof K){const i=new X(e,se(a.orientation),a.orthogonalSize);a.addChild(i,t,s)}else{const[i,...r]=[...o].reverse(),[h,...d]=[...n].reverse();let l=0;const p=i.getChildCachedVisibleSize(h);"number"==typeof p&&(l=J.Invisible(p)),i.removeChild(h);const c=new K(a.orientation,this.proportionalLayout,this.styles,a.size,a.orthogonalSize);i.addChild(c,a.size,h);const m=new X(a.view,i.orientation,a.size);c.addChild(m,l,0),"number"!=typeof t&&"split"===t.type&&(t={type:"split",index:0});const u=new X(e,i.orientation,a.size);c.addChild(u,t,s)}}remove(e,t){const i=ee(e.element);return this.removeView(i,t)}removeView(e,t){const[i,n]=T(e),[s,o]=this.getNode(i);if(!(o instanceof K))throw new Error("Invalid location");const a=o.children[n];if(!(a instanceof X))throw new Error("Invalid location");if(o.removeChild(n,t),0===o.children.length)return a.view;if(o.children.length>1)return a.view;if(0===s.length){const e=o.children[0];return e instanceof X||(o.removeChild(0,t),this.root=e),a.view}const[r,...h]=[...s].reverse(),[d,...l]=[...i].reverse(),p=o.children[0],c=o.isChildVisible(0);o.removeChild(0,t);const m=r.children.map(((e,t)=>r.getChildSize(t)));if(r.removeChild(d,t),p instanceof K){m.splice(d,1,...p.children.map((e=>e.size)));for(let e=0;e<p.children.length;e++){const t=p.children[e];r.addChild(t,t.size,d+e)}}else{const e=new X(p.view,se(p.orientation),p.size),t=c?p.orthogonalSize:J.Invisible(p.orthogonalSize);r.addChild(e,t,d)}for(let e=0;e<m.length;e++)r.resizeChild(e,m[e]);return a.view}layout(e,t){const[i,n]=this.root.orientation===F.HORIZONTAL?[t,e]:[e,t];this.root.layout(i,n)}getNode(e,t=this.root,i=[]){if(0===e.length)return[i,t];if(!(t instanceof K))throw new Error("Invalid location");const[n,...s]=e;if(n<0||n>=t.children.length)throw new Error("Invalid location");const o=t.children[n];return i.push(t),this.getNode(s,o,i)}}
|
|
7
|
+
import*as e from"react";import*as t from"react-dom";var i,n;!function(e,t){void 0===t&&(t={});var i=t.insertAt;if(e&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],s=document.createElement("style");s.type="text/css","top"===i&&n.firstChild?n.insertBefore(s,n.firstChild):n.appendChild(s),s.styleSheet?s.styleSheet.cssText=e:s.appendChild(document.createTextNode(e))}}('.dockview-theme-dark {\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-tab-close-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>\');\n --dv-tab-dirty-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2z"/></svg>\');\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-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-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-tab-close-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>\');\n --dv-tab-dirty-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2z"/></svg>\');\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-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-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-tab-close-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>\');\n --dv-tab-dirty-icon: url(\'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0z" fill="none"/><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2z"/></svg>\');\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-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-activegroup-visiblepanel-tab-background-color: dodgerblue;\n --dv-tabs-and-actions-container-height: 18px;\n --dv-tabs-and-actions-container-font-size: 11px;\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container {\n border-bottom: 2px solid var(--dv-activegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container {\n border-bottom: 2px solid var(--dv-inactivegroup-visiblepanel-tab-background-color);\n}\n.actions-bar {\n text-align: right;\n width: 28px;\n display: flex;\n align-items: center;\n flex-shrink: 0;\n}\n.actions-bar .actions-container {\n display: flex;\n padding: 0px;\n margin: 0px;\n justify-content: flex-end;\n}\n.actions-bar .actions-container a:active {\n -webkit-mask-size: 100% 100% !important;\n mask-size: 100% 100% !important;\n}\n.actions-bar .actions-container .close-action {\n background-color: white;\n height: 16px;\n width: 16px;\n display: block;\n -webkit-mask: var(--dv-tab-close-icon) 50% 50%/90% 90% no-repeat;\n mask: var(--dv-tab-close-icon) 50% 50%/90% 90% no-repeat;\n margin-right: "0.5em";\n cursor: pointer;\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: 10000;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection {\n position: relative;\n pointer-events: none;\n box-sizing: border-box;\n height: 100%;\n width: 100%;\n background-color: var(--dv-drag-over-background-color);\n transition-duration: 0.15s;\n transition-timing-function: ease-out;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.left, .drop-target > .drop-target-dropzone > .drop-target-selection.right {\n width: 50%;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.right {\n transform: translate(100%, 0%);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.bottom {\n transform: translate(0%, 100%);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.top, .drop-target > .drop-target-dropzone > .drop-target-selection.bottom {\n height: 50%;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-top {\n border-top: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-bottom {\n border-bottom: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-left {\n border-left: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-right {\n border-right: 1px solid var(--dv-drag-over-border-color);\n}\n.custom-dragging {\n height: 24px;\n line-height: 24px;\n font-size: 11px;\n width: 100px;\n background-color: dodgerblue;\n color: ghostwhite;\n border-radius: 11px;\n position: absolute;\n padding-left: 10px;\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.active-tab .tab-action {\n background-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.active-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab .tab-action {\n background-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.active-tab .tab-action {\n background-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.groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab .tab-action {\n background-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.dragging {\n background-color: var(--dv-activegroup-visiblepanel-tab-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.grid-view,\n.branch-node {\n height: 100%;\n width: 100%;\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 overflow: hidden;\n outline: none;\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}\n.pane-container .view .default-header > span {\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.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 .void-container {\n display: flex;\n flex-grow: 1;\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.split-view-container {\n position: relative;\n overflow: hidden;\n height: 100%;\n width: 100%;\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}\n.split-view-container .sash-container .sash: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: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}\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.dragged {\n transform: translate3d(0px, 0px, 0px);\n /* 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.dragging .tab-action {\n background-color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.tab.active-tab > .default-tab .tab-action {\n visibility: visible;\n}\n.tab.inactive-tab > .default-tab .tab-action:not(.dirty) {\n visibility: hidden;\n}\n.tab.inactive-tab > .default-tab:hover .tab-action {\n visibility: visible;\n}\n.tab .default-tab {\n position: relative;\n height: 100%;\n display: flex;\n min-width: 80px;\n align-items: center;\n padding-left: 10px;\n white-space: nowrap;\n text-overflow: elipsis;\n}\n.tab .default-tab .tab-content {\n flex-grow: 1;\n}\n.tab .default-tab .action-container {\n text-align: right;\n width: 28px;\n display: flex;\n}\n.tab .default-tab .action-container .tab-list {\n display: flex;\n padding: 0px;\n margin: 0px;\n justify-content: flex-end;\n}\n.tab .default-tab .action-container .tab-list a:active:hover {\n -webkit-mask-size: 100% 100% !important;\n mask-size: 100% 100% !important;\n}\n.tab .default-tab .action-container .tab-list .tab-action {\n height: 16px;\n width: 16px;\n display: block;\n -webkit-mask: var(--dv-tab-close-icon) 50% 50%/90% 90% no-repeat;\n mask: var(--dv-tab-close-icon) 50% 50%/90% 90% no-repeat;\n margin-right: "0.5em";\n}\n.tab .default-tab .action-container .tab-list .tab-action.disable-close {\n display: none;\n}\n.tab .default-tab .action-container .tab-list .tab-action.dirty:not(:hover) {\n display: block;\n -webkit-mask: var(--dv-tab-dirty-icon) 50% 50%/60% 60% no-repeat;\n mask: var(--dv-tab-dirty-icon) 50% 50%/60% 60% no-repeat;\n}\n.watermark {\n display: flex;\n width: 100%;\n}\n.watermark.has-actions .watermark-title .actions-bar {\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}'),function(e){e.any=(...e)=>t=>{const i=e.map((e=>e(t)));return{dispose:()=>{i.forEach((e=>{e.dispose()}))}}}}(i||(i={}));class s{constructor(e){this.options=e,this._listeners=[],this._disposed=!1}get event(){return this._event||(this._event=e=>{var t;return(null===(t=this.options)||void 0===t?void 0:t.replay)&&void 0!==this._last&&e(this._last),this._listeners.length,this._listeners.push(e),{dispose:()=>{const t=this._listeners.indexOf(e);t>-1&&this._listeners.splice(t,1)}}}),this._event}fire(e){this._last=e,this._listeners.forEach((t=>{t(e)}))}dispose(){this._listeners=[],this._disposed=!0}}function o(e,t,i,n){return e.addEventListener(t,i,n),{dispose:()=>{e.removeEventListener(t,i)}}}function a(e,t,i,n){return e.addEventListener(t,i,n),{dispose:()=>{e.removeEventListener(t,i)}}}!function(e){e.NONE={dispose:()=>{}}}(n||(n={}));class r{constructor(...e){this.disposables=e}static from(...e){return new r(...e)}addDisposables(...e){null==e||e.forEach((e=>this.disposables.push(e)))}dispose(){this.disposables.forEach((e=>e.dispose()))}}class h{constructor(){this._disposable=n.NONE}set value(e){this._disposable&&this._disposable.dispose(),this._disposable=e}dispose(){this._disposable&&this._disposable.dispose()}}class d{constructor(){}}class l extends d{constructor(e,t,i){super(),this.viewId=e,this.groupId=t,this.panelId=i}}class p extends d{constructor(e,t){super(),this.viewId=e,this.paneId=t}}const c="splitview/transfer",m=e=>!!e.dataTransfer&&e.dataTransfer.types.includes(c);var u;!function(e){e.DOCKVIEW_TAB="dockview_tab",e.EXTERNAL="external_group_drag"}(u||(u={}));const v=e=>e.type===u.DOCKVIEW_TAB,g=e=>e.type===u.EXTERNAL,w=e=>{if(!e.dataTransfer)return null;const t=function(e,t){try{return JSON.parse(e,t)}catch(e){return void console.warn("failed to parse JSON")}}(e.dataTransfer.getData(c));return t||console.warn(`[dragEvent] ${c} data is missing`),"string"!=typeof t.type&&console.warn(`[dragEvent] invalid type ${t.type}`),t};class b{constructor(){}static getInstance(){return b.INSTANCE}hasData(e){return e&&e===this.proto}clearData(e){this.hasData(e)&&(this.proto=void 0,this.data=void 0)}getData(e){if(this.hasData(e))return this.data}setData(e,t){t&&(this.data=e,this.proto=t)}}function f(){const e=b.getInstance();if(e.hasData(l.prototype))return e.getData(l.prototype)[0]}function _(){const e=b.getInstance();if(e.hasData(p.prototype))return e.getData(p.prototype)[0]}b.INSTANCE=new b;class C{constructor(e){this.component=e}get minimumSize(){return this.component.minimumSize}get maximumSize(){return this.component.maximumSize}get height(){return this.component.height}get width(){return this.component.width}get length(){return this.component.length}get onDidLayoutChange(){return this.component.onDidLayoutChange}get orientation(){return this.component.orientation}updateOptions(e){this.component.updateOptions(e)}removePanel(e,t){this.component.removePanel(e,t)}setVisible(e,t){this.component.setVisible(e,t)}getPanels(){return this.component.getPanels()}focus(){this.component.focus()}getPanel(e){return this.component.getPanel(e)}setActive(e){this.component.setActive(e)}layout(e,t){return this.component.layout(e,t)}addPanel(e){this.component.addPanel(e)}resizeToFit(){this.component.resizeToFit()}movePanel(e,t){this.component.movePanel(e,t)}fromJSON(e,t){this.component.fromJSON(e,t)}toJSON(){return this.component.toJSON()}}class y{constructor(e){this.component=e}get width(){return this.component.width}get height(){return this.component.height}get minimumSize(){return this.component.minimumSize}get maximumSize(){return this.component.maximumSize}get onDidLayoutChange(){return this.component.onDidLayoutChange}getPanels(){return this.component.getPanels()}removePanel(e){this.component.removePanel(e)}getPanel(e){return this.component.getPanel(e)}movePanel(e,t){this.component.movePanel(e,t)}focus(){this.component.focus()}layout(e,t){this.component.layout(e,t)}addPanel(e){return this.component.addPanel(e)}resizeToFit(){this.component.resizeToFit()}fromJSON(e,t){this.component.fromJSON(e,t)}toJSON(){return this.component.toJSON()}}class z{constructor(e){this.component=e}get width(){return this.component.width}get height(){return this.component.height}get minimumHeight(){return this.component.minimumHeight}get maximumHeight(){return this.component.maximumHeight}get minimumWidth(){return this.component.minimumWidth}get maximumWidth(){return this.component.maximumWidth}get onGridEvent(){return this.component.onGridEvent}get onDidLayoutChange(){return this.component.onDidLayoutChange}get panels(){return this.component.groups}get orientation(){return this.component.orientation}set orientation(e){this.component.updateOptions({orientation:e})}focus(){this.component.focus()}layout(e,t,i=!1){this.component.layout(e,t,i)}addPanel(e){this.component.addPanel(e)}removePanel(e,t){this.component.removePanel(e,t)}movePanel(e,t){this.component.movePanel(e,t)}resizeToFit(){this.component.resizeToFit()}getPanel(e){return this.component.getPanel(e)}toggleVisibility(e){this.component.toggleVisibility(e)}setVisible(e,t){this.component.setVisible(e,t)}setActive(e){this.component.setActive(e)}fromJSON(e,t){return this.component.fromJSON(e,t)}toJSON(){return this.component.toJSON()}}class x{constructor(e){this.component=e}get width(){return this.component.width}get height(){return this.component.height}get minimumHeight(){return this.component.minimumHeight}get maximumHeight(){return this.component.maximumHeight}get minimumWidth(){return this.component.minimumWidth}get maximumWidth(){return this.component.maximumWidth}get size(){return this.component.size}get totalPanels(){return this.component.totalPanels}get onGridEvent(){return this.component.onGridEvent}get onDidLayoutChange(){return this.component.onDidLayoutChange}get panels(){return this.component.panels}get groups(){return this.component.groups}get activePanel(){return this.component.activePanel}get activeGroup(){return this.component.activeGroup}getTabHeight(){return this.component.tabHeight}setTabHeight(e){this.component.tabHeight=e}focus(){this.component.focus()}getPanel(e){return this.component.getGroupPanel(e)}setActivePanel(e){this.component.setActivePanel(e)}layout(e,t,i=!1){this.component.layout(e,t,i)}addPanel(e){return this.component.addPanel(e)}removePanel(e){this.component.removePanel(e)}addEmptyGroup(e){this.component.addEmptyGroup(e)}moveToNext(e){this.component.moveToNext(e)}moveToPrevious(e){this.component.moveToPrevious(e)}closeAllGroups(){return this.component.closeAllGroups()}removeGroup(e){this.component.removeGroup(e)}resizeToFit(){return this.component.resizeToFit()}getGroup(e){return this.component.getPanel(e)}fromJSON(e){this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}}function D(e,t){const i=new ResizeObserver((e=>{const i=e[0];t(i)}));return i.observe(e),{dispose:()=>{i.unobserve(e),i.disconnect()}}}const E=(e,...t)=>{for(const i of t)e.classList.contains(i)&&e.classList.remove(i)},S=(e,...t)=>{for(const i of t)e.classList.contains(i)||e.classList.add(i)},A=(e,t,i)=>{const n=e.classList.contains(t);i&&!n&&e.classList.add(t),!i&&n&&e.classList.remove(t)};function P(e,t){for(;e;){if(e===t)return!0;e=e.parentNode}return!1}function O(e){return Array.prototype.slice.call(document.getElementsByTagName(e),0)}function N(e){return new I(e)}class I extends r{constructor(e){super(),this._onDidFocus=new s,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new s,this.onDidBlur=this._onDidBlur.event;let t=P(document.activeElement,e),i=!1;const n=()=>{i=!1,t||(t=!0,this._onDidFocus.fire())},r=()=>{t&&(i=!0,window.setTimeout((()=>{i&&(i=!1,t=!1,this._onDidBlur.fire())}),0))};this._refreshStateHandler=()=>{P(document.activeElement,e)!==t&&(t?r():n())},e instanceof HTMLElement?(this.addDisposables(a(e,"focus",n,!0)),this.addDisposables(a(e,"blur",r,!0))):(this.addDisposables(o(e,"focus",n,!0)),this.addDisposables(o(e,"blur",r,!0)))}refreshState(){this._refreshStateHandler()}dispose(){super.dispose(),this._onDidBlur.dispose(),this._onDidFocus.dispose()}}const k=(e,t,i)=>{if(t>i)throw new Error(`${t} > ${i} is an invalid condition`);return Math.min(i,Math.max(e,t))},V=()=>{let e=1;return{next:()=>(e++).toString()}};function T(e){if(0===e.length)throw new Error("Invalid tail call");return[e.slice(0,e.length-1),e[e.length-1]]}function L(e,t){if(e.length!==t.length)return!1;for(let i=0;i<e.length;i++)if(e[i]!==t[i])return!1;return!0}function G(e,t){const i=e.indexOf(t);i>-1&&(e.splice(i,1),e.unshift(t))}function R(e,t){const i=e.indexOf(t);i>-1&&(e.splice(i,1),e.push(t))}const H=(e,t)=>{const i=[];if("number"!=typeof t&&(t=e,e=0),e<=t)for(let n=e;n<t;n++)i.push(n);else for(let n=e;n>t;n--)i.push(n);return i};class M{constructor(e,t,i,n){this.container=e,this.view=t,this.disposable=n,this._cachedVisibleSize=void 0,"number"==typeof i?(this._size=i,this._cachedVisibleSize=void 0,e.classList.add("visible")):(this._size=0,this._cachedVisibleSize=i.cachedVisibleSize)}set size(e){this._size=e}get size(){return this._size}get cachedVisibleSize(){return this._cachedVisibleSize}get visible(){return void 0===this._cachedVisibleSize}setVisible(e,t){var i;e!==this.visible&&(e?(this.size=k(null!==(i=this._cachedVisibleSize)&&void 0!==i?i:0,this.viewMinimumSize,this.viewMaximumSize),this._cachedVisibleSize=void 0):(this._cachedVisibleSize="number"==typeof t?t:this.size,this.size=0),this.container.classList.toggle("visible",e),this.view.setVisible&&this.view.setVisible(e))}get minimumSize(){return this.visible?this.view.minimumSize:0}get viewMinimumSize(){return this.view.minimumSize}get maximumSize(){return this.visible?this.view.maximumSize:0}get viewMaximumSize(){return this.view.maximumSize}get priority(){return this.view.priority}get snap(){return!!this.view.snap}set enabled(e){this.container.style.pointerEvents=e?"":"none"}dispose(){return this.disposable.dispose(),this.view}}var F,W,B,J,U;!function(e){e.HORIZONTAL="HORIZONTAL",e.VERTICAL="VERTICAL"}(F||(F={})),function(e){e[e.MAXIMUM=0]="MAXIMUM",e[e.MINIMUM=1]="MINIMUM",e[e.DISABLED=2]="DISABLED",e[e.ENABLED=3]="ENABLED"}(W||(W={})),function(e){e.Low="low",e.High="high",e.Normal="normal"}(B||(B={})),function(e){e.Distribute={type:"distribute"},e.Split=function(e){return{type:"split",index:e}},e.Invisible=function(e){return{type:"invisible",cachedVisibleSize:e}}}(J||(J={}));class j{constructor(e,t){this.container=e,this.views=[],this.sashes=[],this._size=0,this._orthogonalSize=0,this.contentSize=0,this._proportions=void 0,this._onDidSashEnd=new s,this.onDidSashEnd=this._onDidSashEnd.event,this._onDidAddView=new s,this.onDidAddView=this._onDidAddView.event,this._onDidRemoveView=new s,this.onDidRemoveView=this._onDidAddView.event,this._startSnappingEnabled=!0,this._endSnappingEnabled=!0,this.resize=(e,t,i=this.views.map((e=>e.size)),n,s,o=Number.NEGATIVE_INFINITY,a=Number.POSITIVE_INFINITY,r,h)=>{if(e<0||e>this.views.length)return 0;const d=H(e,-1),l=H(e+1,this.views.length);if(s)for(const e of s)G(d,e),G(l,e);if(n)for(const e of n)R(d,e),R(l,e);const p=d.map((e=>this.views[e])),c=d.map((e=>i[e])),m=l.map((e=>this.views[e])),u=l.map((e=>i[e])),v=d.reduce(((e,t)=>e+this.views[t].minimumSize-i[t]),0),g=d.reduce(((e,t)=>e+this.views[t].maximumSize-i[t]),0),w=0===l.length?Number.POSITIVE_INFINITY:l.reduce(((e,t)=>e+i[t]-this.views[t].minimumSize),0),b=0===l.length?Number.NEGATIVE_INFINITY:l.reduce(((e,t)=>e+i[t]-this.views[t].maximumSize),0),f=Math.max(v,b),_=Math.min(w,g);let C=!1;if(r){const e=this.views[r.index],i=t>=r.limitDelta;C=i!==e.visible,e.setVisible(i,r.size)}if(!C&&h){const e=this.views[h.index],i=t<h.limitDelta;C=i!==e.visible,e.setVisible(i,h.size)}if(C)return this.resize(e,t,i,n,s,o,a);let y=0,z=k(t,f,_);for(let e=0;e<p.length;e++){const t=p[e],i=k(c[e]+z,t.minimumSize,t.maximumSize),n=i-c[e];y+=n,z-=n,t.size=i}let x=y;for(let e=0;e<m.length;e++){const t=m[e],i=k(u[e]-x,t.minimumSize,t.maximumSize);x+=i-u[e],t.size=i}return t},this._orientation=t.orientation,this.element=this.createContainer(),this.proportionalLayout=void 0===t.proportionalLayout||!!t.proportionalLayout,this.viewContainer=this.createViewContainer(),this.sashContainer=this.createSashContainer(),this.element.appendChild(this.sashContainer),this.element.appendChild(this.viewContainer),this.container.appendChild(this.element),this.style(t.styles),t.descriptor&&(this._size=t.descriptor.size,t.descriptor.views.forEach(((e,t)=>{const i=void 0===e.visible||e.visible?e.size:{type:"invisible",cachedVisibleSize:e.size},n=e.view;this.addView(n,i,t,!0)})),this.contentSize=this.views.reduce(((e,t)=>e+t.size),0),this.saveProportions())}get size(){return this._size}set size(e){this._size=e}get orthogonalSize(){return this._orthogonalSize}set orthogonalSize(e){this._orthogonalSize=e}get length(){return this.views.length}get proportions(){return this._proportions?[...this._proportions]:void 0}get orientation(){return this._orientation}set orientation(e){this._orientation=e;const t=this.size;this.size=this.orthogonalSize,this.orthogonalSize=t,E(this.element,"horizontal","vertical"),this.element.classList.add(this.orientation==F.HORIZONTAL?"horizontal":"vertical")}get minimumSize(){return this.views.reduce(((e,t)=>e+t.minimumSize),0)}get maximumSize(){return 0===this.length?Number.POSITIVE_INFINITY:this.views.reduce(((e,t)=>e+t.maximumSize),0)}get startSnappingEnabled(){return this._startSnappingEnabled}set startSnappingEnabled(e){this._startSnappingEnabled!==e&&(this._startSnappingEnabled=e,this.updateSashEnablement())}get endSnappingEnabled(){return this._endSnappingEnabled}set endSnappingEnabled(e){this._endSnappingEnabled!==e&&(this._endSnappingEnabled=e,this.updateSashEnablement())}style(e){"transparent"===(null==e?void 0:e.separatorBorder)?(E(this.element,"separator-border"),this.element.style.removeProperty("--dv-separator-border")):(S(this.element,"separator-border"),(null==e?void 0:e.separatorBorder)&&this.element.style.setProperty("--dv-separator-border",e.separatorBorder))}isViewVisible(e){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");return this.views[e].visible}setViewVisible(e,t){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");A(this.container,"visible",t);const i=this.views[e];A(this.container,"visible",t),i.setVisible(t,i.size),this.distributeEmptySpace(e),this.layoutViews(),this.saveProportions()}getViewSize(e){return e<0||e>=this.views.length?-1:this.views[e].size}resizeView(e,t){if(e<0||e>=this.views.length)return;const i=H(this.views.length).filter((t=>t!==e)),n=[...i.filter((e=>this.views[e].priority===B.Low)),e],s=i.filter((e=>this.views[e].priority===B.High)),o=this.views[e];t=Math.round(t),t=k(t,o.minimumSize,Math.min(o.maximumSize,this._size)),o.size=t,this.relayout(n,s)}getViews(){return this.views.map((e=>e.view))}onDidChange(e,t){const i=this.views.indexOf(e);i<0||i>=this.views.length||(t="number"==typeof t?t:e.size,t=k(t,e.minimumSize,e.maximumSize),e.size=t,this.relayout([i]))}addView(e,t={type:"distribute"},i=this.views.length,n){const s=document.createElement("div");let o;s.className="view",s.appendChild(e.element),o="number"==typeof t?t:"split"===t.type?this.getViewSize(t.index)/2:"invisible"===t.type?{cachedVisibleSize:t.cachedVisibleSize}:e.minimumSize;const a=e.onDidChange((e=>this.onDidChange(r,e))),r=new M(s,e,o,{dispose:()=>{null==a||a.dispose(),this.viewContainer.removeChild(s)}});if(i===this.views.length?this.viewContainer.appendChild(s):this.viewContainer.insertBefore(s,this.viewContainer.children.item(i)),this.views.splice(i,0,r),this.views.length>1){const e=document.createElement("div");e.className="sash";const t=t=>{for(const e of this.views)e.enabled=!1;const i=[...O("iframe"),...O("webview")];for(const e of i)e.style.pointerEvents="none";const n=this._orientation===F.HORIZONTAL?t.clientX:t.clientY,s=function(e,t){for(let i=0;i<e.length;i++)if(t(e[i]))return i;return-1}(this.sashes,(t=>t.container===e)),o=this.views.map((e=>e.size));let a,r;const h=H(s,-1),d=H(s+1,this.views.length),l=h.reduce(((e,t)=>e+(this.views[t].minimumSize-o[t])),0),p=h.reduce(((e,t)=>e+(this.views[t].viewMaximumSize-o[t])),0),c=0===d.length?Number.POSITIVE_INFINITY:d.reduce(((e,t)=>e+(o[t]-this.views[t].minimumSize)),0),m=0===d.length?Number.NEGATIVE_INFINITY:d.reduce(((e,t)=>e+(o[t]-this.views[t].viewMaximumSize)),0),u=Math.max(l,m),v=Math.min(c,p),g=this.findFirstSnapIndex(h),w=this.findFirstSnapIndex(d);if("number"==typeof g){const e=this.views[g],t=Math.floor(e.viewMinimumSize/2);a={index:g,limitDelta:e.visible?u-t:u+t,size:e.size}}if("number"==typeof w){const e=this.views[w],t=Math.floor(e.viewMinimumSize/2);r={index:w,limitDelta:e.visible?v+t:v-t,size:e.size}}const b=e=>{const t=(this._orientation===F.HORIZONTAL?e.clientX:e.clientY)-n;this.resize(s,t,o,void 0,void 0,u,v,a,r),this.distributeEmptySpace(),this.layoutViews()},f=()=>{for(const e of this.views)e.enabled=!0;for(const e of i)e.style.pointerEvents="auto";this.saveProportions(),document.removeEventListener("mousemove",b),document.removeEventListener("mouseup",f),document.removeEventListener("mouseend",f),this._onDidSashEnd.fire(void 0)};document.addEventListener("mousemove",b),document.addEventListener("mouseup",f),document.addEventListener("mouseend",f)};e.addEventListener("mousedown",t);const i={container:e,disposable:()=>{e.removeEventListener("mousedown",t),this.sashContainer.removeChild(e)}};this.sashContainer.appendChild(e),this.sashes.push(i)}n||this.relayout([i]),n||"number"==typeof t||"distribute"!==t.type||this.distributeViewSizes(),this._onDidAddView.fire(e)}distributeViewSizes(){const e=[];let t=0;for(const i of this.views)i.maximumSize-i.minimumSize>0&&(e.push(i),t+=i.size);const i=Math.floor(t/e.length);for(const t of e)t.size=k(i,t.minimumSize,t.maximumSize);const n=H(this.views.length),s=n.filter((e=>this.views[e].priority===B.Low)),o=n.filter((e=>this.views[e].priority===B.High));this.relayout(s,o)}removeView(e,t,i=!1){const n=this.views.splice(e,1)[0];if(n.dispose(),this.views.length>=1){const t=Math.max(e-1,0);this.sashes.splice(t,1)[0].disposable()}return i||this.relayout(),t&&"distribute"===t.type&&this.distributeViewSizes(),this._onDidRemoveView.fire(n.view),n.view}getViewCachedVisibleSize(e){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");return this.views[e].cachedVisibleSize}moveView(e,t){const i=this.getViewCachedVisibleSize(e),n=void 0===i?this.getViewSize(e):J.Invisible(i),s=this.removeView(e,void 0,!0);this.addView(s,n,t)}layout(e,t){const i=Math.max(this.size,this.contentSize);if(this.size=e,this.orthogonalSize=t,this.proportions)for(let t=0;t<this.views.length;t++){const i=this.views[t];i.size=k(Math.round(this.proportions[t]*e),i.minimumSize,i.maximumSize)}else{const t=H(this.views.length),n=t.filter((e=>this.views[e].priority===B.Low)),s=t.filter((e=>this.views[e].priority===B.High));this.resize(this.views.length-1,e-i,void 0,n,s)}this.distributeEmptySpace(),this.layoutViews()}relayout(e,t){const i=this.views.reduce(((e,t)=>e+t.size),0);this.resize(this.views.length-1,this._size-i,void 0,e,t),this.distributeEmptySpace(),this.layoutViews(),this.saveProportions()}distributeEmptySpace(e){const t=this.views.reduce(((e,t)=>e+t.size),0);let i=this.size-t;const n=H(this.views.length-1,-1),s=n.filter((e=>this.views[e].priority===B.Low)),o=n.filter((e=>this.views[e].priority===B.High));for(const e of o)G(n,e);for(const e of s)R(n,e);"number"==typeof e&&R(n,e);for(let e=0;0!==i&&e<n.length;e++){const t=this.views[n[e]],s=k(t.size+i,t.minimumSize,t.maximumSize);i-=s-t.size,t.size=s}}saveProportions(){this.proportionalLayout&&this.contentSize>0&&(this._proportions=this.views.map((e=>e.size/this.contentSize)))}layoutViews(){this.contentSize=this.views.reduce(((e,t)=>e+t.size),0);let e=0;const t=[];this.updateSashEnablement();for(let i=0;i<this.views.length-1;i++){e+=this.views[i].size,t.push(e);const n=Math.min(Math.max(0,e-2),this.size-4);this._orientation===F.HORIZONTAL&&(this.sashes[i].container.style.left=`${n}px`,this.sashes[i].container.style.top="0px"),this._orientation===F.VERTICAL&&(this.sashes[i].container.style.left="0px",this.sashes[i].container.style.top=`${n}px`)}this.views.forEach(((e,i)=>{this._orientation===F.HORIZONTAL&&(e.container.style.width=`${e.size}px`,e.container.style.left=0==i?"0px":`${t[i-1]}px`,e.container.style.top="",e.container.style.height=""),this._orientation===F.VERTICAL&&(e.container.style.height=`${e.size}px`,e.container.style.top=0==i?"0px":`${t[i-1]}px`,e.container.style.width="",e.container.style.left=""),e.view.layout(e.size,this._orthogonalSize)}))}findFirstSnapIndex(e){for(const t of e){const e=this.views[t];if(e.visible&&e.snap)return t}for(const t of e){const e=this.views[t];if(e.visible&&e.maximumSize-e.minimumSize>0)return;if(!e.visible&&e.snap)return t}}updateSashEnablement(){let e=!1;const t=this.views.map((t=>e=t.size-t.minimumSize>0||e));e=!1;const i=this.views.map((t=>e=t.maximumSize-t.size>0||e)),n=[...this.views].reverse();e=!1;const s=n.map((t=>e=t.size-t.minimumSize>0||e)).reverse();e=!1;const o=n.map((t=>e=t.maximumSize-t.size>0||e)).reverse();let a=0;for(let e=0;e<this.sashes.length;e++){const n=this.sashes[e];a+=this.views[e].size;const r=!(t[e]&&o[e+1]),h=!(i[e]&&s[e+1]);if(r&&h){const i=H(e,-1),o=H(e+1,this.views.length),r=this.findFirstSnapIndex(i),h=this.findFirstSnapIndex(o),d="number"==typeof r&&!this.views[r].visible,l="number"==typeof h&&!this.views[h].visible;d&&s[e]&&(a>0||this.startSnappingEnabled)?this.updateSash(n,W.MINIMUM):l&&t[e]&&(a<this.contentSize||this.endSnappingEnabled)?this.updateSash(n,W.MAXIMUM):this.updateSash(n,W.DISABLED)}else r&&!h?this.updateSash(n,W.MINIMUM):!r&&h?this.updateSash(n,W.MAXIMUM):this.updateSash(n,W.ENABLED)}}updateSash(e,t){A(e.container,"disabled",t===W.DISABLED),A(e.container,"enabled",t===W.ENABLED),A(e.container,"maximum",t===W.MAXIMUM),A(e.container,"minimum",t===W.MINIMUM)}createViewContainer(){const e=document.createElement("div");return e.className="view-container",e}createSashContainer(){const e=document.createElement("div");return e.className="sash-container",e}createContainer(){const e=document.createElement("div"),t=this._orientation===F.HORIZONTAL?"horizontal":"vertical";return e.className=`split-view-container ${t}`,e}dispose(){this._onDidSashEnd.dispose(),this._onDidAddView.dispose(),this._onDidRemoveView.dispose(),this.element.remove();for(let e=0;e<this.element.children.length;e++)if(this.element.children.item(e)===this.element){this.element.removeChild(this.element);break}}}class $ extends r{constructor(e,t){var i;super(),this.paneItems=[],this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.skipAnimation=!1,this._orientation=null!==(i=t.orientation)&&void 0!==i?i:F.VERTICAL,this.element=document.createElement("div"),this.element.className="pane-container",e.appendChild(this.element),this.splitview=new j(this.element,{orientation:this._orientation,proportionalLayout:!1,descriptor:t.descriptor}),this.getPanes().forEach(((e,t)=>{const i=new r(e.onDidChangeExpansionState((()=>{this.setupAnimation(),this._onDidChange.fire(void 0)}))),n={pane:e,disposable:{dispose:()=>{i.dispose()}}};this.paneItems.push(n),e.orthogonalSize=this.splitview.orthogonalSize})),this.addDisposables(this.splitview.onDidSashEnd((()=>{this._onDidChange.fire(void 0)})),this.splitview.onDidAddView((()=>{this._onDidChange.fire()})),this.splitview.onDidRemoveView((()=>{this._onDidChange.fire()})))}get onDidAddView(){return this.splitview.onDidAddView}get onDidRemoveView(){return this.splitview.onDidRemoveView}get minimumSize(){return this.splitview.minimumSize}get maximumSize(){return this.splitview.maximumSize}get orientation(){return this.splitview.orientation}get size(){return this.splitview.size}get orthogonalSize(){return this.splitview.orthogonalSize}addPane(e,t,i=this.splitview.length,n=!1){const s=e.onDidChangeExpansionState((()=>{this.setupAnimation(),this._onDidChange.fire(void 0)})),o={pane:e,disposable:{dispose:()=>{s.dispose()}}};this.paneItems.splice(i,0,o),e.orthogonalSize=this.splitview.orthogonalSize,this.splitview.addView(e,t,i,n)}getViewSize(e){return this.splitview.getViewSize(e)}getPanes(){return this.splitview.getViews()}removePane(e){const t=this.paneItems.splice(e,1)[0];return this.splitview.removeView(e),t.disposable.dispose(),t}moveView(e,t){if(e===t)return;const i=this.removePane(e);this.skipAnimation=!0;try{this.addPane(i.pane,i.pane.size,t,!1)}finally{this.skipAnimation=!1}}layout(e,t){this.splitview.layout(e,t)}setupAnimation(){this.skipAnimation||(this.animationTimer&&(clearTimeout(this.animationTimer),this.animationTimer=void 0),S(this.element,"animated"),this.animationTimer=setTimeout((()=>{this.animationTimer=void 0,E(this.element,"animated")}),200))}dispose(){super.dispose(),this.splitview.dispose(),this.animationTimer&&(clearTimeout(this.animationTimer),this.animationTimer=void 0),this.paneItems.forEach((e=>{e.disposable.dispose()})),this.paneItems=[],this.element.remove()}}class Z extends r{constructor(e,t){super(),this.element=e,this.callbacks=t,this.counter=0,this.registerListeners()}registerListeners(){this.addDisposables(a(this.element,"dragenter",(e=>{this.counter++,this.callbacks.onDragEnter(e)}))),this.addDisposables(a(this.element,"dragover",(e=>{e.preventDefault(),this.callbacks.onDragOver&&this.callbacks.onDragOver(e)}))),this.addDisposables(a(this.element,"dragleave",(e=>{this.counter--,0===this.counter&&this.callbacks.onDragLeave(e)}))),this.addDisposables(a(this.element,"dragend",(e=>{this.counter=0,this.callbacks.onDragEnd(e)}))),this.addDisposables(a(this.element,"drop",(e=>{this.counter=0,this.callbacks.onDrop(e)})))}}!function(e){e.Top="Top",e.Left="Left",e.Bottom="Bottom",e.Right="Right",e.Center="Center"}(U||(U={}));class Y extends r{constructor(e,t){super(),this.element=e,this.options=t,this._onDrop=new s,this.onDrop=this._onDrop.event,this.addDisposables(new Z(this.element,{onDragEnter:e=>{},onDragOver:e=>{if("boolean"==typeof this.options.canDisplayOverlay){if(!this.options.canDisplayOverlay)return}else if(!this.options.canDisplayOverlay(e))return;if(this.target||(this.target=document.createElement("div"),this.target.className="drop-target-dropzone",this.overlay=document.createElement("div"),this.overlay.className="drop-target-selection",this._state=U.Center,this.target.appendChild(this.overlay),this.element.classList.add("drop-target"),this.element.append(this.target)),"none"===this.options.validOverlays)return;if(!this.target||!this.overlay)return;const t=this.target.clientWidth,i=this.target.clientHeight;if(0===t||0===i)return;const n=100*e.offsetX/t,s=100*e.offsetY/i;let o=!1,a=!1,r=!1,h=!1;switch(this.options.validOverlays){case"all":o=n>80,a=n<20,r=!o&&!a&&s<20,h=!o&&!a&&s>80;break;case"vertical":r=s<50,h=s>=50;break;case"horizontal":a=n<50,o=n>=50}const d=t<100,l=i<100;A(this.overlay,"right",!d&&o),A(this.overlay,"left",!d&&a),A(this.overlay,"top",!l&&r),A(this.overlay,"bottom",!l&&h),A(this.overlay,"small-right",d&&o),A(this.overlay,"small-left",d&&a),A(this.overlay,"small-top",l&&r),A(this.overlay,"small-bottom",l&&h),this._state=o?U.Right:a?U.Left:r?U.Top:h?U.Bottom:U.Center},onDragLeave:e=>{this.removeDropTarget()},onDragEnd:e=>{this.removeDropTarget()},onDrop:e=>{e.preventDefault(),e.stopPropagation();const t=this._state;this.removeDropTarget(),t&&this._onDrop.fire({position:t,event:e})}}))}get state(){return this._state}set validOverlays(e){this.options.validOverlays=e}set canDisplayOverlay(e){this.options.canDisplayOverlay=e}dispose(){this._onDrop.dispose(),this.removeDropTarget()}removeDropTarget(){this.target&&(this._state=void 0,this.element.removeChild(this.target),this.target=void 0,this.element.classList.remove("drop-target"))}}class X{constructor(e,t,i,n=0){this.view=e,this.orientation=t,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this._orthogonalSize=i,this._size=n,this._disposable=this.view.onDidChange((e=>{e?this._onDidChange.fire(this.orientation===F.VERTICAL?e.width:e.height):this._onDidChange.fire(void 0)}))}get minimumWidth(){return this.view.minimumWidth}get maximumWidth(){return this.view.maximumWidth}get minimumHeight(){return this.view.minimumHeight}get maximumHeight(){return this.view.maximumHeight}get priority(){return this.view.priority}get snap(){return this.view.snap}get minimumSize(){return this.orientation===F.HORIZONTAL?this.minimumHeight:this.minimumWidth}get maximumSize(){return this.orientation===F.HORIZONTAL?this.maximumHeight:this.maximumWidth}get minimumOrthogonalSize(){return this.orientation===F.HORIZONTAL?this.minimumWidth:this.minimumHeight}get maximumOrthogonalSize(){return this.orientation===F.HORIZONTAL?this.maximumWidth:this.maximumHeight}get orthogonalSize(){return this._orthogonalSize}get size(){return this._size}get element(){return this.view.element}get width(){return this.orientation===F.HORIZONTAL?this.orthogonalSize:this.size}get height(){return this.orientation===F.HORIZONTAL?this.size:this.orthogonalSize}setVisible(e){this.view.setVisible&&(this.view.setVisible(e),this._onDidChange.fire(void 0))}layout(e,t){this._size=e,this._orthogonalSize=t,this.view.layout(this.width,this.height)}dispose(){this._disposable.dispose()}}class K extends r{constructor(e,t,i,o,a,r){if(super(),this.orientation=e,this.proportionalLayout=t,this.styles=i,this.children=[],this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this._childrenDisposable=n.NONE,this._orthogonalSize=a,this._size=o,this.element=document.createElement("div"),this.element.className="branch-node",r){const e={views:r.map((e=>({view:e.node,size:e.node.size,visible:!(e.node instanceof X&&void 0!==e.visible)||e.visible}))),size:this.orthogonalSize};this.children=r.map((e=>e.node)),this.splitview=new j(this.element,{orientation:this.orientation,descriptor:e,proportionalLayout:t})}else this.splitview=new j(this.element,{orientation:this.orientation,proportionalLayout:t,styles:i}),this.splitview.layout(this.size,this.orthogonalSize);this.addDisposables(this.splitview.onDidSashEnd((()=>{this._onDidChange.fire(void 0)}))),this.setupChildrenEvents()}get width(){return this.orientation===F.HORIZONTAL?this.size:this.orthogonalSize}get height(){return this.orientation===F.HORIZONTAL?this.orthogonalSize:this.size}get minimumSize(){return 0===this.children.length?0:Math.max(...this.children.map((e=>e.minimumOrthogonalSize)))}get maximumSize(){return Math.min(...this.children.map((e=>e.maximumOrthogonalSize)))}get minimumOrthogonalSize(){return this.splitview.minimumSize}get maximumOrthogonalSize(){return this.splitview.maximumSize}get orthogonalSize(){return this._orthogonalSize}get size(){return this._size}get minimumWidth(){return this.orientation===F.HORIZONTAL?this.minimumOrthogonalSize:this.minimumSize}get minimumHeight(){return this.orientation===F.HORIZONTAL?this.minimumSize:this.minimumOrthogonalSize}get maximumWidth(){return this.orientation===F.HORIZONTAL?this.maximumOrthogonalSize:this.maximumSize}get maximumHeight(){return this.orientation===F.HORIZONTAL?this.maximumSize:this.maximumOrthogonalSize}get priority(){if(0===this.children.length)return B.Normal;const e=this.children.map((e=>void 0===e.priority?B.Normal:e.priority));return e.some((e=>e===B.High))?B.High:e.some((e=>e===B.Low))?B.Low:B.Normal}setVisible(e){for(const t of this.children)t.setVisible(e)}isChildVisible(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.isViewVisible(e)}setChildVisible(e,t){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.isViewVisible(e)!==t&&this.splitview.setViewVisible(e,t)}moveChild(e,t){if(e===t)return;if(e<0||e>=this.children.length)throw new Error("Invalid from index");e<t&&t--,this.splitview.moveView(e,t);const i=this._removeChild(e);this._addChild(i,t)}getChildSize(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.getViewSize(e)}resizeChild(e,t){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.resizeView(e,t)}layout(e,t){this._size=t,this._orthogonalSize=e,this.splitview.layout(this.size,this.orthogonalSize)}addChild(e,t,i,n){if(i<0||i>this.children.length)throw new Error("Invalid index");this.splitview.addView(e,t,i,n),this._addChild(e,i)}getChildCachedVisibleSize(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.getViewCachedVisibleSize(e)}removeChild(e,t){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.removeView(e,t),this._removeChild(e)}_addChild(e,t){this.children.splice(t,0,e),this.setupChildrenEvents()}_removeChild(e){const[t]=this.children.splice(e,1);return this.setupChildrenEvents(),t}setupChildrenEvents(){this._childrenDisposable.dispose(),this._childrenDisposable=i.any(...this.children.map((e=>e.onDidChange)))((e=>{this._onDidChange.fire(void 0)}))}dispose(){super.dispose(),this._childrenDisposable.dispose(),this.children.forEach((e=>e.dispose())),this.splitview.dispose()}}function q(e,t,i){if(e instanceof K){const n=new K(se(e.orientation),e.proportionalLayout,e.styles,t,i);let s=0;for(let o=e.children.length-1;o>=0;o--){const a=e.children[o],r=a instanceof K?a.orthogonalSize:a.size;let h=0===e.size?0:Math.round(t*r/e.size);s+=h,0===o&&(h+=t-s),n.addChild(q(a,i,h),h,0,!0)}return n}return new X(e.view,se(e.orientation),i)}function Q(e){const t=e.parentElement;if(!t)throw new Error("Invalid grid element");let i=t.firstElementChild,n=0;for(;i!==e&&i!==t.lastElementChild&&i;)i=i.nextElementSibling,n++;return n}function ee(e){const t=e.parentElement;if(!t)throw new Error("Invalid grid element");if(/\bgrid-view\b/.test(t.className))return[];const i=Q(t);return[...ee(t.parentElement.parentElement.parentElement),i]}function te(e,t,i){if(ne(e,t)===ie(i)){const[e,n]=T(t);let s=n;return i!==U.Right&&i!==U.Bottom||(s+=1),[...e,s]}{const e=i===U.Right||i===U.Bottom?1:0;return[...t,e]}}function ie(e){return e===U.Top||e===U.Bottom?F.VERTICAL:F.HORIZONTAL}function ne(e,t){return t.length%2==0?se(e):e}const se=e=>e===F.HORIZONTAL?F.VERTICAL:F.HORIZONTAL;function oe(e){return!!e.children}const ae=(e,t)=>{const i=t===F.VERTICAL?e.box.width:e.box.height;return oe(e)?{type:"branch",data:e.children.map((e=>ae(e,se(t)))),size:i}:"number"==typeof e.cachedVisibleSize?{type:"leaf",data:e.view.toJSON(),size:e.cachedVisibleSize,visible:!1}:{type:"leaf",data:e.view.toJSON(),size:i}};class re{constructor(e,t,i){this.proportionalLayout=e,this.styles=t,this.disposable=new h,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.element=document.createElement("div"),this.element.className="grid-view",this.root=new K(i,e,t,0,0)}serialize(){return{root:ae(this.getView(),this.orientation),width:this.width,height:this.height,orientation:this.orientation}}dispose(){this.disposable.dispose(),this._onDidChange.dispose(),this.root.dispose()}clear(){const e=this.root.orientation;this.root=new K(e,this.proportionalLayout,this.styles,this.root.size,this.root.orthogonalSize)}deserialize(e,t){const i=e.orientation,n=e.height;this._deserialize(e.root,i,t,n)}_deserialize(e,t,i,n){this.root=this._deserializeNode(e,t,i,n)}_deserializeNode(e,t,i,n){let s;if("branch"===e.type){const o=e.data.map((n=>({node:this._deserializeNode(n,se(t),i,e.size),visible:n.visible})));s=new K(t,this.proportionalLayout,this.styles,e.size,n,o)}else s=new X(i.fromJSON(e),t,n,e.size);return s}get orientation(){return this.root.orientation}set orientation(e){if(this.root.orientation===e)return;const{size:t,orthogonalSize:i}=this.root;this.root=q(this.root,i,t),this.root.layout(t,i)}get root(){return this._root}set root(e){const t=this._root;t&&(t.dispose(),this.element.removeChild(t.element)),this._root=e,this.element.appendChild(this._root.element),this.disposable.value=this._root.onDidChange((e=>{this._onDidChange.fire(e)}))}next(e){return this.progmaticSelect(e)}previous(e){return this.progmaticSelect(e,!0)}getView(e){const t=e?this.getNode(e)[1]:this.root;return this._getViews(t,this.orientation)}_getViews(e,t,i){const n={height:e.height,width:e.width};if(e instanceof X)return{box:n,view:e.view,cachedVisibleSize:i};const s=[];for(let i=0;i<e.children.length;i++){const n=e.children[i],o=e.getChildCachedVisibleSize(i);s.push(this._getViews(n,se(t),o))}return{box:n,children:s}}progmaticSelect(e,t=!1){const[i,n]=this.getNode(e);if(!(n instanceof X))throw new Error("invalid location");const s=(e,t)=>{if(e instanceof X)return e;if(e instanceof K)return s(e.children[t?e.children.length-1:0],t);throw new Error("invalid node")};for(let n=i.length-1;n>-1;n--){const o=i[n],a=e[n]||0;if(t?a-1>-1:a+1<o.children.length)return s(o.children[t?a-1:a+1],t)}return s(this.root,t)}get width(){return this.root.width}get height(){return this.root.height}get minimumWidth(){return this.root.minimumWidth}get minimumHeight(){return this.root.minimumHeight}get maximumWidth(){return this.root.maximumHeight}get maximumHeight(){return this.root.maximumHeight}isViewVisible(e){const[t,i]=T(e),[,n]=this.getNode(t);if(!(n instanceof K))throw new Error("Invalid from location");return n.isChildVisible(i)}setViewVisible(e,t){const[i,n]=T(e),[,s]=this.getNode(i);if(!(s instanceof K))throw new Error("Invalid from location");s.setChildVisible(n,t)}moveView(e,t,i){const[,n]=this.getNode(e);if(!(n instanceof K))throw new Error("Invalid location");n.moveChild(t,i)}addView(e,t,i){const[n,s]=T(i),[o,a]=this.getNode(n);if(a instanceof K){const i=new X(e,se(a.orientation),a.orthogonalSize);a.addChild(i,t,s)}else{const[i,...r]=[...o].reverse(),[h,...d]=[...n].reverse();let l=0;const p=i.getChildCachedVisibleSize(h);"number"==typeof p&&(l=J.Invisible(p)),i.removeChild(h);const c=new K(a.orientation,this.proportionalLayout,this.styles,a.size,a.orthogonalSize);i.addChild(c,a.size,h);const m=new X(a.view,i.orientation,a.size);c.addChild(m,l,0),"number"!=typeof t&&"split"===t.type&&(t={type:"split",index:0});const u=new X(e,i.orientation,a.size);c.addChild(u,t,s)}}remove(e,t){const i=ee(e.element);return this.removeView(i,t)}removeView(e,t){const[i,n]=T(e),[s,o]=this.getNode(i);if(!(o instanceof K))throw new Error("Invalid location");const a=o.children[n];if(!(a instanceof X))throw new Error("Invalid location");if(o.removeChild(n,t),0===o.children.length)return a.view;if(o.children.length>1)return a.view;if(0===s.length){const e=o.children[0];return e instanceof X||(o.removeChild(0,t),this.root=e),a.view}const[r,...h]=[...s].reverse(),[d,...l]=[...i].reverse(),p=o.children[0],c=o.isChildVisible(0);o.removeChild(0,t);const m=r.children.map(((e,t)=>r.getChildSize(t)));if(r.removeChild(d,t),p instanceof K){m.splice(d,1,...p.children.map((e=>e.size)));for(let e=0;e<p.children.length;e++){const t=p.children[e];r.addChild(t,t.size,d+e)}}else{const e=new X(p.view,se(p.orientation),p.size),t=c?p.orthogonalSize:J.Invisible(p.orthogonalSize);r.addChild(e,t,d)}for(let e=0;e<m.length;e++)r.resizeChild(e,m[e]);return a.view}layout(e,t){const[i,n]=this.root.orientation===F.HORIZONTAL?[t,e]:[e,t];this.root.layout(i,n)}getNode(e,t=this.root,i=[]){if(0===e.length)return[i,t];if(!(t instanceof K))throw new Error("Invalid location");const[n,...s]=e;if(n<0||n>=t.children.length)throw new Error("Invalid location");const o=t.children[n];return i.push(t),this.getNode(s,o,i)}}
|
|
8
8
|
/*! *****************************************************************************
|
|
9
9
|
Copyright (c) Microsoft Corporation.
|
|
10
10
|
|
|
@@ -18,4 +18,4 @@ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
|
18
18
|
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
19
19
|
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
20
20
|
PERFORMANCE OF THIS SOFTWARE.
|
|
21
|
-
***************************************************************************** */function he(e,t,i,n){return new(i||(i=Promise))((function(s,o){function a(e){try{h(n.next(e))}catch(e){o(e)}}function r(e){try{h(n.throw(e))}catch(e){o(e)}}function h(e){var t;e.done?s(e.value):(t=e.value,t instanceof i?t:new i((function(e){e(t)}))).then(a,r)}h((n=n.apply(e,t||[])).next())}))}class de extends r{constructor(){super(),this.disposable=new h,this._onDidFocus=new s,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new s,this.onDidBlur=this._onDidBlur.event,this._element=document.createElement("div"),this._element.className="content-container",this._element.tabIndex=-1}get element(){return this._element}show(){this.element.style.display=""}hide(){this.element.style.display="none"}openPanel(e){var t;if(this.panel===e)return;this.panel&&((null===(t=this.panel.view)||void 0===t?void 0:t.content)&&this._element.removeChild(this.panel.view.content.element),this.panel=void 0),this.panel=e;const i=new r;if(this.panel.view){const e=this.panel.view.content.onDidFocus,t=this.panel.view.content.onDidBlur,{onDidFocus:n,onDidBlur:s}=N(this._element);i.addDisposables(n((()=>this._onDidFocus.fire())),s((()=>this._onDidBlur.fire()))),e&&i.addDisposables(e((()=>this._onDidFocus.fire()))),t&&i.addDisposables(t((()=>this._onDidBlur.fire()))),this._element.appendChild(this.panel.view.content.element)}this.disposable.value=i}layout(e,t){}closePanel(){var e,t,i;(null===(i=null===(t=null===(e=this.panel)||void 0===e?void 0:e.view)||void 0===t?void 0:t.content)||void 0===i?void 0:i.element)&&(this._element.removeChild(this.panel.view.content.element),this.panel=void 0)}dispose(){this.disposable.dispose(),super.dispose()}}var le,pe,ce,me;!function(e){e[e.Tab=0]="Tab",e[e.Panel=1]="Panel",e[e.TabContainer=2]="TabContainer"}(le||(le={})),function(e){e.CLICK="CLICK",e.CONTEXT_MENU="CONTEXT_MENU"}(pe||(pe={}));class ue extends r{constructor(e,t,i){super(),this.panelId=e,this.accessor=t,this.group=i,this._onChanged=new s,this.onChanged=this._onChanged.event,this._onDropped=new s,this.onDrop=this._onDropped.event,this.panelTransfer=b.getInstance(),this.iframes=[],this.addDisposables(this._onChanged,this._onDropped),this._element=document.createElement("div"),this._element.className="tab",this._element.tabIndex=0,this._element.draggable=!0,this.addDisposables(a(this._element,"dragstart",(e=>{this.iframes=[...O("iframe"),...O("webview")];for(const e of this.iframes)e.style.pointerEvents="none";this.element.classList.add("dragged"),setTimeout((()=>this.element.classList.remove("dragged")),0),this.panelTransfer.setData([new l(this.accessor.id,this.group.id,this.panelId)],l.prototype),e.dataTransfer&&(e.dataTransfer.effectAllowed="move")})),a(this._element,"dragend",(e=>{for(const e of this.iframes)e.style.pointerEvents="auto";this.iframes=[],this.panelTransfer.clearData(l.prototype)})),a(this._element,"mousedown",(e=>{e.defaultPrevented||(e.stopPropagation(),this._onChanged.fire({kind:pe.CLICK,event:e}))})),a(this._element,"contextmenu",(e=>{this._onChanged.fire({kind:pe.CONTEXT_MENU,event:e})}))),this.droptarget=new Y(this._element,{validOverlays:"none",canDisplayOverlay:e=>{const t=f();return t?this.panelId!==t.panelId:this.group.model.canDisplayOverlay(e,le.Tab)}}),this.addDisposables(this.droptarget.onDrop((e=>{this._onDropped.fire(e)})))}get element(){return this._element}setActive(e){A(this.element,"active-tab",e),A(this.element,"inactive-tab",!e)}setContent(e){this.content&&this._element.removeChild(this.content.element),this.content=e,this._element.appendChild(this.content.element)}dispose(){super.dispose(),this.droptarget.dispose()}}class ve extends r{constructor(e,t,i){super(),this.accessor=e,this.group=t,this.tabs=[],this.selectedIndex=-1,this.active=!1,this._onDrop=new s,this.onDrop=this._onDrop.event,this.addDisposables(this._onDrop),this._element=document.createElement("div"),this._element.className="tabs-and-actions-container",this.height=i.tabHeight,this.actionContainer=document.createElement("div"),this.actionContainer.className="action-container",this.tabContainer=document.createElement("div"),this.tabContainer.className="tabs-container",this.voidContainer=document.createElement("div"),this.voidContainer.className="void-container",this._element.appendChild(this.tabContainer),this._element.appendChild(this.voidContainer),this._element.appendChild(this.actionContainer),this.voidDropTarget=new Y(this.voidContainer,{validOverlays:"none",canDisplayOverlay:e=>{var i;const n=f();return n?(null===(i=(s=this.tabs).length>0?s[s.length-1]:void 0)||void 0===i?void 0:i.value.panelId)!==n.panelId:t.model.canDisplayOverlay(e,le.Panel);var s}}),this.addDisposables(this.voidDropTarget.onDrop((e=>{this._onDrop.fire({event:e.event,index:this.tabs.length})})),this.voidDropTarget,a(this.tabContainer,"mousedown",(e=>{if(e.defaultPrevented)return;0===e.button&&this.accessor.doSetGroupActive(this.group)})))}get panels(){return this.tabs.map((e=>e.value.panelId))}get size(){return this.tabs.length}get height(){return this._height}set height(e){this._height=e,"number"!=typeof e?this.element.style.removeProperty("--dv-tabs-and-actions-container-height"):this.element.style.setProperty("--dv-tabs-and-actions-container-height",`${e}px`)}show(){this.element.style.display=""}hide(){this.element.style.display="none"}setActionElement(e){this.actions!==e&&(this.actions&&(this.actions.remove(),this.actions=void 0),e&&(this.actionContainer.appendChild(e),this.actions=e))}get element(){return this._element}isActive(e){return this.selectedIndex>-1&&this.tabs[this.selectedIndex].value===e}at(e){var t;return null===(t=this.tabs[e])||void 0===t?void 0:t.value}indexOf(e){return this.tabs.findIndex((t=>t.value.panelId===e))}setActive(e){this.active=e}addTab(e,t=this.tabs.length){if(t<0||t>this.tabs.length)throw new Error("invalid location");this.tabContainer.insertBefore(e.value.element,this.tabContainer.children[t]),this.tabs=[...this.tabs.slice(0,t),e,...this.tabs.slice(t)],this.selectedIndex<0&&(this.selectedIndex=t)}delete(e){const t=this.tabs.findIndex((t=>t.value.panelId===e)),i=this.tabs.splice(t,1)[0],{value:n,disposable:s}=i;s.dispose(),n.element.remove()}setActivePanel(e){this.tabs.forEach((t=>{const i=e.id===t.value.panelId;t.value.setActive(i)}))}openPanel(e,t=this.tabs.length){var i;if(this.tabs.find((t=>t.value.panelId===e.id)))return;const n=new ue(e.id,this.accessor,this.group);if(!(null===(i=e.view)||void 0===i?void 0:i.tab))throw new Error("invalid header component");n.setContent(e.view.tab);const s=r.from(n.onChanged((t=>{var i;const n=e.id===(null===(i=this.group.model.activePanel)||void 0===i?void 0:i.id)&&this.group.model.isContentFocused();this.accessor.fireMouseEvent(Object.assign(Object.assign({},t),{panel:e,tab:!0}));if(0===t.event.button&&!t.event.defaultPrevented&&t.kind===pe.CLICK)this.group.model.openPanel(e,{skipFocus:n})})),n.onDrop((e=>{this._onDrop.fire({event:e.event,index:this.tabs.findIndex((e=>e.value===n))})}))),o={value:n,disposable:s};this.addTab(o,t),this.activePanel=e}closePanel(e){this.delete(e.id)}dispose(){super.dispose(),this.tabs.forEach((e=>{e.disposable.dispose()})),this.tabs=[]}}!function(e){e.ADD_PANEL="ADD_PANEL",e.REMOVE_PANEL="REMOVE_PANEL",e.PANEL_ACTIVE="PANEL_ACTIVE",e.GROUP_ACTIVE="GROUP_ACTIVE"}(ce||(ce={}));class ge extends r{constructor(e,t,i,n,o){super(),this.container=e,this.accessor=t,this.id=i,this.options=n,this.parent=o,this._isGroupActive=!1,this.mostRecentlyUsed=[],this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this._width=0,this._height=0,this._panels=[],this._onMove=new s,this.onMove=this._onMove.event,this._onDidGroupChange=new s,this.onDidGroupChange=this._onDidGroupChange.event,this.closePanel=e=>he(this,void 0,void 0,(function*(){return!(e.close&&!(yield e.close()))&&(this.doClose(e),!0)})),this.container.classList.add("groupview"),this.addDisposables(this._onMove,this._onDidGroupChange),this.tabsContainer=new ve(this.accessor,this.parent,{tabHeight:n.tabHeight}),this.contentContainer=new de,this.dropTarget=new Y(this.contentContainer.element,{validOverlays:"all",canDisplayOverlay:e=>{const t=f();if(t){return!(1===this._panels.length&&t.groupId===this.id)}return this.canDisplayOverlay(e,le.Panel)}}),e.append(this.tabsContainer.element,this.contentContainer.element),this.addDisposables(this._onMove,this._onDidGroupChange,this.tabsContainer.onDrop((e=>{this.handleDropEvent(e.event,U.Center,e.index)})),this.contentContainer.onDidFocus((()=>{this.accessor.doSetGroupActive(this.parent,!0)})),this.contentContainer.onDidBlur((()=>{})),this.dropTarget.onDrop((e=>{this.handleDropEvent(e.event,e.position)})))}get element(){throw new Error("not supported")}get activePanel(){return this._activePanel}get tabHeight(){return this.tabsContainer.height}set tabHeight(e){this.tabsContainer.height=e,this.layout(this._width,this._height)}get isActive(){return this._isGroupActive}get panels(){return this._panels}get size(){return this._panels.length}get isEmpty(){return 0===this._panels.length}get minimumHeight(){return 100}get maximumHeight(){return Number.MAX_SAFE_INTEGER}get minimumWidth(){return 100}get maximumWidth(){return Number.MAX_SAFE_INTEGER}initialize(){var e,t;(null===(e=this.options)||void 0===e?void 0:e.panels)&&this.options.panels.forEach((e=>{this.doAddPanel(e)})),(null===(t=this.options)||void 0===t?void 0:t.activePanel)&&this.openPanel(this.options.activePanel),this.setActive(this.isActive,!0,!0),this.updateContainer()}isContentFocused(){return!!document.activeElement&&P(document.activeElement,this.contentContainer.element)}indexOf(e){return this.tabsContainer.indexOf(e.id)}toJSON(){var e;return{views:this.tabsContainer.panels,activeView:null===(e=this._activePanel)||void 0===e?void 0:e.id,id:this.id}}moveToNext(e){e||(e={}),e.panel||(e.panel=this.activePanel);const t=e.panel?this.panels.indexOf(e.panel):-1;let i;if(t<this.panels.length-1)i=t+1;else{if(e.suppressRoll)return;i=0}this.openPanel(this.panels[i])}moveToPrevious(e){if(e||(e={}),e.panel||(e.panel=this.activePanel),!e.panel)return;const t=this.panels.indexOf(e.panel);let i;if(t>0)i=t-1;else{if(e.suppressRoll)return;i=this.panels.length-1}this.openPanel(this.panels[i])}containsPanel(e){return this.panels.includes(e)}init(e){}update(e){}focus(){var e;null===(e=this._activePanel)||void 0===e||e.focus()}openPanel(e,t={}){("number"!=typeof t.index||t.index>this.panels.length)&&(t.index=this.panels.length),this._activePanel!==e?(this.doAddPanel(e,t.index),this.doSetActivePanel(e),this.accessor.doSetGroupActive(this.parent,!!t.skipFocus),this.updateContainer()):this.accessor.doSetGroupActive(this.parent)}removePanel(e){const t="string"==typeof e?e:e.id,i=this._panels.find((e=>e.id===t));if(!i)throw new Error("invalid operation");return this._removePanel(i)}closeAllPanels(){var e;return he(this,void 0,void 0,(function*(){const t=this._activePanel?this.panels.indexOf(this._activePanel):-1;if(this._activePanel&&t>-1){this.panels.indexOf(this._activePanel)<0&&console.warn("active panel not tracked");if(!(!(null===(e=this._activePanel)||void 0===e?void 0:e.close)||(yield this._activePanel.close())))return!1}for(let e=0;e<this.panels.length;e++){if(e===t)continue;const i=this.panels[e];if(this.openPanel(i),i.close){if(!(yield i.close()))return!1}}if(this.panels.length>0){const e=[...this.panels];yield Promise.all(e.map((e=>this.doClose(e))))}else this.accessor.removeGroup(this.parent);return!0}))}doClose(e){this.accessor.removePanel(e)}isPanelActive(e){return this._activePanel===e}updateActions(){var e,t;this.isActive&&(null===(t=null===(e=this._activePanel)||void 0===e?void 0:e.view)||void 0===t?void 0:t.actions)?this.tabsContainer.setActionElement(this._activePanel.view.actions.element):this.tabsContainer.setActionElement(void 0)}setActive(e,t=!1,i=!1){var n,s;i||this.isActive!==e?(this._isGroupActive=e,A(this.container,"active-group",e),A(this.container,"inactive-group",!e),this.tabsContainer.setActive(this.isActive),!this._activePanel&&this.panels.length>0&&this.doSetActivePanel(this.panels[0]),this.updateContainer(),e&&(t||null===(s=this._activePanel)||void 0===s||s.focus())):t||null===(n=this._activePanel)||void 0===n||n.focus()}layout(e,t){var i;this._width=e,this._height=t,this.contentContainer.layout(this._width,this._height),(null===(i=this._activePanel)||void 0===i?void 0:i.layout)&&this._activePanel.layout(this._width,this._height)}_removePanel(e){const t=this._activePanel===e;if(this.doRemovePanel(e),t&&this.panels.length>0){const e=this.mostRecentlyUsed[0];this.openPanel(e)}return this._activePanel&&0===this.panels.length&&this.doSetActivePanel(void 0),this.updateContainer(),e}doRemovePanel(e){const t=this.panels.indexOf(e);this._activePanel===e&&this.contentContainer.closePanel(),this.tabsContainer.delete(e.id),this._panels.splice(t,1),this.mostRecentlyUsed.includes(e)&&this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(e),1),this._onDidGroupChange.fire({kind:ce.REMOVE_PANEL,panel:e})}doAddPanel(e,t=this.panels.length){const i=this._panels.indexOf(e)>-1;this.tabsContainer.openPanel(e,t),this.contentContainer.openPanel(e),this.tabsContainer.show(),this.contentContainer.show(),i||(this.updateMru(e),this.panels.splice(t,0,e),this._onDidGroupChange.fire({kind:ce.ADD_PANEL,panel:e}))}doSetActivePanel(e){this._activePanel=e,e&&(this.tabsContainer.setActivePanel(e),e.layout(this._width,this._height),this.updateMru(e),this._onDidGroupChange.fire({kind:ce.PANEL_ACTIVE,panel:e}))}updateMru(e){this.mostRecentlyUsed.includes(e)&&this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(e),1),this.mostRecentlyUsed=[e,...this.mostRecentlyUsed]}updateContainer(){if(this.updateActions(),A(this.container,"empty",this.isEmpty),this.panels.forEach((e=>e.updateParentGroup(this.parent,this.isActive))),this.isEmpty&&!this.watermark){const e=this.accessor.createWatermarkComponent();e.init({containerApi:new x(this.accessor),params:{},title:"",api:null}),this.watermark=e,a(this.watermark.element,"click",(()=>{this.isActive||this.accessor.doSetGroupActive(this.parent)})),this.contentContainer.hide(),this.tabsContainer.hide(),this.container.appendChild(this.watermark.element),this.watermark.updateParentGroup(this.parent,!0)}!this.isEmpty&&this.watermark&&(this.watermark.element.remove(),this.watermark.dispose(),this.watermark=void 0,this.contentContainer.show(),this.tabsContainer.show())}canDisplayOverlay(e,t){return!1}handleDropEvent(e,t,i){const n=f();if(n){if(-1!==this.tabsContainer.indexOf(n.panelId)&&1===this.tabsContainer.size)return;const{groupId:e,panelId:s}=n;if(this.id===e&&!t){if(this.tabsContainer.indexOf(s)===i)return}this._onMove.fire({target:t,groupId:n.groupId,itemId:n.panelId,index:i})}}dispose(){for(const e of this.panels)e.dispose();super.dispose(),this.dropTarget.dispose(),this.tabsContainer.dispose(),this.contentContainer.dispose()}}!function(e){e.ADD_PANEL="ADD_PANEL",e.REMOVE_PANEL="REMOVE_PANEL",e.PANEL_ACTIVE="PANEL_ACTIVE",e.GROUP_ACTIVE="GROUP_ACTIVE",e.ADD_GROUP="ADD_GROUP",e.REMOVE_GROUP="REMOVE_GROUP",e.LAYOUT_FROM_JSON="LAYOUT_FROM_JSON",e.LAYOUT="LAYOUT"}(me||(me={}));const we=V();function be(e){switch(e){case"left":return U.Left;case"right":return U.Right;case"above":return U.Top;case"below":return U.Bottom;default:return U.Center}}class fe extends r{constructor(e,t){super(),this._element=e,this._id=we.next(),this._groups=new Map,this._onGridEvent=new s,this.onGridEvent=this._onGridEvent.event,this._onDidLayoutChange=new s,this.onDidLayoutChange=this._onDidLayoutChange.event,this.gridview=new re(!!t.proportionalLayout,t.styles,t.orientation),this.element.appendChild(this.gridview.element),this.layout(0,0,!0),this.addDisposables(this.gridview.onDidChange((()=>{this._onGridEvent.fire({kind:me.LAYOUT})}))),this.addDisposables((()=>{let e;return this.onGridEvent((t=>{[me.ADD_GROUP,me.REMOVE_GROUP,me.ADD_PANEL,me.REMOVE_PANEL,me.GROUP_ACTIVE,me.PANEL_ACTIVE,me.LAYOUT].includes(t.kind)&&(e&&clearTimeout(e),e=setTimeout((()=>{this._onDidLayoutChange.fire(),clearTimeout(e)})))}))})())}get id(){return this._id}get element(){return this._element}get size(){return this._groups.size}get groups(){return Array.from(this._groups.values()).map((e=>e.value))}get width(){return this.gridview.width}get height(){return this.gridview.height}get minimumHeight(){return this.gridview.minimumHeight}get maximumHeight(){return this.gridview.maximumHeight}get minimumWidth(){return this.gridview.minimumWidth}get maximumWidth(){return this.gridview.maximumWidth}get activeGroup(){return this._activeGroup}setVisible(e,t){this.gridview.setViewVisible(ee(e.element),t),this._onGridEvent.fire({kind:me.LAYOUT})}isVisible(e){return this.gridview.isViewVisible(ee(e.element))}doAddGroup(e,t=[0],i){this.gridview.addView(e,null!=i?i:J.Distribute,t),this._onGridEvent.fire({kind:me.ADD_GROUP}),this.doSetGroupActive(e)}doRemoveGroup(e,t){if(!this._groups.has(e.id))throw new Error("invalid operation");const i=this._groups.get(e.id),n=this.gridview.remove(e,J.Distribute);if(i&&!(null==t?void 0:t.skipDispose)&&(i.disposable.dispose(),this._groups.delete(e.id)),this._onGridEvent.fire({kind:me.REMOVE_GROUP}),!(null==t?void 0:t.skipActive)&&this._activeGroup===e){const e=Array.from(this._groups.values());this.doSetGroupActive(e.length>0?e[0].value:void 0)}return n}getPanel(e){var t;return null===(t=this._groups.get(e))||void 0===t?void 0:t.value}doSetGroupActive(e,t){this._activeGroup!==e&&(this._activeGroup&&(this._activeGroup.setActive(!1),t||this._activeGroup.focus()),e&&(e.setActive(!0),t||e.focus()),this._activeGroup=e,this._onGridEvent.fire({kind:me.GROUP_ACTIVE}))}removeGroup(e){this.doRemoveGroup(e)}moveToNext(e){var t;if(e||(e={}),!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}const i=ee(e.group.element),n=null===(t=this.gridview.next(i))||void 0===t?void 0:t.view;this.doSetGroupActive(n)}moveToPrevious(e){var t;if(e||(e={}),!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}const i=ee(e.group.element),n=null===(t=this.gridview.previous(i))||void 0===t?void 0:t.view;this.doSetGroupActive(n)}layout(e,t,i){(i||e!==this.width||t!==this.height)&&(this.element.style.height=`${t}px`,this.element.style.width=`${e}px`,this.gridview.layout(e,t))}resizeToFit(){if(!this.element.parentElement)return;const{width:e,height:t}=this.element.parentElement.getBoundingClientRect();this.layout(e,t)}dispose(){super.dispose(),this._onGridEvent.dispose(),this.gridview.dispose()}}class _e extends r{constructor(e){super(),this.id=e,this._state={},this._isFocused=!1,this._isActive=!1,this._isVisible=!0,this._width=0,this._height=0,this._onDidStateChange=new s,this.onDidStateChange=this._onDidStateChange.event,this._onDidPanelDimensionChange=new s({replay:!0}),this.onDidDimensionsChange=this._onDidPanelDimensionChange.event,this._onDidChangeFocus=new s({replay:!0}),this.onDidFocusChange=this._onDidChangeFocus.event,this._onFocusEvent=new s,this.onFocusEvent=this._onFocusEvent.event,this._onDidVisibilityChange=new s({replay:!0}),this.onDidVisibilityChange=this._onDidVisibilityChange.event,this._onVisibilityChange=new s,this.onVisibilityChange=this._onVisibilityChange.event,this._onDidActiveChange=new s({replay:!0}),this.onDidActiveChange=this._onDidActiveChange.event,this._onActiveChange=new s,this.onActiveChange=this._onActiveChange.event,this.addDisposables(this._onDidStateChange,this._onDidPanelDimensionChange,this._onDidChangeFocus,this._onDidVisibilityChange,this._onDidActiveChange,this._onFocusEvent,this.onDidFocusChange((e=>{this._isFocused=e.isFocused})),this.onDidActiveChange((e=>{this._isActive=e.isActive})),this.onDidVisibilityChange((e=>{this._isVisible=e.isVisible})),this.onDidDimensionsChange((e=>{this._width=e.width,this._height=e.height})))}get isFocused(){return this._isFocused}get isActive(){return this._isActive}get isVisible(){return this._isVisible}get width(){return this._width}get height(){return this._height}setVisible(e){this._onVisibilityChange.fire({isVisible:e})}setActive(){this._onActiveChange.fire()}setState(e,t){"object"==typeof e?this._state=e:void 0!==typeof t&&(this._state[e]=t),this._onDidStateChange.fire(void 0)}getState(){return this._state}getStateKey(e){return this._state[e]}dispose(){super.dispose()}}class Ce extends _e{constructor(e){super(e),this._onDidConstraintsChangeInternal=new s,this.onDidConstraintsChangeInternal=this._onDidConstraintsChangeInternal.event,this._onDidConstraintsChange=new s({replay:!0}),this.onDidConstraintsChange=this._onDidConstraintsChange.event,this._onDidSizeChange=new s,this.onDidSizeChange=this._onDidSizeChange.event}setConstraints(e){this._onDidConstraintsChangeInternal.fire(e)}setSize(e){this._onDidSizeChange.fire(e)}}class ye extends Ce{constructor(e,t){super(e.id),this.panel=e,this._onDidDirtyChange=new s,this.onDidDirtyChange=this._onDidDirtyChange.event,this._onDidTitleChange=new s,this.onDidTitleChange=this._onDidTitleChange.event,this._titleChanged=new s,this.titleChanged=this._titleChanged.event,this._suppressClosableChanged=new s,this.suppressClosableChanged=this._suppressClosableChanged.event,this._group=t,this.addDisposables(this._onDidDirtyChange)}get tryClose(){return this._interceptor}get title(){return this.panel.title}get suppressClosable(){return!!this.panel.suppressClosable}get isGroupActive(){var e;return!!(null===(e=this.group)||void 0===e?void 0:e.isActive)}set group(e){this._group=e}get group(){return this._group}setTitle(e){this._onDidTitleChange.fire({title:e})}close(){if(!this.group)throw new Error(`panel ${this.id} has no group`);return this.group.model.closePanel(this.panel)}interceptOnCloseAction(e){this._interceptor=e}dispose(){super.dispose()}}class ze extends r{constructor(e,t){super(),this.id=e,this.containerApi=t,this.mutableDisposable=new h,this._suppressClosable=!1,this._title="",this.api=new ye(this,this._group),this.onDidStateChange=this.api.onDidStateChange,this.addDisposables(this.api.onActiveChange((()=>{this.containerApi.setActivePanel(this)})),this.api.onDidTitleChange((e=>{const t=e.title;this.update({params:{title:t}})})))}get title(){return this._title}get suppressClosable(){return this._suppressClosable}get group(){return this._group}get view(){return this._view}init(e){var t;this._params=e.params,this._view=e.view,this.setTitle(e.title),this.setSuppressClosable(e.suppressClosable||!1),e.state&&this.api.setState(e.state),null===(t=this.view)||void 0===t||t.init(Object.assign(Object.assign({},e),{api:this.api,containerApi:this.containerApi}))}focus(){this.api._onFocusEvent.fire()}setDirty(e){this.api._onDidDirtyChange.fire(e)}close(){return this.api.tryClose?this.api.tryClose():Promise.resolve(!0)}toJSON(){const e=this.api.getState();return{id:this.id,view:this.view.toJSON(),params:Object.keys(this._params||{}).length>0?this._params:void 0,state:e&&Object.keys(e).length>0?e:void 0,suppressClosable:this.suppressClosable||void 0,title:this.title}}setTitle(e){var t;e!==(null===(t=this._params)||void 0===t?void 0:t.title)&&(this._title=e,this.api._titleChanged.fire({title:this.title}))}setSuppressClosable(e){var t;e!==(null===(t=this._params)||void 0===t?void 0:t.suppressClosable)&&(this._suppressClosable=e,this.api._suppressClosableChanged.fire({suppressClosable:!!this.suppressClosable}))}update(e){var t;const i=e.params;this._params=Object.assign(Object.assign({},this._params||{}),e.params.params),"string"==typeof i.title&&this.setTitle(i.title),"boolean"==typeof i.suppressClosable&&this.setSuppressClosable(i.suppressClosable),null===(t=this.view)||void 0===t||t.update({params:{params:this._params,title:this.title,suppressClosable:this.suppressClosable}})}updateParentGroup(e,t){var i;this._group=e,this.api.group=e,this.mutableDisposable.value=this._group.model.onDidGroupChange((e=>{var i;if(e.kind===ce.GROUP_ACTIVE){const e=!!(null===(i=this._group)||void 0===i?void 0:i.model.isPanelActive(this));this.api._onDidActiveChange.fire({isActive:t&&e}),this.api._onDidVisibilityChange.fire({isVisible:e})}}));const n=this._group.model.isPanelActive(this);this.api._onDidActiveChange.fire({isActive:t&&n}),this.api._onDidVisibilityChange.fire({isVisible:n}),null===(i=this.view)||void 0===i||i.updateParentGroup(this._group,this._group.model.isPanelActive(this))}layout(e,t){var i,n;this.api._onDidPanelDimensionChange.fire({width:e,height:t-((null===(i=this.group)||void 0===i?void 0:i.model.tabHeight)||0)}),null===(n=this.view)||void 0===n||n.layout(e,t)}dispose(){var e;this.api.dispose(),this.mutableDisposable.dispose(),null===(e=this.view)||void 0===e||e.dispose()}}class xe{constructor(){this._element=document.createElement("div"),this._element.className="actions-bar",this._list=document.createElement("ul"),this._list.className="actions-container",this._element.appendChild(this._list)}get element(){return this._element}add(e){document.createElement("li").className="action-item",this._list.appendChild(e)}}class De extends r{constructor(){super(),this._element=document.createElement("div"),this._element.className="watermark";const e=document.createElement("div");e.className="watermark-title";const t=document.createElement("span");t.style.flexGrow="1";const i=document.createElement("div");i.className="watermark-content",this._element.appendChild(e),this._element.appendChild(i);const n=new xe;e.appendChild(t),e.appendChild(n.element);const s=document.createElement("a");s.className="close-action",n.add(s),this.addDisposables(a(s,"click",(e=>{var t;e.preventDefault(),this.group&&(null===(t=this.params)||void 0===t||t.containerApi.removeGroup(this.group))})))}get id(){return"watermark"}update(e){}focus(){}toJSON(){return{}}layout(e,t){}init(e){this.params=e,this.addDisposables(this.params.containerApi.onDidLayoutChange((e=>{this.render()}))),this.render()}updateParentGroup(e,t){this.group=e,this.render()}get element(){return this._element}render(){const e=!!(this.params&&this.params.containerApi.size<=1);A(this.element,"has-actions",e)}dispose(){super.dispose()}}class Ee{constructor(e,t){this.layout=e,this.panelDeserializer=t}fromJSON(e){const t=e.data.views,i=e.data.activeView,n=[];for(const e of t){const t=this.panelDeserializer.createPanel(e);n.push(t)}return this.layout.createGroup({panels:n,activePanel:n.find((e=>e.id===i)),id:e.data.id})}}function Se(e,t,i={},n={},s,o){const a="string"==typeof t?i[t]:void 0,r="string"==typeof t?n[t]:void 0;if(a&&r)throw new Error(`Cannot create '${e}'. component '${t}' registered as both a component and frameworkComponent`);if(r){if(!s)throw new Error(`Cannot create '${e}' for framework component '${t}'. you must register a frameworkPanelWrapper to use framework components`);return s.createComponent(e,t,r)}if(!a){if(o)return o();throw new Error(`Cannot create '${e}', no component '${t}' provided`)}return new a(e,t)}class Ae{constructor(e){this.renderer=e,this._element=document.createElement("element"),this.show()}get innerRenderer(){return this.renderer}get element(){return this._element}get id(){return this.renderer.id}show(){this.renderer.element.parentElement||this._element.appendChild(this.renderer.element)}hide(){this.renderer.element.parentElement&&this.renderer.element.remove()}layout(e,t){this.renderer.layout(e,t)}update(e){this.renderer.update(e)}toJSON(){return this.renderer.toJSON()}focus(){this.renderer.focus()}init(e){this.renderer.init(e)}updateParentGroup(e,t){this.renderer.updateParentGroup(e,t)}dispose(){this.renderer.dispose()}}class Pe extends r{constructor(){super(),this._isPanelVisible=!1,this._isGroupActive=!1,this.params={},this.isDirtyDisposable=new h,this.addDisposables(this.isDirtyDisposable),this._element=document.createElement("div"),this._element.className="default-tab",this._content=document.createElement("div"),this._content.className="tab-content",this._actionContainer=document.createElement("div"),this._actionContainer.className="action-container",this._list=document.createElement("ul"),this._list.className="tab-list",this.action=document.createElement("a"),this.action.className="tab-action",this._element.appendChild(this._content),this._element.appendChild(this._actionContainer),this._actionContainer.appendChild(this._list),this._list.appendChild(this.action),this.addDisposables(a(this._actionContainer,"mousedown",(e=>{e.preventDefault()}))),this.render()}get element(){return this._element}get id(){return"__DEFAULT_TAB__"}update(e){this.params=Object.assign(Object.assign({},this.params),e.params),this.render()}toJSON(){return{id:this.id}}focus(){}init(e){this.params=e,this._content.textContent=e.title,this.isDirtyDisposable.value=this.params.api.onDidDirtyChange((e=>{const t=e;A(this.action,"dirty",t)})),this.params.suppressClosable?this.action.classList.add("disable-close"):a(this.action,"click",(e=>{e.preventDefault(),this.params.api.close()}))}updateParentGroup(e,t){this._isPanelVisible=t,this._isGroupActive=e.isActive,this.render()}layout(e,t){}render(){this._content.textContent=this.params.title}}class Oe extends r{constructor(e,t,i){super(),this.id=e,this.component=t,this.api=i,this._height=0,this._width=0,this._element=document.createElement("div"),this._element.tabIndex=-1,this._element.style.outline="none",this._element.style.height="100%",this._element.style.width="100%",this._element.style.overflow="hidden";const{onDidFocus:n,onDidBlur:s}=N(this._element);this.addDisposables(this.api,n((()=>{this.api._onDidChangeFocus.fire({isFocused:!0})})),s((()=>{this.api._onDidChangeFocus.fire({isFocused:!1})})))}get element(){return this._element}get width(){return this._width}get height(){return this._height}focus(){this.api._onFocusEvent.fire()}layout(e,t){this._width=e,this._height=t,this.api._onDidPanelDimensionChange.fire({width:e,height:t}),this.part&&this.params&&this.part.update(this.params.params)}init(e){this.params=e,this.part=this.getComponent()}update(e){var t,i;this.params=Object.assign(Object.assign({},this.params),{params:Object.assign(Object.assign({},null===(t=this.params)||void 0===t?void 0:t.params),e.params)}),null===(i=this.part)||void 0===i||i.update({params:this.params.params})}toJSON(){var e,t;const i=this.api.getState(),n=null!==(t=null===(e=this.params)||void 0===e?void 0:e.params)&&void 0!==t?t:{};return{id:this.id,component:this.component,params:Object.keys(n).length>0?n:void 0,state:0===Object.keys(i).length?void 0:i}}dispose(){super.dispose(),this.api.dispose()}}class Ne extends Oe{constructor(e,t,i=new Ce(e)){super(e,t,i),this._evaluatedMinimumWidth=0,this._evaluatedMaximumWidth=Number.MAX_SAFE_INTEGER,this._evaluatedMinimumHeight=0,this._evaluatedMaximumHeight=Number.MAX_SAFE_INTEGER,this._minimumWidth=0,this._minimumHeight=0,this._maximumWidth=Number.MAX_SAFE_INTEGER,this._maximumHeight=Number.MAX_SAFE_INTEGER,this._snap=!1,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.addDisposables(this.api.onVisibilityChange((e=>{const{isVisible:t}=e,{containerApi:i}=this.params;i.setVisible(this,t)})),this.api.onActiveChange((()=>{const{containerApi:e}=this.params;e.setActive(this)})),this.api.onDidConstraintsChangeInternal((e=>{"number"!=typeof e.minimumWidth&&"function"!=typeof e.minimumWidth||(this._minimumWidth=e.minimumWidth),"number"!=typeof e.minimumHeight&&"function"!=typeof e.minimumHeight||(this._minimumHeight=e.minimumHeight),"number"!=typeof e.maximumWidth&&"function"!=typeof e.maximumWidth||(this._maximumWidth=e.maximumWidth),"number"!=typeof e.maximumHeight&&"function"!=typeof e.maximumHeight||(this._maximumHeight=e.maximumHeight)})),this.api.onDidSizeChange((e=>{this._onDidChange.fire({height:e.height,width:e.width})})))}get priority(){return this._priority}get snap(){return this._snap}get minimumWidth(){const e="function"==typeof this._minimumWidth?this._minimumWidth():this._minimumWidth;return e!==this._evaluatedMinimumWidth&&(this._evaluatedMinimumWidth=e,this.updateConstraints()),e}get minimumHeight(){const e="function"==typeof this._minimumHeight?this._minimumHeight():this._minimumHeight;return e!==this._evaluatedMinimumHeight&&(this._evaluatedMinimumHeight=e,this.updateConstraints()),e}get maximumHeight(){const e="function"==typeof this._maximumHeight?this._maximumHeight():this._maximumHeight;return e!==this._evaluatedMaximumHeight&&(this._evaluatedMaximumHeight=e,this.updateConstraints()),e}get maximumWidth(){const e="function"==typeof this._maximumWidth?this._maximumWidth():this._maximumWidth;return e!==this._evaluatedMaximumWidth&&(this._evaluatedMaximumWidth=e,this.updateConstraints()),e}get isActive(){return this.api.isActive}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}init(e){e.maximumHeight&&(this._maximumHeight=e.maximumHeight),e.minimumHeight&&(this._minimumHeight=e.minimumHeight),e.maximumWidth&&(this._maximumWidth=e.maximumWidth),e.minimumWidth&&(this._minimumWidth=e.minimumWidth),this._priority=e.priority,this._snap=!!e.snap,super.init(e),"boolean"==typeof e.isVisible&&this.setVisible(e.isVisible)}updateConstraints(){this.api._onDidConstraintsChange.fire({minimumWidth:this._evaluatedMinimumWidth,maximumWidth:this._evaluatedMaximumWidth,minimumHeight:this._evaluatedMinimumHeight,maximumHeight:this._evaluatedMaximumHeight})}toJSON(){const e=super.toJSON(),t=e=>e===Number.MAX_SAFE_INTEGER?void 0:e,i=e=>e<=0?void 0:e;return Object.assign(Object.assign({},e),{minimumHeight:i(this.minimumHeight),maximumHeight:t(this.maximumHeight),minimumWidth:i(this.minimumWidth),maximumWidth:t(this.maximumWidth),snap:this.snap,priority:this.priority})}dispose(){super.dispose()}}class Ie extends Ne{constructor(e,t,i){super(t,"groupview_default",new Ce(t)),this._model=new ge(this.element,e,t,i,this)}get model(){return this._model}get minimumHeight(){return this._model.minimumHeight}get maximumHeight(){return this._model.maximumHeight}get minimumWidth(){return this._model.minimumWidth}get maximumWidth(){return this._model.maximumWidth}initialize(){this.model.initialize()}setActive(e){super.setActive(e),this.model.setActive(e)}layout(e,t){super.layout(e,t),this.model.layout(e,t)}getComponent(){return this._model}toJSON(){return this.model.toJSON()}}class ke{constructor(e){var t;this._content=e.content,this._tab=new Ae(null!==(t=e.tab)&&void 0!==t?t:new Pe),this._actions=e.actions||(this.content.actions?{element:this.content.actions,dispose:()=>{}}:void 0)}get content(){return this._content}get tab(){return this._tab}get actions(){return this._actions}init(e){this.content.init(Object.assign(Object.assign({},e),{tab:this.tab})),this.tab.init(e)}updateParentGroup(e,t){}layout(e,t){this.content.layout(e,t)}update(e){this.content.update(e),this.tab.update(e)}toJSON(){return{content:this.content.toJSON(),tab:this.tab.innerRenderer instanceof Pe?void 0:this.tab.toJSON()}}dispose(){var e;this.content.dispose(),this.tab.dispose(),null===(e=this.actions)||void 0===e||e.dispose()}}const Ve=V();class Te extends fe{constructor(e,t){super(e,{proportionalLayout:!0,orientation:t.orientation||F.HORIZONTAL,styles:t.styles}),this._panels=new Map,this.dirtyPanels=new Set,this.debouncedDeque=function(e,t){let i;return(...n)=>{clearTimeout(i),i=setTimeout((()=>e(...n)),t)}}(this.syncConfigs.bind(this),5e3),this._onTabInteractionEvent=new s,this.onTabInteractionEvent=this._onTabInteractionEvent.event,this._onTabContextMenu=new s,this.onTabContextMenu=this._onTabContextMenu.event,this.panelState={},this._options=t,this.options.components||(this.options.components={}),this.options.frameworkComponents||(this.options.frameworkComponents={}),this.options.frameworkTabComponents||(this.options.frameworkTabComponents={}),this.options.tabComponents||(this.options.tabComponents={}),this.options.watermarkComponent||this.options.watermarkFrameworkComponent||(this.options.watermarkComponent=De),this._api=new x(this)}get totalPanels(){return this._panels.size}get panels(){return Array.from(this._panels.values()).map((e=>e.value))}get deserializer(){return this._deserializer}set deserializer(e){this._deserializer=e}get options(){return this._options}get activePanel(){const e=this.activeGroup;if(e)return e.model.activePanel}set tabHeight(e){this.options.tabHeight=e,this._groups.forEach((t=>{t.value.model.tabHeight=e}))}get tabHeight(){return this.options.tabHeight}updateOptions(e){const t="string"==typeof e.orientation&&this.options.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),t&&(this.gridview.orientation=e.orientation),this.layout(this.gridview.width,this.gridview.height,!0)}focus(){var e;null===(e=this.activeGroup)||void 0===e||e.focus()}getGroupPanel(e){var t;return null===(t=this._panels.get(e))||void 0===t?void 0:t.value}setActivePanel(e){if(!e.group)throw new Error(`Panel ${e.id} has no associated group`);this.doSetGroupActive(e.group),e.group.model.openPanel(e)}moveToNext(e={}){var t;if(!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}if(e.includePanel&&e.group&&e.group.model.activePanel!==e.group.model.panels[e.group.model.panels.length-1])return void e.group.model.moveToNext({suppressRoll:!0});const i=ee(e.group.element),n=null===(t=this.gridview.next(i))||void 0===t?void 0:t.view;this.doSetGroupActive(n)}moveToPrevious(e={}){var t;if(!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}if(e.includePanel&&e.group&&e.group.model.activePanel!==e.group.model.panels[0])return void e.group.model.moveToPrevious({suppressRoll:!0});const i=ee(e.group.element),n=null===(t=this.gridview.previous(i))||void 0===t?void 0:t.view;n&&this.doSetGroupActive(n)}registerPanel(e){if(this._panels.has(e.id))throw new Error(`panel ${e.id} already exists`);const t=new r(e.onDidStateChange((()=>this.addDirtyPanel(e))));this._panels.set(e.id,{value:e,disposable:t})}unregisterPanel(e){if(!this._panels.has(e.id))throw new Error(`panel ${e.id} doesn't exist`);const t=this._panels.get(e.id);t&&(t.disposable.dispose(),t.value.dispose()),this._panels.delete(e.id)}toJSON(){var e;this.syncConfigs();return{grid:this.gridview.serialize(),panels:Array.from(this._panels.values()).reduce(((e,t)=>(this.panelState[t.value.id]||(e[t.value.id]=t.value.toJSON()),e)),{}),activeGroup:null===(e=this.activeGroup)||void 0===e?void 0:e.id,options:{tabHeight:this.tabHeight}}}fromJSON(e){if(this.gridview.clear(),this._panels.forEach((e=>{e.disposable.dispose(),e.value.dispose()})),this._panels.clear(),this._groups.clear(),!this.deserializer)throw new Error("invalid deserializer");const{grid:t,panels:i,options:n,activeGroup:s}=e;if("number"==typeof(null==n?void 0:n.tabHeight)&&(this.tabHeight=n.tabHeight),!this.deserializer)throw new Error("no deserializer provided");if(this.gridview.deserialize(t,new Ee(this,{createPanel:e=>{const t=i[e],n=this.deserializer.fromJSON(t);return this.registerPanel(n),n}})),"string"==typeof s){const e=this.getPanel(s);e&&this.doSetGroupActive(e)}this.gridview.layout(this.width,this.height),this._onGridEvent.fire({kind:me.LAYOUT_FROM_JSON})}closeAllGroups(){return he(this,void 0,void 0,(function*(){for(const e of this._groups.entries()){const[t,i]=e;if(!(yield i.value.model.closeAllPanels()))return!1}return!0}))}fireMouseEvent(e){if(e.kind===pe.CONTEXT_MENU)e.tab&&e.panel&&this._onTabContextMenu.fire({event:e.event,api:this._api,panel:e.panel})}addPanel(e){var t,i;const n=this._addPanel(e);let s;if(null===(t=e.position)||void 0===t?void 0:t.referencePanel){const t=this.getGroupPanel(e.position.referencePanel);if(!t)throw new Error(`referencePanel ${e.position.referencePanel} does not exist`);s=this.findGroup(t)}else s=this.activeGroup;if(s){const t=be((null===(i=e.position)||void 0===i?void 0:i.direction)||"within");if(t===U.Center)s.model.openPanel(n);else{const e=ee(s.element),i=te(this.gridview.orientation,e,t);this.addPanelToNewGroup(n,i)}}else this.addPanelToNewGroup(n);return n}removePanel(e){this.unregisterPanel(e);const t=e.group;if(!t)throw new Error(`cannot remove panel ${e.id}. it's missing a group.`);t.model.removePanel(e),0===t.model.size&&this.removeGroup(t)}createWatermarkComponent(){var e;return Se("watermark-id","watermark-name",this.options.watermarkComponent?{"watermark-name":this.options.watermarkComponent}:{},this.options.watermarkFrameworkComponent?{"watermark-name":this.options.watermarkFrameworkComponent}:{},null===(e=this.options.frameworkComponentFactory)||void 0===e?void 0:e.watermark)}addEmptyGroup(e){var t;const i=this.createGroup();if(e){const n=null===(t=this._panels.get(e.referencePanel))||void 0===t?void 0:t.value;if(!n)throw new Error(`reference panel ${e.referencePanel} does not exist`);const s=this.findGroup(n);if(!s)throw new Error(`reference group for reference panel ${e.referencePanel} does not exist`);const o=be(e.direction||"within"),a=ee(s.element),r=te(this.gridview.orientation,a,o);this.doAddGroup(i,r)}else this.doAddGroup(i)}removeGroup(e){[...e.model.panels].forEach((e=>{this.removePanel(e)})),1!==this._groups.size?super.removeGroup(e):this._activeGroup=e}moveGroupOrPanel(e,t,i,n,s){var o,a,r;const h=t?null===(o=this._groups.get(t))||void 0===o?void 0:o.value:void 0;if(n&&n!==U.Center){const t=ee(e.element),s=te(this.gridview.orientation,t,n);if(h&&h.model.size<2){const[t,i]=T(s),o=ee(h.element),[a,r]=T(o);if(L(a,t))this.gridview.moveView(a,r,i);else{const t=this.doRemoveGroup(h,{skipActive:!0,skipDispose:!0}),i=ee(e.element),s=te(this.gridview.orientation,i,n);this.doAddGroup(t,s)}}else{const e=(null==h?void 0:h.model.removePanel(i))||(null===(r=this._panels.get(i))||void 0===r?void 0:r.value);if(!e)throw new Error(`No panel with id ${i}`);const s=te(this.gridview.orientation,t,n);this.addPanelToNewGroup(e,s)}}else{const t=(null==h?void 0:h.model.removePanel(i))||(null===(a=this._panels.get(i))||void 0===a?void 0:a.value);if(!t)throw new Error(`No panel with id ${i}`);0===(null==h?void 0:h.model.size)&&this.doRemoveGroup(h),e.model.openPanel(t,{index:s})}}doSetGroupActive(e,t){var i,n;const s=this._activeGroup===e;super.doSetGroupActive(e,t),!s&&(null===(i=this._activeGroup)||void 0===i?void 0:i.model.activePanel)&&this._onGridEvent.fire({kind:me.PANEL_ACTIVE,panel:null===(n=this._activeGroup)||void 0===n?void 0:n.model.activePanel})}createGroup(e){e||(e={tabHeight:this.tabHeight}),"number"!=typeof e.tabHeight&&(e.tabHeight=this.tabHeight);let t=null==e?void 0:e.id;if(t&&this._groups.has(e.id)&&(console.warn(`Duplicate group id ${null==e?void 0:e.id}. reassigning group id to avoid errors`),t=void 0),!t)for(t=Ve.next();this._groups.has(t);)t=Ve.next();const i=new Ie(this,t,e);if(!this._groups.has(i.id)){const e=new r(i.model.onMove((e=>{const{groupId:t,itemId:n,target:s,index:o}=e;this.moveGroupOrPanel(i,t,n,s,o)})),i.model.onDidGroupChange((e=>{switch(e.kind){case ce.ADD_PANEL:this._onGridEvent.fire({kind:me.ADD_PANEL,panel:e.panel});break;case ce.GROUP_ACTIVE:this._onGridEvent.fire({kind:me.GROUP_ACTIVE,panel:e.panel});break;case ce.REMOVE_PANEL:this._onGridEvent.fire({kind:me.REMOVE_PANEL,panel:e.panel});break;case ce.PANEL_ACTIVE:this._onGridEvent.fire({kind:me.PANEL_ACTIVE,panel:e.panel})}})));this._groups.set(i.id,{value:i,disposable:e})}return i.initialize(),"number"==typeof this.options.tabHeight&&(i.model.tabHeight=this.options.tabHeight),i}dispose(){super.dispose(),this._onGridEvent.dispose()}syncConfigs(){const e=Array.from(this.dirtyPanels);e.length,this.dirtyPanels.clear();const t=e.map((e=>this._panels.get(e.id))).filter((e=>!!e)).reduce(((e,t)=>(e[t.value.id]=t.value.toJSON(),e)),{});this.panelState=Object.assign(Object.assign({},this.panelState),t),e.filter((e=>this._panels.has(e.id))).forEach((e=>{e.setDirty(!1)}))}_addPanel(e){const t=new ke({content:this.createContentComponent(e.id,e.component),tab:this.createTabComponent(e.id,e.tabComponent)}),i=new ze(e.id,this._api);return i.init({view:t,title:e.title||e.id,suppressClosable:null==e?void 0:e.suppressClosable,params:(null==e?void 0:e.params)||{}}),this.registerPanel(i),i}createContentComponent(e,t){var i;return Se(e,t,this.options.components||{},this.options.frameworkComponents,null===(i=this.options.frameworkComponentFactory)||void 0===i?void 0:i.content)}createTabComponent(e,t){var i;return Se(e,t,this.options.tabComponents||{},this.options.frameworkTabComponents,null===(i=this.options.frameworkComponentFactory)||void 0===i?void 0:i.tab,(()=>new Pe))}addPanelToNewGroup(e,t=[0]){const i=this.createGroup();this.doAddGroup(i,t),i.model.openPanel(e)}findGroup(e){var t;return null===(t=Array.from(this._groups.values()).find((t=>t.value.model.containsPanel(e))))||void 0===t?void 0:t.value}addDirtyPanel(e){this.dirtyPanels.add(e),e.setDirty(!0),this.debouncedDeque()}}class Le extends fe{constructor(e,t){super(e,{proportionalLayout:t.proportionalLayout,orientation:t.orientation,styles:t.styles}),this._options=t,this.options.components||(this.options.components={}),this.options.frameworkComponents||(this.options.frameworkComponents={})}get orientation(){return this.gridview.orientation}set orientation(e){this.gridview.orientation=e}get options(){return this._options}get deserializer(){return this._deserializer}set deserializer(e){this._deserializer=e}updateOptions(e){const t="string"==typeof e.orientation&&this.options.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),t&&(this.gridview.orientation=e.orientation),this.layout(this.gridview.width,this.gridview.height,!0)}removePanel(e){this.removeGroup(e)}toJSON(){var e;return{grid:this.gridview.serialize(),activePanel:null===(e=this.activeGroup)||void 0===e?void 0:e.id}}setVisible(e,t){this.gridview.setViewVisible(ee(e.element),t)}setActive(e){this._groups.forEach(((t,i)=>{t.value.setActive(e===t.value)}))}toggleVisibility(e){this.setVisible(e,!this.isVisible(e))}focus(){var e;null===(e=this.activeGroup)||void 0===e||e.focus()}fromJSON(e,t){const{grid:i,activePanel:n}=e;this.gridview.clear(),this._groups.clear();const s=[];if(this.gridview.deserialize(i,{fromJSON:e=>{const{data:t}=e,i=Se(t.id,t.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkComponentFactory?{createComponent:this.options.frameworkComponentFactory.createComponent}:void 0);return s.push((()=>i.init({params:t.params,minimumWidth:t.minimumWidth,maximumWidth:t.maximumWidth,minimumHeight:t.minimumHeight,maximumHeight:t.maximumHeight,priority:t.priority,snap:!!t.snap,containerApi:new z(this),isVisible:e.visible}))),this.registerPanel(i),i}}),this.layout(this.width,this.height,!0),t?setTimeout((()=>{s.forEach((e=>e()))}),0):s.forEach((e=>e())),"string"==typeof n){const e=this.getPanel(n);e&&this.doSetGroupActive(e)}this._onGridEvent.fire({kind:me.LAYOUT_FROM_JSON})}movePanel(e,t){var i;let n;const s=this.gridview.remove(e),o=null===(i=this._groups.get(t.reference))||void 0===i?void 0:i.value;if(!o)throw new Error(`reference group ${t.reference} does not exist`);const a=be(t.direction);if(a===U.Center)throw new Error(`${a} not supported as an option`);{const e=ee(o.element);n=te(this.gridview.orientation,e,a)}this.doAddGroup(s,n,t.size)}addPanel(e){var t,i;let n=e.location||[0];if(null===(t=e.position)||void 0===t?void 0:t.reference){const t=null===(i=this._groups.get(e.position.reference))||void 0===i?void 0:i.value;if(!t)throw new Error(`reference group ${e.position.reference} does not exist`);const s=be(e.position.direction);if(s===U.Center)throw new Error(`${s} not supported as an option`);{const e=ee(t.element);n=te(this.gridview.orientation,e,s)}}const s=Se(e.id,e.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkComponentFactory?{createComponent:this.options.frameworkComponentFactory.createComponent}:void 0);return s.init({params:e.params||{},minimumWidth:e.minimumWidth,maximumWidth:e.maximumWidth,minimumHeight:e.minimumHeight,maximumHeight:e.maximumHeight,priority:e.priority,snap:!!e.snap,containerApi:new z(this),isVisible:!0}),this.registerPanel(s),this.doAddGroup(s,n,e.size),{api:s.api}}registerPanel(e){const t=new r(e.api.onDidFocusChange((t=>{t.isFocused&&this._groups.forEach((t=>{const i=t.value;i!==e?i.setActive(!1):i.setActive(!0)}))})));this._groups.set(e.id,{value:e,disposable:t})}moveGroup(e,t,i){const n=this.getPanel(t);if(!n)throw new Error("invalid operation");const s=ee(e.element),o=te(this.gridview.orientation,s,i),[a,r]=T(o),h=ee(n.element),[d,l]=T(h);if(L(d,a))return void this.gridview.moveView(d,l,r);const p=this.doRemoveGroup(n,{skipActive:!0,skipDispose:!0}),c=ee(e.element),m=te(this.gridview.orientation,c,i);this.doAddGroup(p,m)}removeGroup(e){super.removeGroup(e);const t=this._groups.get(e.id);t&&(t.disposable.dispose(),this._groups.delete(e.id))}dispose(){super.dispose()}}class Re extends r{constructor(e,t){super(),this.element=e,this._disposable=new h,this.panels=new Map,this._onDidLayoutChange=new s,this.onDidLayoutChange=this._onDidLayoutChange.event,this._options=t,t.components||(t.components={}),t.frameworkComponents||(t.frameworkComponents={}),this.splitview=new j(this.element,t),this.addDisposables(this._disposable)}get options(){return this._options}get orientation(){return this.splitview.orientation}get splitview(){return this._splitview}set splitview(e){this._splitview=e,this._disposable.value=new r(this._splitview.onDidSashEnd((()=>{this._onDidLayoutChange.fire(void 0)})))}get minimumSize(){return this.splitview.minimumSize}get maximumSize(){return this.splitview.maximumSize}get height(){return this.splitview.orientation===F.HORIZONTAL?this.splitview.orthogonalSize:this.splitview.size}get width(){return this.splitview.orientation===F.HORIZONTAL?this.splitview.size:this.splitview.orthogonalSize}get length(){return this.panels.size}updateOptions(e){const t="string"==typeof e.orientation&&this.options.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),t&&(this.splitview.orientation=e.orientation),this.splitview.layout(this.splitview.size,this.splitview.orthogonalSize)}focus(){var e;null===(e=this._activePanel)||void 0===e||e.focus()}movePanel(e,t){this.splitview.moveView(e,t)}setVisible(e,t){const i=this.getPanels().indexOf(e);this.splitview.setViewVisible(i,t)}setActive(e,t){this._activePanel=e,this.getPanels().filter((t=>t!==e)).forEach((e=>{e.api._onDidActiveChange.fire({isActive:!1}),t||e.focus()})),e.api._onDidActiveChange.fire({isActive:!0}),t||e.focus()}getPanels(){return this.splitview.getViews()}removePanel(e,t){const i=this.panels.get(e.id);null==i||i.dispose(),this.panels.delete(e.id);const n=this.getPanels().findIndex((t=>t===e));this.splitview.removeView(n,t);const s=this.getPanels();s.length>0&&this.setActive(s[s.length-1])}getPanel(e){return this.getPanels().find((t=>t.id===e))}addPanel(e){if(this.panels.has(e.id))throw new Error(`panel ${e.id} already exists`);const t=Se(e.id,e.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.createComponent}:void 0);t.orientation=this.splitview.orientation,t.init({params:e.params||{},minimumSize:e.minimumSize,maximumSize:e.maximumSize,snap:e.snap,priority:e.priority,containerApi:new C(this)});const i="number"==typeof e.size?e.size:J.Distribute,n="number"==typeof e.index?e.index:void 0;this.splitview.addView(t,i,n),this.doAddView(t),this.setActive(t)}resizeToFit(){if(!this.element.parentElement)return;const{width:e,height:t}=this.element.parentElement.getBoundingClientRect();this.layout(e,t)}layout(e,t){const[i,n]=this.splitview.orientation===F.HORIZONTAL?[e,t]:[t,e];this.splitview.layout(i,n)}doAddView(e){const t=e.api.onDidFocusChange((t=>{t.isFocused&&this.setActive(e,!0)}));this.panels.set(e.id,t)}toJSON(){var e;return{views:this.splitview.getViews().map(((e,t)=>({size:this.splitview.getViewSize(t),data:e.toJSON(),snap:!!e.snap,priority:e.priority}))),activeView:null===(e=this._activePanel)||void 0===e?void 0:e.id,size:this.splitview.size,orientation:this.splitview.orientation}}fromJSON(e,t=!1){const{views:i,orientation:n,size:s,activeView:o}=e;this.splitview.dispose();const a=[];if(this.splitview=new j(this.element,{orientation:n,proportionalLayout:this.options.proportionalLayout,descriptor:{size:s,views:i.map((e=>{const t=e.data;if(this.panels.has(t.id))throw new Error(`panel ${t.id} already exists`);const i=Se(t.id,t.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.createComponent}:void 0);return a.push((()=>{i.init({params:t.params||{},minimumSize:t.minimumSize,maximumSize:t.maximumSize,snap:e.snap,priority:e.priority,containerApi:new C(this)})})),i.orientation=n,this.doAddView(i),{size:e.size,view:i}}))}}),this.layout(this.width,this.height),t?setTimeout((()=>{a.forEach((e=>e()))}),0):a.forEach((e=>e())),"string"==typeof o){const e=this.getPanel(o);e&&this.setActive(e)}}dispose(){Array.from(this.panels.values()).forEach((e=>{e.dispose()})),this.panels.clear(),super.dispose()}}class Ge extends r{constructor(e){super(),this.el=e,this.iframes=[],this._onDragStart=new s,this.onDragStart=this._onDragStart.event,this.configure()}configure(){this.addDisposables(a(this.el,"dragstart",(e=>{var t;this.iframes=[...O("iframe"),...O("webview")];for(const e of this.iframes)e.style.pointerEvents="none";this.el.classList.add("dragged"),setTimeout((()=>this.el.classList.remove("dragged")),0),null===(t=this.disposable)||void 0===t||t.dispose(),this.disposable=this.getData()})),a(this.el,"dragend",(e=>{var t;for(const e of this.iframes)e.style.pointerEvents="auto";this.iframes=[],null===(t=this.disposable)||void 0===t||t.dispose(),this.disposable=void 0})))}}class He extends _e{constructor(e){super(e),this._onDidConstraintsChangeInternal=new s,this.onDidConstraintsChangeInternal=this._onDidConstraintsChangeInternal.event,this._onDidConstraintsChange=new s({replay:!0}),this.onDidConstraintsChange=this._onDidConstraintsChange.event,this._onDidSizeChange=new s,this.onDidSizeChange=this._onDidSizeChange.event}setConstraints(e){this._onDidConstraintsChangeInternal.fire(e)}setSize(e){this._onDidSizeChange.fire(e)}dispose(){super.dispose(),this._onDidConstraintsChange.dispose(),this._onDidSizeChange.dispose()}}class Me extends He{constructor(e){super(e),this._onDidExpansionChange=new s({replay:!0}),this.onDidExpansionChange=this._onDidExpansionChange.event,this._onMouseEnter=new s({}),this.onMouseEnter=this._onMouseEnter.event,this._onMouseLeave=new s({}),this.onMouseLeave=this._onMouseLeave.event}set pane(e){this._pane=e}setExpanded(e){var t;null===(t=this._pane)||void 0===t||t.setExpanded(e)}get isExpanded(){var e;return!!(null===(e=this._pane)||void 0===e?void 0:e.isExpanded())}}class Fe extends Oe{constructor(e,t,i,n,o){super(e,t,new Me(e)),this.headerComponent=i,this._onDidChangeExpansionState=new s({replay:!0}),this.onDidChangeExpansionState=this._onDidChangeExpansionState.event,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.headerSize=22,this._orthogonalSize=0,this._size=0,this._minimumBodySize=100,this._maximumBodySize=Number.POSITIVE_INFINITY,this._isExpanded=!1,this.expandedSize=0,this.api.pane=this,this._isExpanded=o,this._onDidChangeExpansionState.fire(this.isExpanded()),this._orientation=n,this.element.classList.add("pane"),this.addDisposables(this.api.onDidSizeChange((e=>{this._onDidChange.fire(e.size)})),a(this.element,"mouseenter",(e=>{this.api._onMouseEnter.fire(e)})),a(this.element,"mouseleave",(e=>{this.api._onMouseLeave.fire(e)}))),this.addDisposables(this._onDidChangeExpansionState,this.onDidChangeExpansionState((e=>{this.api._onDidExpansionChange.fire({isExpanded:e})})),this.api.onDidFocusChange((e=>{this.header&&(e.isFocused?S(this.header,"focused"):E(this.header,"focused"))}))),this.renderOnce()}set orientation(e){this._orientation=e}get orientation(){return this._orientation}get minimumSize(){return this.headerSize+(this.isExpanded()?this._minimumBodySize:0)}get maximumSize(){return this.headerSize+(this.isExpanded()?this._maximumBodySize:0)}get size(){return this._size}get orthogonalSize(){return this._orthogonalSize}set orthogonalSize(e){this._orthogonalSize=e}get minimumBodySize(){return this._minimumBodySize}set minimumBodySize(e){this._minimumBodySize="number"==typeof e?e:0}get maximumBodySize(){return this._maximumBodySize}set maximumBodySize(e){this._maximumBodySize="number"==typeof e?e:Number.POSITIVE_INFINITY}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}isExpanded(){return this._isExpanded}setExpanded(e){this._isExpanded!==e&&(this._isExpanded=e,e?(this.animationTimer&&clearTimeout(this.animationTimer),this.body&&this.element.appendChild(this.body)):this.animationTimer=setTimeout((()=>{var e;null===(e=this.body)||void 0===e||e.remove()}),200),this._onDidChange.fire(e?this.width:void 0),this._onDidChangeExpansionState.fire(e))}layout(e,t){this._size=e,this._orthogonalSize=t;const[i,n]=this.orientation===F.HORIZONTAL?[e,t]:[t,e];this.isExpanded()&&(this.expandedSize=i),super.layout(i,n)}init(e){var t,i;super.init(e),"number"==typeof e.minimumBodySize&&(this.minimumBodySize=e.minimumBodySize),"number"==typeof e.maximumBodySize&&(this.maximumBodySize=e.maximumBodySize),this.bodyPart=this.getBodyComponent(),this.headerPart=this.getHeaderComponent(),this.bodyPart.init(Object.assign(Object.assign({},e),{api:this.api})),this.headerPart.init(Object.assign(Object.assign({},e),{api:this.api})),null===(t=this.body)||void 0===t||t.append(this.bodyPart.element),null===(i=this.header)||void 0===i||i.append(this.headerPart.element),"boolean"==typeof e.isExpanded&&this.setExpanded(e.isExpanded)}toJSON(){const e=this.params;return Object.assign(Object.assign({},super.toJSON()),{headerComponent:this.headerComponent,title:e.title})}renderOnce(){this.header=document.createElement("div"),this.header.tabIndex=0,this.header.className="pane-header",this.header.style.height=`${this.headerSize}px`,this.header.style.lineHeight=`${this.headerSize}px`,this.header.style.minHeight=`${this.headerSize}px`,this.header.style.maxHeight=`${this.headerSize}px`,this.element.appendChild(this.header),this.body=document.createElement("div"),this.body.className="pane-body",this.element.appendChild(this.body)}getComponent(){return{update:e=>{var t,i;null===(t=this.bodyPart)||void 0===t||t.update({params:e}),null===(i=this.headerPart)||void 0===i||i.update({params:e})},dispose:()=>{var e,t;null===(e=this.bodyPart)||void 0===e||e.dispose(),null===(t=this.headerPart)||void 0===t||t.dispose()}}}}class We extends Fe{constructor(e,t,i,n,o,a){super(e,t,i,n,o),this._onDidDrop=new s,this.onDidDrop=this._onDidDrop.event,a||this.initDragFeatures()}initDragFeatures(){if(!this.header)return;const e=this.id;this.header.draggable=!0,this.handler=new class extends Ge{getData(){return b.getInstance().setData([new p("paneview",e)],p.prototype),{dispose:()=>{b.getInstance().clearData(p.prototype)}}}}(this.header),this.target=new Y(this.element,{validOverlays:"vertical",canDisplayOverlay:e=>{const t=_();return!t||t.paneId!==this.id}}),this.addDisposables(this._onDidDrop,this.handler,this.target,this.target.onDrop((e=>{const t=_();if(!t)return void this._onDidDrop.fire(Object.assign(Object.assign({},e),{panel:this,getData:()=>_()}));const i=this.params.containerApi,n=t.paneId,s=i.getPanel(n);if(!s)return void this._onDidDrop.fire(Object.assign(Object.assign({},e),{panel:this,getData:()=>_()}));const o=i.getPanels(),a=o.indexOf(s);let r=i.getPanels().indexOf(this);e.position!==U.Left&&e.position!==U.Top||(r=Math.max(0,r-1)),e.position!==U.Right&&e.position!==U.Bottom||(a>r&&r++,r=Math.min(o.length-1,r)),i.movePanel(a,r)})))}}class Be extends r{constructor(){super(),this.disposable=new h,this.apiRef={api:null},this._element=document.createElement("div"),this.element.className="default-header",this._content=document.createElement("span"),this._expander=document.createElement("a"),this.element.appendChild(this._content),this.element.appendChild(this._expander),this.addDisposables(a(this._expander,"click",(()=>{var e;null===(e=this.apiRef.api)||void 0===e||e.setExpanded(!this.apiRef.api.isExpanded)})))}get element(){return this._element}init(e){this.apiRef.api=e.api,this._content.textContent=e.title,this._expander.textContent=e.api.isExpanded?"<":">",this.disposable.value=e.api.onDidExpansionChange((e=>{this._expander.textContent=e.isExpanded?"<":">"}))}update(e){}dispose(){this.disposable.dispose(),super.dispose()}}class Je extends We{constructor(e){super(e.id,e.component,e.headerComponent,e.orientation,e.isExpanded,e.disableDnd),this.options=e}getBodyComponent(){return this.options.body}getHeaderComponent(){return this.options.header}}class Ue extends r{constructor(e,t){super(),this.element=e,this._disposable=new h,this._onDidLayoutChange=new s,this.onDidLayoutChange=this._onDidLayoutChange.event,this._onDidDrop=new s,this.onDidDrop=this._onDidDrop.event,this._options=t,t.components||(t.components={}),t.frameworkComponents||(t.frameworkComponents={}),this.paneview=new $(this.element,{orientation:F.VERTICAL}),this.addDisposables(this._disposable)}get onDidAddView(){return this._paneview.onDidAddView}get onDidRemoveView(){return this._paneview.onDidRemoveView}set paneview(e){this._paneview=e,this._disposable.value=new r(this.paneview.onDidChange((()=>{this._onDidLayoutChange.fire(void 0)})))}get paneview(){return this._paneview}get minimumSize(){return this.paneview.minimumSize}get maximumSize(){return this.paneview.maximumSize}get height(){return this.paneview.orientation===F.HORIZONTAL?this.paneview.orthogonalSize:this.paneview.size}get width(){return this.paneview.orientation===F.HORIZONTAL?this.paneview.size:this.paneview.orthogonalSize}get options(){return this._options}focus(){}updateOptions(e){this._options=Object.assign(Object.assign({},this.options),e)}addPanel(e){const t=Se(e.id,e.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.body.createComponent}:void 0);let i;i=e.headerComponent?Se(e.id,e.headerComponent,this.options.headerComponents||{},this.options.headerframeworkComponents,this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.header.createComponent}:void 0):new Be;const n=new Je({id:e.id,component:e.component,headerComponent:e.headerComponent,header:i,body:t,orientation:F.VERTICAL,isExpanded:!!e.isExpanded,disableDnd:!!this.options.disableDnd}),s=new r(n.onDidDrop((e=>{this._onDidDrop.fire(e)}))),o="number"==typeof e.size?e.size:J.Distribute,a="number"==typeof e.index?e.index:void 0;return n.init({params:e.params||{},minimumBodySize:e.minimumBodySize,maximumBodySize:e.maximumBodySize,isExpanded:e.isExpanded,title:e.title,containerApi:new y(this)}),this.paneview.addPane(n,o,a),n.orientation=this.paneview.orientation,s}getPanels(){return this.paneview.getPanes()}removePanel(e){const t=this.getPanels().findIndex((t=>t===e));this.paneview.removePane(t)}movePanel(e,t){this.paneview.moveView(e,t)}getPanel(e){return this.getPanels().find((t=>t.id===e))}layout(e,t){const[i,n]=this.paneview.orientation===F.HORIZONTAL?[e,t]:[t,e];this.paneview.layout(i,n)}resizeToFit(){if(!this.element.parentElement)return;const{width:e,height:t}=this.element.parentElement.getBoundingClientRect();this.layout(e,t)}toJSON(){const e=e=>e===Number.MAX_SAFE_INTEGER||e===Number.POSITIVE_INFINITY?void 0:e;return{views:this.paneview.getPanes().map(((t,i)=>{return{size:this.paneview.getViewSize(i),data:t.toJSON(),minimumSize:(n=t.minimumBodySize,n<=0?void 0:n),maximumSize:e(t.maximumBodySize),expanded:t.isExpanded()};var n})),size:this.paneview.size}}fromJSON(e,t){const{views:i,size:n}=e,s=[];this.paneview.dispose(),this.paneview=new $(this.element,{orientation:F.VERTICAL,descriptor:{size:n,views:i.map((e=>{const t=e.data,i=Se(t.id,t.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.body.createComponent}:void 0);let n;n=t.headerComponent?Se(t.id,t.headerComponent,this.options.headerComponents||{},this.options.headerframeworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.header.createComponent}:void 0):new Be;const o=new Je({id:t.id,component:t.component,headerComponent:t.headerComponent,header:n,body:i,orientation:F.VERTICAL,isExpanded:!!e.expanded,disableDnd:!!this.options.disableDnd});return o.onDidDrop((e=>{this._onDidDrop.fire(e)})),s.push((()=>{o.init({params:t.params||{},minimumBodySize:e.minimumSize,maximumBodySize:e.maximumSize,title:t.title,isExpanded:!!e.expanded,containerApi:new y(this)}),o.orientation=this.paneview.orientation})),{size:e.size,view:o}}))}}),this.layout(this.width,this.height),t?setTimeout((()=>{s.forEach((e=>e()))}),0):s.forEach((e=>e()))}}class je extends Oe{constructor(e,t){super(e,t,new He(e)),this._evaluatedMinimumSize=0,this._evaluatedMaximumSize=Number.POSITIVE_INFINITY,this._minimumSize=0,this._maximumSize=Number.POSITIVE_INFINITY,this._snap=!1,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.addDisposables(this.api.onVisibilityChange((e=>{const{isVisible:t}=e,{containerApi:i}=this.params;i.setVisible(this,t)})),this.api.onActiveChange((()=>{const{containerApi:e}=this.params;e.setActive(this)})),this.api.onDidConstraintsChangeInternal((e=>{"number"!=typeof e.minimumSize&&"function"!=typeof e.minimumSize||(this._minimumSize=e.minimumSize),"number"!=typeof e.maximumSize&&"function"!=typeof e.maximumSize||(this._maximumSize=e.maximumSize),this.updateConstraints()})),this.api.onDidSizeChange((e=>{this._onDidChange.fire(e.size)})))}get priority(){return this._priority}set orientation(e){this._orientation=e}get orientation(){return this._orientation}get minimumSize(){const e="function"==typeof this._minimumSize?this._minimumSize():this._minimumSize;return e!==this._evaluatedMinimumSize&&(this._evaluatedMinimumSize=e,this.updateConstraints()),e}get maximumSize(){const e="function"==typeof this._maximumSize?this._maximumSize():this._maximumSize;return e!==this._evaluatedMaximumSize&&(this._evaluatedMaximumSize=e,this.updateConstraints()),e}get snap(){return this._snap}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}layout(e,t){const[i,n]=this.orientation===F.HORIZONTAL?[e,t]:[t,e];super.layout(i,n)}init(e){super.init(e),this._priority=e.priority,e.minimumSize&&(this._minimumSize=e.minimumSize),e.maximumSize&&(this._maximumSize=e.maximumSize),e.snap&&(this._snap=e.snap)}toJSON(){return Object.assign(Object.assign({},super.toJSON()),{minimumSize:(e=this.minimumSize,e<=0?void 0:e),maximumSize:(e=>e===Number.MAX_SAFE_INTEGER||e===Number.POSITIVE_INFINITY?void 0:e)(this.maximumSize)});var e}updateConstraints(){this.api._onDidConstraintsChange.fire({maximumSize:this._evaluatedMaximumSize,minimumSize:this._evaluatedMinimumSize})}}const $e=(t,i)=>{const[n,s]=e.useState(),o=e.useRef(t.componentProps);return e.useImperativeHandle(i,(()=>({update:e=>{o.current=Object.assign(Object.assign({},o.current),e),s(Date.now())}})),[]),e.createElement(t.component,o.current)};$e.displayName="DockviewReactJsBridge";const Ze=V(),Ye=e.createContext({});class Xe{constructor(e,t,i,n,s){this.parent=e,this.portalStore=t,this.component=i,this.parameters=n,this.context=s,this.disposed=!1,this.createPortal()}update(e){var t;if(this.disposed)throw new Error("invalid operation: resource is already disposed");null===(t=this.componentInstance)||void 0===t||t.update(e)}createPortal(){if(this.disposed)throw new Error("invalid operation: resource is already disposed");if("function"!=typeof this.component)throw new Error("invalid operation: only functional components are supported");const i=e.createElement(e.forwardRef($e),{component:this.component,componentProps:this.parameters,ref:e=>{this.componentInstance=e}}),n=this.context?e.createElement(Ye.Provider,{value:this.context},i):i,s=t.createPortal(n,this.parent,Ze.next());this.ref={portal:s,disposable:this.portalStore.addPortal(s)}}dispose(){var e;null===(e=this.ref)||void 0===e||e.disposable.dispose(),this.disposed=!0}}const Ke=()=>{const[t,i]=e.useState([]);e.useDebugValue(`Portal count: ${t.length}`);return[t,e.useCallback((e=>{i((t=>[...t,e]));let t=!1;return{dispose:()=>{if(t)throw new Error("invalid operation: resource already disposed");t=!0,i((t=>t.filter((t=>t!==e))))}}}),[])]};function qe(e){return null==e?void 0:e.type}class Qe{constructor(e,t,i){this.id=e,this.component=t,this.reactPortalStore=i,this._onDidFocus=new s,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new s,this.onDidBlur=this._onDidBlur.event,this._element=document.createElement("div"),this._element.style.height="100%",this._element.style.width="100%",this._actionsElement=document.createElement("div"),this._actionsElement.style.height="100%",this._actionsElement.style.width="100%"}get element(){return this._element}get actions(){return this._actionsElement}focus(){}init(e){const t={api:e.api,containerApi:e.containerApi,actionsPortalElement:this._actionsElement,tabPortalElement:e.tab};this.part=new Xe(this.element,this.reactPortalStore,this.component,{params:e.params,api:e.api,containerApi:e.containerApi},t)}toJSON(){return{id:this.id}}update(e){var t;null===(t=this.part)||void 0===t||t.update(e.params)}updateParentGroup(e,t){this._group=e}layout(e,t){}close(){return Promise.resolve(!0)}dispose(){var e,t;null===(e=this.part)||void 0===e||e.dispose(),null===(t=this.actionsPart)||void 0===t||t.dispose()}}class et{constructor(e,t,i){this.id=e,this.component=t,this.reactPortalStore=i,this._element=document.createElement("div")}get element(){return this._element}focus(){}init(e){this.part=new Xe(this.element,this.reactPortalStore,this.component,{params:e.params,api:e.api,containerApi:e.containerApi})}update(e){var t;null===(t=this.part)||void 0===t||t.update(e.params)}toJSON(){return{id:this.id}}layout(e,t){}updateParentGroup(e,t){}dispose(){var e;null===(e=this.part)||void 0===e||e.dispose()}}class tt{constructor(e){this.layout=e}fromJSON(e){var t,i,n;const s=e.id,o=e.params,a=e.title,r=e.state,h=e.suppressClosable,d=e.view,l=new ke({content:Se(d.content.id,d.content.id,this.layout.options.components,this.layout.options.frameworkComponents,null===(t=this.layout.options.frameworkComponentFactory)||void 0===t?void 0:t.content),tab:(null===(i=d.tab)||void 0===i?void 0:i.id)?Se(d.tab.id,d.tab.id,this.layout.options.tabComponents,this.layout.options.frameworkTabComponents,null===(n=this.layout.options.frameworkComponentFactory)||void 0===n?void 0:n.tab):new Pe}),p=new ze(s,new x(this.layout));return p.init({view:l,title:a,suppressClosable:h,params:o||{},state:r||{}}),p}}class it{constructor(e,t,i){this.id=e,this.component=t,this.reactPortalStore=i,this._groupRef={value:void 0},this._element=document.createElement("div"),this._element.style.height="100%",this._element.style.width="100%"}get element(){return this._element}init(e){this.parameters=e,this.part=new Xe(this.element,this.reactPortalStore,this.component,{params:e.params,api:e.api,containerApi:e.containerApi,close:()=>{this._groupRef.value&&e.containerApi.removeGroup(this._groupRef.value)}})}focus(){}update(e){var t,i;this.parameters&&(this.parameters.params=e.params),null===(t=this.part)||void 0===t||t.update({params:(null===(i=this.parameters)||void 0===i?void 0:i.params)||{}})}toJSON(){return{id:this.id}}layout(e,t){}updateParentGroup(e,t){this._groupRef.value=e}dispose(){var e;null===(e=this.part)||void 0===e||e.dispose()}}const nt=e.forwardRef(((t,i)=>{const n=e.useRef(null),s=e.useRef(),[o,a]=Ke();return e.useImperativeHandle(i,(()=>n.current),[]),e.useEffect((()=>{if(t.disableAutoResizing)return()=>{};const e=D(n.current,(e=>{var t;const{width:i,height:n}=e.contentRect;null===(t=s.current)||void 0===t||t.layout(i,n)}));return()=>{e.dispose()}}),[t.disableAutoResizing]),e.useEffect((()=>{var e;const i={content:{createComponent:(e,t,i)=>new Qe(t,i,{addPortal:a})},tab:{createComponent:(e,t,i)=>new et(t,i,{addPortal:a})},watermark:{createComponent:(e,t,i)=>new it(t,i,{addPortal:a})}},o=document.createElement("div"),r=new Te(o,{frameworkComponentFactory:i,frameworkComponents:t.components,frameworkTabComponents:t.tabComponents,tabHeight:t.tabHeight,debug:t.debug,enableExternalDragEvents:t.enableExternalDragEvents,watermarkFrameworkComponent:t.watermarkComponent,styles:t.hideBorders?{separatorBorder:"transparent"}:void 0});null===(e=n.current)||void 0===e||e.appendChild(r.element),r.deserializer=new tt(r);const{clientWidth:h,clientHeight:d}=n.current;return r.layout(h,d),t.onReady&&t.onReady({api:new x(r)}),s.current=r,()=>{r.dispose()}}),[]),e.useEffect((()=>{if(!t.onTabContextMenu||!s.current)return()=>{};const e=s.current.onTabContextMenu((e=>{t.onTabContextMenu&&t.onTabContextMenu(e)}));return()=>{e.dispose()}}),[t.onTabContextMenu]),e.createElement("div",{className:t.className,style:{height:"100%",width:"100%"},ref:n},o)}));nt.displayName="DockviewComponent";const st=t=>e.createElement(e.Fragment,null,t.children),ot=t=>e.createElement(e.Fragment,null,t.children),at=t=>e.createElement(e.Fragment,null,t.children);const rt={Tab:st,Content:ot,Actions:at,Panel:i=>{const n=e.useContext(Ye),s=e.useMemo((()=>{var t;const n=(null===(t=e.Children.map(i.children,(e=>e)))||void 0===t?void 0:t.filter(qe))||[];if(!!n.find((e=>{return t=e,![ot,at,st].find((e=>t.type===e));var t})))throw new Error("Children of DockviewComponents.Panel must be one of the following: DockviewComponents.Content, DockviewComponents.Actions, DockviewComponents.Tab");return{body:n.find((e=>e.type===ot)),actions:n.find((e=>e.type===at)),tab:n.find((e=>e.type===st))}}),[i.children]);return e.useEffect((()=>{s.tab?n.tabPortalElement.hide():n.tabPortalElement.show()}),[s.tab]),e.createElement(e.Fragment,null,s.actions&&t.createPortal(s.actions,n.actionsPortalElement),s.tab&&t.createPortal(s.tab,n.tabPortalElement.element),s.body||i.children)}};class ht extends je{constructor(e,t,i,n){super(e,t),this.reactComponent=i,this.reactPortalStore=n}getComponent(){var e;return new Xe(this.element,this.reactPortalStore,this.reactComponent,{params:(null===(e=this.params)||void 0===e?void 0:e.params)||{},api:this.api,containerApi:this.params.containerApi})}}const dt=e.forwardRef(((t,i)=>{const n=e.useRef(null),s=e.useRef(),[o,a]=Ke();return e.useImperativeHandle(i,(()=>n.current),[]),e.useEffect((()=>{if(t.disableAutoResizing)return()=>{};const e=D(n.current,(e=>{var t;const{width:i,height:n}=e.contentRect;null===(t=s.current)||void 0===t||t.layout(i,n)}));return()=>{e.dispose()}}),[t.disableAutoResizing]),e.useEffect((()=>{const e=new Re(n.current,{orientation:t.orientation,frameworkComponents:t.components,frameworkWrapper:{createComponent:(e,t,i)=>new ht(e,t,i,{addPortal:a})},proportionalLayout:t.proportionalLayout,styles:t.hideBorders?{separatorBorder:"transparent"}:void 0}),{clientWidth:i,clientHeight:o}=n.current;return e.layout(i,o),t.onReady&&t.onReady({api:new C(e)}),s.current=e,()=>{e.dispose()}}),[]),e.createElement("div",{className:t.className,style:{height:"100%",width:"100%"},ref:n},o)}));dt.displayName="SplitviewComponent";class lt extends Ne{constructor(e,t,i,n){super(e,t),this.reactComponent=i,this.reactPortalStore=n}getComponent(){var e;return new Xe(this.element,this.reactPortalStore,this.reactComponent,{params:(null===(e=this.params)||void 0===e?void 0:e.params)||{},api:this.api,containerApi:this.params.containerApi})}}const pt=e.forwardRef(((t,i)=>{const n=e.useRef(null),s=e.useRef(),[o,a]=Ke();return e.useImperativeHandle(i,(()=>n.current),[]),e.useEffect((()=>{if(t.disableAutoResizing)return()=>{};const e=D(n.current,(e=>{var t;const{width:i,height:n}=e.contentRect;null===(t=s.current)||void 0===t||t.layout(i,n)}));return()=>{e.dispose()}}),[t.disableAutoResizing]),e.useEffect((()=>{var e;const i=document.createElement("div"),o=new Le(i,{proportionalLayout:!!t.proportionalLayout,orientation:t.orientation,frameworkComponents:t.components,frameworkComponentFactory:{createComponent:(e,t,i)=>new lt(e,t,i,{addPortal:a})},styles:t.hideBorders?{separatorBorder:"transparent"}:void 0});null===(e=n.current)||void 0===e||e.appendChild(o.element);const{clientWidth:r,clientHeight:h}=n.current;return o.layout(r,h),t.onReady&&t.onReady({api:new z(o)}),s.current=o,()=>{o.dispose()}}),[]),e.createElement("div",{className:t.className,style:{height:"100%",width:"100%"},ref:n},o)}));pt.displayName="GridviewComponent";class ct{constructor(e,t,i){this.id=e,this.component=t,this.reactPortalStore=i,this._element=document.createElement("div"),this._element.style.height="100%",this._element.style.width="100%"}get element(){return this._element}init(e){this.part=new Xe(this.element,this.reactPortalStore,this.component,{params:e.params,api:e.api,title:e.title,containerApi:e.containerApi})}toJSON(){return{id:this.id}}update(e){var t;null===(t=this.part)||void 0===t||t.update(e.params)}dispose(){var e;null===(e=this.part)||void 0===e||e.dispose()}}const mt=e.forwardRef(((t,i)=>{const n=e.useRef(null),s=e.useRef(),[o,a]=Ke();return e.useImperativeHandle(i,(()=>n.current),[]),e.useEffect((()=>{if(t.disableAutoResizing)return()=>{};const e=D(n.current,(e=>{var t;const{width:i,height:n}=e.contentRect;null===(t=s.current)||void 0===t||t.layout(i,n)}));return()=>{e.dispose()}}),[t.disableAutoResizing]),e.useEffect((()=>{const e=(e,t,i)=>new ct(e,i,{addPortal:a}),i=new Ue(n.current,{frameworkComponents:t.components,components:{},headerComponents:{},disableDnd:t.disableDnd,headerframeworkComponents:t.headerComponents,frameworkWrapper:{header:{createComponent:e},body:{createComponent:e}}}),o=new y(i),{clientWidth:r,clientHeight:h}=n.current;return i.layout(r,h),t.onReady&&t.onReady({api:o}),s.current=i,()=>{i.dispose()}}),[]),e.useEffect((()=>{var e;null===(e=s.current)||void 0===e||e.updateOptions({frameworkComponents:t.components})}),[t.components]),e.useEffect((()=>{var e;null===(e=s.current)||void 0===e||e.updateOptions({headerframeworkComponents:t.headerComponents})}),[t.headerComponents]),e.useEffect((()=>{if(!s.current)return()=>{};const e=s.current,i=e.onDidDrop((i=>{t.onDidDrop&&t.onDidDrop(Object.assign(Object.assign({},i),{api:new y(e)}))}));return()=>{i.dispose()}}),[t.onDidDrop]),e.createElement("div",{className:t.className,style:{height:"100%",width:"100%"},ref:n},o)}));mt.displayName="PaneviewComponent";export{fe as BaseGrid,r as CompositeDisposable,de as ContentContainer,c as DATA_KEY,n as Disposable,x as DockviewApi,Te as DockviewComponent,rt as DockviewComponents,nt as DockviewReact,u as DragType,s as Emitter,i as Event,re as Gridview,z as GridviewApi,Le as GridviewComponent,Ne as GridviewPanel,pt as GridviewReact,me as GroupChangeKind,ce as GroupChangeKind2,ge as Groupview,B as LayoutPriority,b as LocalSelectionTransfer,pe as MouseEventKind,h as MutableDisposable,F as Orientation,Je as PaneFramework,p as PaneTransfer,l as PanelTransfer,$ as Paneview,y as PaneviewApi,Ue as PaneviewComponent,Fe as PaneviewPanel,mt as PaneviewReact,U as Position,Qe as ReactPanelContentPart,et as ReactPanelHeaderPart,Xe as ReactPart,Ye as ReactPartContext,W as SashState,J as Sizing,j as Splitview,C as SplitviewApi,Re as SplitviewComponent,je as SplitviewPanel,dt as SplitviewReact,ue as Tab,a as addDisposableListener,o as addDisposableWindowListener,w as extractData,ie as getDirectionOrientation,ee as getGridLocation,ne as getLocationOrientation,_ as getPaneData,f as getPanelData,te as getRelativeLocation,Q as indexInParent,g as isCustomDragEvent,oe as isGridBranchNode,m as isPanelTransferEvent,qe as isReactElement,v as isTabDragEvent,se as orthogonal,be as toTarget,Ke as usePortalsLifecycle};
|
|
21
|
+
***************************************************************************** */function he(e,t,i,n){return new(i||(i=Promise))((function(s,o){function a(e){try{h(n.next(e))}catch(e){o(e)}}function r(e){try{h(n.throw(e))}catch(e){o(e)}}function h(e){var t;e.done?s(e.value):(t=e.value,t instanceof i?t:new i((function(e){e(t)}))).then(a,r)}h((n=n.apply(e,t||[])).next())}))}class de extends r{constructor(){super(),this.disposable=new h,this._onDidFocus=new s,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new s,this.onDidBlur=this._onDidBlur.event,this._element=document.createElement("div"),this._element.className="content-container",this._element.tabIndex=-1}get element(){return this._element}show(){this.element.style.display=""}hide(){this.element.style.display="none"}openPanel(e){var t;if(this.panel===e)return;this.panel&&((null===(t=this.panel.view)||void 0===t?void 0:t.content)&&this._element.removeChild(this.panel.view.content.element),this.panel=void 0),this.panel=e;const i=new r;if(this.panel.view){const e=this.panel.view.content.onDidFocus,t=this.panel.view.content.onDidBlur,{onDidFocus:n,onDidBlur:s}=N(this._element);i.addDisposables(n((()=>this._onDidFocus.fire())),s((()=>this._onDidBlur.fire()))),e&&i.addDisposables(e((()=>this._onDidFocus.fire()))),t&&i.addDisposables(t((()=>this._onDidBlur.fire()))),this._element.appendChild(this.panel.view.content.element)}this.disposable.value=i}layout(e,t){}closePanel(){var e,t,i;(null===(i=null===(t=null===(e=this.panel)||void 0===e?void 0:e.view)||void 0===t?void 0:t.content)||void 0===i?void 0:i.element)&&(this._element.removeChild(this.panel.view.content.element),this.panel=void 0)}dispose(){this.disposable.dispose(),super.dispose()}}var le,pe,ce,me;!function(e){e[e.Tab=0]="Tab",e[e.Panel=1]="Panel",e[e.TabContainer=2]="TabContainer"}(le||(le={})),function(e){e.CLICK="CLICK",e.CONTEXT_MENU="CONTEXT_MENU"}(pe||(pe={}));class ue extends r{constructor(e,t,i){super(),this.panelId=e,this.accessor=t,this.group=i,this._onChanged=new s,this.onChanged=this._onChanged.event,this._onDropped=new s,this.onDrop=this._onDropped.event,this.panelTransfer=b.getInstance(),this.iframes=[],this.addDisposables(this._onChanged,this._onDropped),this._element=document.createElement("div"),this._element.className="tab",this._element.tabIndex=0,this._element.draggable=!0,this.addDisposables(a(this._element,"dragstart",(e=>{this.iframes=[...O("iframe"),...O("webview")];for(const e of this.iframes)e.style.pointerEvents="none";this.element.classList.add("dragged"),setTimeout((()=>this.element.classList.remove("dragged")),0),this.panelTransfer.setData([new l(this.accessor.id,this.group.id,this.panelId)],l.prototype),e.dataTransfer&&(e.dataTransfer.effectAllowed="move")})),a(this._element,"dragend",(e=>{for(const e of this.iframes)e.style.pointerEvents="auto";this.iframes=[],this.panelTransfer.clearData(l.prototype)})),a(this._element,"mousedown",(e=>{e.defaultPrevented||(e.stopPropagation(),this._onChanged.fire({kind:pe.CLICK,event:e}))})),a(this._element,"contextmenu",(e=>{this._onChanged.fire({kind:pe.CONTEXT_MENU,event:e})}))),this.droptarget=new Y(this._element,{validOverlays:"none",canDisplayOverlay:e=>{const t=f();return t?this.panelId!==t.panelId:this.group.model.canDisplayOverlay(e,le.Tab)}}),this.addDisposables(this.droptarget.onDrop((e=>{this._onDropped.fire(e)})))}get element(){return this._element}setActive(e){A(this.element,"active-tab",e),A(this.element,"inactive-tab",!e)}setContent(e){this.content&&this._element.removeChild(this.content.element),this.content=e,this._element.appendChild(this.content.element)}dispose(){super.dispose(),this.droptarget.dispose()}}class ve extends r{constructor(e,t,i){super(),this.accessor=e,this.group=t,this.tabs=[],this.selectedIndex=-1,this.active=!1,this._onDrop=new s,this.onDrop=this._onDrop.event,this.addDisposables(this._onDrop),this._element=document.createElement("div"),this._element.className="tabs-and-actions-container",this.height=i.tabHeight,this.actionContainer=document.createElement("div"),this.actionContainer.className="action-container",this.tabContainer=document.createElement("div"),this.tabContainer.className="tabs-container",this.voidContainer=document.createElement("div"),this.voidContainer.className="void-container",this._element.appendChild(this.tabContainer),this._element.appendChild(this.voidContainer),this._element.appendChild(this.actionContainer),this.voidDropTarget=new Y(this.voidContainer,{validOverlays:"none",canDisplayOverlay:e=>{var i;const n=f();return n?(null===(i=(s=this.tabs).length>0?s[s.length-1]:void 0)||void 0===i?void 0:i.value.panelId)!==n.panelId:t.model.canDisplayOverlay(e,le.Panel);var s}}),this.addDisposables(this.voidDropTarget.onDrop((e=>{this._onDrop.fire({event:e.event,index:this.tabs.length})})),this.voidDropTarget,a(this.tabContainer,"mousedown",(e=>{if(e.defaultPrevented)return;0===e.button&&this.accessor.doSetGroupActive(this.group)})))}get panels(){return this.tabs.map((e=>e.value.panelId))}get size(){return this.tabs.length}get height(){return this._height}set height(e){this._height=e,"number"!=typeof e?this.element.style.removeProperty("--dv-tabs-and-actions-container-height"):this.element.style.setProperty("--dv-tabs-and-actions-container-height",`${e}px`)}show(){this.element.style.display=""}hide(){this.element.style.display="none"}setActionElement(e){this.actions!==e&&(this.actions&&(this.actions.remove(),this.actions=void 0),e&&(this.actionContainer.appendChild(e),this.actions=e))}get element(){return this._element}isActive(e){return this.selectedIndex>-1&&this.tabs[this.selectedIndex].value===e}at(e){var t;return null===(t=this.tabs[e])||void 0===t?void 0:t.value}indexOf(e){return this.tabs.findIndex((t=>t.value.panelId===e))}setActive(e){this.active=e}addTab(e,t=this.tabs.length){if(t<0||t>this.tabs.length)throw new Error("invalid location");this.tabContainer.insertBefore(e.value.element,this.tabContainer.children[t]),this.tabs=[...this.tabs.slice(0,t),e,...this.tabs.slice(t)],this.selectedIndex<0&&(this.selectedIndex=t)}delete(e){const t=this.tabs.findIndex((t=>t.value.panelId===e)),i=this.tabs.splice(t,1)[0],{value:n,disposable:s}=i;s.dispose(),n.element.remove()}setActivePanel(e){this.tabs.forEach((t=>{const i=e.id===t.value.panelId;t.value.setActive(i)}))}openPanel(e,t=this.tabs.length){var i;if(this.tabs.find((t=>t.value.panelId===e.id)))return;const n=new ue(e.id,this.accessor,this.group);if(!(null===(i=e.view)||void 0===i?void 0:i.tab))throw new Error("invalid header component");n.setContent(e.view.tab);const s=r.from(n.onChanged((t=>{var i;const n=e.id===(null===(i=this.group.model.activePanel)||void 0===i?void 0:i.id)&&this.group.model.isContentFocused();this.accessor.fireMouseEvent(Object.assign(Object.assign({},t),{panel:e,tab:!0}));if(0===t.event.button&&!t.event.defaultPrevented&&t.kind===pe.CLICK)this.group.model.openPanel(e,{skipFocus:n})})),n.onDrop((e=>{this._onDrop.fire({event:e.event,index:this.tabs.findIndex((e=>e.value===n))})}))),o={value:n,disposable:s};this.addTab(o,t),this.activePanel=e}closePanel(e){this.delete(e.id)}dispose(){super.dispose(),this.tabs.forEach((e=>{e.disposable.dispose()})),this.tabs=[]}}!function(e){e.ADD_PANEL="ADD_PANEL",e.REMOVE_PANEL="REMOVE_PANEL",e.PANEL_ACTIVE="PANEL_ACTIVE",e.GROUP_ACTIVE="GROUP_ACTIVE"}(ce||(ce={}));class ge extends r{constructor(e,t,i,n,o){super(),this.container=e,this.accessor=t,this.id=i,this.options=n,this.parent=o,this._isGroupActive=!1,this.mostRecentlyUsed=[],this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this._width=0,this._height=0,this._panels=[],this._onMove=new s,this.onMove=this._onMove.event,this._onDidGroupChange=new s,this.onDidGroupChange=this._onDidGroupChange.event,this.closePanel=e=>he(this,void 0,void 0,(function*(){return!(e.close&&!(yield e.close()))&&(this.doClose(e),!0)})),this.container.classList.add("groupview"),this.addDisposables(this._onMove,this._onDidGroupChange),this.tabsContainer=new ve(this.accessor,this.parent,{tabHeight:n.tabHeight}),this.contentContainer=new de,this.dropTarget=new Y(this.contentContainer.element,{validOverlays:"all",canDisplayOverlay:e=>{const t=f();if(t){return!(1===this._panels.length&&t.groupId===this.id)}return this.canDisplayOverlay(e,le.Panel)}}),e.append(this.tabsContainer.element,this.contentContainer.element),this.addDisposables(this._onMove,this._onDidGroupChange,this.tabsContainer.onDrop((e=>{this.handleDropEvent(e.event,U.Center,e.index)})),this.contentContainer.onDidFocus((()=>{this.accessor.doSetGroupActive(this.parent,!0)})),this.contentContainer.onDidBlur((()=>{})),this.dropTarget.onDrop((e=>{this.handleDropEvent(e.event,e.position)})))}get element(){throw new Error("not supported")}get activePanel(){return this._activePanel}get tabHeight(){return this.tabsContainer.height}set tabHeight(e){this.tabsContainer.height=e,this.layout(this._width,this._height)}get isActive(){return this._isGroupActive}get panels(){return this._panels}get size(){return this._panels.length}get isEmpty(){return 0===this._panels.length}get minimumHeight(){return 100}get maximumHeight(){return Number.MAX_SAFE_INTEGER}get minimumWidth(){return 100}get maximumWidth(){return Number.MAX_SAFE_INTEGER}initialize(){var e,t;(null===(e=this.options)||void 0===e?void 0:e.panels)&&this.options.panels.forEach((e=>{this.doAddPanel(e)})),(null===(t=this.options)||void 0===t?void 0:t.activePanel)&&this.openPanel(this.options.activePanel),this.setActive(this.isActive,!0,!0),this.updateContainer()}isContentFocused(){return!!document.activeElement&&P(document.activeElement,this.contentContainer.element)}indexOf(e){return this.tabsContainer.indexOf(e.id)}toJSON(){var e;return{views:this.tabsContainer.panels,activeView:null===(e=this._activePanel)||void 0===e?void 0:e.id,id:this.id}}moveToNext(e){e||(e={}),e.panel||(e.panel=this.activePanel);const t=e.panel?this.panels.indexOf(e.panel):-1;let i;if(t<this.panels.length-1)i=t+1;else{if(e.suppressRoll)return;i=0}this.openPanel(this.panels[i])}moveToPrevious(e){if(e||(e={}),e.panel||(e.panel=this.activePanel),!e.panel)return;const t=this.panels.indexOf(e.panel);let i;if(t>0)i=t-1;else{if(e.suppressRoll)return;i=this.panels.length-1}this.openPanel(this.panels[i])}containsPanel(e){return this.panels.includes(e)}init(e){}update(e){}focus(){var e;null===(e=this._activePanel)||void 0===e||e.focus()}openPanel(e,t={}){("number"!=typeof t.index||t.index>this.panels.length)&&(t.index=this.panels.length),this._activePanel!==e?(this.doAddPanel(e,t.index),this.doSetActivePanel(e),this.accessor.doSetGroupActive(this.parent,!!t.skipFocus),this.updateContainer()):this.accessor.doSetGroupActive(this.parent)}removePanel(e){const t="string"==typeof e?e:e.id,i=this._panels.find((e=>e.id===t));if(!i)throw new Error("invalid operation");return this._removePanel(i)}closeAllPanels(){var e;return he(this,void 0,void 0,(function*(){const t=this._activePanel?this.panels.indexOf(this._activePanel):-1;if(this._activePanel&&t>-1){this.panels.indexOf(this._activePanel)<0&&console.warn("active panel not tracked");if(!(!(null===(e=this._activePanel)||void 0===e?void 0:e.close)||(yield this._activePanel.close())))return!1}for(let e=0;e<this.panels.length;e++){if(e===t)continue;const i=this.panels[e];if(this.openPanel(i),i.close){if(!(yield i.close()))return!1}}if(this.panels.length>0){const e=[...this.panels];yield Promise.all(e.map((e=>this.doClose(e))))}else this.accessor.removeGroup(this.parent);return!0}))}doClose(e){this.accessor.removePanel(e)}isPanelActive(e){return this._activePanel===e}updateActions(){var e,t;this.isActive&&(null===(t=null===(e=this._activePanel)||void 0===e?void 0:e.view)||void 0===t?void 0:t.actions)?this.tabsContainer.setActionElement(this._activePanel.view.actions.element):this.tabsContainer.setActionElement(void 0)}setActive(e,t=!1,i=!1){var n,s;i||this.isActive!==e?(this._isGroupActive=e,A(this.container,"active-group",e),A(this.container,"inactive-group",!e),this.tabsContainer.setActive(this.isActive),!this._activePanel&&this.panels.length>0&&this.doSetActivePanel(this.panels[0]),this.updateContainer(),e&&(t||null===(s=this._activePanel)||void 0===s||s.focus())):t||null===(n=this._activePanel)||void 0===n||n.focus()}layout(e,t){var i;this._width=e,this._height=t,this.contentContainer.layout(this._width,this._height),(null===(i=this._activePanel)||void 0===i?void 0:i.layout)&&this._activePanel.layout(this._width,this._height)}_removePanel(e){const t=this._activePanel===e;if(this.doRemovePanel(e),t&&this.panels.length>0){const e=this.mostRecentlyUsed[0];this.openPanel(e)}return this._activePanel&&0===this.panels.length&&this.doSetActivePanel(void 0),this.updateContainer(),e}doRemovePanel(e){const t=this.panels.indexOf(e);this._activePanel===e&&this.contentContainer.closePanel(),this.tabsContainer.delete(e.id),this._panels.splice(t,1),this.mostRecentlyUsed.includes(e)&&this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(e),1),this._onDidGroupChange.fire({kind:ce.REMOVE_PANEL,panel:e})}doAddPanel(e,t=this.panels.length){const i=this._panels.indexOf(e)>-1;this.tabsContainer.openPanel(e,t),this.contentContainer.openPanel(e),this.tabsContainer.show(),this.contentContainer.show(),i||(this.updateMru(e),this.panels.splice(t,0,e),this._onDidGroupChange.fire({kind:ce.ADD_PANEL,panel:e}))}doSetActivePanel(e){this._activePanel=e,e&&(this.tabsContainer.setActivePanel(e),e.layout(this._width,this._height),this.updateMru(e),this._onDidGroupChange.fire({kind:ce.PANEL_ACTIVE,panel:e}))}updateMru(e){this.mostRecentlyUsed.includes(e)&&this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(e),1),this.mostRecentlyUsed=[e,...this.mostRecentlyUsed]}updateContainer(){if(this.updateActions(),A(this.container,"empty",this.isEmpty),this.panels.forEach((e=>e.updateParentGroup(this.parent,this.isActive))),this.isEmpty&&!this.watermark){const e=this.accessor.createWatermarkComponent();e.init({containerApi:new x(this.accessor),params:{},title:"",api:null}),this.watermark=e,a(this.watermark.element,"click",(()=>{this.isActive||this.accessor.doSetGroupActive(this.parent)})),this.contentContainer.hide(),this.tabsContainer.hide(),this.container.appendChild(this.watermark.element),this.watermark.updateParentGroup(this.parent,!0)}!this.isEmpty&&this.watermark&&(this.watermark.element.remove(),this.watermark.dispose(),this.watermark=void 0,this.contentContainer.show(),this.tabsContainer.show())}canDisplayOverlay(e,t){return!1}handleDropEvent(e,t,i){const n=f();if(n){if(-1!==this.tabsContainer.indexOf(n.panelId)&&1===this.tabsContainer.size)return;const{groupId:e,panelId:s}=n;if(this.id===e&&!t){if(this.tabsContainer.indexOf(s)===i)return}this._onMove.fire({target:t,groupId:n.groupId,itemId:n.panelId,index:i})}}dispose(){for(const e of this.panels)e.dispose();super.dispose(),this.dropTarget.dispose(),this.tabsContainer.dispose(),this.contentContainer.dispose()}}!function(e){e.ADD_PANEL="ADD_PANEL",e.REMOVE_PANEL="REMOVE_PANEL",e.PANEL_ACTIVE="PANEL_ACTIVE",e.GROUP_ACTIVE="GROUP_ACTIVE",e.ADD_GROUP="ADD_GROUP",e.REMOVE_GROUP="REMOVE_GROUP",e.LAYOUT_FROM_JSON="LAYOUT_FROM_JSON",e.LAYOUT="LAYOUT"}(me||(me={}));const we=V();function be(e){switch(e){case"left":return U.Left;case"right":return U.Right;case"above":return U.Top;case"below":return U.Bottom;default:return U.Center}}class fe extends r{constructor(e,t){super(),this._element=e,this._id=we.next(),this._groups=new Map,this._onGridEvent=new s,this.onGridEvent=this._onGridEvent.event,this._onDidLayoutChange=new s,this.onDidLayoutChange=this._onDidLayoutChange.event,this.gridview=new re(!!t.proportionalLayout,t.styles,t.orientation),this.element.appendChild(this.gridview.element),this.layout(0,0,!0),this.addDisposables(this.gridview.onDidChange((()=>{this._onGridEvent.fire({kind:me.LAYOUT})}))),this.addDisposables((()=>{let e;return this.onGridEvent((t=>{[me.ADD_GROUP,me.REMOVE_GROUP,me.ADD_PANEL,me.REMOVE_PANEL,me.GROUP_ACTIVE,me.PANEL_ACTIVE,me.LAYOUT].includes(t.kind)&&(e&&clearTimeout(e),e=setTimeout((()=>{this._onDidLayoutChange.fire(),clearTimeout(e)})))}))})())}get id(){return this._id}get element(){return this._element}get size(){return this._groups.size}get groups(){return Array.from(this._groups.values()).map((e=>e.value))}get width(){return this.gridview.width}get height(){return this.gridview.height}get minimumHeight(){return this.gridview.minimumHeight}get maximumHeight(){return this.gridview.maximumHeight}get minimumWidth(){return this.gridview.minimumWidth}get maximumWidth(){return this.gridview.maximumWidth}get activeGroup(){return this._activeGroup}setVisible(e,t){this.gridview.setViewVisible(ee(e.element),t),this._onGridEvent.fire({kind:me.LAYOUT})}isVisible(e){return this.gridview.isViewVisible(ee(e.element))}doAddGroup(e,t=[0],i){this.gridview.addView(e,null!=i?i:J.Distribute,t),this._onGridEvent.fire({kind:me.ADD_GROUP}),this.doSetGroupActive(e)}doRemoveGroup(e,t){if(!this._groups.has(e.id))throw new Error("invalid operation");const i=this._groups.get(e.id),n=this.gridview.remove(e,J.Distribute);if(i&&!(null==t?void 0:t.skipDispose)&&(i.disposable.dispose(),this._groups.delete(e.id)),this._onGridEvent.fire({kind:me.REMOVE_GROUP}),!(null==t?void 0:t.skipActive)&&this._activeGroup===e){const e=Array.from(this._groups.values());this.doSetGroupActive(e.length>0?e[0].value:void 0)}return n}getPanel(e){var t;return null===(t=this._groups.get(e))||void 0===t?void 0:t.value}doSetGroupActive(e,t){this._activeGroup!==e&&(this._activeGroup&&(this._activeGroup.setActive(!1),t||this._activeGroup.focus()),e&&(e.setActive(!0),t||e.focus()),this._activeGroup=e,this._onGridEvent.fire({kind:me.GROUP_ACTIVE}))}removeGroup(e){this.doRemoveGroup(e)}moveToNext(e){var t;if(e||(e={}),!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}const i=ee(e.group.element),n=null===(t=this.gridview.next(i))||void 0===t?void 0:t.view;this.doSetGroupActive(n)}moveToPrevious(e){var t;if(e||(e={}),!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}const i=ee(e.group.element),n=null===(t=this.gridview.previous(i))||void 0===t?void 0:t.view;this.doSetGroupActive(n)}layout(e,t,i){(i||e!==this.width||t!==this.height)&&(this.element.style.height=`${t}px`,this.element.style.width=`${e}px`,this.gridview.layout(e,t))}resizeToFit(){if(!this.element.parentElement)return;const{width:e,height:t}=this.element.parentElement.getBoundingClientRect();this.layout(e,t)}dispose(){super.dispose(),this._onGridEvent.dispose(),this.gridview.dispose()}}class _e extends r{constructor(e){super(),this.id=e,this._state={},this._isFocused=!1,this._isActive=!1,this._isVisible=!0,this._width=0,this._height=0,this._onDidStateChange=new s,this.onDidStateChange=this._onDidStateChange.event,this._onDidPanelDimensionChange=new s({replay:!0}),this.onDidDimensionsChange=this._onDidPanelDimensionChange.event,this._onDidChangeFocus=new s({replay:!0}),this.onDidFocusChange=this._onDidChangeFocus.event,this._onFocusEvent=new s,this.onFocusEvent=this._onFocusEvent.event,this._onDidVisibilityChange=new s({replay:!0}),this.onDidVisibilityChange=this._onDidVisibilityChange.event,this._onVisibilityChange=new s,this.onVisibilityChange=this._onVisibilityChange.event,this._onDidActiveChange=new s({replay:!0}),this.onDidActiveChange=this._onDidActiveChange.event,this._onActiveChange=new s,this.onActiveChange=this._onActiveChange.event,this.addDisposables(this._onDidStateChange,this._onDidPanelDimensionChange,this._onDidChangeFocus,this._onDidVisibilityChange,this._onDidActiveChange,this._onFocusEvent,this.onDidFocusChange((e=>{this._isFocused=e.isFocused})),this.onDidActiveChange((e=>{this._isActive=e.isActive})),this.onDidVisibilityChange((e=>{this._isVisible=e.isVisible})),this.onDidDimensionsChange((e=>{this._width=e.width,this._height=e.height})))}get isFocused(){return this._isFocused}get isActive(){return this._isActive}get isVisible(){return this._isVisible}get width(){return this._width}get height(){return this._height}setVisible(e){this._onVisibilityChange.fire({isVisible:e})}setActive(){this._onActiveChange.fire()}setState(e,t){"object"==typeof e?this._state=e:void 0!==typeof t&&(this._state[e]=t),this._onDidStateChange.fire(void 0)}getState(){return this._state}getStateKey(e){return this._state[e]}dispose(){super.dispose()}}class Ce extends _e{constructor(e){super(e),this._onDidConstraintsChangeInternal=new s,this.onDidConstraintsChangeInternal=this._onDidConstraintsChangeInternal.event,this._onDidConstraintsChange=new s({replay:!0}),this.onDidConstraintsChange=this._onDidConstraintsChange.event,this._onDidSizeChange=new s,this.onDidSizeChange=this._onDidSizeChange.event}setConstraints(e){this._onDidConstraintsChangeInternal.fire(e)}setSize(e){this._onDidSizeChange.fire(e)}}class ye extends Ce{constructor(e,t){super(e.id),this.panel=e,this._onDidDirtyChange=new s,this.onDidDirtyChange=this._onDidDirtyChange.event,this._onDidTitleChange=new s,this.onDidTitleChange=this._onDidTitleChange.event,this._titleChanged=new s,this.titleChanged=this._titleChanged.event,this._suppressClosableChanged=new s,this.suppressClosableChanged=this._suppressClosableChanged.event,this._group=t,this.addDisposables(this._onDidDirtyChange)}get tryClose(){return this._interceptor}get title(){return this.panel.title}get suppressClosable(){return!!this.panel.suppressClosable}get isGroupActive(){var e;return!!(null===(e=this.group)||void 0===e?void 0:e.isActive)}set group(e){this._group=e}get group(){return this._group}setTitle(e){this._onDidTitleChange.fire({title:e})}close(){if(!this.group)throw new Error(`panel ${this.id} has no group`);return this.group.model.closePanel(this.panel)}interceptOnCloseAction(e){this._interceptor=e}dispose(){super.dispose()}}class ze extends r{constructor(e,t){super(),this.id=e,this.containerApi=t,this.mutableDisposable=new h,this._suppressClosable=!1,this._title="",this.api=new ye(this,this._group),this.onDidStateChange=this.api.onDidStateChange,this.addDisposables(this.api.onActiveChange((()=>{this.containerApi.setActivePanel(this)})),this.api.onDidTitleChange((e=>{const t=e.title;this.update({params:{title:t}})})))}get title(){return this._title}get suppressClosable(){return this._suppressClosable}get group(){return this._group}get view(){return this._view}init(e){var t;this._params=e.params,this._view=e.view,this.setTitle(e.title),this.setSuppressClosable(e.suppressClosable||!1),e.state&&this.api.setState(e.state),null===(t=this.view)||void 0===t||t.init(Object.assign(Object.assign({},e),{api:this.api,containerApi:this.containerApi}))}focus(){this.api._onFocusEvent.fire()}setDirty(e){this.api._onDidDirtyChange.fire(e)}close(){return this.api.tryClose?this.api.tryClose():Promise.resolve(!0)}toJSON(){const e=this.api.getState();return{id:this.id,view:this.view.toJSON(),params:Object.keys(this._params||{}).length>0?this._params:void 0,state:e&&Object.keys(e).length>0?e:void 0,suppressClosable:this.suppressClosable||void 0,title:this.title}}setTitle(e){var t;e!==(null===(t=this._params)||void 0===t?void 0:t.title)&&(this._title=e,this.api._titleChanged.fire({title:this.title}))}setSuppressClosable(e){var t;e!==(null===(t=this._params)||void 0===t?void 0:t.suppressClosable)&&(this._suppressClosable=e,this.api._suppressClosableChanged.fire({suppressClosable:!!this.suppressClosable}))}update(e){var t;const i=e.params;this._params=Object.assign(Object.assign({},this._params||{}),e.params.params),"string"==typeof i.title&&this.setTitle(i.title),"boolean"==typeof i.suppressClosable&&this.setSuppressClosable(i.suppressClosable),null===(t=this.view)||void 0===t||t.update({params:{params:this._params,title:this.title,suppressClosable:this.suppressClosable}})}updateParentGroup(e,t){var i;this._group=e,this.api.group=e,this.mutableDisposable.value=this._group.model.onDidGroupChange((e=>{var i;if(e.kind===ce.GROUP_ACTIVE){const e=!!(null===(i=this._group)||void 0===i?void 0:i.model.isPanelActive(this));this.api._onDidActiveChange.fire({isActive:t&&e}),this.api._onDidVisibilityChange.fire({isVisible:e})}}));const n=this._group.model.isPanelActive(this);this.api._onDidActiveChange.fire({isActive:t&&n}),this.api._onDidVisibilityChange.fire({isVisible:n}),null===(i=this.view)||void 0===i||i.updateParentGroup(this._group,this._group.model.isPanelActive(this))}layout(e,t){var i,n;this.api._onDidPanelDimensionChange.fire({width:e,height:t-((null===(i=this.group)||void 0===i?void 0:i.model.tabHeight)||0)}),null===(n=this.view)||void 0===n||n.layout(e,t)}dispose(){var e;this.api.dispose(),this.mutableDisposable.dispose(),null===(e=this.view)||void 0===e||e.dispose()}}class xe{constructor(){this._element=document.createElement("div"),this._element.className="actions-bar",this._list=document.createElement("ul"),this._list.className="actions-container",this._element.appendChild(this._list)}get element(){return this._element}add(e){document.createElement("li").className="action-item",this._list.appendChild(e)}}class De extends r{constructor(){super(),this._element=document.createElement("div"),this._element.className="watermark";const e=document.createElement("div");e.className="watermark-title";const t=document.createElement("span");t.style.flexGrow="1";const i=document.createElement("div");i.className="watermark-content",this._element.appendChild(e),this._element.appendChild(i);const n=new xe;e.appendChild(t),e.appendChild(n.element);const s=document.createElement("a");s.className="close-action",n.add(s),this.addDisposables(a(s,"click",(e=>{var t;e.preventDefault(),this.group&&(null===(t=this.params)||void 0===t||t.containerApi.removeGroup(this.group))})))}get id(){return"watermark"}update(e){}focus(){}toJSON(){return{}}layout(e,t){}init(e){this.params=e,this.addDisposables(this.params.containerApi.onDidLayoutChange((e=>{this.render()}))),this.render()}updateParentGroup(e,t){this.group=e,this.render()}get element(){return this._element}render(){const e=!!(this.params&&this.params.containerApi.size<=1);A(this.element,"has-actions",e)}dispose(){super.dispose()}}class Ee{constructor(e,t){this.layout=e,this.panelDeserializer=t}fromJSON(e){const t=e.data.views,i=e.data.activeView,n=[];for(const e of t){const t=this.panelDeserializer.createPanel(e);n.push(t)}return this.layout.createGroup({panels:n,activePanel:n.find((e=>e.id===i)),id:e.data.id})}}function Se(e,t,i={},n={},s,o){const a="string"==typeof t?i[t]:void 0,r="string"==typeof t?n[t]:void 0;if(a&&r)throw new Error(`Cannot create '${e}'. component '${t}' registered as both a component and frameworkComponent`);if(r){if(!s)throw new Error(`Cannot create '${e}' for framework component '${t}'. you must register a frameworkPanelWrapper to use framework components`);return s.createComponent(e,t,r)}if(!a){if(o)return o();throw new Error(`Cannot create '${e}', no component '${t}' provided`)}return new a(e,t)}class Ae{constructor(e){this.renderer=e,this._element=document.createElement("element"),this.show()}get innerRenderer(){return this.renderer}get element(){return this._element}get id(){return this.renderer.id}show(){this.renderer.element.parentElement||this._element.appendChild(this.renderer.element)}hide(){this.renderer.element.parentElement&&this.renderer.element.remove()}layout(e,t){this.renderer.layout(e,t)}update(e){this.renderer.update(e)}toJSON(){return this.renderer.toJSON()}focus(){this.renderer.focus()}init(e){this.renderer.init(e)}updateParentGroup(e,t){this.renderer.updateParentGroup(e,t)}dispose(){this.renderer.dispose()}}class Pe extends r{constructor(){super(),this._isPanelVisible=!1,this._isGroupActive=!1,this.params={},this.isDirtyDisposable=new h,this.addDisposables(this.isDirtyDisposable),this._element=document.createElement("div"),this._element.className="default-tab",this._content=document.createElement("div"),this._content.className="tab-content",this._actionContainer=document.createElement("div"),this._actionContainer.className="action-container",this._list=document.createElement("ul"),this._list.className="tab-list",this.action=document.createElement("a"),this.action.className="tab-action",this._element.appendChild(this._content),this._element.appendChild(this._actionContainer),this._actionContainer.appendChild(this._list),this._list.appendChild(this.action),this.addDisposables(a(this._actionContainer,"mousedown",(e=>{e.preventDefault()}))),this.render()}get element(){return this._element}get id(){return"__DEFAULT_TAB__"}update(e){this.params=Object.assign(Object.assign({},this.params),e.params),this.render()}toJSON(){return{id:this.id}}focus(){}init(e){this.params=e,this._content.textContent=e.title,this.isDirtyDisposable.value=this.params.api.onDidDirtyChange((e=>{const t=e;A(this.action,"dirty",t)})),this.params.suppressClosable?this.action.classList.add("disable-close"):a(this.action,"click",(e=>{e.preventDefault(),this.params.api.close()}))}updateParentGroup(e,t){this._isPanelVisible=t,this._isGroupActive=e.isActive,this.render()}layout(e,t){}render(){this._content.textContent=this.params.title}}class Oe extends r{constructor(e,t,i){super(),this.id=e,this.component=t,this.api=i,this._height=0,this._width=0,this._element=document.createElement("div"),this._element.tabIndex=-1,this._element.style.outline="none",this._element.style.height="100%",this._element.style.width="100%",this._element.style.overflow="hidden";const{onDidFocus:n,onDidBlur:s}=N(this._element);this.addDisposables(this.api,n((()=>{this.api._onDidChangeFocus.fire({isFocused:!0})})),s((()=>{this.api._onDidChangeFocus.fire({isFocused:!1})})))}get element(){return this._element}get width(){return this._width}get height(){return this._height}focus(){this.api._onFocusEvent.fire()}layout(e,t){this._width=e,this._height=t,this.api._onDidPanelDimensionChange.fire({width:e,height:t}),this.part&&this.params&&this.part.update(this.params.params)}init(e){this.params=e,this.part=this.getComponent()}update(e){var t,i;this.params=Object.assign(Object.assign({},this.params),{params:Object.assign(Object.assign({},null===(t=this.params)||void 0===t?void 0:t.params),e.params)}),null===(i=this.part)||void 0===i||i.update({params:this.params.params})}toJSON(){var e,t;const i=this.api.getState(),n=null!==(t=null===(e=this.params)||void 0===e?void 0:e.params)&&void 0!==t?t:{};return{id:this.id,component:this.component,params:Object.keys(n).length>0?n:void 0,state:0===Object.keys(i).length?void 0:i}}dispose(){super.dispose(),this.api.dispose()}}class Ne extends Oe{constructor(e,t,i=new Ce(e)){super(e,t,i),this._evaluatedMinimumWidth=0,this._evaluatedMaximumWidth=Number.MAX_SAFE_INTEGER,this._evaluatedMinimumHeight=0,this._evaluatedMaximumHeight=Number.MAX_SAFE_INTEGER,this._minimumWidth=0,this._minimumHeight=0,this._maximumWidth=Number.MAX_SAFE_INTEGER,this._maximumHeight=Number.MAX_SAFE_INTEGER,this._snap=!1,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.addDisposables(this.api.onVisibilityChange((e=>{const{isVisible:t}=e,{containerApi:i}=this.params;i.setVisible(this,t)})),this.api.onActiveChange((()=>{const{containerApi:e}=this.params;e.setActive(this)})),this.api.onDidConstraintsChangeInternal((e=>{"number"!=typeof e.minimumWidth&&"function"!=typeof e.minimumWidth||(this._minimumWidth=e.minimumWidth),"number"!=typeof e.minimumHeight&&"function"!=typeof e.minimumHeight||(this._minimumHeight=e.minimumHeight),"number"!=typeof e.maximumWidth&&"function"!=typeof e.maximumWidth||(this._maximumWidth=e.maximumWidth),"number"!=typeof e.maximumHeight&&"function"!=typeof e.maximumHeight||(this._maximumHeight=e.maximumHeight)})),this.api.onDidSizeChange((e=>{this._onDidChange.fire({height:e.height,width:e.width})})))}get priority(){return this._priority}get snap(){return this._snap}get minimumWidth(){const e="function"==typeof this._minimumWidth?this._minimumWidth():this._minimumWidth;return e!==this._evaluatedMinimumWidth&&(this._evaluatedMinimumWidth=e,this.updateConstraints()),e}get minimumHeight(){const e="function"==typeof this._minimumHeight?this._minimumHeight():this._minimumHeight;return e!==this._evaluatedMinimumHeight&&(this._evaluatedMinimumHeight=e,this.updateConstraints()),e}get maximumHeight(){const e="function"==typeof this._maximumHeight?this._maximumHeight():this._maximumHeight;return e!==this._evaluatedMaximumHeight&&(this._evaluatedMaximumHeight=e,this.updateConstraints()),e}get maximumWidth(){const e="function"==typeof this._maximumWidth?this._maximumWidth():this._maximumWidth;return e!==this._evaluatedMaximumWidth&&(this._evaluatedMaximumWidth=e,this.updateConstraints()),e}get isActive(){return this.api.isActive}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}init(e){e.maximumHeight&&(this._maximumHeight=e.maximumHeight),e.minimumHeight&&(this._minimumHeight=e.minimumHeight),e.maximumWidth&&(this._maximumWidth=e.maximumWidth),e.minimumWidth&&(this._minimumWidth=e.minimumWidth),this._priority=e.priority,this._snap=!!e.snap,super.init(e),"boolean"==typeof e.isVisible&&this.setVisible(e.isVisible)}updateConstraints(){this.api._onDidConstraintsChange.fire({minimumWidth:this._evaluatedMinimumWidth,maximumWidth:this._evaluatedMaximumWidth,minimumHeight:this._evaluatedMinimumHeight,maximumHeight:this._evaluatedMaximumHeight})}toJSON(){const e=super.toJSON(),t=e=>e===Number.MAX_SAFE_INTEGER?void 0:e,i=e=>e<=0?void 0:e;return Object.assign(Object.assign({},e),{minimumHeight:i(this.minimumHeight),maximumHeight:t(this.maximumHeight),minimumWidth:i(this.minimumWidth),maximumWidth:t(this.maximumWidth),snap:this.snap,priority:this.priority})}dispose(){super.dispose()}}class Ie extends Ne{constructor(e,t,i){super(t,"groupview_default",new Ce(t)),this._model=new ge(this.element,e,t,i,this)}get model(){return this._model}get minimumHeight(){return this._model.minimumHeight}get maximumHeight(){return this._model.maximumHeight}get minimumWidth(){return this._model.minimumWidth}get maximumWidth(){return this._model.maximumWidth}initialize(){this.model.initialize()}setActive(e){super.setActive(e),this.model.setActive(e)}layout(e,t){super.layout(e,t),this.model.layout(e,t)}getComponent(){return this._model}toJSON(){return this.model.toJSON()}}class ke{constructor(e){var t;this._content=e.content,this._tab=new Ae(null!==(t=e.tab)&&void 0!==t?t:new Pe),this._actions=e.actions||(this.content.actions?{element:this.content.actions,dispose:()=>{}}:void 0)}get content(){return this._content}get tab(){return this._tab}get actions(){return this._actions}init(e){this.content.init(Object.assign(Object.assign({},e),{tab:this.tab})),this.tab.init(e)}updateParentGroup(e,t){}layout(e,t){this.content.layout(e,t)}update(e){this.content.update(e),this.tab.update(e)}toJSON(){return{content:this.content.toJSON(),tab:this.tab.innerRenderer instanceof Pe?void 0:this.tab.toJSON()}}dispose(){var e;this.content.dispose(),this.tab.dispose(),null===(e=this.actions)||void 0===e||e.dispose()}}const Ve=V();class Te extends fe{constructor(e,t){super(e,{proportionalLayout:!0,orientation:t.orientation||F.HORIZONTAL,styles:t.styles}),this._panels=new Map,this.dirtyPanels=new Set,this.debouncedDeque=function(e,t){let i;return(...n)=>{clearTimeout(i),i=setTimeout((()=>e(...n)),t)}}(this.syncConfigs.bind(this),5e3),this._onTabInteractionEvent=new s,this.onTabInteractionEvent=this._onTabInteractionEvent.event,this._onTabContextMenu=new s,this.onTabContextMenu=this._onTabContextMenu.event,this.panelState={},this._options=t,this.options.components||(this.options.components={}),this.options.frameworkComponents||(this.options.frameworkComponents={}),this.options.frameworkTabComponents||(this.options.frameworkTabComponents={}),this.options.tabComponents||(this.options.tabComponents={}),this.options.watermarkComponent||this.options.watermarkFrameworkComponent||(this.options.watermarkComponent=De),this._api=new x(this)}get totalPanels(){return this._panels.size}get panels(){return Array.from(this._panels.values()).map((e=>e.value))}get deserializer(){return this._deserializer}set deserializer(e){this._deserializer=e}get options(){return this._options}get activePanel(){const e=this.activeGroup;if(e)return e.model.activePanel}set tabHeight(e){this.options.tabHeight=e,this._groups.forEach((t=>{t.value.model.tabHeight=e}))}get tabHeight(){return this.options.tabHeight}updateOptions(e){const t="string"==typeof e.orientation&&this.options.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),t&&(this.gridview.orientation=e.orientation),this.layout(this.gridview.width,this.gridview.height,!0)}focus(){var e;null===(e=this.activeGroup)||void 0===e||e.focus()}getGroupPanel(e){var t;return null===(t=this._panels.get(e))||void 0===t?void 0:t.value}setActivePanel(e){if(!e.group)throw new Error(`Panel ${e.id} has no associated group`);this.doSetGroupActive(e.group),e.group.model.openPanel(e)}moveToNext(e={}){var t;if(!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}if(e.includePanel&&e.group&&e.group.model.activePanel!==e.group.model.panels[e.group.model.panels.length-1])return void e.group.model.moveToNext({suppressRoll:!0});const i=ee(e.group.element),n=null===(t=this.gridview.next(i))||void 0===t?void 0:t.view;this.doSetGroupActive(n)}moveToPrevious(e={}){var t;if(!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}if(e.includePanel&&e.group&&e.group.model.activePanel!==e.group.model.panels[0])return void e.group.model.moveToPrevious({suppressRoll:!0});const i=ee(e.group.element),n=null===(t=this.gridview.previous(i))||void 0===t?void 0:t.view;n&&this.doSetGroupActive(n)}registerPanel(e){if(this._panels.has(e.id))throw new Error(`panel ${e.id} already exists`);const t=new r(e.onDidStateChange((()=>this.addDirtyPanel(e))));this._panels.set(e.id,{value:e,disposable:t})}unregisterPanel(e){if(!this._panels.has(e.id))throw new Error(`panel ${e.id} doesn't exist`);const t=this._panels.get(e.id);t&&(t.disposable.dispose(),t.value.dispose()),this._panels.delete(e.id)}toJSON(){var e;this.syncConfigs();return{grid:this.gridview.serialize(),panels:Array.from(this._panels.values()).reduce(((e,t)=>(this.panelState[t.value.id]||(e[t.value.id]=t.value.toJSON()),e)),{}),activeGroup:null===(e=this.activeGroup)||void 0===e?void 0:e.id,options:{tabHeight:this.tabHeight}}}fromJSON(e){if(this.gridview.clear(),this._panels.forEach((e=>{e.disposable.dispose(),e.value.dispose()})),this._panels.clear(),this._groups.clear(),!this.deserializer)throw new Error("invalid deserializer");const{grid:t,panels:i,options:n,activeGroup:s}=e;if("number"==typeof(null==n?void 0:n.tabHeight)&&(this.tabHeight=n.tabHeight),!this.deserializer)throw new Error("no deserializer provided");if(this.gridview.deserialize(t,new Ee(this,{createPanel:e=>{const t=i[e],n=this.deserializer.fromJSON(t);return this.registerPanel(n),n}})),"string"==typeof s){const e=this.getPanel(s);e&&this.doSetGroupActive(e)}this.gridview.layout(this.width,this.height),this._onGridEvent.fire({kind:me.LAYOUT_FROM_JSON})}closeAllGroups(){return he(this,void 0,void 0,(function*(){for(const e of this._groups.entries()){const[t,i]=e;if(!(yield i.value.model.closeAllPanels()))return!1}return!0}))}fireMouseEvent(e){if(e.kind===pe.CONTEXT_MENU)e.tab&&e.panel&&this._onTabContextMenu.fire({event:e.event,api:this._api,panel:e.panel})}addPanel(e){var t,i;const n=this._addPanel(e);let s;if(null===(t=e.position)||void 0===t?void 0:t.referencePanel){const t=this.getGroupPanel(e.position.referencePanel);if(!t)throw new Error(`referencePanel ${e.position.referencePanel} does not exist`);s=this.findGroup(t)}else s=this.activeGroup;if(s){const t=be((null===(i=e.position)||void 0===i?void 0:i.direction)||"within");if(t===U.Center)s.model.openPanel(n);else{const e=ee(s.element),i=te(this.gridview.orientation,e,t);this.addPanelToNewGroup(n,i)}}else this.addPanelToNewGroup(n);return n}removePanel(e){this.unregisterPanel(e);const t=e.group;if(!t)throw new Error(`cannot remove panel ${e.id}. it's missing a group.`);t.model.removePanel(e),0===t.model.size&&this.removeGroup(t)}createWatermarkComponent(){var e;return Se("watermark-id","watermark-name",this.options.watermarkComponent?{"watermark-name":this.options.watermarkComponent}:{},this.options.watermarkFrameworkComponent?{"watermark-name":this.options.watermarkFrameworkComponent}:{},null===(e=this.options.frameworkComponentFactory)||void 0===e?void 0:e.watermark)}addEmptyGroup(e){var t;const i=this.createGroup();if(e){const n=null===(t=this._panels.get(e.referencePanel))||void 0===t?void 0:t.value;if(!n)throw new Error(`reference panel ${e.referencePanel} does not exist`);const s=this.findGroup(n);if(!s)throw new Error(`reference group for reference panel ${e.referencePanel} does not exist`);const o=be(e.direction||"within"),a=ee(s.element),r=te(this.gridview.orientation,a,o);this.doAddGroup(i,r)}else this.doAddGroup(i)}removeGroup(e){[...e.model.panels].forEach((e=>{this.removePanel(e)})),1!==this._groups.size?super.removeGroup(e):this._activeGroup=e}moveGroupOrPanel(e,t,i,n,s){var o,a,r;const h=t?null===(o=this._groups.get(t))||void 0===o?void 0:o.value:void 0;if(n&&n!==U.Center){const t=ee(e.element),s=te(this.gridview.orientation,t,n);if(h&&h.model.size<2){const[t,i]=T(s),o=ee(h.element),[a,r]=T(o);if(L(a,t))this.gridview.moveView(a,r,i);else{const t=this.doRemoveGroup(h,{skipActive:!0,skipDispose:!0}),i=ee(e.element),s=te(this.gridview.orientation,i,n);this.doAddGroup(t,s)}}else{const e=(null==h?void 0:h.model.removePanel(i))||(null===(r=this._panels.get(i))||void 0===r?void 0:r.value);if(!e)throw new Error(`No panel with id ${i}`);const s=te(this.gridview.orientation,t,n);this.addPanelToNewGroup(e,s)}}else{const t=(null==h?void 0:h.model.removePanel(i))||(null===(a=this._panels.get(i))||void 0===a?void 0:a.value);if(!t)throw new Error(`No panel with id ${i}`);0===(null==h?void 0:h.model.size)&&this.doRemoveGroup(h),e.model.openPanel(t,{index:s})}}doSetGroupActive(e,t){var i,n;const s=this._activeGroup===e;super.doSetGroupActive(e,t),!s&&(null===(i=this._activeGroup)||void 0===i?void 0:i.model.activePanel)&&this._onGridEvent.fire({kind:me.PANEL_ACTIVE,panel:null===(n=this._activeGroup)||void 0===n?void 0:n.model.activePanel})}createGroup(e){e||(e={tabHeight:this.tabHeight}),"number"!=typeof e.tabHeight&&(e.tabHeight=this.tabHeight);let t=null==e?void 0:e.id;if(t&&this._groups.has(e.id)&&(console.warn(`Duplicate group id ${null==e?void 0:e.id}. reassigning group id to avoid errors`),t=void 0),!t)for(t=Ve.next();this._groups.has(t);)t=Ve.next();const i=new Ie(this,t,e);if(!this._groups.has(i.id)){const e=new r(i.model.onMove((e=>{const{groupId:t,itemId:n,target:s,index:o}=e;this.moveGroupOrPanel(i,t,n,s,o)})),i.model.onDidGroupChange((e=>{switch(e.kind){case ce.ADD_PANEL:this._onGridEvent.fire({kind:me.ADD_PANEL,panel:e.panel});break;case ce.GROUP_ACTIVE:this._onGridEvent.fire({kind:me.GROUP_ACTIVE,panel:e.panel});break;case ce.REMOVE_PANEL:this._onGridEvent.fire({kind:me.REMOVE_PANEL,panel:e.panel});break;case ce.PANEL_ACTIVE:this._onGridEvent.fire({kind:me.PANEL_ACTIVE,panel:e.panel})}})));this._groups.set(i.id,{value:i,disposable:e})}return i.initialize(),"number"==typeof this.options.tabHeight&&(i.model.tabHeight=this.options.tabHeight),i}dispose(){super.dispose(),this._onGridEvent.dispose()}syncConfigs(){const e=Array.from(this.dirtyPanels);e.length,this.dirtyPanels.clear();const t=e.map((e=>this._panels.get(e.id))).filter((e=>!!e)).reduce(((e,t)=>(e[t.value.id]=t.value.toJSON(),e)),{});this.panelState=Object.assign(Object.assign({},this.panelState),t),e.filter((e=>this._panels.has(e.id))).forEach((e=>{e.setDirty(!1)}))}_addPanel(e){const t=new ke({content:this.createContentComponent(e.id,e.component),tab:this.createTabComponent(e.id,e.tabComponent)}),i=new ze(e.id,this._api);return i.init({view:t,title:e.title||e.id,suppressClosable:null==e?void 0:e.suppressClosable,params:(null==e?void 0:e.params)||{}}),this.registerPanel(i),i}createContentComponent(e,t){var i;return Se(e,t,this.options.components||{},this.options.frameworkComponents,null===(i=this.options.frameworkComponentFactory)||void 0===i?void 0:i.content)}createTabComponent(e,t){var i;return Se(e,t,this.options.tabComponents||{},this.options.frameworkTabComponents,null===(i=this.options.frameworkComponentFactory)||void 0===i?void 0:i.tab,(()=>new Pe))}addPanelToNewGroup(e,t=[0]){const i=this.createGroup();this.doAddGroup(i,t),i.model.openPanel(e)}findGroup(e){var t;return null===(t=Array.from(this._groups.values()).find((t=>t.value.model.containsPanel(e))))||void 0===t?void 0:t.value}addDirtyPanel(e){this.dirtyPanels.add(e),e.setDirty(!0),this.debouncedDeque()}}class Le extends fe{constructor(e,t){super(e,{proportionalLayout:t.proportionalLayout,orientation:t.orientation,styles:t.styles}),this._options=t,this.options.components||(this.options.components={}),this.options.frameworkComponents||(this.options.frameworkComponents={})}get orientation(){return this.gridview.orientation}set orientation(e){this.gridview.orientation=e}get options(){return this._options}get deserializer(){return this._deserializer}set deserializer(e){this._deserializer=e}updateOptions(e){const t="string"==typeof e.orientation&&this.options.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),t&&(this.gridview.orientation=e.orientation),this.layout(this.gridview.width,this.gridview.height,!0)}removePanel(e){this.removeGroup(e)}toJSON(){var e;return{grid:this.gridview.serialize(),activePanel:null===(e=this.activeGroup)||void 0===e?void 0:e.id}}setVisible(e,t){this.gridview.setViewVisible(ee(e.element),t)}setActive(e){this._groups.forEach(((t,i)=>{t.value.setActive(e===t.value)}))}toggleVisibility(e){this.setVisible(e,!this.isVisible(e))}focus(){var e;null===(e=this.activeGroup)||void 0===e||e.focus()}fromJSON(e,t){const{grid:i,activePanel:n}=e;this.gridview.clear(),this._groups.clear();const s=[];if(this.gridview.deserialize(i,{fromJSON:e=>{const{data:t}=e,i=Se(t.id,t.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkComponentFactory?{createComponent:this.options.frameworkComponentFactory.createComponent}:void 0);return s.push((()=>i.init({params:t.params,minimumWidth:t.minimumWidth,maximumWidth:t.maximumWidth,minimumHeight:t.minimumHeight,maximumHeight:t.maximumHeight,priority:t.priority,snap:!!t.snap,containerApi:new z(this),isVisible:e.visible}))),this.registerPanel(i),i}}),this.layout(this.width,this.height,!0),t?setTimeout((()=>{s.forEach((e=>e()))}),0):s.forEach((e=>e())),"string"==typeof n){const e=this.getPanel(n);e&&this.doSetGroupActive(e)}this._onGridEvent.fire({kind:me.LAYOUT_FROM_JSON})}movePanel(e,t){var i;let n;const s=this.gridview.remove(e),o=null===(i=this._groups.get(t.reference))||void 0===i?void 0:i.value;if(!o)throw new Error(`reference group ${t.reference} does not exist`);const a=be(t.direction);if(a===U.Center)throw new Error(`${a} not supported as an option`);{const e=ee(o.element);n=te(this.gridview.orientation,e,a)}this.doAddGroup(s,n,t.size)}addPanel(e){var t,i;let n=e.location||[0];if(null===(t=e.position)||void 0===t?void 0:t.reference){const t=null===(i=this._groups.get(e.position.reference))||void 0===i?void 0:i.value;if(!t)throw new Error(`reference group ${e.position.reference} does not exist`);const s=be(e.position.direction);if(s===U.Center)throw new Error(`${s} not supported as an option`);{const e=ee(t.element);n=te(this.gridview.orientation,e,s)}}const s=Se(e.id,e.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkComponentFactory?{createComponent:this.options.frameworkComponentFactory.createComponent}:void 0);return s.init({params:e.params||{},minimumWidth:e.minimumWidth,maximumWidth:e.maximumWidth,minimumHeight:e.minimumHeight,maximumHeight:e.maximumHeight,priority:e.priority,snap:!!e.snap,containerApi:new z(this),isVisible:!0}),this.registerPanel(s),this.doAddGroup(s,n,e.size),{api:s.api}}registerPanel(e){const t=new r(e.api.onDidFocusChange((t=>{t.isFocused&&this._groups.forEach((t=>{const i=t.value;i!==e?i.setActive(!1):i.setActive(!0)}))})));this._groups.set(e.id,{value:e,disposable:t})}moveGroup(e,t,i){const n=this.getPanel(t);if(!n)throw new Error("invalid operation");const s=ee(e.element),o=te(this.gridview.orientation,s,i),[a,r]=T(o),h=ee(n.element),[d,l]=T(h);if(L(d,a))return void this.gridview.moveView(d,l,r);const p=this.doRemoveGroup(n,{skipActive:!0,skipDispose:!0}),c=ee(e.element),m=te(this.gridview.orientation,c,i);this.doAddGroup(p,m)}removeGroup(e){super.removeGroup(e);const t=this._groups.get(e.id);t&&(t.disposable.dispose(),this._groups.delete(e.id))}dispose(){super.dispose()}}class Ge extends r{constructor(e,t){super(),this.element=e,this._disposable=new h,this.panels=new Map,this._onDidLayoutChange=new s,this.onDidLayoutChange=this._onDidLayoutChange.event,this._options=t,t.components||(t.components={}),t.frameworkComponents||(t.frameworkComponents={}),this.splitview=new j(this.element,t),this.addDisposables(this._disposable)}get options(){return this._options}get orientation(){return this.splitview.orientation}get splitview(){return this._splitview}set splitview(e){this._splitview=e,this._disposable.value=new r(this._splitview.onDidSashEnd((()=>{this._onDidLayoutChange.fire(void 0)})))}get minimumSize(){return this.splitview.minimumSize}get maximumSize(){return this.splitview.maximumSize}get height(){return this.splitview.orientation===F.HORIZONTAL?this.splitview.orthogonalSize:this.splitview.size}get width(){return this.splitview.orientation===F.HORIZONTAL?this.splitview.size:this.splitview.orthogonalSize}get length(){return this.panels.size}updateOptions(e){const t="string"==typeof e.orientation&&this.options.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),t&&(this.splitview.orientation=e.orientation),this.splitview.layout(this.splitview.size,this.splitview.orthogonalSize)}focus(){var e;null===(e=this._activePanel)||void 0===e||e.focus()}movePanel(e,t){this.splitview.moveView(e,t)}setVisible(e,t){const i=this.getPanels().indexOf(e);this.splitview.setViewVisible(i,t)}setActive(e,t){this._activePanel=e,this.getPanels().filter((t=>t!==e)).forEach((e=>{e.api._onDidActiveChange.fire({isActive:!1}),t||e.focus()})),e.api._onDidActiveChange.fire({isActive:!0}),t||e.focus()}getPanels(){return this.splitview.getViews()}removePanel(e,t){const i=this.panels.get(e.id);null==i||i.dispose(),this.panels.delete(e.id);const n=this.getPanels().findIndex((t=>t===e));this.splitview.removeView(n,t);const s=this.getPanels();s.length>0&&this.setActive(s[s.length-1])}getPanel(e){return this.getPanels().find((t=>t.id===e))}addPanel(e){if(this.panels.has(e.id))throw new Error(`panel ${e.id} already exists`);const t=Se(e.id,e.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.createComponent}:void 0);t.orientation=this.splitview.orientation,t.init({params:e.params||{},minimumSize:e.minimumSize,maximumSize:e.maximumSize,snap:e.snap,priority:e.priority,containerApi:new C(this)});const i="number"==typeof e.size?e.size:J.Distribute,n="number"==typeof e.index?e.index:void 0;this.splitview.addView(t,i,n),this.doAddView(t),this.setActive(t)}resizeToFit(){if(!this.element.parentElement)return;const{width:e,height:t}=this.element.parentElement.getBoundingClientRect();this.layout(e,t)}layout(e,t){const[i,n]=this.splitview.orientation===F.HORIZONTAL?[e,t]:[t,e];this.splitview.layout(i,n)}doAddView(e){const t=e.api.onDidFocusChange((t=>{t.isFocused&&this.setActive(e,!0)}));this.panels.set(e.id,t)}toJSON(){var e;return{views:this.splitview.getViews().map(((e,t)=>({size:this.splitview.getViewSize(t),data:e.toJSON(),snap:!!e.snap,priority:e.priority}))),activeView:null===(e=this._activePanel)||void 0===e?void 0:e.id,size:this.splitview.size,orientation:this.splitview.orientation}}fromJSON(e,t=!1){const{views:i,orientation:n,size:s,activeView:o}=e;this.splitview.dispose();const a=[];if(this.splitview=new j(this.element,{orientation:n,proportionalLayout:this.options.proportionalLayout,descriptor:{size:s,views:i.map((e=>{const t=e.data;if(this.panels.has(t.id))throw new Error(`panel ${t.id} already exists`);const i=Se(t.id,t.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.createComponent}:void 0);return a.push((()=>{i.init({params:t.params||{},minimumSize:t.minimumSize,maximumSize:t.maximumSize,snap:e.snap,priority:e.priority,containerApi:new C(this)})})),i.orientation=n,this.doAddView(i),{size:e.size,view:i}}))}}),this.layout(this.width,this.height),t?setTimeout((()=>{a.forEach((e=>e()))}),0):a.forEach((e=>e())),"string"==typeof o){const e=this.getPanel(o);e&&this.setActive(e)}}dispose(){Array.from(this.panels.values()).forEach((e=>{e.dispose()})),this.panels.clear(),super.dispose()}}class Re extends r{constructor(e){super(),this.el=e,this.iframes=[],this._onDragStart=new s,this.onDragStart=this._onDragStart.event,this.configure()}configure(){this.addDisposables(a(this.el,"dragstart",(e=>{var t;this.iframes=[...O("iframe"),...O("webview")];for(const e of this.iframes)e.style.pointerEvents="none";this.el.classList.add("dragged"),setTimeout((()=>this.el.classList.remove("dragged")),0),null===(t=this.disposable)||void 0===t||t.dispose(),this.disposable=this.getData()})),a(this.el,"dragend",(e=>{var t;for(const e of this.iframes)e.style.pointerEvents="auto";this.iframes=[],null===(t=this.disposable)||void 0===t||t.dispose(),this.disposable=void 0})))}}class He extends _e{constructor(e){super(e),this._onDidConstraintsChangeInternal=new s,this.onDidConstraintsChangeInternal=this._onDidConstraintsChangeInternal.event,this._onDidConstraintsChange=new s({replay:!0}),this.onDidConstraintsChange=this._onDidConstraintsChange.event,this._onDidSizeChange=new s,this.onDidSizeChange=this._onDidSizeChange.event}setConstraints(e){this._onDidConstraintsChangeInternal.fire(e)}setSize(e){this._onDidSizeChange.fire(e)}dispose(){super.dispose(),this._onDidConstraintsChange.dispose(),this._onDidSizeChange.dispose()}}class Me extends He{constructor(e){super(e),this._onDidExpansionChange=new s({replay:!0}),this.onDidExpansionChange=this._onDidExpansionChange.event,this._onMouseEnter=new s({}),this.onMouseEnter=this._onMouseEnter.event,this._onMouseLeave=new s({}),this.onMouseLeave=this._onMouseLeave.event}set pane(e){this._pane=e}setExpanded(e){var t;null===(t=this._pane)||void 0===t||t.setExpanded(e)}get isExpanded(){var e;return!!(null===(e=this._pane)||void 0===e?void 0:e.isExpanded())}}class Fe extends Oe{constructor(e,t,i,n,o){super(e,t,new Me(e)),this.headerComponent=i,this._onDidChangeExpansionState=new s({replay:!0}),this.onDidChangeExpansionState=this._onDidChangeExpansionState.event,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.headerSize=22,this._orthogonalSize=0,this._size=0,this._minimumBodySize=100,this._maximumBodySize=Number.POSITIVE_INFINITY,this._isExpanded=!1,this.expandedSize=0,this.api.pane=this,this._isExpanded=o,this._onDidChangeExpansionState.fire(this.isExpanded()),this._orientation=n,this.element.classList.add("pane"),this.addDisposables(this.api.onDidSizeChange((e=>{this._onDidChange.fire(e.size)})),a(this.element,"mouseenter",(e=>{this.api._onMouseEnter.fire(e)})),a(this.element,"mouseleave",(e=>{this.api._onMouseLeave.fire(e)}))),this.addDisposables(this._onDidChangeExpansionState,this.onDidChangeExpansionState((e=>{this.api._onDidExpansionChange.fire({isExpanded:e})})),this.api.onDidFocusChange((e=>{this.header&&(e.isFocused?S(this.header,"focused"):E(this.header,"focused"))}))),this.renderOnce()}set orientation(e){this._orientation=e}get orientation(){return this._orientation}get minimumSize(){return this.headerSize+(this.isExpanded()?this._minimumBodySize:0)}get maximumSize(){return this.headerSize+(this.isExpanded()?this._maximumBodySize:0)}get size(){return this._size}get orthogonalSize(){return this._orthogonalSize}set orthogonalSize(e){this._orthogonalSize=e}get minimumBodySize(){return this._minimumBodySize}set minimumBodySize(e){this._minimumBodySize="number"==typeof e?e:0}get maximumBodySize(){return this._maximumBodySize}set maximumBodySize(e){this._maximumBodySize="number"==typeof e?e:Number.POSITIVE_INFINITY}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}isExpanded(){return this._isExpanded}setExpanded(e){this._isExpanded!==e&&(this._isExpanded=e,e?(this.animationTimer&&clearTimeout(this.animationTimer),this.body&&this.element.appendChild(this.body)):this.animationTimer=setTimeout((()=>{var e;null===(e=this.body)||void 0===e||e.remove()}),200),this._onDidChange.fire(e?this.width:void 0),this._onDidChangeExpansionState.fire(e))}layout(e,t){this._size=e,this._orthogonalSize=t;const[i,n]=this.orientation===F.HORIZONTAL?[e,t]:[t,e];this.isExpanded()&&(this.expandedSize=i),super.layout(i,n)}init(e){var t,i;super.init(e),"number"==typeof e.minimumBodySize&&(this.minimumBodySize=e.minimumBodySize),"number"==typeof e.maximumBodySize&&(this.maximumBodySize=e.maximumBodySize),this.bodyPart=this.getBodyComponent(),this.headerPart=this.getHeaderComponent(),this.bodyPart.init(Object.assign(Object.assign({},e),{api:this.api})),this.headerPart.init(Object.assign(Object.assign({},e),{api:this.api})),null===(t=this.body)||void 0===t||t.append(this.bodyPart.element),null===(i=this.header)||void 0===i||i.append(this.headerPart.element),"boolean"==typeof e.isExpanded&&this.setExpanded(e.isExpanded)}toJSON(){const e=this.params;return Object.assign(Object.assign({},super.toJSON()),{headerComponent:this.headerComponent,title:e.title})}renderOnce(){this.header=document.createElement("div"),this.header.tabIndex=0,this.header.className="pane-header",this.header.style.height=`${this.headerSize}px`,this.header.style.lineHeight=`${this.headerSize}px`,this.header.style.minHeight=`${this.headerSize}px`,this.header.style.maxHeight=`${this.headerSize}px`,this.element.appendChild(this.header),this.body=document.createElement("div"),this.body.className="pane-body",this.element.appendChild(this.body)}getComponent(){return{update:e=>{var t,i;null===(t=this.bodyPart)||void 0===t||t.update({params:e}),null===(i=this.headerPart)||void 0===i||i.update({params:e})},dispose:()=>{var e,t;null===(e=this.bodyPart)||void 0===e||e.dispose(),null===(t=this.headerPart)||void 0===t||t.dispose()}}}}class We extends Fe{constructor(e,t,i,n,o,a){super(e,t,i,n,o),this._onDidDrop=new s,this.onDidDrop=this._onDidDrop.event,a||this.initDragFeatures()}initDragFeatures(){if(!this.header)return;const e=this.id;this.header.draggable=!0,this.handler=new class extends Re{getData(){return b.getInstance().setData([new p("paneview",e)],p.prototype),{dispose:()=>{b.getInstance().clearData(p.prototype)}}}}(this.header),this.target=new Y(this.element,{validOverlays:"vertical",canDisplayOverlay:e=>{const t=_();return!t||t.paneId!==this.id}}),this.addDisposables(this._onDidDrop,this.handler,this.target,this.target.onDrop((e=>{const t=_();if(!t)return void this._onDidDrop.fire(Object.assign(Object.assign({},e),{panel:this,getData:()=>_()}));const i=this.params.containerApi,n=t.paneId,s=i.getPanel(n);if(!s)return void this._onDidDrop.fire(Object.assign(Object.assign({},e),{panel:this,getData:()=>_()}));const o=i.getPanels(),a=o.indexOf(s);let r=i.getPanels().indexOf(this);e.position!==U.Left&&e.position!==U.Top||(r=Math.max(0,r-1)),e.position!==U.Right&&e.position!==U.Bottom||(a>r&&r++,r=Math.min(o.length-1,r)),i.movePanel(a,r)})))}}class Be extends r{constructor(){super(),this.disposable=new h,this.apiRef={api:null},this._element=document.createElement("div"),this.element.className="default-header",this._content=document.createElement("span"),this._expander=document.createElement("a"),this.element.appendChild(this._content),this.element.appendChild(this._expander),this.addDisposables(a(this._expander,"click",(()=>{var e;null===(e=this.apiRef.api)||void 0===e||e.setExpanded(!this.apiRef.api.isExpanded)})))}get element(){return this._element}init(e){this.apiRef.api=e.api,this._content.textContent=e.title,this._expander.textContent=e.api.isExpanded?"<":">",this.disposable.value=e.api.onDidExpansionChange((e=>{this._expander.textContent=e.isExpanded?"<":">"}))}update(e){}dispose(){this.disposable.dispose(),super.dispose()}}class Je extends We{constructor(e){super(e.id,e.component,e.headerComponent,e.orientation,e.isExpanded,e.disableDnd),this.options=e}getBodyComponent(){return this.options.body}getHeaderComponent(){return this.options.header}}class Ue extends r{constructor(e,t){super(),this.element=e,this._disposable=new h,this._onDidLayoutChange=new s,this.onDidLayoutChange=this._onDidLayoutChange.event,this._onDidDrop=new s,this.onDidDrop=this._onDidDrop.event,this._options=t,t.components||(t.components={}),t.frameworkComponents||(t.frameworkComponents={}),this.paneview=new $(this.element,{orientation:F.VERTICAL}),this.addDisposables(this._disposable)}get onDidAddView(){return this._paneview.onDidAddView}get onDidRemoveView(){return this._paneview.onDidRemoveView}set paneview(e){this._paneview=e,this._disposable.value=new r(this.paneview.onDidChange((()=>{this._onDidLayoutChange.fire(void 0)})))}get paneview(){return this._paneview}get minimumSize(){return this.paneview.minimumSize}get maximumSize(){return this.paneview.maximumSize}get height(){return this.paneview.orientation===F.HORIZONTAL?this.paneview.orthogonalSize:this.paneview.size}get width(){return this.paneview.orientation===F.HORIZONTAL?this.paneview.size:this.paneview.orthogonalSize}get options(){return this._options}focus(){}updateOptions(e){this._options=Object.assign(Object.assign({},this.options),e)}addPanel(e){const t=Se(e.id,e.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.body.createComponent}:void 0);let i;i=e.headerComponent?Se(e.id,e.headerComponent,this.options.headerComponents||{},this.options.headerframeworkComponents,this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.header.createComponent}:void 0):new Be;const n=new Je({id:e.id,component:e.component,headerComponent:e.headerComponent,header:i,body:t,orientation:F.VERTICAL,isExpanded:!!e.isExpanded,disableDnd:!!this.options.disableDnd}),s=new r(n.onDidDrop((e=>{this._onDidDrop.fire(e)}))),o="number"==typeof e.size?e.size:J.Distribute,a="number"==typeof e.index?e.index:void 0;return n.init({params:e.params||{},minimumBodySize:e.minimumBodySize,maximumBodySize:e.maximumBodySize,isExpanded:e.isExpanded,title:e.title,containerApi:new y(this)}),this.paneview.addPane(n,o,a),n.orientation=this.paneview.orientation,s}getPanels(){return this.paneview.getPanes()}removePanel(e){const t=this.getPanels().findIndex((t=>t===e));this.paneview.removePane(t)}movePanel(e,t){this.paneview.moveView(e,t)}getPanel(e){return this.getPanels().find((t=>t.id===e))}layout(e,t){const[i,n]=this.paneview.orientation===F.HORIZONTAL?[e,t]:[t,e];this.paneview.layout(i,n)}resizeToFit(){if(!this.element.parentElement)return;const{width:e,height:t}=this.element.parentElement.getBoundingClientRect();this.layout(e,t)}toJSON(){const e=e=>e===Number.MAX_SAFE_INTEGER||e===Number.POSITIVE_INFINITY?void 0:e;return{views:this.paneview.getPanes().map(((t,i)=>{return{size:this.paneview.getViewSize(i),data:t.toJSON(),minimumSize:(n=t.minimumBodySize,n<=0?void 0:n),maximumSize:e(t.maximumBodySize),expanded:t.isExpanded()};var n})),size:this.paneview.size}}fromJSON(e,t){const{views:i,size:n}=e,s=[];this.paneview.dispose(),this.paneview=new $(this.element,{orientation:F.VERTICAL,descriptor:{size:n,views:i.map((e=>{const t=e.data,i=Se(t.id,t.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.body.createComponent}:void 0);let n;n=t.headerComponent?Se(t.id,t.headerComponent,this.options.headerComponents||{},this.options.headerframeworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.header.createComponent}:void 0):new Be;const o=new Je({id:t.id,component:t.component,headerComponent:t.headerComponent,header:n,body:i,orientation:F.VERTICAL,isExpanded:!!e.expanded,disableDnd:!!this.options.disableDnd});return o.onDidDrop((e=>{this._onDidDrop.fire(e)})),s.push((()=>{o.init({params:t.params||{},minimumBodySize:e.minimumSize,maximumBodySize:e.maximumSize,title:t.title,isExpanded:!!e.expanded,containerApi:new y(this)}),o.orientation=this.paneview.orientation})),{size:e.size,view:o}}))}}),this.layout(this.width,this.height),t?setTimeout((()=>{s.forEach((e=>e()))}),0):s.forEach((e=>e()))}}class je extends Oe{constructor(e,t){super(e,t,new He(e)),this._evaluatedMinimumSize=0,this._evaluatedMaximumSize=Number.POSITIVE_INFINITY,this._minimumSize=0,this._maximumSize=Number.POSITIVE_INFINITY,this._snap=!1,this._onDidChange=new s,this.onDidChange=this._onDidChange.event,this.addDisposables(this.api.onVisibilityChange((e=>{const{isVisible:t}=e,{containerApi:i}=this.params;i.setVisible(this,t)})),this.api.onActiveChange((()=>{const{containerApi:e}=this.params;e.setActive(this)})),this.api.onDidConstraintsChangeInternal((e=>{"number"!=typeof e.minimumSize&&"function"!=typeof e.minimumSize||(this._minimumSize=e.minimumSize),"number"!=typeof e.maximumSize&&"function"!=typeof e.maximumSize||(this._maximumSize=e.maximumSize),this.updateConstraints()})),this.api.onDidSizeChange((e=>{this._onDidChange.fire(e.size)})))}get priority(){return this._priority}set orientation(e){this._orientation=e}get orientation(){return this._orientation}get minimumSize(){const e="function"==typeof this._minimumSize?this._minimumSize():this._minimumSize;return e!==this._evaluatedMinimumSize&&(this._evaluatedMinimumSize=e,this.updateConstraints()),e}get maximumSize(){const e="function"==typeof this._maximumSize?this._maximumSize():this._maximumSize;return e!==this._evaluatedMaximumSize&&(this._evaluatedMaximumSize=e,this.updateConstraints()),e}get snap(){return this._snap}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}layout(e,t){const[i,n]=this.orientation===F.HORIZONTAL?[e,t]:[t,e];super.layout(i,n)}init(e){super.init(e),this._priority=e.priority,e.minimumSize&&(this._minimumSize=e.minimumSize),e.maximumSize&&(this._maximumSize=e.maximumSize),e.snap&&(this._snap=e.snap)}toJSON(){return Object.assign(Object.assign({},super.toJSON()),{minimumSize:(e=this.minimumSize,e<=0?void 0:e),maximumSize:(e=>e===Number.MAX_SAFE_INTEGER||e===Number.POSITIVE_INFINITY?void 0:e)(this.maximumSize)});var e}updateConstraints(){this.api._onDidConstraintsChange.fire({maximumSize:this._evaluatedMaximumSize,minimumSize:this._evaluatedMinimumSize})}}const $e=(t,i)=>{const[n,s]=e.useState(),o=e.useRef(t.componentProps);return e.useImperativeHandle(i,(()=>({update:e=>{o.current=Object.assign(Object.assign({},o.current),e),s(Date.now())}})),[]),e.createElement(t.component,o.current)};$e.displayName="DockviewReactJsBridge";const Ze=V(),Ye=e.createContext({});class Xe{constructor(e,t,i,n,s){this.parent=e,this.portalStore=t,this.component=i,this.parameters=n,this.context=s,this.disposed=!1,this.createPortal()}update(e){var t;if(this.disposed)throw new Error("invalid operation: resource is already disposed");null===(t=this.componentInstance)||void 0===t||t.update(e)}createPortal(){if(this.disposed)throw new Error("invalid operation: resource is already disposed");if("function"!=typeof this.component)throw new Error("invalid operation: only functional components are supported");const i=e.createElement(e.forwardRef($e),{component:this.component,componentProps:this.parameters,ref:e=>{this.componentInstance=e}}),n=this.context?e.createElement(Ye.Provider,{value:this.context},i):i,s=t.createPortal(n,this.parent,Ze.next());this.ref={portal:s,disposable:this.portalStore.addPortal(s)}}dispose(){var e;null===(e=this.ref)||void 0===e||e.disposable.dispose(),this.disposed=!0}}const Ke=()=>{const[t,i]=e.useState([]);e.useDebugValue(`Portal count: ${t.length}`);return[t,e.useCallback((e=>{i((t=>[...t,e]));let t=!1;return{dispose:()=>{if(t)throw new Error("invalid operation: resource already disposed");t=!0,i((t=>t.filter((t=>t!==e))))}}}),[])]};function qe(e){return null==e?void 0:e.type}class Qe{constructor(e,t,i){this.id=e,this.component=t,this.reactPortalStore=i,this._onDidFocus=new s,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new s,this.onDidBlur=this._onDidBlur.event,this._element=document.createElement("div"),this._element.style.height="100%",this._element.style.width="100%",this._actionsElement=document.createElement("div"),this._actionsElement.style.height="100%",this._actionsElement.style.width="100%"}get element(){return this._element}get actions(){return this._actionsElement}focus(){}init(e){const t={api:e.api,containerApi:e.containerApi,actionsPortalElement:this._actionsElement,tabPortalElement:e.tab};this.part=new Xe(this.element,this.reactPortalStore,this.component,{params:e.params,api:e.api,containerApi:e.containerApi},t)}toJSON(){return{id:this.id}}update(e){var t;null===(t=this.part)||void 0===t||t.update(e.params)}updateParentGroup(e,t){this._group=e}layout(e,t){}close(){return Promise.resolve(!0)}dispose(){var e,t;null===(e=this.part)||void 0===e||e.dispose(),null===(t=this.actionsPart)||void 0===t||t.dispose()}}class et{constructor(e,t,i){this.id=e,this.component=t,this.reactPortalStore=i,this._element=document.createElement("div")}get element(){return this._element}focus(){}init(e){this.part=new Xe(this.element,this.reactPortalStore,this.component,{params:e.params,api:e.api,containerApi:e.containerApi})}update(e){var t;null===(t=this.part)||void 0===t||t.update(e.params)}toJSON(){return{id:this.id}}layout(e,t){}updateParentGroup(e,t){}dispose(){var e;null===(e=this.part)||void 0===e||e.dispose()}}class tt{constructor(e){this.layout=e}fromJSON(e){var t,i,n;const s=e.id,o=e.params,a=e.title,r=e.state,h=e.suppressClosable,d=e.view,l=new ke({content:Se(d.content.id,d.content.id,this.layout.options.components,this.layout.options.frameworkComponents,null===(t=this.layout.options.frameworkComponentFactory)||void 0===t?void 0:t.content),tab:(null===(i=d.tab)||void 0===i?void 0:i.id)?Se(d.tab.id,d.tab.id,this.layout.options.tabComponents,this.layout.options.frameworkTabComponents,null===(n=this.layout.options.frameworkComponentFactory)||void 0===n?void 0:n.tab):new Pe}),p=new ze(s,new x(this.layout));return p.init({view:l,title:a,suppressClosable:h,params:o||{},state:r||{}}),p}}class it{constructor(e,t,i){this.id=e,this.component=t,this.reactPortalStore=i,this._groupRef={value:void 0},this._element=document.createElement("div"),this._element.style.height="100%",this._element.style.width="100%"}get element(){return this._element}init(e){this.parameters=e,this.part=new Xe(this.element,this.reactPortalStore,this.component,{params:e.params,api:e.api,containerApi:e.containerApi,close:()=>{this._groupRef.value&&e.containerApi.removeGroup(this._groupRef.value)}})}focus(){}update(e){var t,i;this.parameters&&(this.parameters.params=e.params),null===(t=this.part)||void 0===t||t.update({params:(null===(i=this.parameters)||void 0===i?void 0:i.params)||{}})}toJSON(){return{id:this.id}}layout(e,t){}updateParentGroup(e,t){this._groupRef.value=e}dispose(){var e;null===(e=this.part)||void 0===e||e.dispose()}}const nt=e.forwardRef(((t,i)=>{const n=e.useRef(null),s=e.useRef(),[o,a]=Ke();return e.useImperativeHandle(i,(()=>n.current),[]),e.useEffect((()=>{if(t.disableAutoResizing)return()=>{};const e=D(n.current,(e=>{var t;const{width:i,height:n}=e.contentRect;null===(t=s.current)||void 0===t||t.layout(i,n)}));return()=>{e.dispose()}}),[t.disableAutoResizing]),e.useEffect((()=>{var e;const i={content:{createComponent:(e,t,i)=>new Qe(t,i,{addPortal:a})},tab:{createComponent:(e,t,i)=>new et(t,i,{addPortal:a})},watermark:{createComponent:(e,t,i)=>new it(t,i,{addPortal:a})}},o=document.createElement("div"),r=new Te(o,{frameworkComponentFactory:i,frameworkComponents:t.components,frameworkTabComponents:t.tabComponents,tabHeight:t.tabHeight,debug:t.debug,enableExternalDragEvents:t.enableExternalDragEvents,watermarkFrameworkComponent:t.watermarkComponent,styles:t.hideBorders?{separatorBorder:"transparent"}:void 0});null===(e=n.current)||void 0===e||e.appendChild(r.element),r.deserializer=new tt(r);const{clientWidth:h,clientHeight:d}=n.current;return r.layout(h,d),t.onReady&&t.onReady({api:new x(r)}),s.current=r,()=>{r.dispose()}}),[]),e.useEffect((()=>{s.current&&s.current.updateOptions({frameworkComponents:t.components})}),[t.components]),e.useEffect((()=>{s.current&&s.current.updateOptions({frameworkTabComponents:t.tabComponents})}),[t.tabComponents]),e.useEffect((()=>{if(!t.onTabContextMenu||!s.current)return()=>{};const e=s.current.onTabContextMenu((e=>{t.onTabContextMenu&&t.onTabContextMenu(e)}));return()=>{e.dispose()}}),[t.onTabContextMenu]),e.createElement("div",{className:t.className,style:{height:"100%",width:"100%"},ref:n},o)}));nt.displayName="DockviewComponent";const st=t=>e.createElement(e.Fragment,null,t.children),ot=t=>e.createElement(e.Fragment,null,t.children),at=t=>e.createElement(e.Fragment,null,t.children);const rt={Tab:st,Content:ot,Actions:at,Panel:i=>{const n=e.useContext(Ye),s=e.useMemo((()=>{var t;const n=(null===(t=e.Children.map(i.children,(e=>e)))||void 0===t?void 0:t.filter(qe))||[];if(!!n.find((e=>{return t=e,![ot,at,st].find((e=>t.type===e));var t})))throw new Error("Children of DockviewComponents.Panel must be one of the following: DockviewComponents.Content, DockviewComponents.Actions, DockviewComponents.Tab");return{body:n.find((e=>e.type===ot)),actions:n.find((e=>e.type===at)),tab:n.find((e=>e.type===st))}}),[i.children]);return e.useEffect((()=>{s.tab?n.tabPortalElement.hide():n.tabPortalElement.show()}),[s.tab]),e.createElement(e.Fragment,null,s.actions&&t.createPortal(s.actions,n.actionsPortalElement),s.tab&&t.createPortal(s.tab,n.tabPortalElement.element),s.body||i.children)}};class ht extends je{constructor(e,t,i,n){super(e,t),this.reactComponent=i,this.reactPortalStore=n}getComponent(){var e;return new Xe(this.element,this.reactPortalStore,this.reactComponent,{params:(null===(e=this.params)||void 0===e?void 0:e.params)||{},api:this.api,containerApi:this.params.containerApi})}}const dt=e.forwardRef(((t,i)=>{const n=e.useRef(null),s=e.useRef(),[o,a]=Ke();return e.useImperativeHandle(i,(()=>n.current),[]),e.useEffect((()=>{if(t.disableAutoResizing)return()=>{};const e=D(n.current,(e=>{var t;const{width:i,height:n}=e.contentRect;null===(t=s.current)||void 0===t||t.layout(i,n)}));return()=>{e.dispose()}}),[t.disableAutoResizing]),e.useEffect((()=>{const e=new Ge(n.current,{orientation:t.orientation,frameworkComponents:t.components,frameworkWrapper:{createComponent:(e,t,i)=>new ht(e,t,i,{addPortal:a})},proportionalLayout:t.proportionalLayout,styles:t.hideBorders?{separatorBorder:"transparent"}:void 0}),{clientWidth:i,clientHeight:o}=n.current;return e.layout(i,o),t.onReady&&t.onReady({api:new C(e)}),s.current=e,()=>{e.dispose()}}),[]),e.useEffect((()=>{s.current&&s.current.updateOptions({frameworkComponents:t.components})}),[t.components]),e.createElement("div",{className:t.className,style:{height:"100%",width:"100%"},ref:n},o)}));dt.displayName="SplitviewComponent";class lt extends Ne{constructor(e,t,i,n){super(e,t),this.reactComponent=i,this.reactPortalStore=n}getComponent(){var e;return new Xe(this.element,this.reactPortalStore,this.reactComponent,{params:(null===(e=this.params)||void 0===e?void 0:e.params)||{},api:this.api,containerApi:this.params.containerApi})}}const pt=e.forwardRef(((t,i)=>{const n=e.useRef(null),s=e.useRef(),[o,a]=Ke();return e.useImperativeHandle(i,(()=>n.current),[]),e.useEffect((()=>{if(t.disableAutoResizing)return()=>{};const e=D(n.current,(e=>{var t;const{width:i,height:n}=e.contentRect;null===(t=s.current)||void 0===t||t.layout(i,n)}));return()=>{e.dispose()}}),[t.disableAutoResizing]),e.useEffect((()=>{var e;const i=document.createElement("div"),o=new Le(i,{proportionalLayout:!!t.proportionalLayout,orientation:t.orientation,frameworkComponents:t.components,frameworkComponentFactory:{createComponent:(e,t,i)=>new lt(e,t,i,{addPortal:a})},styles:t.hideBorders?{separatorBorder:"transparent"}:void 0});null===(e=n.current)||void 0===e||e.appendChild(o.element);const{clientWidth:r,clientHeight:h}=n.current;return o.layout(r,h),t.onReady&&t.onReady({api:new z(o)}),s.current=o,()=>{o.dispose()}}),[]),e.useEffect((()=>{s.current&&s.current.updateOptions({frameworkComponents:t.components})}),[t.components]),e.createElement("div",{className:t.className,style:{height:"100%",width:"100%"},ref:n},o)}));pt.displayName="GridviewComponent";class ct{constructor(e,t,i){this.id=e,this.component=t,this.reactPortalStore=i,this._element=document.createElement("div"),this._element.style.height="100%",this._element.style.width="100%"}get element(){return this._element}init(e){this.part=new Xe(this.element,this.reactPortalStore,this.component,{params:e.params,api:e.api,title:e.title,containerApi:e.containerApi})}toJSON(){return{id:this.id}}update(e){var t;null===(t=this.part)||void 0===t||t.update(e.params)}dispose(){var e;null===(e=this.part)||void 0===e||e.dispose()}}const mt=e.forwardRef(((t,i)=>{const n=e.useRef(null),s=e.useRef(),[o,a]=Ke();return e.useImperativeHandle(i,(()=>n.current),[]),e.useEffect((()=>{if(t.disableAutoResizing)return()=>{};const e=D(n.current,(e=>{var t;const{width:i,height:n}=e.contentRect;null===(t=s.current)||void 0===t||t.layout(i,n)}));return()=>{e.dispose()}}),[t.disableAutoResizing]),e.useEffect((()=>{const e=(e,t,i)=>new ct(e,i,{addPortal:a}),i=new Ue(n.current,{frameworkComponents:t.components,components:{},headerComponents:{},disableDnd:t.disableDnd,headerframeworkComponents:t.headerComponents,frameworkWrapper:{header:{createComponent:e},body:{createComponent:e}}}),o=new y(i),{clientWidth:r,clientHeight:h}=n.current;return i.layout(r,h),t.onReady&&t.onReady({api:o}),s.current=i,()=>{i.dispose()}}),[]),e.useEffect((()=>{s.current&&s.current.updateOptions({frameworkComponents:t.components})}),[t.components]),e.useEffect((()=>{s.current&&s.current.updateOptions({headerframeworkComponents:t.headerComponents})}),[t.headerComponents]),e.useEffect((()=>{if(!s.current)return()=>{};const e=s.current,i=e.onDidDrop((i=>{t.onDidDrop&&t.onDidDrop(Object.assign(Object.assign({},i),{api:new y(e)}))}));return()=>{i.dispose()}}),[t.onDidDrop]),e.createElement("div",{className:t.className,style:{height:"100%",width:"100%"},ref:n},o)}));mt.displayName="PaneviewComponent";export{fe as BaseGrid,r as CompositeDisposable,de as ContentContainer,c as DATA_KEY,n as Disposable,x as DockviewApi,Te as DockviewComponent,rt as DockviewComponents,nt as DockviewReact,u as DragType,s as Emitter,i as Event,re as Gridview,z as GridviewApi,Le as GridviewComponent,Ne as GridviewPanel,pt as GridviewReact,me as GroupChangeKind,ce as GroupChangeKind2,ge as Groupview,B as LayoutPriority,b as LocalSelectionTransfer,pe as MouseEventKind,h as MutableDisposable,F as Orientation,Je as PaneFramework,p as PaneTransfer,l as PanelTransfer,$ as Paneview,y as PaneviewApi,Ue as PaneviewComponent,Fe as PaneviewPanel,mt as PaneviewReact,U as Position,Qe as ReactPanelContentPart,et as ReactPanelHeaderPart,Xe as ReactPart,Ye as ReactPartContext,W as SashState,J as Sizing,j as Splitview,C as SplitviewApi,Ge as SplitviewComponent,je as SplitviewPanel,dt as SplitviewReact,ue as Tab,a as addDisposableListener,o as addDisposableWindowListener,w as extractData,ie as getDirectionOrientation,ee as getGridLocation,ne as getLocationOrientation,_ as getPaneData,f as getPanelData,te as getRelativeLocation,Q as indexInParent,g as isCustomDragEvent,oe as isGridBranchNode,m as isPanelTransferEvent,qe as isReactElement,v as isTabDragEvent,se as orthogonal,be as toTarget,Ke as usePortalsLifecycle};
|