dockview 1.4.3 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (122) hide show
  1. package/README.md +1 -1
  2. package/dist/cjs/dockview/components/tab/defaultTab.d.ts +1 -0
  3. package/dist/cjs/dockview/components/tab/defaultTab.js +6 -3
  4. package/dist/cjs/dockview/components/tab/defaultTab.js.map +1 -1
  5. package/dist/cjs/dockview/components/watermark/watermark.js +3 -1
  6. package/dist/cjs/dockview/components/watermark/watermark.js.map +1 -1
  7. package/dist/cjs/dockview/defaultGroupPanelView.d.ts +1 -5
  8. package/dist/cjs/dockview/defaultGroupPanelView.js +5 -20
  9. package/dist/cjs/dockview/defaultGroupPanelView.js.map +1 -1
  10. package/dist/cjs/dockview/dockviewComponent.d.ts +1 -1
  11. package/dist/cjs/dockview/dockviewComponent.js +7 -18
  12. package/dist/cjs/dockview/dockviewComponent.js.map +1 -1
  13. package/dist/cjs/dockview/options.d.ts +5 -0
  14. package/dist/cjs/groupview/groupview.d.ts +16 -15
  15. package/dist/cjs/groupview/groupview.js +24 -33
  16. package/dist/cjs/groupview/groupview.js.map +1 -1
  17. package/dist/cjs/groupview/tab.d.ts +1 -0
  18. package/dist/cjs/groupview/tab.js +2 -1
  19. package/dist/cjs/groupview/tab.js.map +1 -1
  20. package/dist/cjs/groupview/titlebar/tabsContainer.js +1 -1
  21. package/dist/cjs/groupview/titlebar/tabsContainer.js.map +1 -1
  22. package/dist/cjs/groupview/types.d.ts +0 -4
  23. package/dist/cjs/index.d.ts +1 -0
  24. package/dist/cjs/index.js.map +1 -1
  25. package/dist/cjs/paneview/defaultPaneviewHeader.d.ts +3 -0
  26. package/dist/cjs/paneview/defaultPaneviewHeader.js +29 -5
  27. package/dist/cjs/paneview/defaultPaneviewHeader.js.map +1 -1
  28. package/dist/cjs/paneview/draggablePaneviewPanel.d.ts +3 -1
  29. package/dist/cjs/paneview/draggablePaneviewPanel.js +24 -9
  30. package/dist/cjs/paneview/draggablePaneviewPanel.js.map +1 -1
  31. package/dist/cjs/paneview/options.d.ts +2 -0
  32. package/dist/cjs/paneview/paneviewComponent.d.ts +12 -1
  33. package/dist/cjs/paneview/paneviewComponent.js +13 -1
  34. package/dist/cjs/paneview/paneviewComponent.js.map +1 -1
  35. package/dist/cjs/react/deserializer.js +13 -5
  36. package/dist/cjs/react/deserializer.js.map +1 -1
  37. package/dist/cjs/react/dockview/defaultTab.d.ts +4 -0
  38. package/dist/cjs/react/dockview/defaultTab.js +73 -0
  39. package/dist/cjs/react/dockview/defaultTab.js.map +1 -0
  40. package/dist/cjs/react/dockview/dockview.d.ts +3 -0
  41. package/dist/cjs/react/dockview/dockview.js +45 -3
  42. package/dist/cjs/react/dockview/dockview.js.map +1 -1
  43. package/dist/cjs/react/dockview/groupControlsRenderer.d.ts +43 -0
  44. package/dist/cjs/react/dockview/groupControlsRenderer.js +87 -0
  45. package/dist/cjs/react/dockview/groupControlsRenderer.js.map +1 -0
  46. package/dist/cjs/react/dockview/reactContentPart.d.ts +1 -16
  47. package/dist/cjs/react/dockview/reactContentPart.js +2 -18
  48. package/dist/cjs/react/dockview/reactContentPart.js.map +1 -1
  49. package/dist/cjs/react/dockview/reactHeaderPart.d.ts +2 -0
  50. package/dist/cjs/react/dockview/reactHeaderPart.js +4 -0
  51. package/dist/cjs/react/dockview/reactHeaderPart.js.map +1 -1
  52. package/dist/cjs/react/index.d.ts +2 -2
  53. package/dist/cjs/react/index.js +1 -2
  54. package/dist/cjs/react/index.js.map +1 -1
  55. package/dist/cjs/react/paneview/paneview.d.ts +2 -0
  56. package/dist/cjs/react/paneview/paneview.js +9 -0
  57. package/dist/cjs/react/paneview/paneview.js.map +1 -1
  58. package/dist/cjs/react/react.d.ts +1 -0
  59. package/dist/cjs/react/react.js +12 -2
  60. package/dist/cjs/react/react.js.map +1 -1
  61. package/dist/cjs/react/svg.d.ts +3 -0
  62. package/dist/cjs/react/svg.js +36 -0
  63. package/dist/cjs/react/svg.js.map +1 -0
  64. package/dist/cjs/svg.d.ts +3 -0
  65. package/dist/cjs/svg.js +44 -0
  66. package/dist/cjs/svg.js.map +1 -0
  67. package/dist/dockview.amd.js +327 -113
  68. package/dist/dockview.amd.min.js +2 -2
  69. package/dist/dockview.amd.min.noStyle.js +2 -2
  70. package/dist/dockview.amd.noStyle.js +326 -112
  71. package/dist/dockview.cjs.js +327 -113
  72. package/dist/dockview.esm.js +327 -112
  73. package/dist/dockview.esm.min.js +2 -2
  74. package/dist/dockview.js +327 -113
  75. package/dist/dockview.min.js +2 -2
  76. package/dist/dockview.min.noStyle.js +2 -2
  77. package/dist/dockview.noStyle.js +326 -112
  78. package/dist/esm/dockview/components/tab/defaultTab.d.ts +1 -0
  79. package/dist/esm/dockview/components/tab/defaultTab.js +5 -2
  80. package/dist/esm/dockview/components/watermark/watermark.js +3 -1
  81. package/dist/esm/dockview/defaultGroupPanelView.d.ts +1 -5
  82. package/dist/esm/dockview/defaultGroupPanelView.js +5 -16
  83. package/dist/esm/dockview/dockviewComponent.d.ts +1 -1
  84. package/dist/esm/dockview/dockviewComponent.js +7 -18
  85. package/dist/esm/dockview/options.d.ts +5 -0
  86. package/dist/esm/groupview/groupview.d.ts +16 -15
  87. package/dist/esm/groupview/groupview.js +23 -32
  88. package/dist/esm/groupview/tab.d.ts +1 -0
  89. package/dist/esm/groupview/tab.js +2 -1
  90. package/dist/esm/groupview/titlebar/tabsContainer.js +1 -1
  91. package/dist/esm/groupview/types.d.ts +0 -4
  92. package/dist/esm/index.d.ts +1 -0
  93. package/dist/esm/paneview/defaultPaneviewHeader.d.ts +3 -0
  94. package/dist/esm/paneview/defaultPaneviewHeader.js +29 -5
  95. package/dist/esm/paneview/draggablePaneviewPanel.d.ts +3 -1
  96. package/dist/esm/paneview/draggablePaneviewPanel.js +24 -9
  97. package/dist/esm/paneview/options.d.ts +2 -0
  98. package/dist/esm/paneview/paneviewComponent.d.ts +12 -1
  99. package/dist/esm/paneview/paneviewComponent.js +9 -1
  100. package/dist/esm/react/deserializer.js +13 -5
  101. package/dist/esm/react/dockview/defaultTab.d.ts +4 -0
  102. package/dist/esm/react/dockview/defaultTab.js +34 -0
  103. package/dist/esm/react/dockview/dockview.d.ts +3 -0
  104. package/dist/esm/react/dockview/dockview.js +30 -1
  105. package/dist/esm/react/dockview/groupControlsRenderer.d.ts +43 -0
  106. package/dist/esm/react/dockview/groupControlsRenderer.js +68 -0
  107. package/dist/esm/react/dockview/reactContentPart.d.ts +1 -16
  108. package/dist/esm/react/dockview/reactContentPart.js +2 -14
  109. package/dist/esm/react/dockview/reactHeaderPart.d.ts +2 -0
  110. package/dist/esm/react/dockview/reactHeaderPart.js +4 -0
  111. package/dist/esm/react/index.d.ts +2 -2
  112. package/dist/esm/react/index.js +1 -2
  113. package/dist/esm/react/paneview/paneview.d.ts +2 -0
  114. package/dist/esm/react/paneview/paneview.js +9 -0
  115. package/dist/esm/react/react.d.ts +1 -0
  116. package/dist/esm/react/react.js +12 -2
  117. package/dist/esm/react/svg.d.ts +3 -0
  118. package/dist/esm/react/svg.js +7 -0
  119. package/dist/esm/svg.d.ts +3 -0
  120. package/dist/esm/svg.js +31 -0
  121. package/dist/styles/dockview.css +155 -42
  122. package/package.json +2 -2
