dockview 1.5.0 → 1.5.2

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 (339) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +52 -52
  3. package/dist/cjs/actionbar/actionsContainer.d.ts +7 -7
  4. package/dist/cjs/actionbar/actionsContainer.js +26 -26
  5. package/dist/cjs/api/component.api.d.ts +144 -144
  6. package/dist/cjs/api/component.api.js +571 -571
  7. package/dist/cjs/api/gridviewPanelApi.d.ts +36 -36
  8. package/dist/cjs/api/gridviewPanelApi.js +47 -47
  9. package/dist/cjs/api/groupPanelApi.d.ts +34 -41
  10. package/dist/cjs/api/groupPanelApi.js +85 -96
  11. package/dist/cjs/api/groupPanelApi.js.map +1 -1
  12. package/dist/cjs/api/panelApi.d.ts +81 -81
  13. package/dist/cjs/api/panelApi.js +121 -121
  14. package/dist/cjs/api/paneviewPanelApi.d.ts +26 -26
  15. package/dist/cjs/api/paneviewPanelApi.js +57 -57
  16. package/dist/cjs/api/splitviewPanelApi.d.ts +32 -32
  17. package/dist/cjs/api/splitviewPanelApi.js +47 -47
  18. package/dist/cjs/array.d.ts +13 -13
  19. package/dist/cjs/array.js +77 -77
  20. package/dist/cjs/dnd/abstractDragHandler.d.ts +11 -11
  21. package/dist/cjs/dnd/abstractDragHandler.js +115 -115
  22. package/dist/cjs/dnd/dataTransfer.d.ts +31 -31
  23. package/dist/cjs/dnd/dataTransfer.js +100 -100
  24. package/dist/cjs/dnd/dnd.d.ts +27 -27
  25. package/dist/cjs/dnd/dnd.js +64 -64
  26. package/dist/cjs/dnd/droptarget.d.ts +37 -37
  27. package/dist/cjs/dnd/droptarget.js +201 -201
  28. package/dist/cjs/dockview/components/tab/defaultTab.d.ts +27 -27
  29. package/dist/cjs/dockview/components/tab/defaultTab.js +121 -126
  30. package/dist/cjs/dockview/components/tab/defaultTab.js.map +1 -1
  31. package/dist/cjs/dockview/components/watermark/watermark.d.ts +20 -20
  32. package/dist/cjs/dockview/components/watermark/watermark.js +101 -101
  33. package/dist/cjs/dockview/defaultGroupPanelView.d.ts +29 -29
  34. package/dist/cjs/dockview/defaultGroupPanelView.js +68 -68
  35. package/dist/cjs/dockview/deserializer.d.ts +5 -5
  36. package/dist/cjs/dockview/deserializer.js +2 -2
  37. package/dist/cjs/dockview/dockviewComponent.d.ts +125 -130
  38. package/dist/cjs/dockview/dockviewComponent.js +614 -629
  39. package/dist/cjs/dockview/dockviewComponent.js.map +1 -1
  40. package/dist/cjs/dockview/dockviewGroupPanel.d.ts +31 -33
  41. package/dist/cjs/dockview/dockviewGroupPanel.js +156 -175
  42. package/dist/cjs/dockview/dockviewGroupPanel.js.map +1 -1
  43. package/dist/cjs/dockview/options.d.ts +88 -89
  44. package/dist/cjs/dockview/options.js +2 -2
  45. package/dist/cjs/dom.d.ts +14 -14
  46. package/dist/cjs/dom.js +182 -182
  47. package/dist/cjs/events.d.ts +30 -30
  48. package/dist/cjs/events.js +129 -129
  49. package/dist/cjs/gridview/baseComponentGridview.d.ts +87 -87
  50. package/dist/cjs/gridview/baseComponentGridview.js +279 -279
  51. package/dist/cjs/gridview/basePanelView.d.ts +43 -43
  52. package/dist/cjs/gridview/basePanelView.js +123 -123
  53. package/dist/cjs/gridview/branchNode.d.ts +49 -46
  54. package/dist/cjs/gridview/branchNode.js +342 -342
  55. package/dist/cjs/gridview/branchNode.js.map +1 -1
  56. package/dist/cjs/gridview/gridview.d.ts +126 -123
  57. package/dist/cjs/gridview/gridview.js +479 -479
  58. package/dist/cjs/gridview/gridview.js.map +1 -1
  59. package/dist/cjs/gridview/gridviewComponent.d.ts +85 -85
  60. package/dist/cjs/gridview/gridviewComponent.js +325 -325
  61. package/dist/cjs/gridview/gridviewPanel.d.ts +60 -60
  62. package/dist/cjs/gridview/gridviewPanel.js +202 -202
  63. package/dist/cjs/gridview/leafNode.d.ts +34 -31
  64. package/dist/cjs/gridview/leafNode.js +170 -165
  65. package/dist/cjs/gridview/leafNode.js.map +1 -1
  66. package/dist/cjs/gridview/options.d.ts +18 -18
  67. package/dist/cjs/gridview/options.js +2 -2
  68. package/dist/cjs/gridview/types.d.ts +3 -3
  69. package/dist/cjs/gridview/types.js +2 -2
  70. package/dist/cjs/groupview/dnd.d.ts +5 -5
  71. package/dist/cjs/groupview/dnd.js +9 -9
  72. package/dist/cjs/groupview/groupPanel.d.ts +32 -35
  73. package/dist/cjs/groupview/groupPanel.js +2 -2
  74. package/dist/cjs/groupview/groupview.d.ts +177 -177
  75. package/dist/cjs/groupview/groupview.js +589 -589
  76. package/dist/cjs/groupview/groupviewPanel.d.ts +35 -35
  77. package/dist/cjs/groupview/groupviewPanel.js +128 -128
  78. package/dist/cjs/groupview/panel/content.d.ts +30 -30
  79. package/dist/cjs/groupview/panel/content.js +100 -100
  80. package/dist/cjs/groupview/tab.d.ts +41 -42
  81. package/dist/cjs/groupview/tab.js +120 -126
  82. package/dist/cjs/groupview/tab.js.map +1 -1
  83. package/dist/cjs/groupview/titlebar/tabsContainer.d.ts +68 -68
  84. package/dist/cjs/groupview/titlebar/tabsContainer.js +258 -270
  85. package/dist/cjs/groupview/titlebar/tabsContainer.js.map +1 -1
  86. package/dist/cjs/groupview/types.d.ts +52 -53
  87. package/dist/cjs/groupview/types.js +2 -2
  88. package/dist/cjs/hostedContainer.d.ts +23 -23
  89. package/dist/cjs/hostedContainer.js +73 -73
  90. package/dist/cjs/index.d.ts +30 -30
  91. package/dist/cjs/index.js +46 -46
  92. package/dist/cjs/index.js.map +1 -1
  93. package/dist/cjs/lifecycle.d.ts +22 -22
  94. package/dist/cjs/lifecycle.js +88 -88
  95. package/dist/cjs/math.d.ts +4 -4
  96. package/dist/cjs/math.js +15 -15
  97. package/dist/cjs/panel/componentFactory.d.ts +8 -8
  98. package/dist/cjs/panel/componentFactory.js +30 -30
  99. package/dist/cjs/panel/types.d.ts +33 -33
  100. package/dist/cjs/panel/types.js +2 -2
  101. package/dist/cjs/paneview/defaultPaneviewHeader.d.ts +21 -21
  102. package/dist/cjs/paneview/defaultPaneviewHeader.js +90 -90
  103. package/dist/cjs/paneview/draggablePaneviewPanel.d.ts +19 -19
  104. package/dist/cjs/paneview/draggablePaneviewPanel.js +129 -129
  105. package/dist/cjs/paneview/options.d.ts +27 -27
  106. package/dist/cjs/paneview/options.js +2 -2
  107. package/dist/cjs/paneview/paneview.d.ts +40 -40
  108. package/dist/cjs/paneview/paneview.js +201 -201
  109. package/dist/cjs/paneview/paneviewComponent.d.ts +129 -129
  110. package/dist/cjs/paneview/paneviewComponent.js +394 -394
  111. package/dist/cjs/paneview/paneviewPanel.d.ts +92 -89
  112. package/dist/cjs/paneview/paneviewPanel.js +274 -274
  113. package/dist/cjs/paneview/paneviewPanel.js.map +1 -1
  114. package/dist/cjs/react/deserializer.d.ts +9 -9
  115. package/dist/cjs/react/deserializer.js +43 -45
  116. package/dist/cjs/react/deserializer.js.map +1 -1
  117. package/dist/cjs/react/dockview/defaultTab.d.ts +4 -4
  118. package/dist/cjs/react/dockview/defaultTab.js +72 -72
  119. package/dist/cjs/react/dockview/defaultTab.js.map +1 -1
  120. package/dist/cjs/react/dockview/dockview.d.ts +34 -35
  121. package/dist/cjs/react/dockview/dockview.js +212 -227
  122. package/dist/cjs/react/dockview/dockview.js.map +1 -1
  123. package/dist/cjs/react/dockview/groupControlsRenderer.d.ts +43 -43
  124. package/dist/cjs/react/dockview/groupControlsRenderer.js +86 -86
  125. package/dist/cjs/react/dockview/reactContentPart.d.ts +30 -30
  126. package/dist/cjs/react/dockview/reactContentPart.js +58 -58
  127. package/dist/cjs/react/dockview/reactHeaderPart.d.ts +26 -26
  128. package/dist/cjs/react/dockview/reactHeaderPart.js +55 -55
  129. package/dist/cjs/react/dockview/reactWatermarkPart.d.ts +29 -29
  130. package/dist/cjs/react/dockview/reactWatermarkPart.js +65 -65
  131. package/dist/cjs/react/dockview/v2/reactContentRenderer.d.ts +29 -29
  132. package/dist/cjs/react/dockview/v2/reactContentRenderer.js +87 -87
  133. package/dist/cjs/react/dockview/v2/reactGroupPanelView.d.ts +7 -7
  134. package/dist/cjs/react/dockview/v2/reactGroupPanelView.js +34 -34
  135. package/dist/cjs/react/dockview/v2/webviewContentRenderer.d.ts +18 -18
  136. package/dist/cjs/react/dockview/v2/webviewContentRenderer.js +45 -45
  137. package/dist/cjs/react/gridview/gridview.d.ts +24 -24
  138. package/dist/cjs/react/gridview/gridview.js +112 -112
  139. package/dist/cjs/react/gridview/view.d.ts +11 -11
  140. package/dist/cjs/react/gridview/view.js +40 -40
  141. package/dist/cjs/react/index.d.ts +9 -9
  142. package/dist/cjs/react/index.js +23 -23
  143. package/dist/cjs/react/paneview/paneview.d.ts +30 -30
  144. package/dist/cjs/react/paneview/paneview.js +155 -155
  145. package/dist/cjs/react/paneview/view.d.ts +20 -20
  146. package/dist/cjs/react/paneview/view.js +44 -44
  147. package/dist/cjs/react/react.d.ts +36 -36
  148. package/dist/cjs/react/react.js +194 -194
  149. package/dist/cjs/react/splitview/splitview.d.ts +24 -24
  150. package/dist/cjs/react/splitview/splitview.js +108 -108
  151. package/dist/cjs/react/splitview/view.d.ts +10 -10
  152. package/dist/cjs/react/splitview/view.js +40 -40
  153. package/dist/cjs/react/svg.d.ts +3 -3
  154. package/dist/cjs/react/svg.js +35 -35
  155. package/dist/cjs/react/types.d.ts +7 -7
  156. package/dist/cjs/react/types.js +2 -2
  157. package/dist/cjs/splitview/core/options.d.ts +26 -26
  158. package/dist/cjs/splitview/core/options.js +2 -2
  159. package/dist/cjs/splitview/core/splitview.d.ts +127 -124
  160. package/dist/cjs/splitview/core/splitview.js +908 -908
  161. package/dist/cjs/splitview/core/splitview.js.map +1 -1
  162. package/dist/cjs/splitview/core/viewItem.d.ts +25 -25
  163. package/dist/cjs/splitview/core/viewItem.js +124 -124
  164. package/dist/cjs/splitview/splitviewComponent.d.ts +101 -101
  165. package/dist/cjs/splitview/splitviewComponent.js +373 -373
  166. package/dist/cjs/splitview/splitviewPanel.d.ts +45 -42
  167. package/dist/cjs/splitview/splitviewPanel.js +178 -178
  168. package/dist/cjs/splitview/splitviewPanel.js.map +1 -1
  169. package/dist/cjs/svg.d.ts +3 -3
  170. package/dist/cjs/svg.js +43 -43
  171. package/dist/cjs/types.d.ts +7 -7
  172. package/dist/cjs/types.js +2 -2
  173. package/dist/dockview.amd.js +6737 -6797
  174. package/dist/dockview.amd.min.js +2 -2
  175. package/dist/dockview.amd.min.noStyle.js +2 -2
  176. package/dist/dockview.amd.noStyle.js +6743 -6803
  177. package/dist/dockview.cjs.js +6737 -6797
  178. package/dist/dockview.esm.js +6731 -6791
  179. package/dist/dockview.esm.min.js +2 -2
  180. package/dist/dockview.js +6737 -6797
  181. package/dist/dockview.min.js +2 -2
  182. package/dist/dockview.min.noStyle.js +2 -2
  183. package/dist/dockview.noStyle.js +6743 -6803
  184. package/dist/esm/actionbar/actionsContainer.d.ts +7 -7
  185. package/dist/esm/actionbar/actionsContainer.js +17 -17
  186. package/dist/esm/api/component.api.d.ts +144 -144
  187. package/dist/esm/api/component.api.js +326 -326
  188. package/dist/esm/api/gridviewPanelApi.d.ts +36 -36
  189. package/dist/esm/api/gridviewPanelApi.js +25 -25
  190. package/dist/esm/api/groupPanelApi.d.ts +34 -41
  191. package/dist/esm/api/groupPanelApi.js +50 -57
  192. package/dist/esm/api/panelApi.d.ts +81 -81
  193. package/dist/esm/api/panelApi.js +79 -79
  194. package/dist/esm/api/paneviewPanelApi.d.ts +26 -26
  195. package/dist/esm/api/paneviewPanelApi.js +27 -27
  196. package/dist/esm/api/splitviewPanelApi.d.ts +32 -32
  197. package/dist/esm/api/splitviewPanelApi.js +25 -25
  198. package/dist/esm/array.d.ts +13 -13
  199. package/dist/esm/array.js +67 -67
  200. package/dist/esm/dnd/abstractDragHandler.d.ts +11 -11
  201. package/dist/esm/dnd/abstractDragHandler.js +37 -37
  202. package/dist/esm/dnd/dataTransfer.d.ts +31 -31
  203. package/dist/esm/dnd/dataTransfer.js +69 -69
  204. package/dist/esm/dnd/dnd.d.ts +27 -27
  205. package/dist/esm/dnd/dnd.js +41 -41
  206. package/dist/esm/dnd/droptarget.d.ts +37 -37
  207. package/dist/esm/dnd/droptarget.js +167 -167
  208. package/dist/esm/dockview/components/tab/defaultTab.d.ts +27 -27
  209. package/dist/esm/dockview/components/tab/defaultTab.js +79 -84
  210. package/dist/esm/dockview/components/watermark/watermark.d.ts +20 -20
  211. package/dist/esm/dockview/components/watermark/watermark.js +70 -70
  212. package/dist/esm/dockview/defaultGroupPanelView.d.ts +29 -29
  213. package/dist/esm/dockview/defaultGroupPanelView.js +44 -44
  214. package/dist/esm/dockview/deserializer.d.ts +5 -5
  215. package/dist/esm/dockview/deserializer.js +1 -1
  216. package/dist/esm/dockview/dockviewComponent.d.ts +125 -130
  217. package/dist/esm/dockview/dockviewComponent.js +468 -483
  218. package/dist/esm/dockview/dockviewGroupPanel.d.ts +31 -33
  219. package/dist/esm/dockview/dockviewGroupPanel.js +107 -122
  220. package/dist/esm/dockview/options.d.ts +88 -89
  221. package/dist/esm/dockview/options.js +1 -1
  222. package/dist/esm/dom.d.ts +14 -14
  223. package/dist/esm/dom.js +113 -113
  224. package/dist/esm/events.d.ts +30 -30
  225. package/dist/esm/events.js +88 -88
  226. package/dist/esm/gridview/baseComponentGridview.d.ts +87 -87
  227. package/dist/esm/gridview/baseComponentGridview.js +189 -189
  228. package/dist/esm/gridview/basePanelView.d.ts +43 -43
  229. package/dist/esm/gridview/basePanelView.js +74 -74
  230. package/dist/esm/gridview/branchNode.d.ts +49 -46
  231. package/dist/esm/gridview/branchNode.js +218 -218
  232. package/dist/esm/gridview/gridview.d.ts +126 -123
  233. package/dist/esm/gridview/gridview.js +397 -397
  234. package/dist/esm/gridview/gridviewComponent.d.ts +85 -85
  235. package/dist/esm/gridview/gridviewComponent.js +238 -238
  236. package/dist/esm/gridview/gridviewPanel.d.ts +60 -60
  237. package/dist/esm/gridview/gridviewPanel.js +138 -138
  238. package/dist/esm/gridview/leafNode.d.ts +34 -31
  239. package/dist/esm/gridview/leafNode.js +103 -98
  240. package/dist/esm/gridview/options.d.ts +18 -18
  241. package/dist/esm/gridview/options.js +1 -1
  242. package/dist/esm/gridview/types.d.ts +3 -3
  243. package/dist/esm/gridview/types.js +1 -1
  244. package/dist/esm/groupview/dnd.d.ts +5 -5
  245. package/dist/esm/groupview/dnd.js +6 -6
  246. package/dist/esm/groupview/groupPanel.d.ts +32 -35
  247. package/dist/esm/groupview/groupPanel.js +1 -1
  248. package/dist/esm/groupview/groupview.d.ts +177 -177
  249. package/dist/esm/groupview/groupview.js +444 -444
  250. package/dist/esm/groupview/groupviewPanel.d.ts +35 -35
  251. package/dist/esm/groupview/groupviewPanel.js +61 -61
  252. package/dist/esm/groupview/panel/content.d.ts +30 -30
  253. package/dist/esm/groupview/panel/content.js +73 -73
  254. package/dist/esm/groupview/tab.d.ts +41 -42
  255. package/dist/esm/groupview/tab.js +90 -96
  256. package/dist/esm/groupview/titlebar/tabsContainer.d.ts +68 -68
  257. package/dist/esm/groupview/titlebar/tabsContainer.js +190 -191
  258. package/dist/esm/groupview/types.d.ts +52 -53
  259. package/dist/esm/groupview/types.js +1 -1
  260. package/dist/esm/hostedContainer.d.ts +23 -23
  261. package/dist/esm/hostedContainer.js +63 -63
  262. package/dist/esm/index.d.ts +30 -30
  263. package/dist/esm/index.js +23 -23
  264. package/dist/esm/lifecycle.d.ts +22 -22
  265. package/dist/esm/lifecycle.js +39 -39
  266. package/dist/esm/math.d.ts +4 -4
  267. package/dist/esm/math.js +10 -10
  268. package/dist/esm/panel/componentFactory.d.ts +8 -8
  269. package/dist/esm/panel/componentFactory.js +24 -24
  270. package/dist/esm/panel/types.d.ts +33 -33
  271. package/dist/esm/panel/types.js +1 -1
  272. package/dist/esm/paneview/defaultPaneviewHeader.d.ts +21 -21
  273. package/dist/esm/paneview/defaultPaneviewHeader.js +63 -63
  274. package/dist/esm/paneview/draggablePaneviewPanel.d.ts +19 -19
  275. package/dist/esm/paneview/draggablePaneviewPanel.js +90 -90
  276. package/dist/esm/paneview/options.d.ts +27 -27
  277. package/dist/esm/paneview/options.js +1 -1
  278. package/dist/esm/paneview/paneview.d.ts +40 -40
  279. package/dist/esm/paneview/paneview.js +145 -145
  280. package/dist/esm/paneview/paneviewComponent.d.ts +129 -129
  281. package/dist/esm/paneview/paneviewComponent.js +270 -270
  282. package/dist/esm/paneview/paneviewPanel.d.ts +92 -89
  283. package/dist/esm/paneview/paneviewPanel.js +191 -191
  284. package/dist/esm/react/deserializer.d.ts +9 -9
  285. package/dist/esm/react/deserializer.js +38 -40
  286. package/dist/esm/react/dockview/defaultTab.d.ts +4 -4
  287. package/dist/esm/react/dockview/defaultTab.js +34 -34
  288. package/dist/esm/react/dockview/dockview.d.ts +34 -35
  289. package/dist/esm/react/dockview/dockview.js +157 -172
  290. package/dist/esm/react/dockview/groupControlsRenderer.d.ts +43 -43
  291. package/dist/esm/react/dockview/groupControlsRenderer.js +68 -68
  292. package/dist/esm/react/dockview/reactContentPart.d.ts +30 -30
  293. package/dist/esm/react/dockview/reactContentPart.js +49 -49
  294. package/dist/esm/react/dockview/reactHeaderPart.d.ts +26 -26
  295. package/dist/esm/react/dockview/reactHeaderPart.js +46 -46
  296. package/dist/esm/react/dockview/reactWatermarkPart.d.ts +29 -29
  297. package/dist/esm/react/dockview/reactWatermarkPart.js +55 -55
  298. package/dist/esm/react/dockview/v2/reactContentRenderer.d.ts +29 -29
  299. package/dist/esm/react/dockview/v2/reactContentRenderer.js +69 -69
  300. package/dist/esm/react/dockview/v2/reactGroupPanelView.d.ts +7 -7
  301. package/dist/esm/react/dockview/v2/reactGroupPanelView.js +12 -12
  302. package/dist/esm/react/dockview/v2/webviewContentRenderer.d.ts +18 -18
  303. package/dist/esm/react/dockview/v2/webviewContentRenderer.js +36 -36
  304. package/dist/esm/react/gridview/gridview.d.ts +24 -24
  305. package/dist/esm/react/gridview/gridview.js +70 -70
  306. package/dist/esm/react/gridview/view.d.ts +11 -11
  307. package/dist/esm/react/gridview/view.js +18 -18
  308. package/dist/esm/react/index.d.ts +9 -9
  309. package/dist/esm/react/index.js +7 -7
  310. package/dist/esm/react/paneview/paneview.d.ts +30 -30
  311. package/dist/esm/react/paneview/paneview.js +100 -100
  312. package/dist/esm/react/paneview/view.d.ts +20 -20
  313. package/dist/esm/react/paneview/view.js +35 -35
  314. package/dist/esm/react/react.d.ts +36 -36
  315. package/dist/esm/react/react.js +125 -125
  316. package/dist/esm/react/splitview/splitview.d.ts +24 -24
  317. package/dist/esm/react/splitview/splitview.js +66 -66
  318. package/dist/esm/react/splitview/view.d.ts +10 -10
  319. package/dist/esm/react/splitview/view.js +18 -18
  320. package/dist/esm/react/svg.d.ts +3 -3
  321. package/dist/esm/react/svg.js +7 -7
  322. package/dist/esm/react/types.d.ts +7 -7
  323. package/dist/esm/react/types.js +1 -1
  324. package/dist/esm/splitview/core/options.d.ts +26 -26
  325. package/dist/esm/splitview/core/options.js +1 -1
  326. package/dist/esm/splitview/core/splitview.d.ts +127 -124
  327. package/dist/esm/splitview/core/splitview.js +689 -689
  328. package/dist/esm/splitview/core/viewItem.d.ts +25 -25
  329. package/dist/esm/splitview/core/viewItem.js +79 -79
  330. package/dist/esm/splitview/splitviewComponent.d.ts +101 -101
  331. package/dist/esm/splitview/splitviewComponent.js +249 -249
  332. package/dist/esm/splitview/splitviewPanel.d.ts +45 -42
  333. package/dist/esm/splitview/splitviewPanel.js +107 -107
  334. package/dist/esm/svg.d.ts +3 -3
  335. package/dist/esm/svg.js +31 -31
  336. package/dist/esm/types.d.ts +7 -7
  337. package/dist/esm/types.js +1 -1
  338. package/dist/styles/dockview.css +0 -3
  339. package/package.json +2 -2
