dockview-core 1.7.0 → 1.7.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.
Files changed (428) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +50 -52
  3. package/dist/cjs/api/component.api.d.ts +144 -145
  4. package/dist/cjs/api/component.api.d.ts.map +1 -0
  5. package/dist/cjs/api/component.api.js +572 -578
  6. package/dist/cjs/api/component.api.js.map +1 -1
  7. package/dist/cjs/api/dockviewPanelApi.d.ts +35 -34
  8. package/dist/cjs/api/dockviewPanelApi.d.ts.map +1 -0
  9. package/dist/cjs/api/dockviewPanelApi.js +83 -83
  10. package/dist/cjs/api/gridviewPanelApi.d.ts +38 -37
  11. package/dist/cjs/api/gridviewPanelApi.d.ts.map +1 -0
  12. package/dist/cjs/api/gridviewPanelApi.js +47 -47
  13. package/dist/cjs/api/panelApi.d.ts +89 -88
  14. package/dist/cjs/api/panelApi.d.ts.map +1 -0
  15. package/dist/cjs/api/panelApi.js +137 -137
  16. package/dist/cjs/api/paneviewPanelApi.d.ts +27 -26
  17. package/dist/cjs/api/paneviewPanelApi.d.ts.map +1 -0
  18. package/dist/cjs/api/paneviewPanelApi.js +57 -57
  19. package/dist/cjs/api/splitviewPanelApi.d.ts +33 -32
  20. package/dist/cjs/api/splitviewPanelApi.d.ts.map +1 -0
  21. package/dist/cjs/api/splitviewPanelApi.js +47 -47
  22. package/dist/cjs/array.d.ts +13 -12
  23. package/dist/cjs/array.d.ts.map +1 -0
  24. package/dist/cjs/array.js +58 -58
  25. package/dist/cjs/dnd/abstractDragHandler.d.ts +12 -11
  26. package/dist/cjs/dnd/abstractDragHandler.d.ts.map +1 -0
  27. package/dist/cjs/dnd/abstractDragHandler.js +125 -125
  28. package/dist/cjs/dnd/dataTransfer.d.ts +32 -31
  29. package/dist/cjs/dnd/dataTransfer.d.ts.map +1 -0
  30. package/dist/cjs/dnd/dataTransfer.js +100 -100
  31. package/dist/cjs/dnd/dnd.d.ts +28 -27
  32. package/dist/cjs/dnd/dnd.d.ts.map +1 -0
  33. package/dist/cjs/dnd/dnd.js +59 -59
  34. package/dist/cjs/dnd/droptarget.d.ts +43 -42
  35. package/dist/cjs/dnd/droptarget.d.ts.map +1 -0
  36. package/dist/cjs/dnd/droptarget.js +280 -280
  37. package/dist/cjs/dnd/ghost.d.ts +2 -1
  38. package/dist/cjs/dnd/ghost.d.ts.map +1 -0
  39. package/dist/cjs/dnd/ghost.js +15 -15
  40. package/dist/cjs/dnd/groupDragHandler.d.ts +12 -11
  41. package/dist/cjs/dnd/groupDragHandler.d.ts.map +1 -0
  42. package/dist/cjs/dnd/groupDragHandler.js +61 -61
  43. package/dist/cjs/dockview/components/panel/content.d.ts +31 -30
  44. package/dist/cjs/dockview/components/panel/content.d.ts.map +1 -0
  45. package/dist/cjs/dockview/components/panel/content.js +100 -100
  46. package/dist/cjs/dockview/components/tab/defaultTab.d.ts +22 -21
  47. package/dist/cjs/dockview/components/tab/defaultTab.d.ts.map +1 -0
  48. package/dist/cjs/dockview/components/tab/defaultTab.js +105 -105
  49. package/dist/cjs/dockview/components/tab/tab.d.ts +32 -31
  50. package/dist/cjs/dockview/components/tab/tab.d.ts.map +1 -0
  51. package/dist/cjs/dockview/components/tab/tab.js +124 -124
  52. package/dist/cjs/dockview/components/titlebar/tabsContainer.d.ts +60 -63
  53. package/dist/cjs/dockview/components/titlebar/tabsContainer.d.ts.map +1 -0
  54. package/dist/cjs/dockview/components/titlebar/tabsContainer.js +230 -247
  55. package/dist/cjs/dockview/components/titlebar/tabsContainer.js.map +1 -1
  56. package/dist/cjs/dockview/components/titlebar/voidContainer.d.ts +16 -15
  57. package/dist/cjs/dockview/components/titlebar/voidContainer.d.ts.map +1 -0
  58. package/dist/cjs/dockview/components/titlebar/voidContainer.js +73 -73
  59. package/dist/cjs/dockview/components/watermark/watermark.d.ts +19 -18
  60. package/dist/cjs/dockview/components/watermark/watermark.d.ts.map +1 -0
  61. package/dist/cjs/dockview/components/watermark/watermark.js +87 -86
  62. package/dist/cjs/dockview/components/watermark/watermark.js.map +1 -1
  63. package/dist/cjs/dockview/deserializer.d.ts +13 -12
  64. package/dist/cjs/dockview/deserializer.d.ts.map +1 -0
  65. package/dist/cjs/dockview/deserializer.js +45 -45
  66. package/dist/cjs/dockview/dockviewComponent.d.ts +121 -126
  67. package/dist/cjs/dockview/dockviewComponent.d.ts.map +1 -0
  68. package/dist/cjs/dockview/dockviewComponent.js +749 -771
  69. package/dist/cjs/dockview/dockviewComponent.js.map +1 -1
  70. package/dist/cjs/dockview/dockviewGroupPanel.d.ts +32 -31
  71. package/dist/cjs/dockview/dockviewGroupPanel.d.ts.map +1 -0
  72. package/dist/cjs/dockview/dockviewGroupPanel.js +96 -96
  73. package/dist/cjs/dockview/dockviewGroupPanelModel.d.ts +175 -176
  74. package/dist/cjs/dockview/dockviewGroupPanelModel.d.ts.map +1 -0
  75. package/dist/cjs/dockview/dockviewGroupPanelModel.js +578 -578
  76. package/dist/cjs/dockview/dockviewGroupPanelModel.js.map +1 -1
  77. package/dist/cjs/dockview/dockviewPanel.d.ts +41 -40
  78. package/dist/cjs/dockview/dockviewPanel.d.ts.map +1 -0
  79. package/dist/cjs/dockview/dockviewPanel.js +146 -149
  80. package/dist/cjs/dockview/dockviewPanel.js.map +1 -1
  81. package/dist/cjs/dockview/dockviewPanelModel.d.ts +35 -34
  82. package/dist/cjs/dockview/dockviewPanelModel.d.ts.map +1 -0
  83. package/dist/cjs/dockview/dockviewPanelModel.js +92 -92
  84. package/dist/cjs/dockview/options.d.ts +117 -116
  85. package/dist/cjs/dockview/options.d.ts.map +1 -0
  86. package/dist/cjs/dockview/options.js +31 -31
  87. package/dist/cjs/dockview/types.d.ts +68 -67
  88. package/dist/cjs/dockview/types.d.ts.map +1 -0
  89. package/dist/cjs/dockview/types.js +10 -10
  90. package/dist/cjs/dom.d.ts +15 -14
  91. package/dist/cjs/dom.d.ts.map +1 -0
  92. package/dist/cjs/dom.js +189 -182
  93. package/dist/cjs/dom.js.map +1 -1
  94. package/dist/cjs/events.d.ts +31 -30
  95. package/dist/cjs/events.d.ts.map +1 -0
  96. package/dist/cjs/events.js +129 -129
  97. package/dist/cjs/gridview/baseComponentGridview.d.ts +88 -87
  98. package/dist/cjs/gridview/baseComponentGridview.d.ts.map +1 -0
  99. package/dist/cjs/gridview/baseComponentGridview.js +271 -279
  100. package/dist/cjs/gridview/baseComponentGridview.js.map +1 -1
  101. package/dist/cjs/gridview/basePanelView.d.ts +41 -40
  102. package/dist/cjs/gridview/basePanelView.d.ts.map +1 -0
  103. package/dist/cjs/gridview/basePanelView.js +123 -123
  104. package/dist/cjs/gridview/branchNode.d.ts +50 -49
  105. package/dist/cjs/gridview/branchNode.d.ts.map +1 -0
  106. package/dist/cjs/gridview/branchNode.js +342 -342
  107. package/dist/cjs/gridview/gridview.d.ts +134 -133
  108. package/dist/cjs/gridview/gridview.d.ts.map +1 -0
  109. package/dist/cjs/gridview/gridview.js +517 -510
  110. package/dist/cjs/gridview/gridview.js.map +1 -1
  111. package/dist/cjs/gridview/gridviewComponent.d.ts +81 -80
  112. package/dist/cjs/gridview/gridviewComponent.d.ts.map +1 -0
  113. package/dist/cjs/gridview/gridviewComponent.js +325 -324
  114. package/dist/cjs/gridview/gridviewComponent.js.map +1 -1
  115. package/dist/cjs/gridview/gridviewPanel.d.ts +66 -65
  116. package/dist/cjs/gridview/gridviewPanel.d.ts.map +1 -0
  117. package/dist/cjs/gridview/gridviewPanel.js +214 -214
  118. package/dist/cjs/gridview/leafNode.d.ts +35 -34
  119. package/dist/cjs/gridview/leafNode.d.ts.map +1 -0
  120. package/dist/cjs/gridview/leafNode.js +170 -170
  121. package/dist/cjs/gridview/options.d.ts +19 -18
  122. package/dist/cjs/gridview/options.d.ts.map +1 -0
  123. package/dist/cjs/gridview/options.js +2 -2
  124. package/dist/cjs/gridview/types.d.ts +4 -3
  125. package/dist/cjs/gridview/types.d.ts.map +1 -0
  126. package/dist/cjs/gridview/types.js +2 -2
  127. package/dist/cjs/index.d.ts +42 -41
  128. package/dist/cjs/index.d.ts.map +1 -0
  129. package/dist/cjs/index.js +63 -63
  130. package/dist/cjs/lifecycle.d.ts +25 -22
  131. package/dist/cjs/lifecycle.d.ts.map +1 -0
  132. package/dist/cjs/lifecycle.js +97 -88
  133. package/dist/cjs/lifecycle.js.map +1 -1
  134. package/dist/cjs/math.d.ts +6 -5
  135. package/dist/cjs/math.d.ts.map +1 -0
  136. package/dist/cjs/math.js +34 -34
  137. package/dist/cjs/panel/componentFactory.d.ts +11 -10
  138. package/dist/cjs/panel/componentFactory.d.ts.map +1 -0
  139. package/dist/cjs/panel/componentFactory.js +30 -30
  140. package/dist/cjs/panel/types.d.ts +34 -33
  141. package/dist/cjs/panel/types.d.ts.map +1 -0
  142. package/dist/cjs/panel/types.js +2 -2
  143. package/dist/cjs/paneview/defaultPaneviewHeader.d.ts +22 -21
  144. package/dist/cjs/paneview/defaultPaneviewHeader.d.ts.map +1 -0
  145. package/dist/cjs/paneview/defaultPaneviewHeader.js +90 -90
  146. package/dist/cjs/paneview/draggablePaneviewPanel.d.ts +22 -21
  147. package/dist/cjs/paneview/draggablePaneviewPanel.d.ts.map +1 -0
  148. package/dist/cjs/paneview/draggablePaneviewPanel.js +131 -131
  149. package/dist/cjs/paneview/options.d.ts +29 -27
  150. package/dist/cjs/paneview/options.d.ts.map +1 -0
  151. package/dist/cjs/paneview/options.js +2 -2
  152. package/dist/cjs/paneview/paneview.d.ts +41 -40
  153. package/dist/cjs/paneview/paneview.d.ts.map +1 -0
  154. package/dist/cjs/paneview/paneview.js +201 -201
  155. package/dist/cjs/paneview/paneviewComponent.d.ts +130 -129
  156. package/dist/cjs/paneview/paneviewComponent.d.ts.map +1 -0
  157. package/dist/cjs/paneview/paneviewComponent.js +394 -394
  158. package/dist/cjs/paneview/paneviewComponent.js.map +1 -1
  159. package/dist/cjs/paneview/paneviewPanel.d.ts +93 -92
  160. package/dist/cjs/paneview/paneviewPanel.d.ts.map +1 -0
  161. package/dist/cjs/paneview/paneviewPanel.js +275 -275
  162. package/dist/cjs/resizable.d.ts +8 -0
  163. package/dist/cjs/resizable.d.ts.map +1 -0
  164. package/dist/cjs/resizable.js +57 -0
  165. package/dist/cjs/resizable.js.map +1 -0
  166. package/dist/cjs/splitview/options.d.ts +28 -26
  167. package/dist/cjs/splitview/options.d.ts.map +1 -0
  168. package/dist/cjs/splitview/options.js +2 -2
  169. package/dist/cjs/splitview/splitview.d.ts +128 -127
  170. package/dist/cjs/splitview/splitview.d.ts.map +1 -0
  171. package/dist/cjs/splitview/splitview.js +908 -908
  172. package/dist/cjs/splitview/splitviewComponent.d.ts +102 -101
  173. package/dist/cjs/splitview/splitviewComponent.d.ts.map +1 -0
  174. package/dist/cjs/splitview/splitviewComponent.js +373 -373
  175. package/dist/cjs/splitview/splitviewComponent.js.map +1 -1
  176. package/dist/cjs/splitview/splitviewPanel.d.ts +46 -45
  177. package/dist/cjs/splitview/splitviewPanel.d.ts.map +1 -0
  178. package/dist/cjs/splitview/splitviewPanel.js +179 -179
  179. package/dist/cjs/splitview/viewItem.d.ts +26 -25
  180. package/dist/cjs/splitview/viewItem.d.ts.map +1 -0
  181. package/dist/cjs/splitview/viewItem.js +119 -119
  182. package/dist/cjs/svg.d.ts +4 -3
  183. package/dist/cjs/svg.d.ts.map +1 -0
  184. package/dist/cjs/svg.js +43 -43
  185. package/dist/cjs/types.d.ts +3 -2
  186. package/dist/cjs/types.d.ts.map +1 -0
  187. package/dist/cjs/types.js +2 -2
  188. package/dist/dockview-core.amd.js +6343 -6339
  189. package/dist/dockview-core.amd.min.js +2 -2
  190. package/dist/dockview-core.amd.min.noStyle.js +2 -2
  191. package/dist/dockview-core.amd.noStyle.js +6310 -6306
  192. package/dist/dockview-core.cjs.js +6339 -6335
  193. package/dist/dockview-core.esm.js +6339 -6335
  194. package/dist/dockview-core.esm.min.js +2 -2
  195. package/dist/dockview-core.js +6343 -6339
  196. package/dist/dockview-core.min.js +2 -2
  197. package/dist/dockview-core.min.noStyle.js +2 -2
  198. package/dist/dockview-core.noStyle.js +6310 -6306
  199. package/dist/esm/api/component.api.d.ts +144 -145
  200. package/dist/esm/api/component.api.d.ts.map +1 -0
  201. package/dist/esm/api/component.api.js +324 -329
  202. package/dist/esm/api/component.api.js.map +1 -0
  203. package/dist/esm/api/dockviewPanelApi.d.ts +35 -34
  204. package/dist/esm/api/dockviewPanelApi.d.ts.map +1 -0
  205. package/dist/esm/api/dockviewPanelApi.js +49 -48
  206. package/dist/esm/api/dockviewPanelApi.js.map +1 -0
  207. package/dist/esm/api/gridviewPanelApi.d.ts +38 -37
  208. package/dist/esm/api/gridviewPanelApi.d.ts.map +1 -0
  209. package/dist/esm/api/gridviewPanelApi.js +26 -25
  210. package/dist/esm/api/gridviewPanelApi.js.map +1 -0
  211. package/dist/esm/api/panelApi.d.ts +89 -88
  212. package/dist/esm/api/panelApi.d.ts.map +1 -0
  213. package/dist/esm/api/panelApi.js +96 -95
  214. package/dist/esm/api/panelApi.js.map +1 -0
  215. package/dist/esm/api/paneviewPanelApi.d.ts +27 -26
  216. package/dist/esm/api/paneviewPanelApi.d.ts.map +1 -0
  217. package/dist/esm/api/paneviewPanelApi.js +28 -27
  218. package/dist/esm/api/paneviewPanelApi.js.map +1 -0
  219. package/dist/esm/api/splitviewPanelApi.d.ts +33 -32
  220. package/dist/esm/api/splitviewPanelApi.d.ts.map +1 -0
  221. package/dist/esm/api/splitviewPanelApi.js +26 -25
  222. package/dist/esm/api/splitviewPanelApi.js.map +1 -0
  223. package/dist/esm/array.d.ts +13 -12
  224. package/dist/esm/array.d.ts.map +1 -0
  225. package/dist/esm/array.js +50 -49
  226. package/dist/esm/array.js.map +1 -0
  227. package/dist/esm/dnd/abstractDragHandler.d.ts +12 -11
  228. package/dist/esm/dnd/abstractDragHandler.d.ts.map +1 -0
  229. package/dist/esm/dnd/abstractDragHandler.js +48 -47
  230. package/dist/esm/dnd/abstractDragHandler.js.map +1 -0
  231. package/dist/esm/dnd/dataTransfer.d.ts +32 -31
  232. package/dist/esm/dnd/dataTransfer.d.ts.map +1 -0
  233. package/dist/esm/dnd/dataTransfer.js +70 -69
  234. package/dist/esm/dnd/dataTransfer.js.map +1 -0
  235. package/dist/esm/dnd/dnd.d.ts +28 -27
  236. package/dist/esm/dnd/dnd.d.ts.map +1 -0
  237. package/dist/esm/dnd/dnd.js +37 -36
  238. package/dist/esm/dnd/dnd.js.map +1 -0
  239. package/dist/esm/dnd/droptarget.d.ts +43 -42
  240. package/dist/esm/dnd/droptarget.d.ts.map +1 -0
  241. package/dist/esm/dnd/droptarget.js +251 -250
  242. package/dist/esm/dnd/droptarget.js.map +1 -0
  243. package/dist/esm/dnd/ghost.d.ts +2 -1
  244. package/dist/esm/dnd/ghost.d.ts.map +1 -0
  245. package/dist/esm/dnd/ghost.js +12 -11
  246. package/dist/esm/dnd/ghost.js.map +1 -0
  247. package/dist/esm/dnd/groupDragHandler.d.ts +12 -11
  248. package/dist/esm/dnd/groupDragHandler.d.ts.map +1 -0
  249. package/dist/esm/dnd/groupDragHandler.js +39 -38
  250. package/dist/esm/dnd/groupDragHandler.js.map +1 -0
  251. package/dist/esm/dockview/components/panel/content.d.ts +31 -30
  252. package/dist/esm/dockview/components/panel/content.d.ts.map +1 -0
  253. package/dist/esm/dockview/components/panel/content.js +74 -73
  254. package/dist/esm/dockview/components/panel/content.js.map +1 -0
  255. package/dist/esm/dockview/components/tab/defaultTab.d.ts +22 -21
  256. package/dist/esm/dockview/components/tab/defaultTab.d.ts.map +1 -0
  257. package/dist/esm/dockview/components/tab/defaultTab.js +68 -67
  258. package/dist/esm/dockview/components/tab/defaultTab.js.map +1 -0
  259. package/dist/esm/dockview/components/tab/tab.d.ts +32 -31
  260. package/dist/esm/dockview/components/tab/tab.d.ts.map +1 -0
  261. package/dist/esm/dockview/components/tab/tab.js +95 -94
  262. package/dist/esm/dockview/components/tab/tab.js.map +1 -0
  263. package/dist/esm/dockview/components/titlebar/tabsContainer.d.ts +60 -63
  264. package/dist/esm/dockview/components/titlebar/tabsContainer.d.ts.map +1 -0
  265. package/dist/esm/dockview/components/titlebar/tabsContainer.js +167 -179
  266. package/dist/esm/dockview/components/titlebar/tabsContainer.js.map +1 -0
  267. package/dist/esm/dockview/components/titlebar/voidContainer.d.ts +16 -15
  268. package/dist/esm/dockview/components/titlebar/voidContainer.d.ts.map +1 -0
  269. package/dist/esm/dockview/components/titlebar/voidContainer.js +48 -47
  270. package/dist/esm/dockview/components/titlebar/voidContainer.js.map +1 -0
  271. package/dist/esm/dockview/components/watermark/watermark.d.ts +19 -18
  272. package/dist/esm/dockview/components/watermark/watermark.d.ts.map +1 -0
  273. package/dist/esm/dockview/components/watermark/watermark.js +62 -60
  274. package/dist/esm/dockview/components/watermark/watermark.js.map +1 -0
  275. package/dist/esm/dockview/deserializer.d.ts +13 -12
  276. package/dist/esm/dockview/deserializer.d.ts.map +1 -0
  277. package/dist/esm/dockview/deserializer.js +41 -40
  278. package/dist/esm/dockview/deserializer.js.map +1 -0
  279. package/dist/esm/dockview/dockviewComponent.d.ts +121 -126
  280. package/dist/esm/dockview/dockviewComponent.d.ts.map +1 -0
  281. package/dist/esm/dockview/dockviewComponent.js +595 -612
  282. package/dist/esm/dockview/dockviewComponent.js.map +1 -0
  283. package/dist/esm/dockview/dockviewGroupPanel.d.ts +32 -31
  284. package/dist/esm/dockview/dockviewGroupPanel.d.ts.map +1 -0
  285. package/dist/esm/dockview/dockviewGroupPanel.js +51 -50
  286. package/dist/esm/dockview/dockviewGroupPanel.js.map +1 -0
  287. package/dist/esm/dockview/dockviewGroupPanelModel.d.ts +175 -176
  288. package/dist/esm/dockview/dockviewGroupPanelModel.d.ts.map +1 -0
  289. package/dist/esm/dockview/dockviewGroupPanelModel.js +450 -449
  290. package/dist/esm/dockview/dockviewGroupPanelModel.js.map +1 -0
  291. package/dist/esm/dockview/dockviewPanel.d.ts +41 -40
  292. package/dist/esm/dockview/dockviewPanel.d.ts.map +1 -0
  293. package/dist/esm/dockview/dockviewPanel.js +102 -104
  294. package/dist/esm/dockview/dockviewPanel.js.map +1 -0
  295. package/dist/esm/dockview/dockviewPanelModel.d.ts +35 -34
  296. package/dist/esm/dockview/dockviewPanelModel.d.ts.map +1 -0
  297. package/dist/esm/dockview/dockviewPanelModel.js +69 -68
  298. package/dist/esm/dockview/dockviewPanelModel.js.map +1 -0
  299. package/dist/esm/dockview/options.d.ts +117 -116
  300. package/dist/esm/dockview/options.d.ts.map +1 -0
  301. package/dist/esm/dockview/options.js +25 -24
  302. package/dist/esm/dockview/options.js.map +1 -0
  303. package/dist/esm/dockview/types.d.ts +68 -67
  304. package/dist/esm/dockview/types.d.ts.map +1 -0
  305. package/dist/esm/dockview/types.js +8 -7
  306. package/dist/esm/dockview/types.js.map +1 -0
  307. package/dist/esm/dom.d.ts +15 -14
  308. package/dist/esm/dom.d.ts.map +1 -0
  309. package/dist/esm/dom.js +121 -113
  310. package/dist/esm/dom.js.map +1 -0
  311. package/dist/esm/events.d.ts +31 -30
  312. package/dist/esm/events.d.ts.map +1 -0
  313. package/dist/esm/events.js +89 -88
  314. package/dist/esm/events.js.map +1 -0
  315. package/dist/esm/gridview/baseComponentGridview.d.ts +88 -87
  316. package/dist/esm/gridview/baseComponentGridview.d.ts.map +1 -0
  317. package/dist/esm/gridview/baseComponentGridview.js +186 -189
  318. package/dist/esm/gridview/baseComponentGridview.js.map +1 -0
  319. package/dist/esm/gridview/basePanelView.d.ts +41 -40
  320. package/dist/esm/gridview/basePanelView.d.ts.map +1 -0
  321. package/dist/esm/gridview/basePanelView.js +75 -74
  322. package/dist/esm/gridview/basePanelView.js.map +1 -0
  323. package/dist/esm/gridview/branchNode.d.ts +50 -49
  324. package/dist/esm/gridview/branchNode.d.ts.map +1 -0
  325. package/dist/esm/gridview/branchNode.js +219 -218
  326. package/dist/esm/gridview/branchNode.js.map +1 -0
  327. package/dist/esm/gridview/gridview.d.ts +134 -133
  328. package/dist/esm/gridview/gridview.d.ts.map +1 -0
  329. package/dist/esm/gridview/gridview.js +431 -423
  330. package/dist/esm/gridview/gridview.js.map +1 -0
  331. package/dist/esm/gridview/gridviewComponent.d.ts +81 -80
  332. package/dist/esm/gridview/gridviewComponent.d.ts.map +1 -0
  333. package/dist/esm/gridview/gridviewComponent.js +239 -237
  334. package/dist/esm/gridview/gridviewComponent.js.map +1 -0
  335. package/dist/esm/gridview/gridviewPanel.d.ts +66 -65
  336. package/dist/esm/gridview/gridviewPanel.d.ts.map +1 -0
  337. package/dist/esm/gridview/gridviewPanel.js +152 -151
  338. package/dist/esm/gridview/gridviewPanel.js.map +1 -0
  339. package/dist/esm/gridview/leafNode.d.ts +35 -34
  340. package/dist/esm/gridview/leafNode.d.ts.map +1 -0
  341. package/dist/esm/gridview/leafNode.js +104 -103
  342. package/dist/esm/gridview/leafNode.js.map +1 -0
  343. package/dist/esm/gridview/options.d.ts +19 -18
  344. package/dist/esm/gridview/options.d.ts.map +1 -0
  345. package/dist/esm/gridview/options.js +2 -1
  346. package/dist/esm/gridview/options.js.map +1 -0
  347. package/dist/esm/gridview/types.d.ts +4 -3
  348. package/dist/esm/gridview/types.d.ts.map +1 -0
  349. package/dist/esm/gridview/types.js +2 -1
  350. package/dist/esm/gridview/types.js.map +1 -0
  351. package/dist/esm/index.d.ts +42 -41
  352. package/dist/esm/index.d.ts.map +1 -0
  353. package/dist/esm/index.js +36 -35
  354. package/dist/esm/index.js.map +1 -0
  355. package/dist/esm/lifecycle.d.ts +25 -22
  356. package/dist/esm/lifecycle.d.ts.map +1 -0
  357. package/dist/esm/lifecycle.js +45 -39
  358. package/dist/esm/lifecycle.js.map +1 -0
  359. package/dist/esm/math.d.ts +6 -5
  360. package/dist/esm/math.d.ts.map +1 -0
  361. package/dist/esm/math.js +29 -28
  362. package/dist/esm/math.js.map +1 -0
  363. package/dist/esm/panel/componentFactory.d.ts +11 -10
  364. package/dist/esm/panel/componentFactory.d.ts.map +1 -0
  365. package/dist/esm/panel/componentFactory.js +25 -24
  366. package/dist/esm/panel/componentFactory.js.map +1 -0
  367. package/dist/esm/panel/types.d.ts +34 -33
  368. package/dist/esm/panel/types.d.ts.map +1 -0
  369. package/dist/esm/panel/types.js +2 -1
  370. package/dist/esm/panel/types.js.map +1 -0
  371. package/dist/esm/paneview/defaultPaneviewHeader.d.ts +22 -21
  372. package/dist/esm/paneview/defaultPaneviewHeader.d.ts.map +1 -0
  373. package/dist/esm/paneview/defaultPaneviewHeader.js +64 -63
  374. package/dist/esm/paneview/defaultPaneviewHeader.js.map +1 -0
  375. package/dist/esm/paneview/draggablePaneviewPanel.d.ts +22 -21
  376. package/dist/esm/paneview/draggablePaneviewPanel.d.ts.map +1 -0
  377. package/dist/esm/paneview/draggablePaneviewPanel.js +93 -92
  378. package/dist/esm/paneview/draggablePaneviewPanel.js.map +1 -0
  379. package/dist/esm/paneview/options.d.ts +29 -27
  380. package/dist/esm/paneview/options.d.ts.map +1 -0
  381. package/dist/esm/paneview/options.js +2 -1
  382. package/dist/esm/paneview/options.js.map +1 -0
  383. package/dist/esm/paneview/paneview.d.ts +41 -40
  384. package/dist/esm/paneview/paneview.d.ts.map +1 -0
  385. package/dist/esm/paneview/paneview.js +146 -145
  386. package/dist/esm/paneview/paneview.js.map +1 -0
  387. package/dist/esm/paneview/paneviewComponent.d.ts +130 -129
  388. package/dist/esm/paneview/paneviewComponent.d.ts.map +1 -0
  389. package/dist/esm/paneview/paneviewComponent.js +271 -270
  390. package/dist/esm/paneview/paneviewComponent.js.map +1 -0
  391. package/dist/esm/paneview/paneviewPanel.d.ts +93 -92
  392. package/dist/esm/paneview/paneviewPanel.d.ts.map +1 -0
  393. package/dist/esm/paneview/paneviewPanel.js +193 -192
  394. package/dist/esm/paneview/paneviewPanel.js.map +1 -0
  395. package/dist/esm/resizable.d.ts +8 -0
  396. package/dist/esm/resizable.d.ts.map +1 -0
  397. package/dist/esm/resizable.js +31 -0
  398. package/dist/esm/resizable.js.map +1 -0
  399. package/dist/esm/splitview/options.d.ts +28 -26
  400. package/dist/esm/splitview/options.d.ts.map +1 -0
  401. package/dist/esm/splitview/options.js +2 -1
  402. package/dist/esm/splitview/options.js.map +1 -0
  403. package/dist/esm/splitview/splitview.d.ts +128 -127
  404. package/dist/esm/splitview/splitview.d.ts.map +1 -0
  405. package/dist/esm/splitview/splitview.js +690 -689
  406. package/dist/esm/splitview/splitview.js.map +1 -0
  407. package/dist/esm/splitview/splitviewComponent.d.ts +102 -101
  408. package/dist/esm/splitview/splitviewComponent.d.ts.map +1 -0
  409. package/dist/esm/splitview/splitviewComponent.js +250 -249
  410. package/dist/esm/splitview/splitviewComponent.js.map +1 -0
  411. package/dist/esm/splitview/splitviewPanel.d.ts +46 -45
  412. package/dist/esm/splitview/splitviewPanel.d.ts.map +1 -0
  413. package/dist/esm/splitview/splitviewPanel.js +109 -108
  414. package/dist/esm/splitview/splitviewPanel.js.map +1 -0
  415. package/dist/esm/splitview/viewItem.d.ts +26 -25
  416. package/dist/esm/splitview/viewItem.d.ts.map +1 -0
  417. package/dist/esm/splitview/viewItem.js +75 -74
  418. package/dist/esm/splitview/viewItem.js.map +1 -0
  419. package/dist/esm/svg.d.ts +4 -3
  420. package/dist/esm/svg.d.ts.map +1 -0
  421. package/dist/esm/svg.js +32 -31
  422. package/dist/esm/svg.js.map +1 -0
  423. package/dist/esm/types.d.ts +3 -2
  424. package/dist/esm/types.d.ts.map +1 -0
  425. package/dist/esm/types.js +2 -1
  426. package/dist/esm/types.js.map +1 -0
  427. package/dist/styles/dockview.css +54 -54
  428. package/package.json +4 -4