@@ -1 +1 @@
1
- {"version":3,"file":"deserializer.js","sourceRoot":"","sources":["../../../src/react/deserializer.ts"],"names":[],"mappings":";;;AAEA,qEAAoE;AAEpE,8DAA4D;AAC5D,sDAAmD;AACnD,oEAAmE;AACnE,2EAA0E;AAG1E;IACI,gCAA6B,MAAyB;QAAzB,WAAM,GAAN,MAAM,CAAmB;IAAG,CAAC;IAEnD,yCAAQ,GAAf,UACI,SAA8B,EAC9B,KAAiB;;QAEjB,IAAM,OAAO,GAAG,SAAS,CAAC,EAAE,CAAC;QAC7B,IAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;QAChC,IAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC;QAC9B,IAAM,gBAAgB,GAAG,SAAS,CAAC,gBAAgB,CAAC;QACpD,IAAM,QAAQ,GAAG,SAAS,CAAC,IAAI,CAAC;QAEhC,IAAM,IAAI,GAAG,IAAI,6CAAqB,CAAC;YACnC,OAAO,EAAE,IAAA,kCAAe,EACpB,QAAQ,CAAC,OAAO,CAAC,EAAE,EACnB,QAAQ,CAAC,OAAO,CAAC,EAAE,EACnB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,EAC9B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,EACvC,MAAA,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,yBAAyB,0CAAE,OAAO,CACzD;YACD,GAAG,EAAE,CAAA,MAAA,QAAQ,CAAC,GAAG,0CAAE,EAAE;gBACjB,CAAC,CAAC,IAAA,kCAAe,EACX,QAAQ,CAAC,GAAG,CAAC,EAAE,EACf,QAAQ,CAAC,GAAG,CAAC,EAAE,EACf,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,EACjC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,sBAAsB,EAC1C,MAAA,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,yBAAyB,0CAAE,GAAG,CACrD;gBACH,CAAC,CAAC,IAAI,uBAAU,EAAE;SACzB,CAAC,CAAC;QAEH,IAAM,KAAK,GAAG,IAAI,uCAAkB,CAChC,OAAO,EACP,IAAI,CAAC,MAAM,EACX,IAAI,2BAAW,CAAC,IAAI,CAAC,MAAM,CAAC,EAC5B,KAAK,CACR,CAAC;QAEF,KAAK,CAAC,IAAI,CAAC;YACP,IAAI,MAAA;YACJ,KAAK,OAAA;YACL,gBAAgB,kBAAA;YAChB,MAAM,EAAE,MAAM,IAAI,EAAE;SACvB,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACjB,CAAC;IACL,6BAAC;AAAD,CAAC,AAhDD,IAgDC;AAhDY,wDAAsB"}
1
+ {"version":3,"file":"deserializer.js","sourceRoot":"","sources":["../../../src/react/deserializer.ts"],"names":[],"mappings":";;;AAEA,qEAAoE;AAEpE,8DAA4D;AAC5D,sDAAmD;AACnD,oEAAmE;AACnE,2EAA0E;AAI1E;IACI,gCAA6B,MAAyB;QAAzB,WAAM,GAAN,MAAM,CAAmB;IAAG,CAAC;IAEnD,yCAAQ,GAAf,UACI,SAA8B,EAC9B,KAAiB;;QAEjB,IAAM,OAAO,GAAG,SAAS,CAAC,EAAE,CAAC;QAC7B,IAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;QAChC,IAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC;QAC9B,IAAM,gBAAgB,GAAG,SAAS,CAAC,gBAAgB,CAAC;QACpD,IAAM,QAAQ,GAAG,SAAS,CAAC,IAAI,CAAC;QAEhC,IAAI,GAAiB,CAAC;QAEtB,IAAI,MAAA,QAAQ,CAAC,GAAG,0CAAE,EAAE,EAAE;YAClB,GAAG,GAAG,IAAA,kCAAe,EACjB,QAAQ,CAAC,GAAG,CAAC,EAAE,EACf,QAAQ,CAAC,GAAG,CAAC,EAAE,EACf,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,EACjC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,sBAAsB,EAC1C,MAAA,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,yBAAyB,0CAAE,GAAG,EAClD,cAAM,OAAA,IAAI,uBAAU,EAAE,EAAhB,CAAgB,CACzB,CAAC;SACL;aAAM,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,EAAE;YAChD,GAAG,GAAG,IAAA,kCAAe,EACjB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,EACvC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,EACvC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,EACjC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,sBAAsB,EAC1C,MAAA,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,yBAAyB,0CAAE,GAAG,EAClD,cAAM,OAAA,IAAI,uBAAU,EAAE,EAAhB,CAAgB,CACzB,CAAC;SACL;aAAM;YACH,GAAG,GAAG,IAAI,uBAAU,EAAE,CAAC;SAC1B;QAED,IAAM,IAAI,GAAG,IAAI,6CAAqB,CAAC;YACnC,OAAO,EAAE,IAAA,kCAAe,EACpB,QAAQ,CAAC,OAAO,CAAC,EAAE,EACnB,QAAQ,CAAC,OAAO,CAAC,EAAE,EACnB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,EAC9B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,EACvC,MAAA,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,yBAAyB,0CAAE,OAAO,CACzD;YACD,GAAG,KAAA;SACN,CAAC,CAAC;QAEH,IAAM,KAAK,GAAG,IAAI,uCAAkB,CAChC,OAAO,EACP,IAAI,CAAC,MAAM,EACX,IAAI,2BAAW,CAAC,IAAI,CAAC,MAAM,CAAC,EAC5B,KAAK,CACR,CAAC;QAEF,KAAK,CAAC,IAAI,CAAC;YACP,IAAI,MAAA;YACJ,KAAK,OAAA;YACL,gBAAgB,kBAAA;YAChB,MAAM,EAAE,MAAM,IAAI,EAAE;SACvB,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACjB,CAAC;IACL,6BAAC;AAAD,CAAC,AAhED,IAgEC;AAhEY,wDAAsB"}
@@ -0,0 +1,4 @@
1
+ import { IDockviewPanelHeaderProps } from './dockview';
2
+ import * as React from 'react';
3
+ export declare type IDockviewDefaultTabProps = IDockviewPanelHeaderProps & React.DOMAttributes<HTMLDivElement>;
4
+ export declare const DockviewDefaultTab: React.FunctionComponent<IDockviewDefaultTabProps>;
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ var desc = Object.getOwnPropertyDescriptor(m, k);
16
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
17
+ desc = { enumerable: true, get: function() { return m[k]; } };
18
+ }
19
+ Object.defineProperty(o, k2, desc);
20
+ }) : (function(o, m, k, k2) {
21
+ if (k2 === undefined) k2 = k;
22
+ o[k2] = m[k];
23
+ }));
24
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
26
+ }) : function(o, v) {
27
+ o["default"] = v;
28
+ });
29
+ var __importStar = (this && this.__importStar) || function (mod) {
30
+ if (mod && mod.__esModule) return mod;
31
+ var result = {};
32
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
33
+ __setModuleDefault(result, mod);
34
+ return result;
35
+ };
36
+ var __rest = (this && this.__rest) || function (s, e) {
37
+ var t = {};
38
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
39
+ t[p] = s[p];
40
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
41
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
42
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
43
+ t[p[i]] = s[p[i]];
44
+ }
45
+ return t;
46
+ };
47
+ Object.defineProperty(exports, "__esModule", { value: true });
48
+ exports.DockviewDefaultTab = void 0;
49
+ var React = __importStar(require("react"));
50
+ var svg_1 = require("../svg");
51
+ var DockviewDefaultTab = function (_a) {
52
+ var api = _a.api, _containerApi = _a.containerApi, _params = _a.params, rest = __rest(_a, ["api", "containerApi", "params"]);
53
+ var onClose = React.useCallback(function (event) {
54
+ event.stopPropagation();
55
+ api.close();
56
+ }, [api]);
57
+ var onClick = React.useCallback(function (event) {
58
+ api.setActive();
59
+ if (rest.onClick) {
60
+ rest.onClick(event);
61
+ }
62
+ }, [api, rest.onClick]);
63
+ var iconClassname = React.useMemo(function () {
64
+ var cn = ['dockview-react-tab-action'];
65
+ return cn.join(',');
66
+ }, [api.suppressClosable]);
67
+ return (React.createElement("div", __assign({}, rest, { onClick: onClick, className: "dockview-react-tab" }),
68
+ React.createElement("span", { className: "dockview-react-tab-title" }, api.title),
69
+ React.createElement("div", { className: iconClassname, onClick: onClose },
70
+ React.createElement(svg_1.CloseButton, null))));
71
+ };
72
+ exports.DockviewDefaultTab = DockviewDefaultTab;
73
+ //# sourceMappingURL=defaultTab.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defaultTab.js","sourceRoot":"","sources":["../../../../src/react/dockview/defaultTab.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,2CAA+B;AAC/B,8BAAqC;AAK9B,IAAM,kBAAkB,GAC3B,UAAC,EAA8D;IAA5D,IAAA,GAAG,SAAA,EAAgB,aAAa,kBAAA,EAAU,OAAO,YAAA,EAAK,IAAI,cAA5D,iCAA8D,CAAF;IACzD,IAAM,OAAO,GAAG,KAAK,CAAC,WAAW,CAC7B,UAAC,KAAwC;QACrC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,GAAG,CAAC,KAAK,EAAE,CAAC;IAChB,CAAC,EACD,CAAC,GAAG,CAAC,CACR,CAAC;IAEF,IAAM,OAAO,GAAG,KAAK,CAAC,WAAW,CAC7B,UAAC,KAAuC;QACpC,GAAG,CAAC,SAAS,EAAE,CAAC;QAEhB,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;SACvB;IACL,CAAC,EACD,CAAC,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,CACtB,CAAC;IAEF,IAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC;QAChC,IAAM,EAAE,GAAG,CAAC,2BAA2B,CAAC,CAAC;QACzC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC,EAAE,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAE3B,OAAO,CACH,wCAAS,IAAI,IAAE,OAAO,EAAE,OAAO,EAAE,SAAS,EAAC,oBAAoB;QAC3D,8BAAM,SAAS,EAAC,0BAA0B,IAAE,GAAG,CAAC,KAAK,CAAQ;QAC7D,6BAAK,SAAS,EAAE,aAAa,EAAE,OAAO,EAAE,OAAO;YAC3C,oBAAC,iBAAW,OAAG,CACb,CACJ,CACT,CAAC;AACN,CAAC,CAAC;AAlCO,QAAA,kBAAkB,sBAkCzB"}
@@ -5,6 +5,7 @@ import { DockviewPanelApi } from '../../api/groupPanelApi';
5
5
  import { DockviewApi } from '../../api/component.api';