@@ -1,249 +1,249 @@
1
- import { CompositeDisposable, MutableDisposable, } from '../lifecycle';
2
- import { Orientation, Sizing, Splitview, } from './core/splitview';
3
- import { Emitter } from '../events';
4
- import { createComponent } from '../panel/componentFactory';
5
- /**
6
- * A high-level implementation of splitview that works using 'panels'
7
- */
8
- export class SplitviewComponent extends CompositeDisposable {
9
- constructor(element, options) {
10
- super();
11
- this.element = element;
12
- this._disposable = new MutableDisposable();
13
- this._panels = new Map();
14
- this._onDidLayoutfromJSON = new Emitter();
15
- this.onDidLayoutFromJSON = this._onDidLayoutfromJSON.event;
16
- this._onDidAddView = new Emitter();
17
- this.onDidAddView = this._onDidAddView.event;
18
- this._onDidRemoveView = new Emitter();
19
- this.onDidRemoveView = this._onDidRemoveView.event;
20
- this._onDidLayoutChange = new Emitter();
21
- this.onDidLayoutChange = this._onDidLayoutChange.event;
22
- this._options = options;
23
- if (!options.components) {
24
- options.components = {};
25
- }
26
- if (!options.frameworkComponents) {
27
- options.frameworkComponents = {};
28
- }
29
- this.splitview = new Splitview(this.element, options);
30
- this.addDisposables(this._disposable, this._onDidAddView, this._onDidLayoutfromJSON, this._onDidRemoveView, this._onDidLayoutChange);
31
- }
32
- get panels() {
33
- return this.splitview.getViews();
34
- }
35
- get options() {
36
- return this._options;
37
- }
38
- get length() {
39
- return this._panels.size;
40
- }
41
- get orientation() {
42
- return this.splitview.orientation;
43
- }
44
- get splitview() {
45
- return this._splitview;
46
- }
47
- set splitview(value) {
48
- this._splitview = value;
49
- this._disposable.value = new CompositeDisposable(this._splitview.onDidSashEnd(() => {
50
- this._onDidLayoutChange.fire(undefined);
51
- }), this._splitview.onDidAddView((e) => this._onDidAddView.fire(e)), this._splitview.onDidRemoveView((e) => this._onDidRemoveView.fire(e)));
52
- }
53
- get minimumSize() {
54
- return this.splitview.minimumSize;
55
- }
56
- get maximumSize() {
57
- return this.splitview.maximumSize;
58
- }
59
- get height() {
60
- return this.splitview.orientation === Orientation.HORIZONTAL
61
- ? this.splitview.orthogonalSize
62
- : this.splitview.size;
63
- }
64
- get width() {
65
- return this.splitview.orientation === Orientation.HORIZONTAL
66
- ? this.splitview.size
67
- : this.splitview.orthogonalSize;
68
- }
69
- updateOptions(options) {
70
- const hasOrientationChanged = typeof options.orientation === 'string' &&
71
- this.options.orientation !== options.orientation;
72
- this._options = Object.assign(Object.assign({}, this.options), options);
73
- if (hasOrientationChanged) {
74
- this.splitview.orientation = options.orientation;
75
- }
76
- this.splitview.layout(this.splitview.size, this.splitview.orthogonalSize);
77
- }
78
- focus() {
79
- var _a;
80
- (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.focus();
81
- }
82
- movePanel(from, to) {
83
- this.splitview.moveView(from, to);
84
- }
85
- setVisible(panel, visible) {
86
- const index = this.panels.indexOf(panel);
87
- this.splitview.setViewVisible(index, visible);
88
- }
89
- setActive(view, skipFocus) {
90
- this._activePanel = view;
91
- this.panels
92
- .filter((v) => v !== view)
93
- .forEach((v) => {
94
- v.api._onDidActiveChange.fire({ isActive: false });
95
- if (!skipFocus) {
96
- v.focus();
97
- }
98
- });
99
- view.api._onDidActiveChange.fire({ isActive: true });
100
- if (!skipFocus) {
101
- view.focus();
102
- }
103
- }
104
- removePanel(panel, sizing) {
105
- const disposable = this._panels.get(panel.id);
106
- if (!disposable) {
107
- throw new Error(`unknown splitview panel ${panel.id}`);
108
- }
109
- disposable.disposable.dispose();
110
- disposable.value.dispose();
111
- this._panels.delete(panel.id);
112
- const index = this.panels.findIndex((_) => _ === panel);
113
- this.splitview.removeView(index, sizing);
114
- const panels = this.panels;
115
- if (panels.length > 0) {
116
- this.setActive(panels[panels.length - 1]);
117
- }
118
- }
119
- getPanel(id) {
120
- return this.panels.find((view) => view.id === id);
121
- }
122
- addPanel(options) {
123
- if (this._panels.has(options.id)) {
124
- throw new Error(`panel ${options.id} already exists`);
125
- }
126
- const view = createComponent(options.id, options.component, this.options.components || {}, this.options.frameworkComponents || {}, this.options.frameworkWrapper
127
- ? {
128
- createComponent: this.options.frameworkWrapper.createComponent,
129
- }
130
- : undefined);
131
- view.orientation = this.splitview.orientation;
132
- view.init({
133
- params: options.params || {},
134
- minimumSize: options.minimumSize,
135
- maximumSize: options.maximumSize,
136
- snap: options.snap,
137
- priority: options.priority,
138
- accessor: this,
139
- });
140
- const size = typeof options.size === 'number' ? options.size : Sizing.Distribute;
141
- const index = typeof options.index === 'number' ? options.index : undefined;
142
- this.splitview.addView(view, size, index);
143
- this.doAddView(view);
144
- this.setActive(view);
145
- return view;
146
- }
147
- layout(width, height) {
148
- const [size, orthogonalSize] = this.splitview.orientation === Orientation.HORIZONTAL
149
- ? [width, height]
150
- : [height, width];
151
- this.splitview.layout(size, orthogonalSize);
152
- }
153
- doAddView(view) {
154
- const disposable = view.api.onDidFocusChange((event) => {
155
- if (!event.isFocused) {
156
- return;
157
- }
158
- this.setActive(view, true);
159
- });
160
- this._panels.set(view.id, { disposable, value: view });
161
- }
162
- toJSON() {
163
- var _a;
164
- const views = this.splitview
165
- .getViews()
166
- .map((view, i) => {
167
- const size = this.splitview.getViewSize(i);
168
- return {
169
- size,
170
- data: view.toJSON(),
171
- snap: !!view.snap,
172
- priority: view.priority,
173
- };
174
- });
175
- return {
176
- views,
177
- activeView: (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.id,
178
- size: this.splitview.size,
179
- orientation: this.splitview.orientation,
180
- };
181
- }
182
- fromJSON(serializedSplitview) {
183
- this.clear();
184
- const { views, orientation, size, activeView } = serializedSplitview;
185
- const queue = [];
186
- this.splitview = new Splitview(this.element, {
187
- orientation,
188
- proportionalLayout: this.options.proportionalLayout,
189
- descriptor: {
190
- size,
191
- views: views.map((view) => {
192
- const data = view.data;
193
- if (this._panels.has(data.id)) {
194
- throw new Error(`panel ${data.id} already exists`);
195
- }
196
- const panel = createComponent(data.id, data.component, this.options.components || {}, this.options.frameworkComponents || {}, this.options.frameworkWrapper
197
- ? {
198
- createComponent: this.options.frameworkWrapper
199
- .createComponent,
200
- }
201
- : undefined);
202
- queue.push(() => {
203
- panel.init({
204
- params: data.params || {},
205
- minimumSize: data.minimumSize,
206
- maximumSize: data.maximumSize,
207
- snap: view.snap,
208
- priority: view.priority,
209
- accessor: this,
210
- });
211
- });
212
- panel.orientation = orientation;
213
- this.doAddView(panel);
214
- setTimeout(() => {
215
- // the original onDidAddView events are missed since they are fired before we can subcribe to them
216
- this._onDidAddView.fire(panel);
217
- }, 0);
218
- return { size: view.size, view: panel };
219
- }),
220
- },
221
- });
222
- this.layout(this.width, this.height);
223
- queue.forEach((f) => f());
224
- if (typeof activeView === 'string') {
225
- const panel = this.getPanel(activeView);
226
- if (panel) {
227
- this.setActive(panel);
228
- }
229
- }
230
- this._onDidLayoutfromJSON.fire();
231
- }
232
- clear() {
233
- for (const [_, value] of this._panels.entries()) {
234
- value.disposable.dispose();
235
- value.value.dispose();
236
- }
237
- this._panels.clear();
238
- this.splitview.dispose();
239
- }
240
- dispose() {
241
- for (const [_, value] of this._panels.entries()) {
242
- value.disposable.dispose();
243
- value.value.dispose();
244
- }
245
- this._panels.clear();
246
- this.splitview.dispose();
247
- super.dispose();
248
- }
249
- }
1
+ import { CompositeDisposable, MutableDisposable, } from '../lifecycle';
2
+ import { Orientation, Sizing, Splitview, } from './core/splitview';
3
+ import { Emitter } from '../events';
4
+ import { createComponent } from '../panel/componentFactory';
5
+ /**
6
+ * A high-level implementation of splitview that works using 'panels'
7
+ */
8
+ export class SplitviewComponent extends CompositeDisposable {
9
+ constructor(element, options) {
10
+ super();
11
+ this.element = element;
12
+ this._disposable = new MutableDisposable();
13
+ this._panels = new Map();
14
+ this._onDidLayoutfromJSON = new Emitter();
15
+ this.onDidLayoutFromJSON = this._onDidLayoutfromJSON.event;
16
+ this._onDidAddView = new Emitter();
17
+ this.onDidAddView = this._onDidAddView.event;
18
+ this._onDidRemoveView = new Emitter();
19
+ this.onDidRemoveView = this._onDidRemoveView.event;
20
+ this._onDidLayoutChange = new Emitter();
21
+ this.onDidLayoutChange = this._onDidLayoutChange.event;
22
+ this._options = options;
23
+ if (!options.components) {
24
+ options.components = {};
25
+ }
26
+ if (!options.frameworkComponents) {
27
+ options.frameworkComponents = {};
28
+ }
29
+ this.splitview = new Splitview(this.element, options);
30
+ this.addDisposables(this._disposable, this._onDidAddView, this._onDidLayoutfromJSON, this._onDidRemoveView, this._onDidLayoutChange);
31
+ }
32
+ get panels() {
33
+ return this.splitview.getViews();
34
+ }
35
+ get options() {
36
+ return this._options;
37
+ }
38
+ get length() {
39
+ return this._panels.size;
40
+ }
41
+ get orientation() {
42
+ return this.splitview.orientation;
43
+ }
44
+ get splitview() {
45
+ return this._splitview;
46
+ }
47
+ set splitview(value) {
48
+ this._splitview = value;
49
+ this._disposable.value = new CompositeDisposable(this._splitview.onDidSashEnd(() => {
50
+ this._onDidLayoutChange.fire(undefined);
51
+ }), this._splitview.onDidAddView((e) => this._onDidAddView.fire(e)), this._splitview.onDidRemoveView((e) => this._onDidRemoveView.fire(e)));
52
+ }
53
+ get minimumSize() {
54
+ return this.splitview.minimumSize;
55
+ }
56
+ get maximumSize() {
57
+ return this.splitview.maximumSize;
58
+ }
59
+ get height() {
60
+ return this.splitview.orientation === Orientation.HORIZONTAL
61
+ ? this.splitview.orthogonalSize
62
+ : this.splitview.size;
63
+ }
64
+ get width() {
65
+ return this.splitview.orientation === Orientation.HORIZONTAL
66
+ ? this.splitview.size
67
+ : this.splitview.orthogonalSize;
68
+ }
69
+ updateOptions(options) {
70
+ const hasOrientationChanged = typeof options.orientation === 'string' &&
71
+ this.options.orientation !== options.orientation;
72
+ this._options = Object.assign(Object.assign({}, this.options), options);
73
+ if (hasOrientationChanged) {
74
+ this.splitview.orientation = options.orientation;
75
+ }
76
+ this.splitview.layout(this.splitview.size, this.splitview.orthogonalSize);
77
+ }
78
+ focus() {
79
+ var _a;
80
+ (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.focus();
81
+ }
82
+ movePanel(from, to) {
83
+ this.splitview.moveView(from, to);
84
+ }
85
+ setVisible(panel, visible) {
86
+ const index = this.panels.indexOf(panel);
87
+ this.splitview.setViewVisible(index, visible);
88
+ }
89
+ setActive(view, skipFocus) {
90
+ this._activePanel = view;
91
+ this.panels
92
+ .filter((v) => v !== view)
93
+ .forEach((v) => {
94
+ v.api._onDidActiveChange.fire({ isActive: false });
95
+ if (!skipFocus) {
96
+ v.focus();
97
+ }
98
+ });
99
+ view.api._onDidActiveChange.fire({ isActive: true });
100
+ if (!skipFocus) {
101
+ view.focus();
102
+ }
103
+ }
104
+ removePanel(panel, sizing) {
105
+ const disposable = this._panels.get(panel.id);
106
+ if (!disposable) {
107
+ throw new Error(`unknown splitview panel ${panel.id}`);
108
+ }
109
+ disposable.disposable.dispose();
110
+ disposable.value.dispose();
111
+ this._panels.delete(panel.id);
112
+ const index = this.panels.findIndex((_) => _ === panel);
113
+ this.splitview.removeView(index, sizing);
114
+ const panels = this.panels;
115
+ if (panels.length > 0) {
116
+ this.setActive(panels[panels.length - 1]);
117
+ }
118
+ }
119
+ getPanel(id) {
120
+ return this.panels.find((view) => view.id === id);
121
+ }
122
+ addPanel(options) {
123
+ if (this._panels.has(options.id)) {
124
+ throw new Error(`panel ${options.id} already exists`);
125
+ }
126
+ const view = createComponent(options.id, options.component, this.options.components || {}, this.options.frameworkComponents || {}, this.options.frameworkWrapper
127
+ ? {
128
+ createComponent: this.options.frameworkWrapper.createComponent,
129
+ }
130
+ : undefined);
131
+ view.orientation = this.splitview.orientation;
132
+ view.init({
133
+ params: options.params || {},
134
+ minimumSize: options.minimumSize,
135
+ maximumSize: options.maximumSize,
136
+ snap: options.snap,
137
+ priority: options.priority,
138
+ accessor: this,
139
+ });
140
+ const size = typeof options.size === 'number' ? options.size : Sizing.Distribute;
141
+ const index = typeof options.index === 'number' ? options.index : undefined;
142
+ this.splitview.addView(view, size, index);
143
+ this.doAddView(view);
144
+ this.setActive(view);
145
+ return view;
146
+ }
147
+ layout(width, height) {
148
+ const [size, orthogonalSize] = this.splitview.orientation === Orientation.HORIZONTAL
149
+ ? [width, height]
150
+ : [height, width];
151
+ this.splitview.layout(size, orthogonalSize);
152
+ }
153
+ doAddView(view) {
154
+ const disposable = view.api.onDidFocusChange((event) => {
155
+ if (!event.isFocused) {
156
+ return;
157
+ }
158
+ this.setActive(view, true);
159
+ });
160
+ this._panels.set(view.id, { disposable, value: view });
161
+ }
162
+ toJSON() {
163
+ var _a;
164
+ const views = this.splitview
165
+ .getViews()
166
+ .map((view, i) => {
167
+ const size = this.splitview.getViewSize(i);
168
+ return {
169
+ size,
170
+ data: view.toJSON(),
171
+ snap: !!view.snap,
172
+ priority: view.priority,
173
+ };
174
+ });
175
+ return {
176
+ views,
177
+ activeView: (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.id,
178
+ size: this.splitview.size,
179
+ orientation: this.splitview.orientation,
180
+ };
181
+ }
182
+ fromJSON(serializedSplitview) {
183
+ this.clear();
184
+ const { views, orientation, size, activeView } = serializedSplitview;
185
+ const queue = [];
186
+ this.splitview = new Splitview(this.element, {
187
+ orientation,
188
+ proportionalLayout: this.options.proportionalLayout,
189
+ descriptor: {
190
+ size,
191
+ views: views.map((view) => {
192
+ const data = view.data;
193
+ if (this._panels.has(data.id)) {
194
+ throw new Error(`panel ${data.id} already exists`);
195
+ }
196
+ const panel = createComponent(data.id, data.component, this.options.components || {}, this.options.frameworkComponents || {}, this.options.frameworkWrapper
197
+ ? {
198
+ createComponent: this.options.frameworkWrapper
199
+ .createComponent,
200
+ }
201
+ : undefined);
202
+ queue.push(() => {
203
+ panel.init({
204
+ params: data.params || {},
205
+ minimumSize: data.minimumSize,
206
+ maximumSize: data.maximumSize,
207
+ snap: view.snap,
208
+ priority: view.priority,
209
+ accessor: this,
210
+ });
211
+ });
212
+ panel.orientation = orientation;
213
+ this.doAddView(panel);
214
+ setTimeout(() => {
215
+ // the original onDidAddView events are missed since they are fired before we can subcribe to them
216
+ this._onDidAddView.fire(panel);
217
+ }, 0);
218
+ return { size: view.size, view: panel };
219
+ }),
220
+ },
221
+ });
222
+ this.layout(this.width, this.height);
223
+ queue.forEach((f) => f());
224
+ if (typeof activeView === 'string') {
225
+ const panel = this.getPanel(activeView);
226
+ if (panel) {
227
+ this.setActive(panel);
228
+ }
229
+ }
230
+ this._onDidLayoutfromJSON.fire();
231
+ }
232
+ clear() {
233
+ for (const [_, value] of this._panels.entries()) {
234
+ value.disposable.dispose();
235
+ value.value.dispose();
236
+ }
237
+ this._panels.clear();
238
+ this.splitview.dispose();
239
+ }
240
+ dispose() {
241
+ for (const [_, value] of this._panels.entries()) {
242
+ value.disposable.dispose();
243
+ value.value.dispose();
244
+ }
245
+ this._panels.clear();
246
+ this.splitview.dispose();
247
+ super.dispose();
248
+ }
249
+ }
@@ -1,42 +1,45 @@
1
- import { ISerializableView, PanelViewInitParameters } from './core/options';
2
- import { BasePanelView, BasePanelViewExported } from '../gridview/basePanelView';
3
- import { SplitviewPanelApiImpl } from '../api/splitviewPanelApi';
4
- import { LayoutPriority, Orientation } from './core/splitview';
5
- import { Event } from '../events';
6
- export interface ISplitviewPanel extends BasePanelViewExported<SplitviewPanelApiImpl> {
7
- readonly priority: LayoutPriority | undefined;
8
- readonly minimumSize: number;
9
- readonly maximumSize: number;
10
- readonly snap: boolean;
11
- readonly orientation: Orientation;
12
- }
13
- export declare abstract class SplitviewPanel extends BasePanelView<SplitviewPanelApiImpl> implements ISerializableView, ISplitviewPanel {
14
- private _evaluatedMinimumSize;
15
- private _evaluatedMaximumSize;
16
- private _minimumSize;
17
- private _maximumSize;
18
- private _priority?;
19
- private _snap;
20
- private _orientation?;
21
- private readonly _onDidChange;
22
- readonly onDidChange: Event<number | undefined>;
23
- get priority(): LayoutPriority | undefined;
24
- set orientation(value: Orientation);
25
- get orientation(): Orientation;
26
- get minimumSize(): number;
27
- get maximumSize(): number;
28
- get snap(): boolean;
29
- constructor(id: string, componentName: string);
30
- setVisible(isVisible: boolean): void;
31
- setActive(isActive: boolean): void;
32
- layout(size: number, orthogonalSize: number): void;
33
- init(parameters: PanelViewInitParameters): void;
34
- toJSON(): {
35
- minimumSize: number | undefined;
36
- maximumSize: number | undefined;
37
- id: string;
38
- component: string;
39
- params?: Record<string, any> | undefined;
40
- };
41
- private updateConstraints;
42
- }
1
+ import { ISerializableView, PanelViewInitParameters } from './core/options';
2
+ import { BasePanelView, BasePanelViewExported } from '../gridview/basePanelView';
3
+ import { SplitviewPanelApiImpl } from '../api/splitviewPanelApi';
4
+ import { LayoutPriority, Orientation } from './core/splitview';
5
+ import { Event } from '../events';
6
+ export interface ISplitviewPanel extends BasePanelViewExported<SplitviewPanelApiImpl> {
7
+ readonly priority: LayoutPriority | undefined;
8
+ readonly minimumSize: number;
9
+ readonly maximumSize: number;
10
+ readonly snap: boolean;
11
+ readonly orientation: Orientation;
12
+ }
13
+ export declare abstract class SplitviewPanel extends BasePanelView<SplitviewPanelApiImpl> implements ISerializableView, ISplitviewPanel {
14
+ private _evaluatedMinimumSize;
15
+ private _evaluatedMaximumSize;
16
+ private _minimumSize;
17
+ private _maximumSize;
18
+ private _priority?;
19
+ private _snap;
20
+ private _orientation?;
21
+ private readonly _onDidChange;
22
+ readonly onDidChange: Event<{
23
+ size?: number;
24
+ orthogonalSize?: number;
25
+ }>;
26
+ get priority(): LayoutPriority | undefined;
27
+ set orientation(value: Orientation);
28
+ get orientation(): Orientation;
29
+ get minimumSize(): number;
30
+ get maximumSize(): number;
31
+ get snap(): boolean;
32
+ constructor(id: string, componentName: string);
33
+ setVisible(isVisible: boolean): void;
34
+ setActive(isActive: boolean): void;
35
+ layout(size: number, orthogonalSize: number): void;
36
+ init(parameters: PanelViewInitParameters): void;
37
+ toJSON(): {
38
+ minimumSize: number | undefined;
39
+ maximumSize: number | undefined;
40
+ id: string;
41
+ component: string;
42
+ params?: Record<string, any> | undefined;
43
+ };
44
+ private updateConstraints;
45
+ }