@@ -1,579 +1,579 @@
1
- "use strict";
2
- var __extends = (this && this.__extends) || (function () {
3
- var extendStatics = function (d, b) {
4
- extendStatics = Object.setPrototypeOf ||
5
- ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
- function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
- return extendStatics(d, b);
8
- };
9
- return function (d, b) {
10
- if (typeof b !== "function" && b !== null)
11
- throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
- extendStatics(d, b);
13
- function __() { this.constructor = d; }
14
- d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
- };
16
- })();
17
- var __read = (this && this.__read) || function (o, n) {
18
- var m = typeof Symbol === "function" && o[Symbol.iterator];
19
- if (!m) return o;
20
- var i = m.call(o), r, ar = [], e;
21
- try {
22
- while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
23
- }
24
- catch (error) { e = { error: error }; }
25
- finally {
26
- try {
27
- if (r && !r.done && (m = i["return"])) m.call(i);
28
- }
29
- finally { if (e) throw e.error; }
30
- }
31
- return ar;
32
- };
33
- var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
34
- if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
35
- if (ar || !(i in from)) {
36
- if (!ar) ar = Array.prototype.slice.call(from, 0, i);
37
- ar[i] = from[i];
38
- }
39
- }
40
- return to.concat(ar || Array.prototype.slice.call(from));
41
- };
42
- var __values = (this && this.__values) || function(o) {
43
- var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
44
- if (m) return m.call(o);
45
- if (o && typeof o.length === "number") return {
46
- next: function () {
47
- if (o && i >= o.length) o = void 0;
48
- return { value: o && o[i++], done: !o };
49
- }
50
- };
51
- throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
52
- };
53
- Object.defineProperty(exports, "__esModule", { value: true });
54
- exports.DockviewGroupPanelModel = void 0;
55
- var component_api_1 = require("../api/component.api");
56
- var dataTransfer_1 = require("../dnd/dataTransfer");
57
- var droptarget_1 = require("../dnd/droptarget");
58
- var dom_1 = require("../dom");
59
- var events_1 = require("../events");
60
- var lifecycle_1 = require("../lifecycle");
61
- var content_1 = require("./components/panel/content");
62
- var tabsContainer_1 = require("./components/titlebar/tabsContainer");
63
- var types_1 = require("./types");
64
- var DockviewGroupPanelModel = /** @class */ (function (_super) {
65
- __extends(DockviewGroupPanelModel, _super);
66
- function DockviewGroupPanelModel(container, accessor, id, options, groupPanel) {
67
- var _this = _super.call(this) || this;
68
- _this.container = container;
69
- _this.accessor = accessor;
70
- _this.id = id;
71
- _this.options = options;
72
- _this.groupPanel = groupPanel;
73
- _this._isGroupActive = false;
74
- _this._locked = false;
75
- _this.mostRecentlyUsed = [];
76
- _this._onDidChange = new events_1.Emitter();
77
- _this.onDidChange = _this._onDidChange.event;
78
- _this._width = 0;
79
- _this._height = 0;
80
- _this._panels = [];
81
- _this._onMove = new events_1.Emitter();
82
- _this.onMove = _this._onMove.event;
83
- _this._onDidDrop = new events_1.Emitter();
84
- _this.onDidDrop = _this._onDidDrop.event;
85
- _this._onDidAddPanel = new events_1.Emitter();
86
- _this.onDidAddPanel = _this._onDidAddPanel.event;
87
- _this._onDidRemovePanel = new events_1.Emitter();
88
- _this.onDidRemovePanel = _this._onDidRemovePanel.event;
89
- _this._onDidActivePanelChange = new events_1.Emitter();
90
- _this.onDidActivePanelChange = _this._onDidActivePanelChange.event;
91
- _this.container.classList.add('groupview');
92
- _this.tabsContainer = new tabsContainer_1.TabsContainer(_this.accessor, _this.groupPanel);
93
- _this.contentContainer = new content_1.ContentContainer();
94
- _this.dropTarget = new droptarget_1.Droptarget(_this.contentContainer.element, {
95
- acceptedTargetZones: ['top', 'bottom', 'left', 'right', 'center'],
96
- canDisplayOverlay: function (event, position) {
97
- if (_this.locked && position === 'center') {
98
- return false;
99
- }
100
- var data = (0, dataTransfer_1.getPanelData)();
101
- if (data && data.viewId === _this.accessor.id) {
102
- if (data.groupId === _this.id) {
103
- if (position === 'center') {
104
- // don't allow to drop on self for center position
105
- return false;
106
- }
107
- if (data.panelId === null) {
108
- // don't allow group move to drop anywhere on self
109
- return false;
110
- }
111
- }
112
- var groupHasOnePanelAndIsActiveDragElement = _this._panels.length === 1 && data.groupId === _this.id;
113
- return !groupHasOnePanelAndIsActiveDragElement;
114
- }
115
- return _this.canDisplayOverlay(event, position, types_1.DockviewDropTargets.Panel);
116
- },
117
- });
118
- container.append(_this.tabsContainer.element, _this.contentContainer.element);
119
- _this.header.hidden = !!options.hideHeader;
120
- _this.locked = !!options.locked;
121
- _this.addDisposables(_this._onMove, _this._onDidChange, _this._onDidDrop, _this._onDidAddPanel, _this._onDidRemovePanel, _this._onDidActivePanelChange, _this.tabsContainer.onDrop(function (event) {
122
- _this.handleDropEvent(event.event, 'center', event.index);
123
- }), _this.contentContainer.onDidFocus(function () {
124
- _this.accessor.doSetGroupActive(_this.groupPanel, true);
125
- }), _this.contentContainer.onDidBlur(function () {
126
- // noop
127
- }), _this.dropTarget.onDrop(function (event) {
128
- _this.handleDropEvent(event.nativeEvent, event.position);
129
- }));
130
- return _this;
131
- }
132
- Object.defineProperty(DockviewGroupPanelModel.prototype, "element", {
133
- get: function () {
134
- throw new Error('not supported');
135
- },
136
- enumerable: false,
137
- configurable: true
138
- });
139
- Object.defineProperty(DockviewGroupPanelModel.prototype, "activePanel", {
140
- get: function () {
141
- return this._activePanel;
142
- },
143
- enumerable: false,
144
- configurable: true
145
- });
146
- Object.defineProperty(DockviewGroupPanelModel.prototype, "locked", {
147
- get: function () {
148
- return this._locked;
149
- },
150
- set: function (value) {
151
- this._locked = value;
152
- (0, dom_1.toggleClass)(this.container, 'locked-groupview', value);
153
- },
154
- enumerable: false,
155
- configurable: true
156
- });
157
- Object.defineProperty(DockviewGroupPanelModel.prototype, "isActive", {
158
- get: function () {
159
- return this._isGroupActive;
160
- },
161
- enumerable: false,
162
- configurable: true
163
- });
164
- Object.defineProperty(DockviewGroupPanelModel.prototype, "panels", {
165
- get: function () {
166
- return this._panels;
167
- },
168
- enumerable: false,
169
- configurable: true
170
- });
171
- Object.defineProperty(DockviewGroupPanelModel.prototype, "size", {
172
- get: function () {
173
- return this._panels.length;
174
- },
175
- enumerable: false,
176
- configurable: true
177
- });
178
- Object.defineProperty(DockviewGroupPanelModel.prototype, "isEmpty", {
179
- get: function () {
180
- return this._panels.length === 0;
181
- },
182
- enumerable: false,
183
- configurable: true
184
- });
185
- Object.defineProperty(DockviewGroupPanelModel.prototype, "hasWatermark", {
186
- get: function () {
187
- return !!(this.watermark && this.container.contains(this.watermark.element));
188
- },
189
- enumerable: false,
190
- configurable: true
191
- });
192
- Object.defineProperty(DockviewGroupPanelModel.prototype, "header", {
193
- get: function () {
194
- return this.tabsContainer;
195
- },
196
- enumerable: false,
197
- configurable: true
198
- });
199
- Object.defineProperty(DockviewGroupPanelModel.prototype, "isContentFocused", {
200
- get: function () {
201
- if (!document.activeElement) {
202
- return false;
203
- }
204
- return (0, dom_1.isAncestor)(document.activeElement, this.contentContainer.element);
205
- },
206
- enumerable: false,
207
- configurable: true
208
- });
209
- DockviewGroupPanelModel.prototype.initialize = function () {
210
- var _this = this;
211
- var _a, _b;
212
- if ((_a = this.options) === null || _a === void 0 ? void 0 : _a.panels) {
213
- this.options.panels.forEach(function (panel) {
214
- _this.doAddPanel(panel);
215
- });
216
- }
217
- if ((_b = this.options) === null || _b === void 0 ? void 0 : _b.activePanel) {
218
- this.openPanel(this.options.activePanel);
219
- }
220
- // must be run after the constructor otherwise this.parent may not be
221
- // correctly initialized
222
- this.setActive(this.isActive, true, true);
223
- this.updateContainer();
224
- if (this.accessor.options.createGroupControlElement) {
225
- this._control = this.accessor.options.createGroupControlElement(this.groupPanel);
226
- this.addDisposables(this._control);
227
- this._control.init({
228
- containerApi: new component_api_1.DockviewApi(this.accessor),
229
- api: this.groupPanel.api,
230
- });
231
- this.tabsContainer.setActionElement(this._control.element);
232
- }
233
- };
234
- DockviewGroupPanelModel.prototype.indexOf = function (panel) {
235
- return this.tabsContainer.indexOf(panel.id);
236
- };
237
- DockviewGroupPanelModel.prototype.toJSON = function () {
238
- var _a;
239
- var result = {
240
- views: this.tabsContainer.panels,
241
- activeView: (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.id,
242
- id: this.id,
243
- };
244
- if (this.locked) {
245
- result.locked = true;
246
- }
247
- if (this.header.hidden) {
248
- result.hideHeader = true;
249
- }
250
- return result;
251
- };
252
- DockviewGroupPanelModel.prototype.moveToNext = function (options) {
253
- if (!options) {
254
- options = {};
255
- }
256
- if (!options.panel) {
257
- options.panel = this.activePanel;
258
- }
259
- var index = options.panel ? this.panels.indexOf(options.panel) : -1;
260
- var normalizedIndex;
261
- if (index < this.panels.length - 1) {
262
- normalizedIndex = index + 1;
263
- }
264
- else if (!options.suppressRoll) {
265
- normalizedIndex = 0;
266
- }
267
- else {
268
- return;
269
- }
270
- this.openPanel(this.panels[normalizedIndex]);
271
- };
272
- DockviewGroupPanelModel.prototype.moveToPrevious = function (options) {
273
- if (!options) {
274
- options = {};
275
- }
276
- if (!options.panel) {
277
- options.panel = this.activePanel;
278
- }
279
- if (!options.panel) {
280
- return;
281
- }
282
- var index = this.panels.indexOf(options.panel);
283
- var normalizedIndex;
284
- if (index > 0) {
285
- normalizedIndex = index - 1;
286
- }
287
- else if (!options.suppressRoll) {
288
- normalizedIndex = this.panels.length - 1;
289
- }
290
- else {
291
- return;
292
- }
293
- this.openPanel(this.panels[normalizedIndex]);
294
- };
295
- DockviewGroupPanelModel.prototype.containsPanel = function (panel) {
296
- return this.panels.includes(panel);
297
- };
298
- DockviewGroupPanelModel.prototype.init = function (_params) {
299
- //noop
300
- };
301
- DockviewGroupPanelModel.prototype.update = function (_params) {
302
- //noop
303
- };
304
- DockviewGroupPanelModel.prototype.focus = function () {
305
- var _a, _b;
306
- (_b = (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.focus) === null || _b === void 0 ? void 0 : _b.call(_a);
307
- };
308
- DockviewGroupPanelModel.prototype.openPanel = function (panel, options) {
309
- if (options === void 0) { options = {}; }
310
- if (typeof options.index !== 'number' ||
311
- options.index > this.panels.length) {
312
- options.index = this.panels.length;
313
- }
314
- var skipSetPanelActive = !!options.skipSetPanelActive;
315
- var skipSetGroupActive = !!options.skipSetGroupActive;
316
- // ensure the group is updated before we fire any events
317
- panel.updateParentGroup(this.groupPanel, true);
318
- if (this._activePanel === panel) {
319
- if (!skipSetGroupActive) {
320
- this.accessor.doSetGroupActive(this.groupPanel);
321
- }
322
- return;
323
- }
324
- this.doAddPanel(panel, options.index, skipSetPanelActive);
325
- if (!skipSetPanelActive) {
326
- this.doSetActivePanel(panel);
327
- }
328
- if (!skipSetGroupActive) {
329
- this.accessor.doSetGroupActive(this.groupPanel, !!options.skipFocus);
330
- }
331
- this.updateContainer();
332
- };
333
- DockviewGroupPanelModel.prototype.removePanel = function (groupItemOrId) {
334
- var id = typeof groupItemOrId === 'string'
335
- ? groupItemOrId
336
- : groupItemOrId.id;
337
- var panelToRemove = this._panels.find(function (panel) { return panel.id === id; });
338
- if (!panelToRemove) {
339
- throw new Error('invalid operation');
340
- }
341
- return this._removePanel(panelToRemove);
342
- };
343
- DockviewGroupPanelModel.prototype.closeAllPanels = function () {
344
- var e_1, _a;
345
- if (this.panels.length > 0) {
346
- // take a copy since we will be edting the array as we iterate through
347
- var arrPanelCpy = __spreadArray([], __read(this.panels), false);
348
- try {
349
- for (var arrPanelCpy_1 = __values(arrPanelCpy), arrPanelCpy_1_1 = arrPanelCpy_1.next(); !arrPanelCpy_1_1.done; arrPanelCpy_1_1 = arrPanelCpy_1.next()) {
350
- var panel = arrPanelCpy_1_1.value;
351
- this.doClose(panel);
352
- }
353
- }
354
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
355
- finally {
356
- try {
357
- if (arrPanelCpy_1_1 && !arrPanelCpy_1_1.done && (_a = arrPanelCpy_1.return)) _a.call(arrPanelCpy_1);
358
- }
359
- finally { if (e_1) throw e_1.error; }
360
- }
361
- }
362
- else {
363
- this.accessor.removeGroup(this.groupPanel);
364
- }
365
- };
366
- DockviewGroupPanelModel.prototype.closePanel = function (panel) {
367
- this.doClose(panel);
368
- };
369
- DockviewGroupPanelModel.prototype.doClose = function (panel) {
370
- this.accessor.removePanel(panel);
371
- };
372
- DockviewGroupPanelModel.prototype.isPanelActive = function (panel) {
373
- return this._activePanel === panel;
374
- };
375
- DockviewGroupPanelModel.prototype.updateActions = function (element) {
376
- this.tabsContainer.setActionElement(element);
377
- };
378
- DockviewGroupPanelModel.prototype.setActive = function (isGroupActive, skipFocus, force) {
379
- var _a, _b, _c, _d;
380
- if (skipFocus === void 0) { skipFocus = false; }
381
- if (force === void 0) { force = false; }
382
- if (!force && this.isActive === isGroupActive) {
383
- if (!skipFocus) {
384
- (_b = (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.focus) === null || _b === void 0 ? void 0 : _b.call(_a);
385
- }
386
- return;
387
- }
388
- this._isGroupActive = isGroupActive;
389
- (0, dom_1.toggleClass)(this.container, 'active-group', isGroupActive);
390
- (0, dom_1.toggleClass)(this.container, 'inactive-group', !isGroupActive);
391
- this.tabsContainer.setActive(this.isActive);
392
- if (!this._activePanel && this.panels.length > 0) {
393
- this.doSetActivePanel(this.panels[0]);
394
- }
395
- this.updateContainer();
396
- if (isGroupActive) {
397
- if (!skipFocus) {
398
- (_d = (_c = this._activePanel) === null || _c === void 0 ? void 0 : _c.focus) === null || _d === void 0 ? void 0 : _d.call(_c);
399
- }
400
- }
401
- };
402
- DockviewGroupPanelModel.prototype.layout = function (width, height) {
403
- var _a;
404
- this._width = width;
405
- this._height = height;
406
- this.contentContainer.layout(this._width, this._height);
407
- if ((_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.layout) {
408
- this._activePanel.layout(this._width, this._height);
409
- }
410
- };
411
- DockviewGroupPanelModel.prototype._removePanel = function (panel) {
412
- var isActivePanel = this._activePanel === panel;
413
- this.doRemovePanel(panel);
414
- if (isActivePanel && this.panels.length > 0) {
415
- var nextPanel = this.mostRecentlyUsed[0];
416
- this.openPanel(nextPanel);
417
- }
418
- if (this._activePanel && this.panels.length === 0) {
419
- this.doSetActivePanel(undefined);
420
- }
421
- this.updateContainer();
422
- return panel;
423
- };
424
- DockviewGroupPanelModel.prototype.doRemovePanel = function (panel) {
425
- var index = this.panels.indexOf(panel);
426
- if (this._activePanel === panel) {
427
- this.contentContainer.closePanel();
428
- }
429
- this.tabsContainer.delete(panel.id);
430
- this._panels.splice(index, 1);
431
- if (this.mostRecentlyUsed.includes(panel)) {
432
- this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(panel), 1);
433
- }
434
- this._onDidRemovePanel.fire({ panel: panel });
435
- };
436
- DockviewGroupPanelModel.prototype.doAddPanel = function (panel, index, skipSetActive) {
437
- if (index === void 0) { index = this.panels.length; }
438
- if (skipSetActive === void 0) { skipSetActive = false; }
439
- var existingPanel = this._panels.indexOf(panel);
440
- var hasExistingPanel = existingPanel > -1;
441
- this.tabsContainer.openPanel(panel, index);
442
- if (!skipSetActive) {
443
- this.contentContainer.openPanel(panel);
444
- }
445
- this.tabsContainer.show();
446
- this.contentContainer.show();
447
- if (hasExistingPanel) {
448
- // TODO - need to ensure ordering hasn't changed and if it has need to re-order this.panels
449
- return;
450
- }
451
- this.updateMru(panel);
452
- this.panels.splice(index, 0, panel);
453
- this._onDidAddPanel.fire({ panel: panel });
454
- };
455
- DockviewGroupPanelModel.prototype.doSetActivePanel = function (panel) {
456
- this._activePanel = panel;
457
- if (panel) {
458
- this.tabsContainer.setActivePanel(panel);
459
- panel.layout(this._width, this._height);
460
- this.updateMru(panel);
461
- this._onDidActivePanelChange.fire({ panel: panel });
462
- }
463
- };
464
- DockviewGroupPanelModel.prototype.updateMru = function (panel) {
465
- if (this.mostRecentlyUsed.includes(panel)) {
466
- this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(panel), 1);
467
- }
468
- this.mostRecentlyUsed = __spreadArray([panel], __read(this.mostRecentlyUsed), false);
469
- };
470
- DockviewGroupPanelModel.prototype.updateContainer = function () {
471
- var _this = this;
472
- var _a, _b;
473
- (0, dom_1.toggleClass)(this.container, 'empty', this.isEmpty);
474
- this.panels.forEach(function (panel) {
475
- return panel.updateParentGroup(_this.groupPanel, _this.isActive);
476
- });
477
- if (this.isEmpty && !this.watermark) {
478
- var watermark = this.accessor.createWatermarkComponent();
479
- watermark.init({
480
- containerApi: new component_api_1.DockviewApi(this.accessor),
481
- group: this.groupPanel,
482
- });
483
- this.watermark = watermark;
484
- (0, events_1.addDisposableListener)(this.watermark.element, 'click', function () {
485
- if (!_this.isActive) {
486
- _this.accessor.doSetGroupActive(_this.groupPanel);
487
- }
488
- });
489
- this.tabsContainer.hide();
490
- this.contentContainer.element.appendChild(this.watermark.element);
491
- this.watermark.updateParentGroup(this.groupPanel, true);
492
- }
493
- if (!this.isEmpty && this.watermark) {
494
- this.watermark.element.remove();
495
- (_b = (_a = this.watermark).dispose) === null || _b === void 0 ? void 0 : _b.call(_a);
496
- this.watermark = undefined;
497
- this.tabsContainer.show();
498
- }
499
- };
500
- DockviewGroupPanelModel.prototype.canDisplayOverlay = function (event, position, target) {
501
- // custom overlay handler
502
- if (this.accessor.options.showDndOverlay) {
503
- return this.accessor.options.showDndOverlay({
504
- nativeEvent: event,
505
- target: target,
506
- group: this.accessor.getPanel(this.id),
507
- position: position,
508
- getData: dataTransfer_1.getPanelData,
509
- });
510
- }
511
- return false;
512
- };
513
- DockviewGroupPanelModel.prototype.handleDropEvent = function (event, position, index) {
514
- var data = (0, dataTransfer_1.getPanelData)();
515
- if (data && data.viewId === this.accessor.id) {
516
- if (data.panelId === null) {
517
- // this is a group move dnd event
518
- var groupId_1 = data.groupId;
519
- this._onMove.fire({
520
- target: position,
521
- groupId: groupId_1,
522
- index: index,
523
- });
524
- return;
525
- }
526
- var fromSameGroup = this.tabsContainer.indexOf(data.panelId) !== -1;
527
- if (fromSameGroup && this.tabsContainer.size === 1) {
528
- return;
529
- }
530
- var groupId = data.groupId, panelId = data.panelId;
531
- var isSameGroup = this.id === groupId;
532
- if (isSameGroup && !position) {
533
- var oldIndex = this.tabsContainer.indexOf(panelId);
534
- if (oldIndex === index) {
535
- return;
536
- }
537
- }
538
- this._onMove.fire({
539
- target: position,
540
- groupId: data.groupId,
541
- itemId: data.panelId,
542
- index: index,
543
- });
544
- }
545
- else {
546
- this._onDidDrop.fire({
547
- nativeEvent: event,
548
- position: position,
549
- index: index,
550
- getData: function () { return (0, dataTransfer_1.getPanelData)(); },
551
- });
552
- }
553
- };
554
- DockviewGroupPanelModel.prototype.dispose = function () {
555
- var e_2, _a;
556
- var _b, _c;
557
- _super.prototype.dispose.call(this);
558
- (_c = (_b = this.watermark) === null || _b === void 0 ? void 0 : _b.dispose) === null || _c === void 0 ? void 0 : _c.call(_b);
559
- try {
560
- for (var _d = __values(this.panels), _e = _d.next(); !_e.done; _e = _d.next()) {
561
- var panel = _e.value;
562
- panel.dispose();
563
- }
564
- }
565
- catch (e_2_1) { e_2 = { error: e_2_1 }; }
566
- finally {
567
- try {
568
- if (_e && !_e.done && (_a = _d.return)) _a.call(_d);
569
- }
570
- finally { if (e_2) throw e_2.error; }
571
- }
572
- this.dropTarget.dispose();
573
- this.tabsContainer.dispose();
574
- this.contentContainer.dispose();
575
- };
576
- return DockviewGroupPanelModel;
577
- }(lifecycle_1.CompositeDisposable));
578
- exports.DockviewGroupPanelModel = DockviewGroupPanelModel;
1
+ "use strict";
2
+ var __extends = (this && this.__extends) || (function () {
3
+ var extendStatics = function (d, b) {
4
+ extendStatics = Object.setPrototypeOf ||
5
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
+ return extendStatics(d, b);
8
+ };
9
+ return function (d, b) {
10
+ if (typeof b !== "function" && b !== null)
11
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
+ extendStatics(d, b);
13
+ function __() { this.constructor = d; }
14
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
+ };
16
+ })();
17
+ var __read = (this && this.__read) || function (o, n) {
18
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
19
+ if (!m) return o;
20
+ var i = m.call(o), r, ar = [], e;
21
+ try {
22
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
23
+ }
24
+ catch (error) { e = { error: error }; }
25
+ finally {
26
+ try {
27
+ if (r && !r.done && (m = i["return"])) m.call(i);
28
+ }
29
+ finally { if (e) throw e.error; }
30
+ }
31
+ return ar;
32
+ };
33
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
34
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
35
+ if (ar || !(i in from)) {
36
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
37
+ ar[i] = from[i];
38
+ }
39
+ }
40
+ return to.concat(ar || Array.prototype.slice.call(from));
41
+ };
42
+ var __values = (this && this.__values) || function(o) {
43
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
44
+ if (m) return m.call(o);
45
+ if (o && typeof o.length === "number") return {
46
+ next: function () {
47
+ if (o && i >= o.length) o = void 0;
48
+ return { value: o && o[i++], done: !o };
49
+ }
50
+ };
51
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
52
+ };
53
+ Object.defineProperty(exports, "__esModule", { value: true });
54
+ exports.DockviewGroupPanelModel = void 0;
55
+ var component_api_1 = require("../api/component.api");
56
+ var dataTransfer_1 = require("../dnd/dataTransfer");
57
+ var droptarget_1 = require("../dnd/droptarget");
58
+ var dom_1 = require("../dom");
59
+ var events_1 = require("../events");
60
+ var lifecycle_1 = require("../lifecycle");
61
+ var content_1 = require("./components/panel/content");
62
+ var tabsContainer_1 = require("./components/titlebar/tabsContainer");
63
+ var types_1 = require("./types");
64
+ var DockviewGroupPanelModel = /** @class */ (function (_super) {
65
+ __extends(DockviewGroupPanelModel, _super);
66
+ function DockviewGroupPanelModel(container, accessor, id, options, groupPanel) {
67
+ var _this = _super.call(this) || this;
68
+ _this.container = container;
69
+ _this.accessor = accessor;
70
+ _this.id = id;
71
+ _this.options = options;
72
+ _this.groupPanel = groupPanel;
73
+ _this._isGroupActive = false;
74
+ _this._locked = false;
75
+ _this.mostRecentlyUsed = [];
76
+ _this._onDidChange = new events_1.Emitter();
77
+ _this.onDidChange = _this._onDidChange.event;
78
+ _this._width = 0;
79
+ _this._height = 0;
80
+ _this._panels = [];
81
+ _this._onMove = new events_1.Emitter();
82
+ _this.onMove = _this._onMove.event;
83
+ _this._onDidDrop = new events_1.Emitter();
84
+ _this.onDidDrop = _this._onDidDrop.event;
85
+ _this._onDidAddPanel = new events_1.Emitter();
86
+ _this.onDidAddPanel = _this._onDidAddPanel.event;
87
+ _this._onDidRemovePanel = new events_1.Emitter();
88
+ _this.onDidRemovePanel = _this._onDidRemovePanel.event;
89
+ _this._onDidActivePanelChange = new events_1.Emitter();
90
+ _this.onDidActivePanelChange = _this._onDidActivePanelChange.event;
91
+ _this.container.classList.add('groupview');
92
+ _this.tabsContainer = new tabsContainer_1.TabsContainer(_this.accessor, _this.groupPanel);
93
+ _this.contentContainer = new content_1.ContentContainer();
94
+ _this.dropTarget = new droptarget_1.Droptarget(_this.contentContainer.element, {
95
+ acceptedTargetZones: ['top', 'bottom', 'left', 'right', 'center'],
96
+ canDisplayOverlay: function (event, position) {
97
+ if (_this.locked && position === 'center') {
98
+ return false;
99
+ }
100
+ var data = (0, dataTransfer_1.getPanelData)();
101
+ if (data && data.viewId === _this.accessor.id) {
102
+ if (data.groupId === _this.id) {
103
+ if (position === 'center') {
104
+ // don't allow to drop on self for center position
105
+ return false;
106
+ }
107
+ if (data.panelId === null) {
108
+ // don't allow group move to drop anywhere on self
109
+ return false;
110
+ }
111
+ }
112
+ var groupHasOnePanelAndIsActiveDragElement = _this._panels.length === 1 && data.groupId === _this.id;
113
+ return !groupHasOnePanelAndIsActiveDragElement;
114
+ }
115
+ return _this.canDisplayOverlay(event, position, types_1.DockviewDropTargets.Panel);
116
+ },
117
+ });
118
+ container.append(_this.tabsContainer.element, _this.contentContainer.element);
119
+ _this.header.hidden = !!options.hideHeader;
120
+ _this.locked = !!options.locked;
121
+ _this.addDisposables(_this._onMove, _this._onDidChange, _this._onDidDrop, _this._onDidAddPanel, _this._onDidRemovePanel, _this._onDidActivePanelChange, _this.tabsContainer.onDrop(function (event) {
122
+ _this.handleDropEvent(event.event, 'center', event.index);
123
+ }), _this.contentContainer.onDidFocus(function () {
124
+ _this.accessor.doSetGroupActive(_this.groupPanel, true);
125
+ }), _this.contentContainer.onDidBlur(function () {
126
+ // noop
127
+ }), _this.dropTarget.onDrop(function (event) {
128
+ _this.handleDropEvent(event.nativeEvent, event.position);
129
+ }));
130
+ return _this;
131
+ }
132
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "element", {
133
+ get: function () {
134
+ throw new Error('not supported');
135
+ },
136
+ enumerable: false,
137
+ configurable: true
138
+ });
139
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "activePanel", {
140
+ get: function () {
141
+ return this._activePanel;
142
+ },
143
+ enumerable: false,
144
+ configurable: true
145
+ });
146
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "locked", {
147
+ get: function () {
148
+ return this._locked;
149
+ },
150
+ set: function (value) {
151
+ this._locked = value;
152
+ (0, dom_1.toggleClass)(this.container, 'locked-groupview', value);
153
+ },
154
+ enumerable: false,
155
+ configurable: true
156
+ });
157
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "isActive", {
158
+ get: function () {
159
+ return this._isGroupActive;
160
+ },
161
+ enumerable: false,
162
+ configurable: true
163
+ });
164
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "panels", {
165
+ get: function () {
166
+ return this._panels;
167
+ },
168
+ enumerable: false,
169
+ configurable: true
170
+ });
171
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "size", {
172
+ get: function () {
173
+ return this._panels.length;
174
+ },
175
+ enumerable: false,
176
+ configurable: true
177
+ });
178
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "isEmpty", {
179
+ get: function () {
180
+ return this._panels.length === 0;
181
+ },
182
+ enumerable: false,
183
+ configurable: true
184
+ });
185
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "hasWatermark", {
186
+ get: function () {
187
+ return !!(this.watermark && this.container.contains(this.watermark.element));
188
+ },
189
+ enumerable: false,
190
+ configurable: true
191
+ });
192
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "header", {
193
+ get: function () {
194
+ return this.tabsContainer;
195
+ },
196
+ enumerable: false,
197
+ configurable: true
198
+ });
199
+ Object.defineProperty(DockviewGroupPanelModel.prototype, "isContentFocused", {
200
+ get: function () {
201
+ if (!document.activeElement) {
202
+ return false;
203
+ }
204
+ return (0, dom_1.isAncestor)(document.activeElement, this.contentContainer.element);
205
+ },
206
+ enumerable: false,
207
+ configurable: true
208
+ });
209
+ DockviewGroupPanelModel.prototype.initialize = function () {
210
+ var _this = this;
211
+ var _a, _b;
212
+ if ((_a = this.options) === null || _a === void 0 ? void 0 : _a.panels) {
213
+ this.options.panels.forEach(function (panel) {
214
+ _this.doAddPanel(panel);
215
+ });
216
+ }
217
+ if ((_b = this.options) === null || _b === void 0 ? void 0 : _b.activePanel) {
218
+ this.openPanel(this.options.activePanel);
219
+ }
220
+ // must be run after the constructor otherwise this.parent may not be
221
+ // correctly initialized
222
+ this.setActive(this.isActive, true, true);
223
+ this.updateContainer();
224
+ if (this.accessor.options.createGroupControlElement) {
225
+ this._control = this.accessor.options.createGroupControlElement(this.groupPanel);
226
+ this.addDisposables(this._control);
227
+ this._control.init({
228
+ containerApi: new component_api_1.DockviewApi(this.accessor),
229
+ api: this.groupPanel.api,
230
+ });
231
+ this.tabsContainer.setActionElement(this._control.element);
232
+ }
233
+ };
234
+ DockviewGroupPanelModel.prototype.indexOf = function (panel) {
235
+ return this.tabsContainer.indexOf(panel.id);
236
+ };
237
+ DockviewGroupPanelModel.prototype.toJSON = function () {
238
+ var _a;
239
+ var result = {
240
+ views: this.tabsContainer.panels,
241
+ activeView: (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.id,
242
+ id: this.id,
243
+ };
244
+ if (this.locked) {
245
+ result.locked = true;
246
+ }
247
+ if (this.header.hidden) {
248
+ result.hideHeader = true;
249
+ }
250
+ return result;
251
+ };
252
+ DockviewGroupPanelModel.prototype.moveToNext = function (options) {
253
+ if (!options) {
254
+ options = {};
255
+ }
256
+ if (!options.panel) {
257
+ options.panel = this.activePanel;
258
+ }
259
+ var index = options.panel ? this.panels.indexOf(options.panel) : -1;
260
+ var normalizedIndex;
261
+ if (index < this.panels.length - 1) {
262
+ normalizedIndex = index + 1;
263
+ }
264
+ else if (!options.suppressRoll) {
265
+ normalizedIndex = 0;
266
+ }
267
+ else {
268
+ return;
269
+ }
270
+ this.openPanel(this.panels[normalizedIndex]);
271
+ };
272
+ DockviewGroupPanelModel.prototype.moveToPrevious = function (options) {
273
+ if (!options) {
274
+ options = {};
275
+ }
276
+ if (!options.panel) {
277
+ options.panel = this.activePanel;
278
+ }
279
+ if (!options.panel) {
280
+ return;
281
+ }
282
+ var index = this.panels.indexOf(options.panel);
283
+ var normalizedIndex;
284
+ if (index > 0) {
285
+ normalizedIndex = index - 1;
286
+ }
287
+ else if (!options.suppressRoll) {
288
+ normalizedIndex = this.panels.length - 1;
289
+ }
290
+ else {
291
+ return;
292
+ }
293
+ this.openPanel(this.panels[normalizedIndex]);
294
+ };
295
+ DockviewGroupPanelModel.prototype.containsPanel = function (panel) {
296
+ return this.panels.includes(panel);
297
+ };
298
+ DockviewGroupPanelModel.prototype.init = function (_params) {
299
+ //noop
300
+ };
301
+ DockviewGroupPanelModel.prototype.update = function (_params) {
302
+ //noop
303
+ };
304
+ DockviewGroupPanelModel.prototype.focus = function () {
305
+ var _a, _b;
306
+ (_b = (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.focus) === null || _b === void 0 ? void 0 : _b.call(_a);
307
+ };
308
+ DockviewGroupPanelModel.prototype.openPanel = function (panel, options) {
309
+ if (options === void 0) { options = {}; }
310
+ if (typeof options.index !== 'number' ||
311
+ options.index > this.panels.length) {
312
+ options.index = this.panels.length;
313
+ }
314
+ var skipSetPanelActive = !!options.skipSetPanelActive;
315
+ var skipSetGroupActive = !!options.skipSetGroupActive;
316
+ // ensure the group is updated before we fire any events
317
+ panel.updateParentGroup(this.groupPanel, true);
318
+ if (this._activePanel === panel) {
319
+ if (!skipSetGroupActive) {
320
+ this.accessor.doSetGroupActive(this.groupPanel);
321
+ }
322
+ return;
323
+ }
324
+ this.doAddPanel(panel, options.index, skipSetPanelActive);
325
+ if (!skipSetPanelActive) {
326
+ this.doSetActivePanel(panel);
327
+ }
328
+ if (!skipSetGroupActive) {
329
+ this.accessor.doSetGroupActive(this.groupPanel, !!options.skipFocus);
330
+ }
331
+ this.updateContainer();
332
+ };
333
+ DockviewGroupPanelModel.prototype.removePanel = function (groupItemOrId) {
334
+ var id = typeof groupItemOrId === 'string'
335
+ ? groupItemOrId
336
+ : groupItemOrId.id;
337
+ var panelToRemove = this._panels.find(function (panel) { return panel.id === id; });
338
+ if (!panelToRemove) {
339
+ throw new Error('invalid operation');
340
+ }
341
+ return this._removePanel(panelToRemove);
342
+ };
343
+ DockviewGroupPanelModel.prototype.closeAllPanels = function () {
344
+ var e_1, _a;
345
+ if (this.panels.length > 0) {
346
+ // take a copy since we will be edting the array as we iterate through
347
+ var arrPanelCpy = __spreadArray([], __read(this.panels), false);
348
+ try {
349
+ for (var arrPanelCpy_1 = __values(arrPanelCpy), arrPanelCpy_1_1 = arrPanelCpy_1.next(); !arrPanelCpy_1_1.done; arrPanelCpy_1_1 = arrPanelCpy_1.next()) {
350
+ var panel = arrPanelCpy_1_1.value;
351
+ this.doClose(panel);
352
+ }
353
+ }
354
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
355
+ finally {
356
+ try {
357
+ if (arrPanelCpy_1_1 && !arrPanelCpy_1_1.done && (_a = arrPanelCpy_1.return)) _a.call(arrPanelCpy_1);
358
+ }
359
+ finally { if (e_1) throw e_1.error; }
360
+ }
361
+ }
362
+ else {
363
+ this.accessor.removeGroup(this.groupPanel);
364
+ }
365
+ };
366
+ DockviewGroupPanelModel.prototype.closePanel = function (panel) {
367
+ this.doClose(panel);
368
+ };
369
+ DockviewGroupPanelModel.prototype.doClose = function (panel) {
370
+ this.accessor.removePanel(panel);
371
+ };
372
+ DockviewGroupPanelModel.prototype.isPanelActive = function (panel) {
373
+ return this._activePanel === panel;
374
+ };
375
+ DockviewGroupPanelModel.prototype.updateActions = function (element) {
376
+ this.tabsContainer.setActionElement(element);
377
+ };
378
+ DockviewGroupPanelModel.prototype.setActive = function (isGroupActive, skipFocus, force) {
379
+ var _a, _b, _c, _d;
380
+ if (skipFocus === void 0) { skipFocus = false; }
381
+ if (force === void 0) { force = false; }
382
+ if (!force && this.isActive === isGroupActive) {
383
+ if (!skipFocus) {
384
+ (_b = (_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.focus) === null || _b === void 0 ? void 0 : _b.call(_a);
385
+ }
386
+ return;
387
+ }
388
+ this._isGroupActive = isGroupActive;
389
+ (0, dom_1.toggleClass)(this.container, 'active-group', isGroupActive);
390
+ (0, dom_1.toggleClass)(this.container, 'inactive-group', !isGroupActive);
391
+ this.tabsContainer.setActive(this.isActive);
392
+ if (!this._activePanel && this.panels.length > 0) {
393
+ this.doSetActivePanel(this.panels[0]);
394
+ }
395
+ this.updateContainer();
396
+ if (isGroupActive) {
397
+ if (!skipFocus) {
398
+ (_d = (_c = this._activePanel) === null || _c === void 0 ? void 0 : _c.focus) === null || _d === void 0 ? void 0 : _d.call(_c);
399
+ }
400
+ }
401
+ };
402
+ DockviewGroupPanelModel.prototype.layout = function (width, height) {
403
+ var _a;
404
+ this._width = width;
405
+ this._height = height;
406
+ this.contentContainer.layout(this._width, this._height);
407
+ if ((_a = this._activePanel) === null || _a === void 0 ? void 0 : _a.layout) {
408
+ this._activePanel.layout(this._width, this._height);
409
+ }
410
+ };
411
+ DockviewGroupPanelModel.prototype._removePanel = function (panel) {
412
+ var isActivePanel = this._activePanel === panel;
413
+ this.doRemovePanel(panel);
414
+ if (isActivePanel && this.panels.length > 0) {
415
+ var nextPanel = this.mostRecentlyUsed[0];
416
+ this.openPanel(nextPanel);
417
+ }
418
+ if (this._activePanel && this.panels.length === 0) {
419
+ this.doSetActivePanel(undefined);
420
+ }
421
+ this.updateContainer();
422
+ return panel;
423
+ };
424
+ DockviewGroupPanelModel.prototype.doRemovePanel = function (panel) {
425
+ var index = this.panels.indexOf(panel);
426
+ if (this._activePanel === panel) {
427
+ this.contentContainer.closePanel();
428
+ }
429
+ this.tabsContainer.delete(panel.id);
430
+ this._panels.splice(index, 1);
431
+ if (this.mostRecentlyUsed.includes(panel)) {
432
+ this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(panel), 1);
433
+ }
434
+ this._onDidRemovePanel.fire({ panel: panel });
435
+ };
436
+ DockviewGroupPanelModel.prototype.doAddPanel = function (panel, index, skipSetActive) {
437
+ if (index === void 0) { index = this.panels.length; }
438
+ if (skipSetActive === void 0) { skipSetActive = false; }
439
+ var existingPanel = this._panels.indexOf(panel);
440
+ var hasExistingPanel = existingPanel > -1;
441
+ this.tabsContainer.openPanel(panel, index);
442
+ if (!skipSetActive) {
443
+ this.contentContainer.openPanel(panel);
444
+ }
445
+ this.tabsContainer.show();
446
+ this.contentContainer.show();
447
+ if (hasExistingPanel) {
448
+ // TODO - need to ensure ordering hasn't changed and if it has need to re-order this.panels
449
+ return;
450
+ }
451
+ this.updateMru(panel);
452
+ this.panels.splice(index, 0, panel);
453
+ this._onDidAddPanel.fire({ panel: panel });
454
+ };
455
+ DockviewGroupPanelModel.prototype.doSetActivePanel = function (panel) {
456
+ this._activePanel = panel;
457
+ if (panel) {
458
+ this.tabsContainer.setActivePanel(panel);
459
+ panel.layout(this._width, this._height);
460
+ this.updateMru(panel);
461
+ this._onDidActivePanelChange.fire({ panel: panel });
462
+ }
463
+ };
464
+ DockviewGroupPanelModel.prototype.updateMru = function (panel) {
465
+ if (this.mostRecentlyUsed.includes(panel)) {
466
+ this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(panel), 1);
467
+ }
468
+ this.mostRecentlyUsed = __spreadArray([panel], __read(this.mostRecentlyUsed), false);
469
+ };
470
+ DockviewGroupPanelModel.prototype.updateContainer = function () {
471
+ var _this = this;
472
+ var _a, _b;
473
+ (0, dom_1.toggleClass)(this.container, 'empty', this.isEmpty);
474
+ this.panels.forEach(function (panel) {
475
+ return panel.updateParentGroup(_this.groupPanel, _this.isActive);
476
+ });
477
+ if (this.isEmpty && !this.watermark) {
478
+ var watermark = this.accessor.createWatermarkComponent();
479
+ watermark.init({
480
+ containerApi: new component_api_1.DockviewApi(this.accessor),
481
+ group: this.groupPanel,
482
+ });
483
+ this.watermark = watermark;
484
+ (0, events_1.addDisposableListener)(this.watermark.element, 'click', function () {
485
+ if (!_this.isActive) {
486
+ _this.accessor.doSetGroupActive(_this.groupPanel);
487
+ }
488
+ });
489
+ this.tabsContainer.hide();
490
+ this.contentContainer.element.appendChild(this.watermark.element);
491
+ this.watermark.updateParentGroup(this.groupPanel, true);
492
+ }
493
+ if (!this.isEmpty && this.watermark) {
494
+ this.watermark.element.remove();
495
+ (_b = (_a = this.watermark).dispose) === null || _b === void 0 ? void 0 : _b.call(_a);
496
+ this.watermark = undefined;
497
+ this.tabsContainer.show();
498
+ }
499
+ };
500
+ DockviewGroupPanelModel.prototype.canDisplayOverlay = function (event, position, target) {
501
+ // custom overlay handler
502
+ if (this.accessor.options.showDndOverlay) {
503
+ return this.accessor.options.showDndOverlay({
504
+ nativeEvent: event,
505
+ target: target,
506
+ group: this.accessor.getPanel(this.id),
507
+ position: position,
508
+ getData: dataTransfer_1.getPanelData,
509
+ });
510
+ }
511
+ return false;
512
+ };
513
+ DockviewGroupPanelModel.prototype.handleDropEvent = function (event, position, index) {
514
+ var data = (0, dataTransfer_1.getPanelData)();
515
+ if (data && data.viewId === this.accessor.id) {
516
+ if (data.panelId === null) {
517
+ // this is a group move dnd event
518
+ var groupId_1 = data.groupId;
519
+ this._onMove.fire({
520
+ target: position,
521
+ groupId: groupId_1,
522
+ index: index,
523
+ });
524
+ return;
525
+ }
526
+ var fromSameGroup = this.tabsContainer.indexOf(data.panelId) !== -1;
527
+ if (fromSameGroup && this.tabsContainer.size === 1) {
528
+ return;
529
+ }
530
+ var groupId = data.groupId, panelId = data.panelId;
531
+ var isSameGroup = this.id === groupId;
532
+ if (isSameGroup && !position) {
533
+ var oldIndex = this.tabsContainer.indexOf(panelId);
534
+ if (oldIndex === index) {
535
+ return;
536
+ }
537
+ }
538
+ this._onMove.fire({
539
+ target: position,
540
+ groupId: data.groupId,
541
+ itemId: data.panelId,
542
+ index: index,
543
+ });
544
+ }
545
+ else {
546
+ this._onDidDrop.fire({
547
+ nativeEvent: event,
548
+ position: position,
549
+ index: index,
550
+ getData: function () { return (0, dataTransfer_1.getPanelData)(); },
551
+ });
552
+ }
553
+ };
554
+ DockviewGroupPanelModel.prototype.dispose = function () {
555
+ var e_2, _a;
556
+ var _b, _c;
557
+ _super.prototype.dispose.call(this);
558
+ (_c = (_b = this.watermark) === null || _b === void 0 ? void 0 : _b.dispose) === null || _c === void 0 ? void 0 : _c.call(_b);
559
+ try {
560
+ for (var _d = __values(this.panels), _e = _d.next(); !_e.done; _e = _d.next()) {
561
+ var panel = _e.value;
562
+ panel.dispose();
563
+ }
564
+ }
565
+ catch (e_2_1) { e_2 = { error: e_2_1 }; }
566
+ finally {
567
+ try {
568
+ if (_e && !_e.done && (_a = _d.return)) _a.call(_d);
569
+ }
570
+ finally { if (e_2) throw e_2.error; }
571
+ }
572
+ this.dropTarget.dispose();
573
+ this.tabsContainer.dispose();
574
+ this.contentContainer.dispose();
575
+ };
576
+ return DockviewGroupPanelModel;
577
+ }(lifecycle_1.CompositeDisposable));
578
+ exports.DockviewGroupPanelModel = DockviewGroupPanelModel;
579
579
  //# sourceMappingURL=dockviewGroupPanelModel.js.map