6
6
  import { IWatermarkPanelProps } from './reactWatermarkPart';
7
7
  import { PanelCollection, PanelParameters } from '../types';
8
+ import { IDockviewGroupControlProps } from './groupControlsRenderer';
8
9
  export interface IGroupPanelBaseProps<T extends {} = Record<string, any>> extends PanelParameters<T> {
9
10
  api: DockviewPanelApi;
10
11
  containerApi: DockviewApi;
@@ -28,5 +29,7 @@ export interface IDockviewReactProps {
28
29
  hideBorders?: boolean;
29
30
  className?: string;
30
31
  disableAutoResizing?: boolean;
32
+ defaultTabComponent?: React.FunctionComponent<IDockviewPanelHeaderProps>;
33
+ groupControlComponent?: React.FunctionComponent<IDockviewGroupControlProps>;
31
34
  }
32
35
  export declare const DockviewReact: React.ForwardRefExoticComponent<IDockviewReactProps & React.RefAttributes<HTMLDivElement>>;
@@ -1,4 +1,15 @@
1
1
  "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
2
13
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
14
  if (k2 === undefined) k2 = k;
4
15
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -49,6 +60,15 @@ var react_1 = require("../react");
49
60
  var component_api_1 = require("../../api/component.api");
50
61
  var reactWatermarkPart_1 = require("./reactWatermarkPart");
51
62
  var dom_1 = require("../../dom");
63
+ var groupControlsRenderer_1 = require("./groupControlsRenderer");
64
+ var defaultTab_1 = require("../../dockview/components/tab/defaultTab");
65
+ function createGroupControlElement(component, store) {
66
+ return component
67
+ ? function (groupPanel) {
68
+ return new groupControlsRenderer_1.ReactGroupControlsRendererPart(component, store, groupPanel);
69
+ }
70
+ : undefined;
71
+ }
52
72
  exports.DockviewReact = React.forwardRef(function (props, ref) {
53
73
  var domRef = React.useRef(null);
54
74
  var dockviewRef = React.useRef();
@@ -71,6 +91,7 @@ exports.DockviewReact = React.forwardRef(function (props, ref) {
71
91
  }, [props.disableAutoResizing]);
72
92
  React.useEffect(function () {
73
93
  var _a;
94
+ var _b;
74
95
  var factory = {
75
96
  content: {
76
97
  createComponent: function (_id, componentId, component) {
@@ -98,16 +119,19 @@ exports.DockviewReact = React.forwardRef(function (props, ref) {
98
119
  var dockview = new dockviewComponent_1.DockviewComponent(element, {
99
120
  frameworkComponentFactory: factory,
100
121
  frameworkComponents: props.components,
101
- frameworkTabComponents: props.tabComponents,
122
+ frameworkTabComponents: __assign(__assign({}, (props.tabComponents || {})), (_a = {}, _a[defaultTab_1.DEFAULT_TAB_IDENTIFIER] = props.defaultTabComponent, _a)),
102
123
  tabHeight: props.tabHeight,
103
124
  watermarkFrameworkComponent: props.watermarkComponent,
125
+ defaultTabComponent: defaultTab_1.DEFAULT_TAB_IDENTIFIER,
104
126
  styles: props.hideBorders
105
127
  ? { separatorBorder: 'transparent' }
106
128
  : undefined,
129
+ showDndOverlay: props.showDndOverlay,
130
+ createGroupControlElement: createGroupControlElement(props.groupControlComponent, { addPortal: addPortal }),
107
131
  });
108
- (_a = domRef.current) === null || _a === void 0 ? void 0 : _a.appendChild(dockview.element);
132
+ (_b = domRef.current) === null || _b === void 0 ? void 0 : _b.appendChild(dockview.element);
109
133
  dockview.deserializer = new deserializer_1.ReactPanelDeserialzier(dockview);
110
- var _b = domRef.current, clientWidth = _b.clientWidth, clientHeight = _b.clientHeight;
134
+ var _c = domRef.current, clientWidth = _c.clientWidth, clientHeight = _c.clientHeight;
111
135
  dockview.layout(clientWidth, clientHeight);
112
136
  if (props.onReady) {
113
137
  props.onReady({ api: new component_api_1.DockviewApi(dockview) });
@@ -180,6 +204,24 @@ exports.DockviewReact = React.forwardRef(function (props, ref) {
180
204
  disposable.dispose();
181
205
  };
182
206
  }, [props.onTabContextMenu]);
207
+ React.useEffect(function () {
208
+ var _a;
209
+ if (!dockviewRef.current) {
210
+ return;
211
+ }
212
+ dockviewRef.current.updateOptions({
213
+ defaultTabComponent: defaultTab_1.DEFAULT_TAB_IDENTIFIER,
214
+ frameworkTabComponents: __assign(__assign({}, (props.tabComponents || {})), (_a = {}, _a[defaultTab_1.DEFAULT_TAB_IDENTIFIER] = props.defaultTabComponent, _a)),
215
+ });
216
+ }, [props.defaultTabComponent]);
217
+ React.useEffect(function () {
218
+ if (!dockviewRef.current) {
219
+ return;
220
+ }
221
+ dockviewRef.current.updateOptions({
222
+ createGroupControlElement: createGroupControlElement(props.groupControlComponent, { addPortal: addPortal }),
223
+ });
224
+ }, [props.groupControlComponent]);
183
225
  return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
184
226
  });
185
227
  exports.DockviewReact.displayName = 'DockviewComponent';
@@ -1 +1 @@
1
- {"version":3,"file":"dockview.js","sourceRoot":"","sources":["../../../../src/react/dockview/dockview.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"dockview.js","sourceRoot":"","sources":["../../../../src/react/dockview/dockview.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ import * as React from 'react';
2
+ import { ReactPart, ReactPortalStore } from '../react';
3
+ import { PanelUpdateEvent } from '../../panel/types';
4
+ import { GroupPanel, GroupviewPanelApi } from '../../groupview/groupviewPanel';
5
+ import { DockviewApi } from '../../api/component.api';
6
+ import { IDisposable } from '../../lifecycle';
7
+ import { IDockviewPanel } from '../../groupview/groupPanel';
8
+ export interface IDockviewGroupControlProps {
9
+ api: GroupviewPanelApi;
10
+ containerApi: DockviewApi;
11
+ panels: IDockviewPanel[];
12
+ activePanel: IDockviewPanel | undefined;
13
+ isGroupActive: boolean;
14
+ }
15
+ export interface IGroupControlRenderer extends IDisposable {
16
+ readonly element: HTMLElement;
17
+ init(params: {
18
+ containerApi: DockviewApi;
19
+ api: GroupviewPanelApi;
20
+ }): void;
21
+ }
22
+ export declare class ReactGroupControlsRendererPart {
23
+ private readonly component;
24
+ private readonly reactPortalStore;
25
+ private readonly _group;
26
+ private mutableDisposable;
27
+ private _element;
28
+ private _part?;
29
+ get element(): HTMLElement;
30
+ get part(): ReactPart<IDockviewGroupControlProps> | undefined;
31
+ get group(): GroupPanel;
32
+ constructor(component: React.FunctionComponent<IDockviewGroupControlProps>, reactPortalStore: ReactPortalStore, _group: GroupPanel);
33
+ focus(): void;
34
+ init(parameters: {
35
+ containerApi: DockviewApi;
36
+ api: GroupviewPanelApi;
37
+ }): void;
38
+ update(event: PanelUpdateEvent): void;
39
+ dispose(): void;
40
+ private updatePanels;
41
+ private updateActivePanel;
42
+ private updateGroupActive;
43
+ }
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ReactGroupControlsRendererPart = void 0;
4
+ var react_1 = require("../react");
5
+ var lifecycle_1 = require("../../lifecycle");
6
+ var ReactGroupControlsRendererPart = /** @class */ (function () {
7
+ function ReactGroupControlsRendererPart(component, reactPortalStore, _group) {
8
+ this.component = component;
9
+ this.reactPortalStore = reactPortalStore;
10
+ this._group = _group;
11
+ this.mutableDisposable = new lifecycle_1.MutableDisposable();
12
+ this._element = document.createElement('div');
13
+ this._element.className = 'dockview-react-part';
14
+ }
15
+ Object.defineProperty(ReactGroupControlsRendererPart.prototype, "element", {
16
+ get: function () {
17
+ return this._element;
18
+ },
19
+ enumerable: false,
20
+ configurable: true
21
+ });
22
+ Object.defineProperty(ReactGroupControlsRendererPart.prototype, "part", {
23
+ get: function () {
24
+ return this._part;
25
+ },
26
+ enumerable: false,
27
+ configurable: true
28
+ });
29
+ Object.defineProperty(ReactGroupControlsRendererPart.prototype, "group", {
30
+ get: function () {
31
+ return this._group;
32
+ },
33
+ enumerable: false,
34
+ configurable: true
35
+ });
36
+ ReactGroupControlsRendererPart.prototype.focus = function () {
37
+ // TODO
38
+ };
39
+ ReactGroupControlsRendererPart.prototype.init = function (parameters) {
40
+ var _this = this;
41
+ this.mutableDisposable.value = new lifecycle_1.CompositeDisposable(this._group.model.onDidAddPanel(function () {
42
+ _this.updatePanels();
43
+ }), this._group.model.onDidRemovePanel(function () {
44
+ _this.updatePanels();
45
+ }), this._group.model.onDidActivePanelChange(function () {
46
+ _this.updateActivePanel();
47
+ }), parameters.api.onDidActiveChange(function () {
48
+ _this.updateGroupActive();
49
+ }));
50
+ this._part = new react_1.ReactPart(this.element, this.reactPortalStore, this.component, {
51
+ api: parameters.api,
52
+ containerApi: parameters.containerApi,
53
+ panels: this._group.model.panels,
54
+ activePanel: this._group.model.activePanel,
55
+ isGroupActive: this._group.api.isActive,
56
+ });
57
+ };
58
+ ReactGroupControlsRendererPart.prototype.update = function (event) {
59
+ var _a;
60
+ (_a = this._part) === null || _a === void 0 ? void 0 : _a.update(event.params);
61
+ };
62
+ ReactGroupControlsRendererPart.prototype.dispose = function () {
63
+ var _a;
64
+ this.mutableDisposable.dispose();
65
+ (_a = this._part) === null || _a === void 0 ? void 0 : _a.dispose();
66
+ };
67
+ ReactGroupControlsRendererPart.prototype.updatePanels = function () {
68
+ this.update({ params: { panels: this._group.model.panels } });
69
+ };
70
+ ReactGroupControlsRendererPart.prototype.updateActivePanel = function () {
71
+ this.update({
72
+ params: {
73
+ activePanel: this._group.model.activePanel,
74
+ },
75
+ });
76
+ };
77
+ ReactGroupControlsRendererPart.prototype.updateGroupActive = function () {
78
+ this.update({
79
+ params: {
80
+ isGroupActive: this._group.api.isActive,
81
+ },
82
+ });
83
+ };
84
+ return ReactGroupControlsRendererPart;
85
+ }());
86
+ exports.ReactGroupControlsRendererPart = ReactGroupControlsRendererPart;
87
+ //# sourceMappingURL=groupControlsRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"groupControlsRenderer.js","sourceRoot":"","sources":["../../../../src/react/dockview/groupControlsRenderer.ts"],"names":[],"mappings":"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"}
@@ -1,37 +1,22 @@
1
1
  import * as React from 'react';
2
- import { IContentRenderer, GroupPanelContentPartInitParameters, ITabRenderer } from '../../groupview/types';
2
+ import { IContentRenderer, GroupPanelContentPartInitParameters } from '../../groupview/types';
3
3
  import { ReactPortalStore } from '../react';
4
4
  import { IDockviewPanelProps } from '../dockview/dockview';
5
5
  import { PanelUpdateEvent } from '../../panel/types';
6
- import { DockviewPanelApi } from '../../api/groupPanelApi';
7
- import { DockviewApi } from '../../api/component.api';
8
6
  import { GroupPanel } from '../../groupview/groupviewPanel';
9
7
  import { Event } from '../../events';
10
- export interface IGroupPanelActionbarProps {
11
- api: DockviewPanelApi;
12
- containerApi: DockviewApi;
13
- }
14
- export interface ReactContentPartContext {
15
- api: DockviewPanelApi;
16
- containerApi: DockviewApi;
17
- actionsPortalElement: HTMLElement;
18
- tabPortalElement: ITabRenderer;
19
- }
20
8
  export declare class ReactPanelContentPart implements IContentRenderer {
21
9
  readonly id: string;
22
10
  private readonly component;
23
11
  private readonly reactPortalStore;
24
12
  private _element;
25
13
  private part?;
26
- private _actionsElement;
27
- private actionsPart?;
28
14
  private _group;
29
15
  private readonly _onDidFocus;
30
16
  readonly onDidFocus: Event<void>;
31
17
  private readonly _onDidBlur;
32
18
  readonly onDidBlur: Event<void>;
33
19
  get element(): HTMLElement;
34
- get actions(): HTMLElement;
35
20
  constructor(id: string, component: React.FunctionComponent<IDockviewPanelProps>, reactPortalStore: ReactPortalStore);
36
21
  focus(): void;
37
22
  init(parameters: GroupPanelContentPartInitParameters): void;
@@ -14,8 +14,6 @@ var ReactPanelContentPart = /** @class */ (function () {
14
14
  this.onDidBlur = this._onDidBlur.event;
15
15
  this._element = document.createElement('div');
16
16
  this._element.className = 'dockview-react-part';
17
- this._actionsElement = document.createElement('div');
18
- this._actionsElement.className = 'dockview-react-part';
19
17
  }
20
18
  Object.defineProperty(ReactPanelContentPart.prototype, "element", {
21
19
  get: function () {
@@ -24,28 +22,15 @@ var ReactPanelContentPart = /** @class */ (function () {
24
22
  enumerable: false,
25
23
  configurable: true
26
24
  });
27
- Object.defineProperty(ReactPanelContentPart.prototype, "actions", {
28
- get: function () {
29
- return this._actionsElement;
30
- },
31
- enumerable: false,
32
- configurable: true
33
- });
34
25
  ReactPanelContentPart.prototype.focus = function () {
35
26
  // TODO
36
27
  };
37
28
  ReactPanelContentPart.prototype.init = function (parameters) {
38
- var context = {
39
- api: parameters.api,
40
- containerApi: parameters.containerApi,
41
- actionsPortalElement: this._actionsElement,
42
- tabPortalElement: parameters.tab,
43
- };
44
29
  this.part = new react_1.ReactPart(this.element, this.reactPortalStore, this.component, {
45
30
  params: parameters.params,
46
31
  api: parameters.api,
47
32
  containerApi: parameters.containerApi,
48
- }, context);
33
+ });
49
34
  };
50
35
  ReactPanelContentPart.prototype.toJSON = function () {
51
36
  return {
@@ -63,11 +48,10 @@ var ReactPanelContentPart = /** @class */ (function () {
63
48
  // noop
64
49
  };
65
50
  ReactPanelContentPart.prototype.dispose = function () {
66
- var _a, _b;
51
+ var _a;
67
52
  this._onDidFocus.dispose();
68
53
  this._onDidBlur.dispose();
69
54
  (_a = this.part) === null || _a === void 0 ? void 0 : _a.dispose();
70
- (_b = this.actionsPart) === null || _b === void 0 ? void 0 : _b.dispose();
71
55
  };
72
56
  return ReactPanelContentPart;
73
57
  }());
@@ -1 +1 @@
1
- {"version":3,"file":"reactContentPart.js","sourceRoot":"","sources":["../../../../src/react/dockview/reactContentPart.ts"],"names":[],"mappings":";;;AAMA,kCAAuD;AAMvD,uCAA8C;AAc9C;IAsBI,+BACoB,EAAU,EACT,SAAuD,EACvD,gBAAkC;QAFnC,OAAE,GAAF,EAAE,CAAQ;QACT,cAAS,GAAT,SAAS,CAA8C;QACvD,qBAAgB,GAAhB,gBAAgB,CAAkB;QAjBtC,gBAAW,GAAG,IAAI,gBAAO,EAAQ,CAAC;QAC1C,eAAU,GAAgB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;QAEzC,eAAU,GAAG,IAAI,gBAAO,EAAQ,CAAC;QACzC,cAAS,GAAgB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;QAepD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,qBAAqB,CAAC;QAEhD,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACrD,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,qBAAqB,CAAC;IAC3D,CAAC;IAlBD,sBAAI,0CAAO;aAAX;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;OAAA;IAED,sBAAI,0CAAO;aAAX;YACI,OAAO,IAAI,CAAC,eAAe,CAAC;QAChC,CAAC;;;OAAA;IAcD,qCAAK,GAAL;QACI,OAAO;IACX,CAAC;IAEM,oCAAI,GAAX,UAAY,UAA+C;QACvD,IAAM,OAAO,GAA4B;YACrC,GAAG,EAAE,UAAU,CAAC,GAAG;YACnB,YAAY,EAAE,UAAU,CAAC,YAAY;YACrC,oBAAoB,EAAE,IAAI,CAAC,eAAe;YAC1C,gBAAgB,EAAE,UAAU,CAAC,GAAG;SACnC,CAAC;QAEF,IAAI,CAAC,IAAI,GAAG,IAAI,iBAAS,CACrB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,SAAS,EACd;YACI,MAAM,EAAE,UAAU,CAAC,MAAM;YACzB,GAAG,EAAE,UAAU,CAAC,GAAG;YACnB,YAAY,EAAE,UAAU,CAAC,YAAY;SACxC,EACD,OAAO,CACV,CAAC;IACN,CAAC;IAEM,sCAAM,GAAb;QACI,OAAO;YACH,EAAE,EAAE,IAAI,CAAC,EAAE;SACd,CAAC;IACN,CAAC;IAEM,sCAAM,GAAb,UAAc,KAAuB;;QACjC,MAAA,IAAI,CAAC,IAAI,0CAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAEM,iDAAiB,GAAxB,UACI,KAAiB,EACjB,eAAwB;QAExB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAEM,sCAAM,GAAb,UAAc,MAAc,EAAE,OAAe;QACzC,OAAO;IACX,CAAC;IAEM,uCAAO,GAAd;;QACI,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QAC3B,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;QAC1B,MAAA,IAAI,CAAC,IAAI,0CAAE,OAAO,EAAE,CAAC;QACrB,MAAA,IAAI,CAAC,WAAW,0CAAE,OAAO,EAAE,CAAC;IAChC,CAAC;IACL,4BAAC;AAAD,CAAC,AAtFD,IAsFC;AAtFY,sDAAqB"}
1
+ {"version":3,"file":"reactContentPart.js","sourceRoot":"","sources":["../../../../src/react/dockview/reactContentPart.ts"],"names":[],"mappings":";;;AAKA,kCAAuD;AAIvD,uCAA8C;AAE9C;IAgBI,+BACoB,EAAU,EACT,SAAuD,EACvD,gBAAkC;QAFnC,OAAE,GAAF,EAAE,CAAQ;QACT,cAAS,GAAT,SAAS,CAA8C;QACvD,qBAAgB,GAAhB,gBAAgB,CAAkB;QAbtC,gBAAW,GAAG,IAAI,gBAAO,EAAQ,CAAC;QAC1C,eAAU,GAAgB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;QAEzC,eAAU,GAAG,IAAI,gBAAO,EAAQ,CAAC;QACzC,cAAS,GAAgB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;QAWpD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,qBAAqB,CAAC;IACpD,CAAC;IAXD,sBAAI,0CAAO;aAAX;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;OAAA;IAWD,qCAAK,GAAL;QACI,OAAO;IACX,CAAC;IAEM,oCAAI,GAAX,UAAY,UAA+C;QACvD,IAAI,CAAC,IAAI,GAAG,IAAI,iBAAS,CACrB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,SAAS,EACd;YACI,MAAM,EAAE,UAAU,CAAC,MAAM;YACzB,GAAG,EAAE,UAAU,CAAC,GAAG;YACnB,YAAY,EAAE,UAAU,CAAC,YAAY;SACxC,CACJ,CAAC;IACN,CAAC;IAEM,sCAAM,GAAb;QACI,OAAO;YACH,EAAE,EAAE,IAAI,CAAC,EAAE;SACd,CAAC;IACN,CAAC;IAEM,sCAAM,GAAb,UAAc,KAAuB;;QACjC,MAAA,IAAI,CAAC,IAAI,0CAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAEM,iDAAiB,GAAxB,UACI,KAAiB,EACjB,eAAwB;QAExB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAEM,sCAAM,GAAb,UAAc,MAAc,EAAE,OAAe;QACzC,OAAO;IACX,CAAC;IAEM,uCAAO,GAAd;;QACI,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QAC3B,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;QAC1B,MAAA,IAAI,CAAC,IAAI,0CAAE,OAAO,EAAE,CAAC;IACzB,CAAC;IACL,4BAAC;AAAD,CAAC,AApED,IAoEC;AApEY,sDAAqB"}
@@ -16,6 +16,8 @@ export declare class ReactPanelHeaderPart implements ITabRenderer {
16
16
  init(parameters: GroupPanelPartInitParameters): void;
17
17
  update(event: PanelUpdateEvent): void;
18
18
  toJSON(): {
19
+ id?: undefined;
20
+ } | {
19
21
  id: string;
20
22
  };
21
23
  layout(_width: number, _height: number): void;
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ReactPanelHeaderPart = void 0;
4
4
  var react_1 = require("../react");
5
+ var defaultTab_1 = require("../../dockview/components/tab/defaultTab");
5
6
  var ReactPanelHeaderPart = /** @class */ (function () {
6
7
  function ReactPanelHeaderPart(id, component, reactPortalStore) {
7
8
  this.id = id;
@@ -32,6 +33,9 @@ var ReactPanelHeaderPart = /** @class */ (function () {
32
33
  (_a = this.part) === null || _a === void 0 ? void 0 : _a.update(event.params);
33
34
  };
34
35
  ReactPanelHeaderPart.prototype.toJSON = function () {
36
+ if (this.id === defaultTab_1.DEFAULT_TAB_IDENTIFIER) {
37
+ return {};
38
+ }
35
39
  return {
36
40
  id: this.id,
37
41
  };
@@ -1 +1 @@
1
- {"version":3,"file":"reactHeaderPart.js","sourceRoot":"","sources":["../../../../src/react/dockview/reactHeaderPart.ts"],"names":[],"mappings":";;;AAOA,kCAAuD;AAGvD;IAQI,8BACoB,EAAU,EACT,SAAwD,EACxD,gBAAkC;QAFnC,OAAE,GAAF,EAAE,CAAQ;QACT,cAAS,GAAT,SAAS,CAA+C;QACxD,qBAAgB,GAAhB,gBAAgB,CAAkB;QAEnD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,qBAAqB,CAAC;IACpD,CAAC;IAXD,sBAAI,yCAAO;aAAX;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;OAAA;IAWD,oCAAK,GAAL;QACI,MAAM;IACV,CAAC;IAEM,mCAAI,GAAX,UAAY,UAAwC;QAChD,IAAI,CAAC,IAAI,GAAG,IAAI,iBAAS,CACrB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,SAAS,EACd;YACI,MAAM,EAAE,UAAU,CAAC,MAAM;YACzB,GAAG,EAAE,UAAU,CAAC,GAAG;YACnB,YAAY,EAAE,UAAU,CAAC,YAAY;SACxC,CACJ,CAAC;IACN,CAAC;IAEM,qCAAM,GAAb,UAAc,KAAuB;;QACjC,MAAA,IAAI,CAAC,IAAI,0CAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAEM,qCAAM,GAAb;QACI,OAAO;YACH,EAAE,EAAE,IAAI,CAAC,EAAE;SACd,CAAC;IACN,CAAC;IAEM,qCAAM,GAAb,UAAc,MAAc,EAAE,OAAe;QACzC,4BAA4B;IAChC,CAAC;IAEM,gDAAiB,GAAxB,UACI,MAAkB,EAClB,eAAwB;QAExB,4BAA4B;IAChC,CAAC;IAEM,sCAAO,GAAd;;QACI,MAAA,IAAI,CAAC,IAAI,0CAAE,OAAO,EAAE,CAAC;IACzB,CAAC;IACL,2BAAC;AAAD,CAAC,AA1DD,IA0DC;AA1DY,oDAAoB"}
1
+ {"version":3,"file":"reactHeaderPart.js","sourceRoot":"","sources":["../../../../src/react/dockview/reactHeaderPart.ts"],"names":[],"mappings":";;;AAOA,kCAAuD;AAEvD,uEAAkF;AAElF;IAQI,8BACoB,EAAU,EACT,SAAwD,EACxD,gBAAkC;QAFnC,OAAE,GAAF,EAAE,CAAQ;QACT,cAAS,GAAT,SAAS,CAA+C;QACxD,qBAAgB,GAAhB,gBAAgB,CAAkB;QAEnD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,qBAAqB,CAAC;IACpD,CAAC;IAXD,sBAAI,yCAAO;aAAX;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;OAAA;IAWD,oCAAK,GAAL;QACI,MAAM;IACV,CAAC;IAEM,mCAAI,GAAX,UAAY,UAAwC;QAChD,IAAI,CAAC,IAAI,GAAG,IAAI,iBAAS,CACrB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,SAAS,EACd;YACI,MAAM,EAAE,UAAU,CAAC,MAAM;YACzB,GAAG,EAAE,UAAU,CAAC,GAAG;YACnB,YAAY,EAAE,UAAU,CAAC,YAAY;SACxC,CACJ,CAAC;IACN,CAAC;IAEM,qCAAM,GAAb,UAAc,KAAuB;;QACjC,MAAA,IAAI,CAAC,IAAI,0CAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAEM,qCAAM,GAAb;QACI,IAAI,IAAI,CAAC,EAAE,KAAK,mCAAsB,EAAE;YACpC,OAAO,EAAE,CAAC;SACb;QAED,OAAO;YACH,EAAE,EAAE,IAAI,CAAC,EAAE;SACd,CAAC;IACN,CAAC;IAEM,qCAAM,GAAb,UAAc,MAAc,EAAE,OAAe;QACzC,4BAA4B;IAChC,CAAC;IAEM,gDAAiB,GAAxB,UACI,MAAkB,EAClB,eAAwB;QAExB,4BAA4B;IAChC,CAAC;IAEM,sCAAO,GAAd;;QACI,MAAA,IAAI,CAAC,IAAI,0CAAE,OAAO,EAAE,CAAC;IACzB,CAAC;IACL,2BAAC;AAAD,CAAC,AA9DD,IA8DC;AA9DY,oDAAoB"}
@@ -1,8 +1,8 @@
1
1
  export * from './dockview/dockview';
2
+ export * from './dockview/defaultTab';
2
3
  export * from './splitview/splitview';
3
4
  export * from './gridview/gridview';
4
- export * from './dockview/reactContentPart';
5
- export * from './dockview/reactHeaderPart';
5
+ export { IDockviewGroupControlProps } from './dockview/groupControlsRenderer';
6
6
  export { IWatermarkPanelProps } from './dockview/reactWatermarkPart';
7
7
  export * from './paneview/paneview';
8
8
  export * from './types';
@@ -15,10 +15,9 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./dockview/dockview"), exports);
18
+ __exportStar(require("./dockview/defaultTab"), exports);
18
19
  __exportStar(require("./splitview/splitview"), exports);
19
20
  __exportStar(require("./gridview/gridview"), exports);
20
- __exportStar(require("./dockview/reactContentPart"), exports);
21
- __exportStar(require("./dockview/reactHeaderPart"), exports);
22
21
  __exportStar(require("./paneview/paneview"), exports);
23
22
  __exportStar(require("./types"), exports);
24
23
  __exportStar(require("./react"), exports);
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/react/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sDAAoC;AACpC,wDAAsC;AACtC,sDAAoC;AACpC,8DAA4C;AAC5C,6DAA2C;AAE3C,sDAAoC;AACpC,0CAAwB;AACxB,0CAAwB"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/react/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sDAAoC;AACpC,wDAAsC;AACtC,wDAAsC;AACtC,sDAAoC;AAGpC,sDAAoC;AACpC,0CAAwB;AACxB,0CAAwB"}
@@ -1,5 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { PaneviewPanelApi } from '../../api/paneviewPanelApi';
3
+ import { PaneviewDndOverlayEvent } from '../../paneview/paneviewComponent';
3
4
  import { PaneviewApi } from '../../api/component.api';
4
5
  import { PanelCollection, PanelParameters } from '../types';
5
6
  import { PaneviewDropEvent2 } from '../../paneview/draggablePaneviewPanel';
@@ -23,6 +24,7 @@ export interface IPaneviewReactProps {
23
24
  className?: string;
24
25
  disableAutoResizing?: boolean;
25
26
  disableDnd?: boolean;
27
+ showDndOverlay?: (event: PaneviewDndOverlayEvent) => boolean;
26
28
  onDidDrop?(event: PaneviewDropEvent): void;
27
29
  }
28
30
  export declare const PaneviewReact: React.ForwardRefExoticComponent<IPaneviewReactProps & React.RefAttributes<HTMLDivElement>>;
@@ -97,6 +97,7 @@ exports.PaneviewReact = React.forwardRef(function (props, ref) {
97
97
  createComponent: createComponent,
98
98
  },
99
99
  },
100
+ showDndOverlay: props.showDndOverlay,
100
101
  });
101
102
  var api = new component_api_1.PaneviewApi(paneview);
102
103
  var _a = domRef.current, clientWidth = _a.clientWidth, clientHeight = _a.clientHeight;
@@ -141,6 +142,14 @@ exports.PaneviewReact = React.forwardRef(function (props, ref) {
141
142
  disposable.dispose();
142
143
  };
143
144
  }, [props.onDidDrop]);
145
+ React.useEffect(function () {
146
+ if (!paneviewRef.current) {
147
+ return;
148
+ }
149
+ paneviewRef.current.updateOptions({
150
+ showDndOverlay: props.showDndOverlay,
151
+ });
152
+ }, [props.showDndOverlay]);
144
153
  return (React.createElement("div", { className: props.className, style: { height: '100%', width: '100%' }, ref: domRef }, portals));
145
154
  });
146
155
  exports.PaneviewReact.displayName = 'PaneviewComponent';
@@ -1 +1 @@
1
- {"version":3,"file":"paneview.js","sourceRoot":"","sources":["../../../../src/react/paneview/paneview.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"paneview.js","sourceRoot":"","sources":["../../../../src/react/paneview/paneview.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA+B;AAE/B,sEAI0C;AAC1C,kCAA+C;AAC/C,yDAAsD;AACtD,+BAA0C;AAE1C,iCAA+C;AA6BlC,QAAA,aAAa,GAAG,KAAK,CAAC,UAAU,CACzC,UAAC,KAA0B,EAAE,GAAuC;IAChE,IAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAiB,IAAI,CAAC,CAAC;IAClD,IAAM,WAAW,GAAG,KAAK,CAAC,MAAM,EAAsB,CAAC;IACjD,IAAA,KAAA,OAAuB,IAAA,2BAAmB,GAAE,IAAA,EAA3C,OAAO,QAAA,EAAE,SAAS,QAAyB,CAAC;IAEnD,KAAK,CAAC,mBAAmB,CAAC,GAAG,EAAE,cAAM,OAAA,MAAM,CAAC,OAAQ,EAAf,CAAe,EAAE,EAAE,CAAC,CAAC;IAE1D,KAAK,CAAC,SAAS,CAAC;QACZ,IAAI,KAAK,CAAC,mBAAmB,EAAE;YAC3B,OAAO;gBACH,EAAE;YACN,CAAC,CAAC;SACL;QAED,IAAM,OAAO,GAAG,IAAA,wBAAkB,EAAC,MAAM,CAAC,OAAQ,EAAE,UAAC,KAAK;;YAChD,IAAA,KAAoB,KAAK,CAAC,WAAW,EAAnC,KAAK,WAAA,EAAE,MAAM,YAAsB,CAAC;YAC5C,MAAA,WAAW,CAAC,OAAO,0CAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,OAAO;YACH,OAAO,CAAC,OAAO,EAAE,CAAC;QACtB,CAAC,CAAC;IACN,CAAC,EAAE,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC;IAEhC,KAAK,CAAC,SAAS,CAAC;QACZ,IAAM,eAAe,GAAG,UACpB,EAAU,EACV,YAAoB,EACpB,SAAc;YAEd,OAAA,IAAI,uBAAgB,CAAC,EAAE,EAAE,SAAS,EAAE;gBAChC,SAAS,WAAA;aACZ,CAAC;QAFF,CAEE,CAAC;QAEP,IAAM,QAAQ,GAAG,IAAI,qCAAiB,CAAC,MAAM,CAAC,OAAQ,EAAE;YACpD,mBAAmB,EAAE,KAAK,CAAC,UAAU;YACrC,UAAU,EAAE,EAAE;YACd,gBAAgB,EAAE,EAAE;YACpB,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,yBAAyB,EAAE,KAAK,CAAC,gBAAgB;YACjD,gBAAgB,EAAE;gBACd,MAAM,EAAE;oBACJ,eAAe,iBAAA;iBAClB;gBACD,IAAI,EAAE;oBACF,eAAe,iBAAA;iBAClB;aACJ;YACD,cAAc,EAAE,KAAK,CAAC,cAAc;SACvC,CAAC,CAAC;QAEH,IAAM,GAAG,GAAG,IAAI,2BAAW,CAAC,QAAQ,CAAC,CAAC;QAEhC,IAAA,KAAgC,MAAM,CAAC,OAAQ,EAA7C,WAAW,iBAAA,EAAE,YAAY,kBAAoB,CAAC;QACtD,QAAQ,CAAC,MAAM,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;QAE3C,IAAI,KAAK,CAAC,OAAO,EAAE;YACf,KAAK,CAAC,OAAO,CAAC,EAAE,GAAG,KAAA,EAAE,CAAC,CAAC;SAC1B;QAED,WAAW,CAAC,OAAO,GAAG,QAAQ,CAAC;QAE/B,OAAO;YACH,QAAQ,CAAC,OAAO,EAAE,CAAC;QACvB,CAAC,CAAC;IACN,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,KAAK,CAAC,SAAS,CAAC;QACZ,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE;YACtB,OAAO;SACV;QACD,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC;YAC9B,mBAAmB,EAAE,KAAK,CAAC,UAAU;SACxC,CAAC,CAAC;IACP,CAAC,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC;IAEvB,KAAK,CAAC,SAAS,CAAC;QACZ,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE;YACtB,OAAO;SACV;QACD,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC;YAC9B,yBAAyB,EAAE,KAAK,CAAC,gBAAgB;SACpD,CAAC,CAAC;IACP,CAAC,EAAE,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAE7B,KAAK,CAAC,SAAS,CAAC;QACZ,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE;YACtB,OAAO;gBACH,EAAE;YACN,CAAC,CAAC;SACL;QAED,IAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,CAAC;QAErC,IAAM,UAAU,GAAG,QAAQ,CAAC,SAAS,CAAC,UAAC,KAAK;YACxC,IAAI,KAAK,CAAC,SAAS,EAAE;gBACjB,KAAK,CAAC,SAAS,uBACR,KAAK,KACR,GAAG,EAAE,IAAI,2BAAW,CAAC,QAAQ,CAAC,IAChC,CAAC;aACN;QACL,CAAC,CAAC,CAAC;QAEH,OAAO;YACH,UAAU,CAAC,OAAO,EAAE,CAAC;QACzB,CAAC,CAAC;IACN,CAAC,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;IAEtB,KAAK,CAAC,SAAS,CAAC;QACZ,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE;YACtB,OAAO;SACV;QACD,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC;YAC9B,cAAc,EAAE,KAAK,CAAC,cAAc;SACvC,CAAC,CAAC;IACP,CAAC,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC;IAE3B,OAAO,CACH,6BACI,SAAS,EAAE,KAAK,CAAC,SAAS,EAC1B,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,EACxC,GAAG,EAAE,MAAM,IAEV,OAAO,CACN,CACT,CAAC;AACN,CAAC,CACJ,CAAC;AACF,qBAAa,CAAC,WAAW,GAAG,mBAAmB,CAAC"}
@@ -11,6 +11,7 @@ export declare class ReactPart<P extends object, C extends object = {}> implemen
11
11
  private readonly component;
12
12
  private readonly parameters;
13
13
  private readonly context?;
14
+ private _initialProps;
14
15
  private componentInstance?;
15
16
  private ref?;
16
17
  private disposed;
@@ -103,15 +103,21 @@ var ReactPart = /** @class */ (function () {
103
103
  this.component = component;
104
104
  this.parameters = parameters;
105
105
  this.context = context;
106
+ this._initialProps = {};
106
107
  this.disposed = false;
107
108
  this.createPortal();
108
109
  }
109
110
  ReactPart.prototype.update = function (props) {
110
- var _a;
111
111
  if (this.disposed) {
112
112
  throw new Error('invalid operation: resource is already disposed');
113
113
  }
114
- (_a = this.componentInstance) === null || _a === void 0 ? void 0 : _a.update(props);
114
+ if (!this.componentInstance) {
115
+ // if the component is yet to be mounted store the props
116
+ this._initialProps = __assign(__assign({}, this._initialProps), props);
117
+ }
118
+ else {
119
+ this.componentInstance.update(props);
120
+ }
115
121
  };
116
122
  ReactPart.prototype.createPortal = function () {
117
123
  var _this = this;
@@ -132,6 +138,10 @@ var ReactPart = /** @class */ (function () {
132
138
  componentProps: this.parameters,
133
139
  ref: function (element) {
134
140
  _this.componentInstance = element;
141
+ if (Object.keys(_this._initialProps).length > 0) {
142
+ _this.componentInstance.update(_this._initialProps);
143
+ _this._initialProps = {}; // don't keep a reference to the users object once no longer required
144
+ }
135
145
  },
136
146
  });
137
147
  var node = this.context