dockview-core 1.6.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 +6 -5
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * dockview-core
3
- * @version 1.6.0
3
+ * @version 1.7.1
4
4
  * @link https://github.com/mathuo/dockview
5
5
  * @license MIT
6
6
  */
7
- !function(e,i){"object"==typeof exports&&"undefined"!=typeof module?i(exports):"function"==typeof define&&define.amd?define(["exports"],i):i((e="undefined"!=typeof globalThis?globalThis:e||self)["dockview-core"]={})}(this,(function(e){"use strict";var i;!function(e,i){void 0===i&&(i={});var t=i.insertAt;if(e&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],o=document.createElement("style");o.type="text/css","top"===t&&n.firstChild?n.insertBefore(o,n.firstChild):n.appendChild(o),o.styleSheet?o.styleSheet.cssText=e:o.appendChild(document.createTextNode(e))}}('.dockview-svg {\n display: inline-block;\n fill: currentcolor;\n line-height: 1;\n stroke: currentcolor;\n stroke-width: 0;\n}\n.dockview-theme-dark {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: #1e1e1e;\n --dv-tabs-and-actions-container-background-color: #252526;\n --dv-activegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-activegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-inactivegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-tab-divider-color: #1e1e1e;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: #969696;\n --dv-inactivegroup-visiblepanel-tab-color: #8f8f8f;\n --dv-inactivegroup-hiddenpanel-tab-color: #626262;\n --dv-separator-border: rgb(68, 68, 68);\n --dv-paneview-header-border-color: rgba(204, 204, 204, 0.2);\n}\n\n.dockview-theme-light {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: white;\n --dv-tabs-and-actions-container-background-color: #f3f3f3;\n --dv-activegroup-visiblepanel-tab-background-color: white;\n --dv-activegroup-hiddenpanel-tab-background-color: #ececec;\n --dv-inactivegroup-visiblepanel-tab-background-color: white;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #ececec;\n --dv-tab-divider-color: white;\n --dv-activegroup-visiblepanel-tab-color: rgb(51, 51, 51);\n --dv-activegroup-hiddenpanel-tab-color: rgba(51, 51, 51, 0.7);\n --dv-inactivegroup-visiblepanel-tab-color: rgba(51, 51, 51, 0.7);\n --dv-inactivegroup-hiddenpanel-tab-color: rgba(51, 51, 51, 0.35);\n --dv-separator-border: rgba(128, 128, 128, 0.35);\n --dv-paneview-header-border-color: rgb(51, 51, 51);\n}\n\n.dockview-theme-vs {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: #1e1e1e;\n --dv-tabs-and-actions-container-background-color: #252526;\n --dv-activegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-activegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-inactivegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-tab-divider-color: #1e1e1e;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: #969696;\n --dv-inactivegroup-visiblepanel-tab-color: #8f8f8f;\n --dv-inactivegroup-hiddenpanel-tab-color: #626262;\n --dv-separator-border: rgb(68, 68, 68);\n --dv-paneview-header-border-color: rgba(204, 204, 204, 0.2);\n --dv-tabs-and-actions-container-background-color: #2d2d30;\n --dv-tabs-and-actions-container-height: 20px;\n --dv-tabs-and-actions-container-font-size: 11px;\n --dv-activegroup-visiblepanel-tab-background-color: #007acc;\n --dv-inactivegroup-visiblepanel-tab-background-color: #3f3f46;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: white;\n --dv-inactivegroup-visiblepanel-tab-color: white;\n --dv-inactivegroup-hiddenpanel-tab-color: white;\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container {\n box-sizing: content-box;\n border-bottom: 2px solid var(--dv-activegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container .tab.active-tab {\n border-top: 2px solid var(--dv-activegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container .tab.inactive-tab {\n border-top: 2px solid var(--dv-activegroup-hiddenpanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container {\n box-sizing: content-box;\n border-bottom: 2px solid var(--dv-inactivegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container .tab.active-tab {\n border-top: 2px solid var(--dv-inactivegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container .tab.inactive-tab {\n border-top: 2px solid var(--dv-inactivegroup-hiddenpanel-tab-background-color);\n}\n\n.dockview-theme-abyss {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: #000c18;\n --dv-tabs-and-actions-container-background-color: #1c1c2a;\n --dv-activegroup-visiblepanel-tab-background-color: #000c18;\n --dv-activegroup-hiddenpanel-tab-background-color: #10192c;\n --dv-inactivegroup-visiblepanel-tab-background-color: #000c18;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #10192c;\n --dv-tab-divider-color: #2b2b4a;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: rgba(255, 255, 255, 0.5);\n --dv-inactivegroup-visiblepanel-tab-color: rgba(255, 255, 255, 0.5);\n --dv-inactivegroup-hiddenpanel-tab-color: rgba(255, 255, 255, 0.25);\n --dv-separator-border: #2b2b4a;\n --dv-paneview-header-border-color: #2b2b4a;\n --dv-paneview-active-outline-color: #596f99;\n}\n\n.dockview-theme-dracula {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: #282a36;\n --dv-tabs-and-actions-container-background-color: #191a21;\n --dv-activegroup-visiblepanel-tab-background-color: #282a36;\n --dv-activegroup-hiddenpanel-tab-background-color: #21222c;\n --dv-inactivegroup-visiblepanel-tab-background-color: #282a36;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #21222c;\n --dv-tab-divider-color: #191a21;\n --dv-activegroup-visiblepanel-tab-color: rgb(248, 248, 242);\n --dv-activegroup-hiddenpanel-tab-color: rgb(98, 114, 164);\n --dv-inactivegroup-visiblepanel-tab-color: rgba(248, 248, 242, 0.5);\n --dv-inactivegroup-hiddenpanel-tab-color: rgba(98, 114, 164, 0.5);\n --dv-separator-border: #bd93f9;\n --dv-paneview-header-border-color: #bd93f9;\n --dv-paneview-active-outline-color: #6272a4;\n}\n.dockview-theme-dracula .groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n position: relative;\n}\n.dockview-theme-dracula .groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab::after {\n position: absolute;\n left: 0px;\n top: 0px;\n content: "";\n width: 100%;\n height: 1px;\n background-color: #94527e;\n z-index: 999;\n}\n.dockview-theme-dracula .groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n position: relative;\n}\n.dockview-theme-dracula .groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab::after {\n position: absolute;\n left: 0px;\n bottom: 0px;\n content: "";\n width: 100%;\n height: 1px;\n background-color: #5e3d5a;\n z-index: 999;\n}\n.drop-target {\n position: relative;\n}\n.drop-target > .drop-target-dropzone {\n position: absolute;\n left: 0px;\n top: 0px;\n height: 100%;\n width: 100%;\n z-index: 10000;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection {\n position: relative;\n box-sizing: border-box;\n height: 100%;\n width: 100%;\n background-color: var(--dv-drag-over-background-color);\n transition: top 70ms ease-out, left 70ms ease-out, width 70ms ease-out, height 70ms ease-out, opacity 0.15s ease-out;\n will-change: transform;\n pointer-events: none;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-top {\n border-top: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-bottom {\n border-bottom: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-left {\n border-left: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-right {\n border-right: 1px solid var(--dv-drag-over-border-color);\n}\n.dv-dockview {\n position: relative;\n background-color: var(--dv-group-view-background-color);\n}\n.dv-dockview .dv-watermark-container {\n position: absolute;\n top: 0px;\n left: 0px;\n height: 100%;\n width: 100%;\n}\n\n.groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n background-color: var(--dv-activegroup-visiblepanel-tab-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab {\n background-color: var(--dv-activegroup-hiddenpanel-tab-background-color);\n color: var(--dv-activegroup-hiddenpanel-tab-color);\n}\n.groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n background-color: var(--dv-inactivegroup-visiblepanel-tab-background-color);\n color: var(--dv-inactivegroup-visiblepanel-tab-color);\n}\n.groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab {\n background-color: var(--dv-inactivegroup-hiddenpanel-tab-background-color);\n color: var(--dv-inactivegroup-hiddenpanel-tab-color);\n}\n\n/**\n * when a tab is dragged we lose the above stylings because they are conditional on parent elements\n * therefore we also set some stylings for the dragging event\n **/\n.tab.dv-tab-dragging {\n background-color: var(--dv-activegroup-visiblepanel-tab-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.groupview {\n display: flex;\n flex-direction: column;\n height: 100%;\n background-color: var(--dv-group-view-background-color);\n overflow: hidden;\n}\n.groupview:focus {\n outline: none;\n}\n.groupview.empty > .tabs-and-actions-container {\n display: none;\n}\n.groupview > .content-container {\n flex-grow: 1;\n overflow: hidden;\n outline: none;\n}\n.grid-view,\n.branch-node {\n height: 100%;\n width: 100%;\n}\n.pane-container {\n height: 100%;\n width: 100%;\n}\n.pane-container.animated .view {\n transition-duration: 0.15s;\n transition-timing-function: ease-out;\n}\n.pane-container .view {\n overflow: hidden;\n display: flex;\n flex-direction: column;\n padding: 0px !important;\n}\n.pane-container .view:not(:first-child)::before {\n background-color: transparent !important;\n}\n.pane-container .view:not(:first-child) .pane > .pane-header {\n border-top: 1px solid var(--dv-paneview-header-border-color);\n}\n.pane-container .view .default-header {\n background-color: var(--dv-group-view-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n display: flex;\n padding: 0px 8px;\n cursor: pointer;\n}\n.pane-container .view .default-header .dockview-pane-header-icon {\n display: flex;\n justify-content: center;\n align-items: center;\n}\n.pane-container .view .default-header > span {\n padding-left: 8px;\n flex-grow: 1;\n}\n.pane-container:first-of-type > .pane > .pane-header {\n border-top: none !important;\n}\n.pane-container .pane {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n height: 100%;\n}\n.pane-container .pane .pane-header {\n box-sizing: border-box;\n user-select: none;\n position: relative;\n outline: none;\n}\n.pane-container .pane .pane-header.pane-draggable {\n cursor: pointer;\n}\n.pane-container .pane .pane-header:focus:before, .pane-container .pane .pane-header:focus-within:before {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 5;\n content: "";\n pointer-events: none;\n outline: 1px solid;\n outline-width: -1px;\n outline-style: solid;\n outline-offset: -1px;\n outline-color: var(--dv-paneview-active-outline-color);\n}\n.pane-container .pane .pane-body {\n overflow-y: auto;\n overflow-x: hidden;\n flex-grow: 1;\n position: relative;\n outline: none;\n}\n.pane-container .pane .pane-body:focus:before, .pane-container .pane .pane-body:focus-within:before {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 5;\n content: "";\n pointer-events: none;\n outline: 1px solid;\n outline-width: -1px;\n outline-style: solid;\n outline-offset: -1px;\n outline-color: var(--dv-paneview-active-outline-color);\n}\n.split-view-container {\n position: relative;\n overflow: hidden;\n height: 100%;\n width: 100%;\n}\n.split-view-container.animation .view,\n.split-view-container.animation .sash {\n transition-duration: 0.15s;\n transition-timing-function: ease-out;\n}\n.split-view-container.horizontal {\n height: 100%;\n}\n.split-view-container.horizontal > .sash-container > .sash {\n height: 100%;\n width: 4px;\n}\n.split-view-container.horizontal > .sash-container > .sash.enabled {\n cursor: ew-resize;\n}\n.split-view-container.horizontal > .sash-container > .sash.disabled {\n cursor: default;\n}\n.split-view-container.horizontal > .sash-container > .sash.maximum {\n cursor: w-resize;\n}\n.split-view-container.horizontal > .sash-container > .sash.minimum {\n cursor: e-resize;\n}\n.split-view-container.horizontal > .view-container > .view:not(:first-child)::before {\n height: 100%;\n width: 1px;\n}\n.split-view-container.vertical {\n width: 100%;\n}\n.split-view-container.vertical > .sash-container > .sash {\n width: 100%;\n height: 4px;\n}\n.split-view-container.vertical > .sash-container > .sash.enabled {\n cursor: ns-resize;\n}\n.split-view-container.vertical > .sash-container > .sash.disabled {\n cursor: default;\n}\n.split-view-container.vertical > .sash-container > .sash.maximum {\n cursor: n-resize;\n}\n.split-view-container.vertical > .sash-container > .sash.minimum {\n cursor: s-resize;\n}\n.split-view-container.vertical > .view-container > .view {\n width: 100%;\n}\n.split-view-container.vertical > .view-container > .view:not(:first-child)::before {\n height: 1px;\n width: 100%;\n}\n.split-view-container .sash-container {\n height: 100%;\n width: 100%;\n position: absolute;\n}\n.split-view-container .sash-container .sash {\n position: absolute;\n z-index: 99;\n outline: none;\n}\n.split-view-container .sash-container .sash:active {\n transition: background-color 0.1s ease-in-out;\n background-color: var(--dv-active-sash-color, transparent);\n}\n.split-view-container .sash-container .sash:hover {\n background-color: var(--dv-active-sash-color, transparent);\n transition: background-color 0.1s ease-in-out;\n transition-delay: 0.5s;\n}\n.split-view-container .view-container {\n position: relative;\n height: 100%;\n width: 100%;\n background-color: var(--dv-background-color);\n}\n.split-view-container .view-container .view {\n height: 100%;\n box-sizing: border-box;\n overflow: auto;\n position: absolute;\n}\n.split-view-container.separator-border .view:not(:first-child)::before {\n content: " ";\n position: absolute;\n top: 0;\n left: 0;\n z-index: 5;\n pointer-events: none;\n background-color: var(--dv-separator-border);\n}\n.dv-dragged {\n transform: translate3d(0px, 0px, 0px); /* forces tab to be drawn on a separate layer (see https://github.com/microsoft/vscode/issues/18733) */\n}\n\n.tab {\n flex-shrink: 0;\n}\n.tab.dv-tab-dragging .tab-action {\n background-color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.tab.active-tab > .default-tab .tab-action {\n visibility: visible;\n}\n.tab.inactive-tab > .default-tab .tab-action {\n visibility: hidden;\n}\n.tab.inactive-tab > .default-tab:hover .tab-action {\n visibility: visible;\n}\n.tab .default-tab {\n position: relative;\n height: 100%;\n display: flex;\n min-width: 80px;\n align-items: center;\n padding: 0px 8px;\n white-space: nowrap;\n text-overflow: elipsis;\n}\n.tab .default-tab .tab-content {\n padding: 0px 8px;\n flex-grow: 1;\n}\n.tab .default-tab .action-container {\n text-align: right;\n display: flex;\n}\n.tab .default-tab .action-container .tab-list {\n display: flex;\n padding: 0px;\n margin: 0px;\n justify-content: flex-end;\n}\n.tab .default-tab .action-container .tab-list .tab-action {\n padding: 4px;\n display: flex;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n}\n.tab .default-tab .action-container .tab-list .tab-action:hover {\n border-radius: 2px;\n background-color: var(--dv-icon-hover-background-color);\n}\n.tabs-and-actions-container {\n display: flex;\n background-color: var(--dv-tabs-and-actions-container-background-color);\n flex-shrink: 0;\n box-sizing: border-box;\n height: var(--dv-tabs-and-actions-container-height);\n font-size: var(--dv-tabs-and-actions-container-font-size);\n}\n.tabs-and-actions-container.hidden {\n display: none;\n}\n.tabs-and-actions-container.dv-single-tab.dv-full-width-single-tab .tabs-container {\n flex-grow: 1;\n}\n.tabs-and-actions-container.dv-single-tab.dv-full-width-single-tab .tabs-container .tab {\n flex-grow: 1;\n}\n.tabs-and-actions-container.dv-single-tab.dv-full-width-single-tab .void-container {\n flex-grow: 0;\n}\n.tabs-and-actions-container .void-container {\n display: flex;\n flex-grow: 1;\n cursor: grab;\n}\n.tabs-and-actions-container .tabs-container {\n display: flex;\n overflow-x: overlay;\n overflow-y: hidden;\n scrollbar-width: thin;\n /* Track */\n /* Handle */\n}\n.tabs-and-actions-container .tabs-container::-webkit-scrollbar {\n height: 3px;\n}\n.tabs-and-actions-container .tabs-container::-webkit-scrollbar-track {\n background: transparent;\n}\n.tabs-and-actions-container .tabs-container::-webkit-scrollbar-thumb {\n background: var(--dv-tabs-container-scrollbar-color);\n}\n.tabs-and-actions-container .tabs-container .tab {\n -webkit-user-drag: element;\n outline: none;\n min-width: 75px;\n cursor: pointer;\n position: relative;\n box-sizing: border-box;\n}\n.tabs-and-actions-container .tabs-container .tab:not(:first-child)::before {\n content: " ";\n position: absolute;\n top: 0;\n left: 0;\n z-index: 5;\n pointer-events: none;\n background-color: var(--dv-tab-divider-color);\n width: 1px;\n height: 100%;\n}\n.watermark {\n display: flex;\n width: 100%;\n}\n.watermark.has-actions .watermark-title .actions-container {\n display: none;\n}\n.watermark .watermark-title {\n height: 35px;\n width: 100%;\n display: flex;\n}\n.watermark .watermark-content {\n flex-grow: 1;\n}\n.watermark .actions-container {\n display: flex;\n align-items: center;\n padding: 0px 8px;\n}\n.watermark .actions-container .close-action {\n padding: 4px;\n display: flex;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n cursor: pointer;\n color: var(--dv-activegroup-hiddenpanel-tab-color);\n}\n.watermark .actions-container .close-action:hover {\n border-radius: 2px;\n background-color: var(--dv-icon-hover-background-color);\n}');class t{constructor(){}}class n extends t{constructor(e,i,t){super(),this.viewId=e,this.groupId=i,this.panelId=t}}class o extends t{constructor(e,i){super(),this.viewId=e,this.paneId=i}}class s{constructor(){}static getInstance(){return s.INSTANCE}hasData(e){return e&&e===this.proto}clearData(e){this.hasData(e)&&(this.proto=void 0,this.data=void 0)}getData(e){if(this.hasData(e))return this.data}setData(e,i){i&&(this.data=e,this.proto=i)}}function a(){const e=s.getInstance();if(e.hasData(n.prototype))return e.getData(n.prototype)[0]}function r(){const e=s.getInstance();if(e.hasData(o.prototype))return e.getData(o.prototype)[0]}s.INSTANCE=new s,e.DockviewEvent=void 0,(e.DockviewEvent||(e.DockviewEvent={})).any=(...e)=>i=>{const t=e.map((e=>e(i)));return{dispose:()=>{t.forEach((e=>{e.dispose()}))}}};class h{constructor(e){this.options=e,this._listeners=[],this._disposed=!1}get event(){return this._event||(this._event=e=>{var i;return(null===(i=this.options)||void 0===i?void 0:i.replay)&&void 0!==this._last&&e(this._last),this._listeners.push(e),{dispose:()=>{const i=this._listeners.indexOf(e);i>-1&&this._listeners.splice(i,1)}}}),this._event}fire(e){this._last=e;for(const i of this._listeners)i(e)}dispose(){this._listeners=[],this._disposed=!0}}function d(e,i,t,n){return e.addEventListener(i,t,n),{dispose:()=>{e.removeEventListener(i,t)}}}function l(e,i,t,n){return e.addEventListener(i,t,n),{dispose:()=>{e.removeEventListener(i,t)}}}class p{constructor(){this._onFired=new h,this.onEvent=this._onFired.event}fire(){this.timer&&clearTimeout(this.timer),this.timer=setTimeout((()=>{this._onFired.fire(),clearTimeout(this.timer)}))}dispose(){this._onFired.dispose()}}!function(e){e.NONE={dispose:()=>{}}}(i||(i={}));class c{static from(...e){return new c(...e)}constructor(...e){this.disposables=e}addDisposables(...e){e.forEach((e=>this.disposables.push(e)))}dispose(){this.disposables.forEach((e=>e.dispose()))}}class u{constructor(){this._disposable=i.NONE}set value(e){this._disposable&&this._disposable.dispose(),this._disposable=e}dispose(){this._disposable&&(this._disposable.dispose(),this._disposable=i.NONE)}}const m=(e,...i)=>{for(const t of i)e.classList.contains(t)&&e.classList.remove(t)},v=(e,...i)=>{for(const t of i)e.classList.contains(t)||e.classList.add(t)},g=(e,i,t)=>{const n=e.classList.contains(i);t&&!n&&e.classList.add(i),!t&&n&&e.classList.remove(i)};function w(e,i){for(;e;){if(e===i)return!0;e=e.parentNode}return!1}function b(e){return Array.prototype.slice.call(document.getElementsByTagName(e),0)}function f(e){return new _(e)}class _ extends c{constructor(e){super(),this._onDidFocus=new h,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new h,this.onDidBlur=this._onDidBlur.event;let i=w(document.activeElement,e),t=!1;const n=()=>{t=!1,i||(i=!0,this._onDidFocus.fire())},o=()=>{i&&(t=!0,window.setTimeout((()=>{t&&(t=!1,i=!1,this._onDidBlur.fire())}),0))};this._refreshStateHandler=()=>{w(document.activeElement,e)!==i&&(i?o():n())},e instanceof HTMLElement?(this.addDisposables(l(e,"focus",n,!0)),this.addDisposables(l(e,"blur",o,!0))):(this.addDisposables(d(e,"focus",n,!0)),this.addDisposables(d(e,"blur",o,!0)))}refreshState(){this._refreshStateHandler()}dispose(){super.dispose(),this._onDidBlur.dispose(),this._onDidFocus.dispose()}}function D(e,i,t={},n={},o,s){const a="string"==typeof i?t[i]:void 0,r="string"==typeof i?n[i]:void 0;if(a&&r)throw new Error(`Cannot create '${e}'. component '${i}' registered as both a component and frameworkComponent`);if(r){if(!o)throw new Error(`Cannot create '${e}' for framework component '${i}'. you must register a frameworkPanelWrapper to use framework components`);return o.createComponent(e,i,r)}if(!a){if(s)return s();throw new Error(`Cannot create '${e}', no component '${i}' provided`)}return new a(e,i)}function y(e){if(0===e.length)throw new Error("Invalid tail call");return[e.slice(0,e.length-1),e[e.length-1]]}function C(e,i){if(e.length!==i.length)return!1;for(let t=0;t<e.length;t++)if(e[t]!==i[t])return!1;return!0}function z(e,i){const t=e.indexOf(i);t>-1&&(e.splice(t,1),e.unshift(i))}function x(e,i){const t=e.indexOf(i);t>-1&&(e.splice(t,1),e.push(i))}const S=(e,i,t)=>{if(i>t)throw new Error(`${i} > ${t} is an invalid condition`);return Math.min(t,Math.max(e,i))},P=()=>{let e=1;return{next:()=>(e++).toString()}},E=(e,i)=>{const t=[];if("number"!=typeof i&&(i=e,e=0),e<=i)for(let n=e;n<i;n++)t.push(n);else for(let n=e;n>i;n--)t.push(n);return t};class A{set size(e){this._size=e}get size(){return this._size}get cachedVisibleSize(){return this._cachedVisibleSize}get visible(){return void 0===this._cachedVisibleSize}get minimumSize(){return this.visible?this.view.minimumSize:0}get viewMinimumSize(){return this.view.minimumSize}get maximumSize(){return this.visible?this.view.maximumSize:0}get viewMaximumSize(){return this.view.maximumSize}get priority(){return this.view.priority}get snap(){return!!this.view.snap}set enabled(e){this.container.style.pointerEvents=e?"":"none"}constructor(e,i,t,n){this.container=e,this.view=i,this.disposable=n,this._cachedVisibleSize=void 0,"number"==typeof t?(this._size=t,this._cachedVisibleSize=void 0,e.classList.add("visible")):(this._size=0,this._cachedVisibleSize=t.cachedVisibleSize)}setVisible(e,i){var t;e!==this.visible&&(e?(this.size=S(null!==(t=this._cachedVisibleSize)&&void 0!==t?t:0,this.viewMinimumSize,this.viewMaximumSize),this._cachedVisibleSize=void 0):(this._cachedVisibleSize="number"==typeof i?i:this.size,this.size=0),this.container.classList.toggle("visible",e),this.view.setVisible&&this.view.setVisible(e))}dispose(){return this.disposable.dispose(),this.view}}var k,O,I,V;e.Orientation=void 0,(k=e.Orientation||(e.Orientation={})).HORIZONTAL="HORIZONTAL",k.VERTICAL="VERTICAL",e.SashState=void 0,(O=e.SashState||(e.SashState={}))[O.MAXIMUM=0]="MAXIMUM",O[O.MINIMUM=1]="MINIMUM",O[O.DISABLED=2]="DISABLED",O[O.ENABLED=3]="ENABLED",e.LayoutPriority=void 0,(I=e.LayoutPriority||(e.LayoutPriority={})).Low="low",I.High="high",I.Normal="normal",e.Sizing=void 0,(V=e.Sizing||(e.Sizing={})).Distribute={type:"distribute"},V.Split=function(e){return{type:"split",index:e}},V.Invisible=function(e){return{type:"invisible",cachedVisibleSize:e}};class N{get size(){return this._size}set size(e){this._size=e}get orthogonalSize(){return this._orthogonalSize}set orthogonalSize(e){this._orthogonalSize=e}get length(){return this.views.length}get proportions(){return this._proportions?[...this._proportions]:void 0}get orientation(){return this._orientation}set orientation(i){this._orientation=i;const t=this.size;this.size=this.orthogonalSize,this.orthogonalSize=t,m(this.element,"horizontal","vertical"),this.element.classList.add(this.orientation==e.Orientation.HORIZONTAL?"horizontal":"vertical")}get minimumSize(){return this.views.reduce(((e,i)=>e+i.minimumSize),0)}get maximumSize(){return 0===this.length?Number.POSITIVE_INFINITY:this.views.reduce(((e,i)=>e+i.maximumSize),0)}get startSnappingEnabled(){return this._startSnappingEnabled}set startSnappingEnabled(e){this._startSnappingEnabled!==e&&(this._startSnappingEnabled=e,this.updateSashEnablement())}get endSnappingEnabled(){return this._endSnappingEnabled}set endSnappingEnabled(e){this._endSnappingEnabled!==e&&(this._endSnappingEnabled=e,this.updateSashEnablement())}constructor(e,i){this.container=e,this.views=[],this.sashes=[],this._size=0,this._orthogonalSize=0,this.contentSize=0,this._proportions=void 0,this._startSnappingEnabled=!0,this._endSnappingEnabled=!0,this._onDidSashEnd=new h,this.onDidSashEnd=this._onDidSashEnd.event,this._onDidAddView=new h,this.onDidAddView=this._onDidAddView.event,this._onDidRemoveView=new h,this.onDidRemoveView=this._onDidRemoveView.event,this.resize=(e,i,t=this.views.map((e=>e.size)),n,o,s=Number.NEGATIVE_INFINITY,a=Number.POSITIVE_INFINITY,r,h)=>{if(e<0||e>this.views.length)return 0;const d=E(e,-1),l=E(e+1,this.views.length);if(o)for(const e of o)z(d,e),z(l,e);if(n)for(const e of n)x(d,e),x(l,e);const p=d.map((e=>this.views[e])),c=d.map((e=>t[e])),u=l.map((e=>this.views[e])),m=l.map((e=>t[e])),v=d.reduce(((e,i)=>e+this.views[i].minimumSize-t[i]),0),g=d.reduce(((e,i)=>e+this.views[i].maximumSize-t[i]),0),w=0===l.length?Number.POSITIVE_INFINITY:l.reduce(((e,i)=>e+t[i]-this.views[i].minimumSize),0),b=0===l.length?Number.NEGATIVE_INFINITY:l.reduce(((e,i)=>e+t[i]-this.views[i].maximumSize),0),f=Math.max(v,b),_=Math.min(w,g);let D=!1;if(r){const e=this.views[r.index],t=i>=r.limitDelta;D=t!==e.visible,e.setVisible(t,r.size)}if(!D&&h){const e=this.views[h.index],t=i<h.limitDelta;D=t!==e.visible,e.setVisible(t,h.size)}if(D)return this.resize(e,i,t,n,o,s,a);let y=0,C=S(i,f,_);for(let e=0;e<p.length;e++){const i=p[e],t=S(c[e]+C,i.minimumSize,i.maximumSize),n=t-c[e];y+=n,C-=n,i.size=t}let P=y;for(let e=0;e<u.length;e++){const i=u[e],t=S(m[e]-P,i.minimumSize,i.maximumSize);P+=t-m[e],i.size=t}return i},this._orientation=i.orientation,this.element=this.createContainer(),this.proportionalLayout=void 0===i.proportionalLayout||!!i.proportionalLayout,this.viewContainer=this.createViewContainer(),this.sashContainer=this.createSashContainer(),this.element.appendChild(this.sashContainer),this.element.appendChild(this.viewContainer),this.container.appendChild(this.element),this.style(i.styles),i.descriptor&&(this._size=i.descriptor.size,i.descriptor.views.forEach(((e,i)=>{const t=void 0===e.visible||e.visible?e.size:{type:"invisible",cachedVisibleSize:e.size},n=e.view;this.addView(n,t,i,!0)})),this.contentSize=this.views.reduce(((e,i)=>e+i.size),0),this.saveProportions())}style(e){"transparent"===(null==e?void 0:e.separatorBorder)?(m(this.element,"separator-border"),this.element.style.removeProperty("--dv-separator-border")):(v(this.element,"separator-border"),(null==e?void 0:e.separatorBorder)&&this.element.style.setProperty("--dv-separator-border",e.separatorBorder))}isViewVisible(e){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");return this.views[e].visible}setViewVisible(e,i){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");g(this.container,"visible",i);const t=this.views[e];g(this.container,"visible",i),t.setVisible(i,t.size),this.distributeEmptySpace(e),this.layoutViews(),this.saveProportions()}getViewSize(e){return e<0||e>=this.views.length?-1:this.views[e].size}resizeView(i,t){if(i<0||i>=this.views.length)return;const n=E(this.views.length).filter((e=>e!==i)),o=[...n.filter((i=>this.views[i].priority===e.LayoutPriority.Low)),i],s=n.filter((i=>this.views[i].priority===e.LayoutPriority.High)),a=this.views[i];t=Math.round(t),t=S(t,a.minimumSize,Math.min(a.maximumSize,this._size)),a.size=t,this.relayout(o,s)}getViews(){return this.views.map((e=>e.view))}onDidChange(e,i){const t=this.views.indexOf(e);t<0||t>=this.views.length||(i="number"==typeof i?i:e.size,i=S(i,e.minimumSize,e.maximumSize),e.size=i,this.relayout([t]))}addView(i,t={type:"distribute"},n=this.views.length,o){const s=document.createElement("div");let a;s.className="view",s.appendChild(i.element),a="number"==typeof t?t:"split"===t.type?this.getViewSize(t.index)/2:"invisible"===t.type?{cachedVisibleSize:t.cachedVisibleSize}:i.minimumSize;const r=i.onDidChange((e=>this.onDidChange(h,e.size))),h=new A(s,i,a,{dispose:()=>{null==r||r.dispose(),this.viewContainer.removeChild(s)}});if(n===this.views.length?this.viewContainer.appendChild(s):this.viewContainer.insertBefore(s,this.viewContainer.children.item(n)),this.views.splice(n,0,h),this.views.length>1){const i=document.createElement("div");i.className="sash";const t=t=>{for(const e of this.views)e.enabled=!1;const n=[...b("iframe"),...b("webview")];for(const e of n)e.style.pointerEvents="none";const o=this._orientation===e.Orientation.HORIZONTAL?t.clientX:t.clientY,s=function(e,i){for(let t=0;t<e.length;t++)if(i(e[t]))return t;return-1}(this.sashes,(e=>e.container===i)),a=this.views.map((e=>e.size));let r,h;const d=E(s,-1),l=E(s+1,this.views.length),p=d.reduce(((e,i)=>e+(this.views[i].minimumSize-a[i])),0),c=d.reduce(((e,i)=>e+(this.views[i].viewMaximumSize-a[i])),0),u=0===l.length?Number.POSITIVE_INFINITY:l.reduce(((e,i)=>e+(a[i]-this.views[i].minimumSize)),0),m=0===l.length?Number.NEGATIVE_INFINITY:l.reduce(((e,i)=>e+(a[i]-this.views[i].viewMaximumSize)),0),v=Math.max(p,m),g=Math.min(u,c),w=this.findFirstSnapIndex(d),f=this.findFirstSnapIndex(l);if("number"==typeof w){const e=this.views[w],i=Math.floor(e.viewMinimumSize/2);r={index:w,limitDelta:e.visible?v-i:v+i,size:e.size}}if("number"==typeof f){const e=this.views[f],i=Math.floor(e.viewMinimumSize/2);h={index:f,limitDelta:e.visible?g+i:g-i,size:e.size}}const _=i=>{const t=(this._orientation===e.Orientation.HORIZONTAL?i.clientX:i.clientY)-o;this.resize(s,t,a,void 0,void 0,v,g,r,h),this.distributeEmptySpace(),this.layoutViews()},D=()=>{for(const e of this.views)e.enabled=!0;for(const e of n)e.style.pointerEvents="auto";this.saveProportions(),document.removeEventListener("mousemove",_),document.removeEventListener("mouseup",D),document.removeEventListener("mouseend",D),this._onDidSashEnd.fire(void 0)};document.addEventListener("mousemove",_),document.addEventListener("mouseup",D),document.addEventListener("mouseend",D)};i.addEventListener("mousedown",t);const n={container:i,disposable:()=>{i.removeEventListener("mousedown",t),this.sashContainer.removeChild(i)}};this.sashContainer.appendChild(i),this.sashes.push(n)}o||this.relayout([n]),o||"number"==typeof t||"distribute"!==t.type||this.distributeViewSizes(),this._onDidAddView.fire(i)}distributeViewSizes(){const i=[];let t=0;for(const e of this.views)e.maximumSize-e.minimumSize>0&&(i.push(e),t+=e.size);const n=Math.floor(t/i.length);for(const e of i)e.size=S(n,e.minimumSize,e.maximumSize);const o=E(this.views.length),s=o.filter((i=>this.views[i].priority===e.LayoutPriority.Low)),a=o.filter((i=>this.views[i].priority===e.LayoutPriority.High));this.relayout(s,a)}removeView(e,i,t=!1){const n=this.views.splice(e,1)[0];if(n.dispose(),this.views.length>=1){const i=Math.max(e-1,0);this.sashes.splice(i,1)[0].disposable()}return t||this.relayout(),i&&"distribute"===i.type&&this.distributeViewSizes(),this._onDidRemoveView.fire(n.view),n.view}getViewCachedVisibleSize(e){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");return this.views[e].cachedVisibleSize}moveView(i,t){const n=this.getViewCachedVisibleSize(i),o=void 0===n?this.getViewSize(i):e.Sizing.Invisible(n),s=this.removeView(i,void 0,!0);this.addView(s,o,t)}layout(i,t){const n=Math.max(this.size,this.contentSize);if(this.size=i,this.orthogonalSize=t,this.proportions)for(let e=0;e<this.views.length;e++){const t=this.views[e];t.size=S(Math.round(this.proportions[e]*i),t.minimumSize,t.maximumSize)}else{const t=E(this.views.length),o=t.filter((i=>this.views[i].priority===e.LayoutPriority.Low)),s=t.filter((i=>this.views[i].priority===e.LayoutPriority.High));this.resize(this.views.length-1,i-n,void 0,o,s)}this.distributeEmptySpace(),this.layoutViews()}relayout(e,i){const t=this.views.reduce(((e,i)=>e+i.size),0);this.resize(this.views.length-1,this._size-t,void 0,e,i),this.distributeEmptySpace(),this.layoutViews(),this.saveProportions()}distributeEmptySpace(i){const t=this.views.reduce(((e,i)=>e+i.size),0);let n=this.size-t;const o=E(this.views.length-1,-1),s=o.filter((i=>this.views[i].priority===e.LayoutPriority.Low)),a=o.filter((i=>this.views[i].priority===e.LayoutPriority.High));for(const e of a)z(o,e);for(const e of s)x(o,e);"number"==typeof i&&x(o,i);for(let e=0;0!==n&&e<o.length;e++){const i=this.views[o[e]],t=S(i.size+n,i.minimumSize,i.maximumSize);n-=t-i.size,i.size=t}}saveProportions(){this.proportionalLayout&&this.contentSize>0&&(this._proportions=this.views.map((e=>e.size/this.contentSize)))}layoutViews(){this.contentSize=this.views.reduce(((e,i)=>e+i.size),0);let i=0;const t=[];this.updateSashEnablement();for(let n=0;n<this.views.length-1;n++){i+=this.views[n].size,t.push(i);const o=Math.min(Math.max(0,i-2),this.size-4);this._orientation===e.Orientation.HORIZONTAL&&(this.sashes[n].container.style.left=`${o}px`,this.sashes[n].container.style.top="0px"),this._orientation===e.Orientation.VERTICAL&&(this.sashes[n].container.style.left="0px",this.sashes[n].container.style.top=`${o}px`)}this.views.forEach(((i,n)=>{this._orientation===e.Orientation.HORIZONTAL&&(i.container.style.width=`${i.size}px`,i.container.style.left=0==n?"0px":`${t[n-1]}px`,i.container.style.top="",i.container.style.height=""),this._orientation===e.Orientation.VERTICAL&&(i.container.style.height=`${i.size}px`,i.container.style.top=0==n?"0px":`${t[n-1]}px`,i.container.style.width="",i.container.style.left=""),i.view.layout(i.size,this._orthogonalSize)}))}findFirstSnapIndex(e){for(const i of e){const e=this.views[i];if(e.visible&&e.snap)return i}for(const i of e){const e=this.views[i];if(e.visible&&e.maximumSize-e.minimumSize>0)return;if(!e.visible&&e.snap)return i}}updateSashEnablement(){let i=!1;const t=this.views.map((e=>i=e.size-e.minimumSize>0||i));i=!1;const n=this.views.map((e=>i=e.maximumSize-e.size>0||i)),o=[...this.views].reverse();i=!1;const s=o.map((e=>i=e.size-e.minimumSize>0||i)).reverse();i=!1;const a=o.map((e=>i=e.maximumSize-e.size>0||i)).reverse();let r=0;for(let i=0;i<this.sashes.length;i++){const o=this.sashes[i];r+=this.views[i].size;const h=!(t[i]&&a[i+1]),d=!(n[i]&&s[i+1]);if(h&&d){const n=E(i,-1),a=E(i+1,this.views.length),h=this.findFirstSnapIndex(n),d=this.findFirstSnapIndex(a),l="number"==typeof h&&!this.views[h].visible,p="number"==typeof d&&!this.views[d].visible;l&&s[i]&&(r>0||this.startSnappingEnabled)?this.updateSash(o,e.SashState.MINIMUM):p&&t[i]&&(r<this.contentSize||this.endSnappingEnabled)?this.updateSash(o,e.SashState.MAXIMUM):this.updateSash(o,e.SashState.DISABLED)}else h&&!d?this.updateSash(o,e.SashState.MINIMUM):!h&&d?this.updateSash(o,e.SashState.MAXIMUM):this.updateSash(o,e.SashState.ENABLED)}}updateSash(i,t){g(i.container,"disabled",t===e.SashState.DISABLED),g(i.container,"enabled",t===e.SashState.ENABLED),g(i.container,"maximum",t===e.SashState.MAXIMUM),g(i.container,"minimum",t===e.SashState.MINIMUM)}createViewContainer(){const e=document.createElement("div");return e.className="view-container",e}createSashContainer(){const e=document.createElement("div");return e.className="sash-container",e}createContainer(){const i=document.createElement("div"),t=this._orientation===e.Orientation.HORIZONTAL?"horizontal":"vertical";return i.className=`split-view-container ${t}`,i}dispose(){this._onDidSashEnd.dispose(),this._onDidAddView.dispose(),this._onDidRemoveView.dispose();for(let e=0;e<this.element.children.length;e++)if(this.element.children.item(e)===this.element){this.element.removeChild(this.element);break}this.element.remove()}}class L extends c{get onDidAddView(){return this.splitview.onDidAddView}get onDidRemoveView(){return this.splitview.onDidRemoveView}get minimumSize(){return this.splitview.minimumSize}get maximumSize(){return this.splitview.maximumSize}get orientation(){return this.splitview.orientation}get size(){return this.splitview.size}get orthogonalSize(){return this.splitview.orthogonalSize}constructor(i,t){var n;super(),this.paneItems=[],this.skipAnimation=!1,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this._orientation=null!==(n=t.orientation)&&void 0!==n?n:e.Orientation.VERTICAL,this.element=document.createElement("div"),this.element.className="pane-container",i.appendChild(this.element),this.splitview=new N(this.element,{orientation:this._orientation,proportionalLayout:!1,descriptor:t.descriptor}),this.getPanes().forEach((e=>{const i=new c(e.onDidChangeExpansionState((()=>{this.setupAnimation(),this._onDidChange.fire(void 0)}))),t={pane:e,disposable:{dispose:()=>{i.dispose()}}};this.paneItems.push(t),e.orthogonalSize=this.splitview.orthogonalSize})),this.addDisposables(this._onDidChange,this.splitview.onDidSashEnd((()=>{this._onDidChange.fire(void 0)})),this.splitview.onDidAddView((()=>{this._onDidChange.fire()})),this.splitview.onDidRemoveView((()=>{this._onDidChange.fire()})))}addPane(e,i,t=this.splitview.length,n=!1){const o=e.onDidChangeExpansionState((()=>{this.setupAnimation(),this._onDidChange.fire(void 0)})),s={pane:e,disposable:{dispose:()=>{o.dispose()}}};this.paneItems.splice(t,0,s),e.orthogonalSize=this.splitview.orthogonalSize,this.splitview.addView(e,i,t,n)}getViewSize(e){return this.splitview.getViewSize(e)}getPanes(){return this.splitview.getViews()}removePane(e,i={skipDispose:!1}){const t=this.paneItems.splice(e,1)[0];return this.splitview.removeView(e),i.skipDispose||(t.disposable.dispose(),t.pane.dispose()),t}moveView(e,i){if(e===i)return;const t=this.removePane(e,{skipDispose:!0});this.skipAnimation=!0;try{this.addPane(t.pane,t.pane.size,i,!1)}finally{this.skipAnimation=!1}}layout(e,i){this.splitview.layout(e,i)}setupAnimation(){this.skipAnimation||(this.animationTimer&&(clearTimeout(this.animationTimer),this.animationTimer=void 0),v(this.element,"animated"),this.animationTimer=setTimeout((()=>{this.animationTimer=void 0,m(this.element,"animated")}),200))}dispose(){super.dispose(),this.animationTimer&&(clearTimeout(this.animationTimer),this.animationTimer=void 0),this.paneItems.forEach((e=>{e.disposable.dispose(),e.pane.dispose()})),this.paneItems=[],this.splitview.dispose(),this.element.remove()}}class G{get minimumWidth(){return this.view.minimumWidth}get maximumWidth(){return this.view.maximumWidth}get minimumHeight(){return this.view.minimumHeight}get maximumHeight(){return this.view.maximumHeight}get priority(){return this.view.priority}get snap(){return this.view.snap}get minimumSize(){return this.orientation===e.Orientation.HORIZONTAL?this.minimumHeight:this.minimumWidth}get maximumSize(){return this.orientation===e.Orientation.HORIZONTAL?this.maximumHeight:this.maximumWidth}get minimumOrthogonalSize(){return this.orientation===e.Orientation.HORIZONTAL?this.minimumWidth:this.minimumHeight}get maximumOrthogonalSize(){return this.orientation===e.Orientation.HORIZONTAL?this.maximumWidth:this.maximumHeight}get orthogonalSize(){return this._orthogonalSize}get size(){return this._size}get element(){return this.view.element}get width(){return this.orientation===e.Orientation.HORIZONTAL?this.orthogonalSize:this.size}get height(){return this.orientation===e.Orientation.HORIZONTAL?this.size:this.orthogonalSize}constructor(i,t,n,o=0){this.view=i,this.orientation=t,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this._orthogonalSize=n,this._size=o,this._disposable=this.view.onDidChange((i=>{i?this._onDidChange.fire({size:this.orientation===e.Orientation.VERTICAL?i.width:i.height,orthogonalSize:this.orientation===e.Orientation.VERTICAL?i.height:i.width}):this._onDidChange.fire({})}))}setVisible(e){this.view.setVisible&&(this.view.setVisible(e),this._onDidChange.fire({}))}layout(e,i){this._size=e,this._orthogonalSize=i,this.view.layout(this.width,this.height)}dispose(){this._onDidChange.dispose(),this._disposable.dispose()}}class T extends c{get width(){return this.orientation===e.Orientation.HORIZONTAL?this.size:this.orthogonalSize}get height(){return this.orientation===e.Orientation.HORIZONTAL?this.orthogonalSize:this.size}get minimumSize(){return 0===this.children.length?0:Math.max(...this.children.map((e=>e.minimumOrthogonalSize)))}get maximumSize(){return Math.min(...this.children.map((e=>e.maximumOrthogonalSize)))}get minimumOrthogonalSize(){return this.splitview.minimumSize}get maximumOrthogonalSize(){return this.splitview.maximumSize}get orthogonalSize(){return this._orthogonalSize}get size(){return this._size}get minimumWidth(){return this.orientation===e.Orientation.HORIZONTAL?this.minimumOrthogonalSize:this.minimumSize}get minimumHeight(){return this.orientation===e.Orientation.HORIZONTAL?this.minimumSize:this.minimumOrthogonalSize}get maximumWidth(){return this.orientation===e.Orientation.HORIZONTAL?this.maximumOrthogonalSize:this.maximumSize}get maximumHeight(){return this.orientation===e.Orientation.HORIZONTAL?this.maximumSize:this.maximumOrthogonalSize}get priority(){if(0===this.children.length)return e.LayoutPriority.Normal;const i=this.children.map((i=>void 0===i.priority?e.LayoutPriority.Normal:i.priority));return i.some((i=>i===e.LayoutPriority.High))?e.LayoutPriority.High:i.some((i=>i===e.LayoutPriority.Low))?e.LayoutPriority.Low:e.LayoutPriority.Normal}constructor(e,t,n,o,s,a){if(super(),this.orientation=e,this.proportionalLayout=t,this.styles=n,this._childrenDisposable=i.NONE,this.children=[],this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this._orthogonalSize=s,this._size=o,this.element=document.createElement("div"),this.element.className="branch-node",a){const e={views:a.map((e=>({view:e.node,size:e.node.size,visible:!(e.node instanceof G&&void 0!==e.visible)||e.visible}))),size:this.size};this.children=a.map((e=>e.node)),this.splitview=new N(this.element,{orientation:this.orientation,descriptor:e,proportionalLayout:t})}else this.splitview=new N(this.element,{orientation:this.orientation,proportionalLayout:t,styles:n}),this.splitview.layout(this.size,this.orthogonalSize);this.addDisposables(this._onDidChange,this.splitview.onDidSashEnd((()=>{this._onDidChange.fire({})}))),this.setupChildrenEvents()}setVisible(e){for(const i of this.children)i.setVisible(e)}isChildVisible(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.isViewVisible(e)}setChildVisible(e,i){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.isViewVisible(e)!==i&&this.splitview.setViewVisible(e,i)}moveChild(e,i){if(e===i)return;if(e<0||e>=this.children.length)throw new Error("Invalid from index");e<i&&i--,this.splitview.moveView(e,i);const t=this._removeChild(e);this._addChild(t,i)}getChildSize(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.getViewSize(e)}resizeChild(e,i){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.resizeView(e,i)}layout(e,i){this._size=i,this._orthogonalSize=e,this.splitview.layout(this.size,this.orthogonalSize)}addChild(e,i,t,n){if(t<0||t>this.children.length)throw new Error("Invalid index");this.splitview.addView(e,i,t,n),this._addChild(e,t)}getChildCachedVisibleSize(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.getViewCachedVisibleSize(e)}removeChild(e,i){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.removeView(e,i),this._removeChild(e)}_addChild(e,i){this.children.splice(i,0,e),this.setupChildrenEvents()}_removeChild(e){const[i]=this.children.splice(e,1);return this.setupChildrenEvents(),i}setupChildrenEvents(){this._childrenDisposable.dispose(),this._childrenDisposable=e.DockviewEvent.any(...this.children.map((e=>e.onDidChange)))((e=>{this._onDidChange.fire({size:e.orthogonalSize})}))}dispose(){super.dispose(),this._childrenDisposable.dispose(),this.children.forEach((e=>e.dispose())),this.splitview.dispose()}}function H(e,i){if(e instanceof G)return e;if(e instanceof T)return H(e.children[i?e.children.length-1:0],i);throw new Error("invalid node")}function R(e,i,t){if(e instanceof T){const n=new T($(e.orientation),e.proportionalLayout,e.styles,i,t);let o=0;for(let s=e.children.length-1;s>=0;s--){const a=e.children[s],r=a instanceof T?a.orthogonalSize:a.size;let h=0===e.size?0:Math.round(i*r/e.size);o+=h,0===s&&(h+=i-o),n.addChild(R(a,t,h),h,0,!0)}return n}return new G(e.view,$(e.orientation),t)}function M(e){const i=e.parentElement;if(!i)throw new Error("Invalid grid element");let t=i.firstElementChild,n=0;for(;t!==e&&t!==i.lastElementChild&&t;)t=t.nextElementSibling,n++;return n}function F(e){const i=e.parentElement;if(!i)throw new Error("Invalid grid element");if(/\bgrid-view\b/.test(i.className))return[];const t=M(i);return[...F(i.parentElement.parentElement.parentElement),t]}function W(e,i,t){if(B(e,i)===J(t)){const[e,n]=y(i);let o=n;return"right"!==t&&"bottom"!==t||(o+=1),[...e,o]}{const e="right"===t||"bottom"===t?1:0;return[...i,e]}}function J(i){return"top"===i||"bottom"===i?e.Orientation.VERTICAL:e.Orientation.HORIZONTAL}function B(e,i){return i.length%2==0?$(e):e}const $=i=>i===e.Orientation.HORIZONTAL?e.Orientation.VERTICAL:e.Orientation.HORIZONTAL;function j(e){return!!e.children}const Z=(i,t)=>{const n=t===e.Orientation.VERTICAL?i.box.width:i.box.height;return j(i)?{type:"branch",data:i.children.map((e=>Z(e,$(t)))),size:n}:"number"==typeof i.cachedVisibleSize?{type:"leaf",data:i.view.toJSON(),size:i.cachedVisibleSize,visible:!1}:{type:"leaf",data:i.view.toJSON(),size:n}};class U{get length(){return this._root?this._root.children.length:0}get orientation(){return this.root.orientation}set orientation(e){if(this.root.orientation===e)return;const{size:i,orthogonalSize:t}=this.root;this.root=R(this.root,t,i),this.root.layout(i,t)}get width(){return this.root.width}get height(){return this.root.height}get minimumWidth(){return this.root.minimumWidth}get minimumHeight(){return this.root.minimumHeight}get maximumWidth(){return this.root.maximumHeight}get maximumHeight(){return this.root.maximumHeight}serialize(){return{root:Z(this.getView(),this.orientation),width:this.width,height:this.height,orientation:this.orientation}}dispose(){this.disposable.dispose(),this._onDidChange.dispose(),this.root.dispose(),this.element.remove()}clear(){const e=this.root.orientation;this.root=new T(e,this.proportionalLayout,this.styles,this.root.size,this.root.orthogonalSize)}deserialize(i,t){const n=i.orientation,o=n===e.Orientation.VERTICAL?i.height:i.width;this._deserialize(i.root,n,t,o)}_deserialize(e,i,t,n){this.root=this._deserializeNode(e,i,t,n,!0)}_deserializeNode(e,i,t,n,o=!1){let s;if("branch"===e.type){const a=e.data.map((n=>({node:this._deserializeNode(n,$(i),t,e.size),visible:n.visible})));s=new T(i,this.proportionalLayout,this.styles,o?n:e.size,o?e.size:n,a)}else s=new G(t.fromJSON(e),i,n,e.size);return s}get root(){return this._root}set root(e){const i=this._root;i&&(i.dispose(),this.element.removeChild(i.element)),this._root=e,this.element.appendChild(this._root.element),this.disposable.value=this._root.onDidChange((e=>{this._onDidChange.fire(e)}))}insertOrthogonalSplitviewAtRoot(){if(!this._root)return;const i=this.root;if(i.element.remove(),this._root=new T($(i.orientation),this.proportionalLayout,this.styles,this.root.orthogonalSize,this.root.size),1===i.children.length){const t=i.children[0];i.removeChild(0),i.dispose(),this._root.addChild(t,e.Sizing.Distribute,0)}else this._root.addChild(i,e.Sizing.Distribute,0);this.element.appendChild(this._root.element),this.disposable.value=this._root.onDidChange((e=>{this._onDidChange.fire(e)}))}next(e){return this.progmaticSelect(e)}previous(e){return this.progmaticSelect(e,!0)}getView(e){const i=e?this.getNode(e)[1]:this.root;return this._getViews(i,this.orientation)}_getViews(e,i,t){const n={height:e.height,width:e.width};if(e instanceof G)return{box:n,view:e.view,cachedVisibleSize:t};const o=[];for(let t=0;t<e.children.length;t++){const n=e.children[t],s=e.getChildCachedVisibleSize(t);o.push(this._getViews(n,$(i),s))}return{box:n,children:o}}progmaticSelect(e,i=!1){const[t,n]=this.getNode(e);if(!(n instanceof G))throw new Error("invalid location");for(let n=t.length-1;n>-1;n--){const o=t[n],s=e[n]||0;if(i?s-1>-1:s+1<o.children.length)return H(o.children[i?s-1:s+1],i)}return H(this.root,i)}constructor(e,i,t){this.proportionalLayout=e,this.styles=i,this.disposable=new u,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this.element=document.createElement("div"),this.element.className="grid-view",this.root=new T(t,e,i,0,0)}isViewVisible(e){const[i,t]=y(e),[,n]=this.getNode(i);if(!(n instanceof T))throw new Error("Invalid from location");return n.isChildVisible(t)}setViewVisible(e,i){const[t,n]=y(e),[,o]=this.getNode(t);if(!(o instanceof T))throw new Error("Invalid from location");o.setChildVisible(n,i)}moveView(e,i,t){const[,n]=this.getNode(e);if(!(n instanceof T))throw new Error("Invalid location");n.moveChild(i,t)}addView(i,t,n){const[o,s]=y(n),[a,r]=this.getNode(o);if(r instanceof T){const e=new G(i,$(r.orientation),r.orthogonalSize);r.addChild(e,t,s)}else{const[n,...h]=[...a].reverse(),[d,...l]=[...o].reverse();let p=0;const c=n.getChildCachedVisibleSize(d);"number"==typeof c&&(p=e.Sizing.Invisible(c)),n.removeChild(d);const u=new T(r.orientation,this.proportionalLayout,this.styles,r.size,r.orthogonalSize);n.addChild(u,r.size,d);const m=new G(r.view,n.orientation,r.size);u.addChild(m,p,0),"number"!=typeof t&&"split"===t.type&&(t={type:"split",index:0});const v=new G(i,n.orientation,r.size);u.addChild(v,t,s)}}remove(e,i){const t=F(e.element);return this.removeView(t,i)}removeView(i,t){const[n,o]=y(i),[s,a]=this.getNode(n);if(!(a instanceof T))throw new Error("Invalid location");const r=a.children[o];if(!(r instanceof G))throw new Error("Invalid location");if(a.removeChild(o,t),0===a.children.length)return r.view;if(a.children.length>1)return r.view;const h=a.children[0];if(0===s.length)return h instanceof G||(a.removeChild(0,t),this.root=h),r.view;const[d,...l]=[...s].reverse(),[p,...c]=[...n].reverse(),u=a.isChildVisible(0);a.removeChild(0,t);const m=d.children.map(((e,i)=>d.getChildSize(i)));if(d.removeChild(p,t),h instanceof T){m.splice(p,1,...h.children.map((e=>e.size)));for(let e=0;e<h.children.length;e++){const i=h.children[e];d.addChild(i,i.size,p+e)}}else{const i=new G(h.view,$(h.orientation),h.size),t=u?h.orthogonalSize:e.Sizing.Invisible(h.orthogonalSize);d.addChild(i,t,p)}for(let e=0;e<m.length;e++)d.resizeChild(e,m[e]);return r.view}layout(i,t){const[n,o]=this.root.orientation===e.Orientation.HORIZONTAL?[t,i]:[i,t];this.root.layout(n,o)}getNode(e,i=this.root,t=[]){if(0===e.length)return[t,i];if(!(i instanceof T))throw new Error("Invalid location");const[n,...o]=e;if(n<0||n>=i.children.length)throw new Error("Invalid location");const s=i.children[n];return t.push(i),this.getNode(o,s,t)}}class Y{get minimumSize(){return this.component.minimumSize}get maximumSize(){return this.component.maximumSize}get height(){return this.component.height}get width(){return this.component.width}get panels(){return this.component.panels}get onDidLayoutChange(){return this.component.onDidLayoutChange}get onDidLayoutFromJSON(){return this.component.onDidLayoutFromJSON}get onDidAddView(){return this.component.onDidAddView}get onDidRemoveView(){return this.component.onDidRemoveView}get onDidDrop(){const e=new h,i=this.component.onDidDrop((i=>{e.fire(Object.assign(Object.assign({},i),{api:this}))}));return e.dispose=()=>{i.dispose(),e.dispose()},e.event}constructor(e){this.component=e}removePanel(e){this.component.removePanel(e)}getPanel(e){return this.component.getPanel(e)}movePanel(e,i){this.component.movePanel(e,i)}focus(){this.component.focus()}layout(e,i){this.component.layout(e,i)}addPanel(e){return this.component.addPanel(e)}fromJSON(e){this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}clear(){this.component.clear()}}class X{get id(){return this.component.id}get width(){return this.component.width}get height(){return this.component.height}get minimumHeight(){return this.component.minimumHeight}get maximumHeight(){return this.component.maximumHeight}get minimumWidth(){return this.component.minimumWidth}get maximumWidth(){return this.component.maximumWidth}get size(){return this.component.size}get totalPanels(){return this.component.totalPanels}get onDidActiveGroupChange(){return this.component.onDidActiveGroupChange}get onDidAddGroup(){return this.component.onDidAddGroup}get onDidRemoveGroup(){return this.component.onDidRemoveGroup}get onDidActivePanelChange(){return this.component.onDidActivePanelChange}get onDidAddPanel(){return this.component.onDidAddPanel}get onDidRemovePanel(){return this.component.onDidRemovePanel}get onDidLayoutFromJSON(){return this.component.onDidLayoutFromJSON}get onDidLayoutChange(){return this.component.onDidLayoutChange}get onDidDrop(){return this.component.onDidDrop}get panels(){return this.component.panels}get groups(){return this.component.groups}get activePanel(){return this.component.activePanel}get activeGroup(){return this.component.activeGroup}constructor(e){this.component=e}getTabHeight(){return this.component.tabHeight}setTabHeight(e){this.component.tabHeight=e}focus(){this.component.focus()}getPanel(e){return this.component.getGroupPanel(e)}layout(e,i,t=!1){this.component.layout(e,i,t)}addPanel(e){return this.component.addPanel(e)}addGroup(e){return this.component.addGroup(e)}moveToNext(e){this.component.moveToNext(e)}moveToPrevious(e){this.component.moveToPrevious(e)}closeAllGroups(){return this.component.closeAllGroups()}removeGroup(e){this.component.removeGroup(e)}getGroup(e){return this.component.getPanel(e)}fromJSON(e){this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}clear(){this.component.clear()}}class Q extends c{constructor(e,i){super(),this.element=e,this.callbacks=i,this.target=null,this.registerListeners()}registerListeners(){this.addDisposables(l(this.element,"dragenter",(e=>{this.target=e.target,this.callbacks.onDragEnter(e)}),!0)),this.addDisposables(l(this.element,"dragover",(e=>{e.preventDefault(),this.callbacks.onDragOver&&this.callbacks.onDragOver(e)}),!0)),this.addDisposables(l(this.element,"dragleave",(e=>{this.target===e.target&&(this.target=null,this.callbacks.onDragLeave(e))}))),this.addDisposables(l(this.element,"dragend",(e=>{this.target=null,this.callbacks.onDragEnd(e)}))),this.addDisposables(l(this.element,"drop",(e=>{this.callbacks.onDrop(e)})))}}function q(e){switch(e){case"above":return"top";case"below":return"bottom";case"left":return"left";case"right":return"right";case"within":return"center";default:throw new Error(`invalid direction '${e}'`)}}class K extends c{get state(){return this._state}constructor(e,i){super(),this.element=e,this.options=i,this._onDrop=new h,this.onDrop=this._onDrop.event;const t=new Set(this.options.acceptedTargetZones);this.addDisposables(this._onDrop,new Q(this.element,{onDragEnter:()=>{},onDragOver:e=>{const i=this.element.clientWidth,n=this.element.clientHeight;if(0===i||0===n)return;const o=e.currentTarget.getBoundingClientRect(),s=e.clientX-o.left,a=e.clientY-o.top,r=this.calculateQuadrant(t,s,a,i,n);if(null!==r){if("boolean"==typeof this.options.canDisplayOverlay){if(!this.options.canDisplayOverlay)return}else if(!this.options.canDisplayOverlay(e,r))return;this.targetElement||(this.targetElement=document.createElement("div"),this.targetElement.className="drop-target-dropzone",this.overlayElement=document.createElement("div"),this.overlayElement.className="drop-target-selection",this._state="center",this.targetElement.appendChild(this.overlayElement),this.element.classList.add("drop-target"),this.element.append(this.targetElement)),0!==this.options.acceptedTargetZones.length&&this.targetElement&&this.overlayElement&&(this.toggleClasses(r,i,n),this.setState(r))}else this.removeDropTarget()},onDragLeave:()=>{this.removeDropTarget()},onDragEnd:()=>{this.removeDropTarget()},onDrop:e=>{e.preventDefault();const i=this._state;this.removeDropTarget(),i&&(e.stopPropagation(),this._onDrop.fire({position:i,nativeEvent:e}))}}))}dispose(){this.removeDropTarget()}toggleClasses(e,i,t){var n,o,s,a;if(!this.overlayElement)return;const r=i<100,h=t<100,d="left"===e,l="right"===e,p="top"===e,c="bottom"===e,u=!r&&l,m=!r&&d,v=!h&&p,w=!h&&c;let b=.5;"percentage"===(null===(o=null===(n=this.options.overlayModel)||void 0===n?void 0:n.size)||void 0===o?void 0:o.type)&&(b=S(this.options.overlayModel.size.value,0,100)/100),"pixels"===(null===(a=null===(s=this.options.overlayModel)||void 0===s?void 0:s.size)||void 0===a?void 0:a.type)&&((u||m)&&(b=S(0,this.options.overlayModel.size.value,i)/i),(v||w)&&(b=S(0,this.options.overlayModel.size.value,t)/t));const f=(1-b)/2;let _;_=u?`translateX(${100*f}%) scaleX(${b})`:m?`translateX(-${100*f}%) scaleX(${b})`:v?`translateY(-${100*f}%) scaleY(${b})`:w?`translateY(${100*f}%) scaleY(${b})`:"",this.overlayElement.style.transform=_,g(this.overlayElement,"small-right",r&&l),g(this.overlayElement,"small-left",r&&d),g(this.overlayElement,"small-top",h&&p),g(this.overlayElement,"small-bottom",h&&c)}setState(e){switch(e){case"top":this._state="top";break;case"left":this._state="left";break;case"bottom":this._state="bottom";break;case"right":this._state="right";break;case"center":this._state="center"}}calculateQuadrant(e,i,t,n,o){var s,a,r,h,d,l;const p=void 0===(null===(s=this.options.overlayModel)||void 0===s?void 0:s.activationSize)||"percentage"===(null===(r=null===(a=this.options.overlayModel)||void 0===a?void 0:a.activationSize)||void 0===r?void 0:r.type),c=(u=null===(l=null===(d=null===(h=this.options)||void 0===h?void 0:h.overlayModel)||void 0===d?void 0:d.activationSize)||void 0===l?void 0:l.value,m=20,"number"==typeof u?u:m);var u,m;return p?function(e,i,t,n,o,s){const a=100*i/n,r=100*t/o;if(e.has("left")&&a<s)return"left";if(e.has("right")&&a>100-s)return"right";if(e.has("top")&&r<s)return"top";if(e.has("bottom")&&r>100-s)return"bottom";if(!e.has("center"))return null;return"center"}(e,i,t,n,o,c):function(e,i,t,n,o,s){if(e.has("left")&&i<s)return"left";if(e.has("right")&&i>n-s)return"right";if(e.has("top")&&t<s)return"top";if(e.has("bottom")&&t>o-s)return"bottom";if(!e.has("center"))return null;return"center"}(e,i,t,n,o,c)}removeDropTarget(){this.targetElement&&(this._state=void 0,this.element.removeChild(this.targetElement),this.targetElement=void 0,this.overlayElement=void 0,this.element.classList.remove("drop-target"))}}class ee extends c{get element(){return this._element}constructor(){super(),this.disposable=new u,this._onDidFocus=new h,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new h,this.onDidBlur=this._onDidBlur.event,this._element=document.createElement("div"),this._element.className="content-container",this._element.tabIndex=-1,this.addDisposables(this._onDidFocus,this._onDidBlur)}show(){this.element.style.display=""}hide(){this.element.style.display="none"}openPanel(e){var i;if(this.panel===e)return;this.panel&&((null===(i=this.panel.view)||void 0===i?void 0:i.content)&&this._element.removeChild(this.panel.view.content.element),this.panel=void 0),this.panel=e;const t=new c;if(this.panel.view){const e=this.panel.view.content.onDidFocus,i=this.panel.view.content.onDidBlur,{onDidFocus:n,onDidBlur:o}=f(this._element);t.addDisposables(n((()=>this._onDidFocus.fire())),o((()=>this._onDidBlur.fire()))),e&&t.addDisposables(e((()=>this._onDidFocus.fire()))),i&&t.addDisposables(i((()=>this._onDidBlur.fire()))),this._element.appendChild(this.panel.view.content.element)}this.disposable.value=t}layout(e,i){}closePanel(){var e,i,t;(null===(t=null===(i=null===(e=this.panel)||void 0===e?void 0:e.view)||void 0===i?void 0:i.content)||void 0===t?void 0:t.element)&&(this._element.removeChild(this.panel.view.content.element),this.panel=void 0)}dispose(){this.disposable.dispose(),super.dispose()}}var ie;e.DockviewDropTargets=void 0,(ie=e.DockviewDropTargets||(e.DockviewDropTargets={}))[ie.Tab=0]="Tab",ie[ie.Panel=1]="Panel",ie[ie.TabContainer=2]="TabContainer",ie[ie.Edge=3]="Edge";class te extends c{constructor(e){super(),this.el=e,this.disposable=new u,this._onDragStart=new h,this.onDragStart=this._onDragStart.event,this.iframes=[],this.configure()}configure(){this.addDisposables(this._onDragStart,l(this.el,"dragstart",(e=>{this.iframes=[...b("iframe"),...b("webview")];for(const e of this.iframes)e.style.pointerEvents="none";this.el.classList.add("dv-dragged"),setTimeout((()=>this.el.classList.remove("dv-dragged")),0),this.disposable.value=this.getData(e.dataTransfer),e.dataTransfer&&(e.dataTransfer.effectAllowed="move",e.dataTransfer.setData("text/plain","__dockview_internal_drag_event__"))})),l(this.el,"dragend",(()=>{for(const e of this.iframes)e.style.pointerEvents="auto";this.iframes=[],this.disposable.dispose()})))}}class ne extends c{get element(){return this._element}constructor(i,t,o){super(),this.panelId=i,this.accessor=t,this.group=o,this._onChanged=new h,this.onChanged=this._onChanged.event,this._onDropped=new h,this.onDrop=this._onDropped.event,this.addDisposables(this._onChanged,this._onDropped),this._element=document.createElement("div"),this._element.className="tab",this._element.tabIndex=0,this._element.draggable=!0,g(this.element,"inactive-tab",!0),this.addDisposables(new class extends te{constructor(){super(...arguments),this.panelTransfer=s.getInstance()}getData(){return this.panelTransfer.setData([new n(t.id,o.id,i)],n.prototype),{dispose:()=>{this.panelTransfer.clearData(n.prototype)}}}dispose(){}}(this._element)),this.addDisposables(l(this._element,"mousedown",(e=>{e.defaultPrevented||(e.stopPropagation(),this._onChanged.fire(e))}))),this.droptarget=new K(this._element,{acceptedTargetZones:["center"],canDisplayOverlay:(i,t)=>{if(this.group.locked)return!1;const n=a();return n&&this.accessor.id===n.viewId?(null!==n.panelId||n.groupId!==this.group.id)&&this.panelId!==n.panelId:this.group.model.canDisplayOverlay(i,t,e.DockviewDropTargets.Tab)}}),this.addDisposables(this.droptarget.onDrop((e=>{this._onDropped.fire(e)})))}setActive(e){g(this.element,"active-tab",e),g(this.element,"inactive-tab",!e)}setContent(e){this.content&&this._element.removeChild(this.content.element),this.content=e,this._element.appendChild(this.content.element)}dispose(){super.dispose(),this.droptarget.dispose()}}class oe extends te{constructor(e,i,t){super(e),this.accessorId=i,this.group=t,this.panelTransfer=s.getInstance()}getData(e){this.panelTransfer.setData([new n(this.accessorId,this.group.id,null)],n.prototype);const i=window.getComputedStyle(this.el),t=i.getPropertyValue("--dv-activegroup-visiblepanel-tab-background-color"),o=i.getPropertyValue("--dv-activegroup-visiblepanel-tab-color");if(e){const i=document.createElement("div");i.style.backgroundColor=t,i.style.color=o,i.style.padding="2px 8px",i.style.height="24px",i.style.fontSize="11px",i.style.lineHeight="20px",i.style.borderRadius="12px",i.style.position="absolute",i.textContent=`Multiple Panels (${this.group.size})`,function(e,i){v(i,"dv-dragged"),document.body.appendChild(i),e.setDragImage(i,0,0),setTimeout((()=>{m(i,"dv-dragged"),i.remove()}),0)}(e,i)}return{dispose:()=>{this.panelTransfer.clearData(n.prototype)}}}dispose(){}}class se extends c{get element(){return this._element}constructor(i,t){super(),this.accessor=i,this.group=t,this._onDrop=new h,this.onDrop=this._onDrop.event,this._element=document.createElement("div"),this._element.className="void-container",this._element.tabIndex=0,this._element.draggable=!0,this.addDisposables(this._onDrop,l(this._element,"click",(()=>{this.accessor.doSetGroupActive(this.group)})));const n=new oe(this._element,i.id,t);this.voidDropTarget=new K(this._element,{acceptedTargetZones:["center"],canDisplayOverlay:(i,n)=>{var o;const s=a();return s&&this.accessor.id===s.viewId?(null!==s.panelId||s.groupId!==this.group.id)&&(null===(o=(r=this.group.panels).length>0?r[r.length-1]:void 0)||void 0===o?void 0:o.id)!==s.panelId:t.model.canDisplayOverlay(i,n,e.DockviewDropTargets.Panel);var r}}),this.addDisposables(n,this.voidDropTarget.onDrop((e=>{this._onDrop.fire(e)})),this.voidDropTarget)}}class ae extends c{get panels(){return this.tabs.map((e=>e.value.panelId))}get size(){return this.tabs.length}get height(){return this._height}set height(e){this._height=e,"number"!=typeof e?this.element.style.removeProperty("--dv-tabs-and-actions-container-height"):this.element.style.setProperty("--dv-tabs-and-actions-container-height",`${e}px`)}get hidden(){return this._hidden}set hidden(e){this._hidden=e,this.element.style.display=e?"none":""}show(){this.hidden||(this.element.style.display="")}hide(){this._element.style.display="none"}setActionElement(e){this.actions!==e&&(this.actions&&(this.actions.remove(),this.actions=void 0),e&&(this.actionContainer.appendChild(e),this.actions=e))}get element(){return this._element}isActive(e){return this.selectedIndex>-1&&this.tabs[this.selectedIndex].value===e}indexOf(e){return this.tabs.findIndex((i=>i.value.panelId===e))}constructor(e,i){super(),this.accessor=e,this.group=i,this.tabs=[],this.selectedIndex=-1,this._hidden=!1,this._onDrop=new h,this.onDrop=this._onDrop.event,this.addDisposables(this._onDrop),this._element=document.createElement("div"),this._element.className="tabs-and-actions-container",this.height=e.options.tabHeight,g(this._element,"dv-full-width-single-tab","fullwidth"===this.accessor.options.singleTabMode),this.addDisposables(this.accessor.onDidAddPanel((e=>{e.api.group===this.group&&g(this._element,"dv-single-tab",1===this.size)})),this.accessor.onDidRemovePanel((e=>{e.api.group===this.group&&g(this._element,"dv-single-tab",1===this.size)}))),this.actionContainer=document.createElement("div"),this.actionContainer.className="action-container",this.tabContainer=document.createElement("div"),this.tabContainer.className="tabs-container",this.voidContainer=new se(this.accessor,this.group),this._element.appendChild(this.tabContainer),this._element.appendChild(this.voidContainer.element),this._element.appendChild(this.actionContainer),this.addDisposables(this.voidContainer,this.voidContainer.onDrop((e=>{this._onDrop.fire({event:e.nativeEvent,index:this.tabs.length})})),l(this.tabContainer,"mousedown",(e=>{if(e.defaultPrevented)return;0===e.button&&this.accessor.doSetGroupActive(this.group)})))}setActive(e){}addTab(e,i=this.tabs.length){if(i<0||i>this.tabs.length)throw new Error("invalid location");this.tabContainer.insertBefore(e.value.element,this.tabContainer.children[i]),this.tabs=[...this.tabs.slice(0,i),e,...this.tabs.slice(i)],this.selectedIndex<0&&(this.selectedIndex=i)}delete(e){const i=this.tabs.findIndex((i=>i.value.panelId===e)),t=this.tabs.splice(i,1)[0],{value:n,disposable:o}=t;o.dispose(),n.element.remove()}setActivePanel(e){this.tabs.forEach((i=>{const t=e.id===i.value.panelId;i.value.setActive(t)}))}openPanel(e,i=this.tabs.length){var t;if(this.tabs.find((i=>i.value.panelId===e.id)))return;const n=new ne(e.id,this.accessor,this.group);if(!(null===(t=e.view)||void 0===t?void 0:t.tab))throw new Error("invalid header component");n.setContent(e.view.tab);const o=c.from(n.onChanged((i=>{var t;const n=e.id===(null===(t=this.group.model.activePanel)||void 0===t?void 0:t.id)&&this.group.model.isContentFocused;0===i.button&&!i.defaultPrevented&&this.group.model.openPanel(e,{skipFocus:n})})),n.onDrop((e=>{this._onDrop.fire({event:e.nativeEvent,index:this.tabs.findIndex((e=>e.value===n))})}))),s={value:n,disposable:o};this.addTab(s,i)}closePanel(e){this.delete(e.id)}dispose(){super.dispose(),this.tabs.forEach((e=>{e.disposable.dispose()})),this.tabs=[]}}class re extends c{get element(){throw new Error("not supported")}get activePanel(){return this._activePanel}get locked(){return this._locked}set locked(e){this._locked=e,g(this.container,"locked-groupview",e)}get isActive(){return this._isGroupActive}get panels(){return this._panels}get size(){return this._panels.length}get isEmpty(){return 0===this._panels.length}get hasWatermark(){return!(!this.watermark||!this.container.contains(this.watermark.element))}get header(){return this.tabsContainer}get isContentFocused(){return!!document.activeElement&&w(document.activeElement,this.contentContainer.element)}constructor(i,t,n,o,s){super(),this.container=i,this.accessor=t,this.id=n,this.options=o,this.groupPanel=s,this._isGroupActive=!1,this._locked=!1,this.mostRecentlyUsed=[],this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this._width=0,this._height=0,this._panels=[],this._onMove=new h,this.onMove=this._onMove.event,this._onDidDrop=new h,this.onDidDrop=this._onDidDrop.event,this._onDidAddPanel=new h,this.onDidAddPanel=this._onDidAddPanel.event,this._onDidRemovePanel=new h,this.onDidRemovePanel=this._onDidRemovePanel.event,this._onDidActivePanelChange=new h,this.onDidActivePanelChange=this._onDidActivePanelChange.event,this.container.classList.add("groupview"),this.tabsContainer=new ae(this.accessor,this.groupPanel),this.contentContainer=new ee,this.dropTarget=new K(this.contentContainer.element,{acceptedTargetZones:["top","bottom","left","right","center"],canDisplayOverlay:(i,t)=>{if(this.locked&&"center"===t)return!1;const n=a();if(n&&n.viewId===this.accessor.id){if(n.groupId===this.id){if("center"===t)return!1;if(null===n.panelId)return!1}return!(1===this._panels.length&&n.groupId===this.id)}return this.canDisplayOverlay(i,t,e.DockviewDropTargets.Panel)}}),i.append(this.tabsContainer.element,this.contentContainer.element),this.header.hidden=!!o.hideHeader,this.locked=!!o.locked,this.addDisposables(this._onMove,this._onDidChange,this._onDidDrop,this._onDidAddPanel,this._onDidRemovePanel,this._onDidActivePanelChange,this.tabsContainer.onDrop((e=>{this.handleDropEvent(e.event,"center",e.index)})),this.contentContainer.onDidFocus((()=>{this.accessor.doSetGroupActive(this.groupPanel,!0)})),this.contentContainer.onDidBlur((()=>{})),this.dropTarget.onDrop((e=>{this.handleDropEvent(e.nativeEvent,e.position)})))}initialize(){var e,i;(null===(e=this.options)||void 0===e?void 0:e.panels)&&this.options.panels.forEach((e=>{this.doAddPanel(e)})),(null===(i=this.options)||void 0===i?void 0:i.activePanel)&&this.openPanel(this.options.activePanel),this.setActive(this.isActive,!0,!0),this.updateContainer(),this.accessor.options.createGroupControlElement&&(this._control=this.accessor.options.createGroupControlElement(this.groupPanel),this.addDisposables(this._control),this._control.init({containerApi:new X(this.accessor),api:this.groupPanel.api}),this.tabsContainer.setActionElement(this._control.element))}indexOf(e){return this.tabsContainer.indexOf(e.id)}toJSON(){var e;const i={views:this.tabsContainer.panels,activeView:null===(e=this._activePanel)||void 0===e?void 0:e.id,id:this.id};return this.locked&&(i.locked=!0),this.header.hidden&&(i.hideHeader=!0),i}moveToNext(e){e||(e={}),e.panel||(e.panel=this.activePanel);const i=e.panel?this.panels.indexOf(e.panel):-1;let t;if(i<this.panels.length-1)t=i+1;else{if(e.suppressRoll)return;t=0}this.openPanel(this.panels[t])}moveToPrevious(e){if(e||(e={}),e.panel||(e.panel=this.activePanel),!e.panel)return;const i=this.panels.indexOf(e.panel);let t;if(i>0)t=i-1;else{if(e.suppressRoll)return;t=this.panels.length-1}this.openPanel(this.panels[t])}containsPanel(e){return this.panels.includes(e)}init(e){}update(e){}focus(){var e,i;null===(i=null===(e=this._activePanel)||void 0===e?void 0:e.focus)||void 0===i||i.call(e)}openPanel(e,i={}){("number"!=typeof i.index||i.index>this.panels.length)&&(i.index=this.panels.length);const t=!!i.skipSetPanelActive,n=!!i.skipSetGroupActive;e.updateParentGroup(this.groupPanel,!0),this._activePanel!==e?(this.doAddPanel(e,i.index,t),t||this.doSetActivePanel(e),n||this.accessor.doSetGroupActive(this.groupPanel,!!i.skipFocus),this.updateContainer()):n||this.accessor.doSetGroupActive(this.groupPanel)}removePanel(e){const i="string"==typeof e?e:e.id,t=this._panels.find((e=>e.id===i));if(!t)throw new Error("invalid operation");return this._removePanel(t)}closeAllPanels(){if(this.panels.length>0){const e=[...this.panels];for(const i of e)this.doClose(i)}else this.accessor.removeGroup(this.groupPanel)}closePanel(e){this.doClose(e)}doClose(e){this.accessor.removePanel(e)}isPanelActive(e){return this._activePanel===e}updateActions(e){this.tabsContainer.setActionElement(e)}setActive(e,i=!1,t=!1){var n,o,s,a;t||this.isActive!==e?(this._isGroupActive=e,g(this.container,"active-group",e),g(this.container,"inactive-group",!e),this.tabsContainer.setActive(this.isActive),!this._activePanel&&this.panels.length>0&&this.doSetActivePanel(this.panels[0]),this.updateContainer(),e&&(i||null===(a=null===(s=this._activePanel)||void 0===s?void 0:s.focus)||void 0===a||a.call(s))):i||null===(o=null===(n=this._activePanel)||void 0===n?void 0:n.focus)||void 0===o||o.call(n)}layout(e,i){var t;this._width=e,this._height=i,this.contentContainer.layout(this._width,this._height),(null===(t=this._activePanel)||void 0===t?void 0:t.layout)&&this._activePanel.layout(this._width,this._height)}_removePanel(e){const i=this._activePanel===e;if(this.doRemovePanel(e),i&&this.panels.length>0){const e=this.mostRecentlyUsed[0];this.openPanel(e)}return this._activePanel&&0===this.panels.length&&this.doSetActivePanel(void 0),this.updateContainer(),e}doRemovePanel(e){const i=this.panels.indexOf(e);this._activePanel===e&&this.contentContainer.closePanel(),this.tabsContainer.delete(e.id),this._panels.splice(i,1),this.mostRecentlyUsed.includes(e)&&this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(e),1),this._onDidRemovePanel.fire({panel:e})}doAddPanel(e,i=this.panels.length,t=!1){const n=this._panels.indexOf(e)>-1;this.tabsContainer.openPanel(e,i),t||this.contentContainer.openPanel(e),this.tabsContainer.show(),this.contentContainer.show(),n||(this.updateMru(e),this.panels.splice(i,0,e),this._onDidAddPanel.fire({panel:e}))}doSetActivePanel(e){this._activePanel=e,e&&(this.tabsContainer.setActivePanel(e),e.layout(this._width,this._height),this.updateMru(e),this._onDidActivePanelChange.fire({panel:e}))}updateMru(e){this.mostRecentlyUsed.includes(e)&&this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(e),1),this.mostRecentlyUsed=[e,...this.mostRecentlyUsed]}updateContainer(){var e,i;if(g(this.container,"empty",this.isEmpty),this.panels.forEach((e=>e.updateParentGroup(this.groupPanel,this.isActive))),this.isEmpty&&!this.watermark){const e=this.accessor.createWatermarkComponent();e.init({containerApi:new X(this.accessor),group:this.groupPanel}),this.watermark=e,l(this.watermark.element,"click",(()=>{this.isActive||this.accessor.doSetGroupActive(this.groupPanel)})),this.tabsContainer.hide(),this.contentContainer.element.appendChild(this.watermark.element),this.watermark.updateParentGroup(this.groupPanel,!0)}!this.isEmpty&&this.watermark&&(this.watermark.element.remove(),null===(i=(e=this.watermark).dispose)||void 0===i||i.call(e),this.watermark=void 0,this.tabsContainer.show())}canDisplayOverlay(e,i,t){return!!this.accessor.options.showDndOverlay&&this.accessor.options.showDndOverlay({nativeEvent:e,target:t,group:this.accessor.getPanel(this.id),position:i,getData:a})}handleDropEvent(e,i,t){const n=a();if(n&&n.viewId===this.accessor.id){if(null===n.panelId){const{groupId:e}=n;return void this._onMove.fire({target:i,groupId:e,index:t})}if(-1!==this.tabsContainer.indexOf(n.panelId)&&1===this.tabsContainer.size)return;const{groupId:e,panelId:o}=n;if(this.id===e&&!i){if(this.tabsContainer.indexOf(o)===t)return}this._onMove.fire({target:i,groupId:n.groupId,itemId:n.panelId,index:t})}else this._onDidDrop.fire({nativeEvent:e,position:i,index:t,getData:()=>a()})}dispose(){var e,i;super.dispose(),null===(i=null===(e=this.watermark)||void 0===e?void 0:e.dispose)||void 0===i||i.call(e);for(const e of this.panels)e.dispose();this.dropTarget.dispose(),this.tabsContainer.dispose(),this.contentContainer.dispose()}}const he=P();function de(e){switch(e){case"left":return"left";case"right":return"right";case"above":return"top";case"below":return"bottom";default:return"center"}}class le extends c{get id(){return this._id}get element(){return this._element}get size(){return this._groups.size}get groups(){return Array.from(this._groups.values()).map((e=>e.value))}get width(){return this.gridview.width}get height(){return this.gridview.height}get minimumHeight(){return this.gridview.minimumHeight}get maximumHeight(){return this.gridview.maximumHeight}get minimumWidth(){return this.gridview.minimumWidth}get maximumWidth(){return this.gridview.maximumWidth}get activeGroup(){return this._activeGroup}constructor(i,t){super(),this._element=i,this._id=he.next(),this._groups=new Map,this._onDidLayoutChange=new h,this.onDidLayoutChange=this._onDidLayoutChange.event,this._onDidRemoveGroup=new h,this.onDidRemoveGroup=this._onDidRemoveGroup.event,this._onDidAddGroup=new h,this.onDidAddGroup=this._onDidAddGroup.event,this._onDidActiveGroupChange=new h,this.onDidActiveGroupChange=this._onDidActiveGroupChange.event,this._bufferOnDidLayoutChange=new p,this.gridview=new U(!!t.proportionalLayout,t.styles,t.orientation),this.element.appendChild(this.gridview.element),this.layout(0,0,!0),this.addDisposables(this.gridview.onDidChange((()=>{this._bufferOnDidLayoutChange.fire()}))),this.addDisposables(e.DockviewEvent.any(this.onDidAddGroup,this.onDidRemoveGroup,this.onDidActiveGroupChange)((()=>{this._bufferOnDidLayoutChange.fire()})),this._bufferOnDidLayoutChange.onEvent((()=>{this._onDidLayoutChange.fire()})),this._bufferOnDidLayoutChange)}setVisible(e,i){this.gridview.setViewVisible(F(e.element),i),this._onDidLayoutChange.fire()}isVisible(e){return this.gridview.isViewVisible(F(e.element))}doAddGroup(i,t=[0],n){this.gridview.addView(i,null!=n?n:e.Sizing.Distribute,t),this._onDidAddGroup.fire(i),this.doSetGroupActive(i)}doRemoveGroup(i,t){if(!this._groups.has(i.id))throw new Error("invalid operation");const n=this._groups.get(i.id),o=this.gridview.remove(i,e.Sizing.Distribute);if(n&&!(null==t?void 0:t.skipDispose)&&(n.disposable.dispose(),n.value.dispose(),this._groups.delete(i.id)),this._onDidRemoveGroup.fire(i),!(null==t?void 0:t.skipActive)&&this._activeGroup===i){const e=Array.from(this._groups.values());this.doSetGroupActive(e.length>0?e[0].value:void 0)}return o}getPanel(e){var i;return null===(i=this._groups.get(e))||void 0===i?void 0:i.value}doSetGroupActive(e,i){var t,n,o;this._activeGroup!==e&&(this._activeGroup&&(this._activeGroup.setActive(!1),i||null===(n=(t=this._activeGroup).focus)||void 0===n||n.call(t)),e&&(e.setActive(!0),i||null===(o=e.focus)||void 0===o||o.call(e)),this._activeGroup=e,this._onDidActiveGroupChange.fire(e))}removeGroup(e){this.doRemoveGroup(e)}moveToNext(e){var i;if(e||(e={}),!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}const t=F(e.group.element),n=null===(i=this.gridview.next(t))||void 0===i?void 0:i.view;this.doSetGroupActive(n)}moveToPrevious(e){var i;if(e||(e={}),!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}const t=F(e.group.element),n=null===(i=this.gridview.previous(t))||void 0===i?void 0:i.view;this.doSetGroupActive(n)}layout(e,i,t){(t||e!==this.width||i!==this.height)&&(this.element.style.height=`${i}px`,this.element.style.width=`${e}px`,this.gridview.layout(e,i))}dispose(){super.dispose(),this._onDidActiveGroupChange.dispose(),this._onDidAddGroup.dispose(),this._onDidRemoveGroup.dispose(),this._onDidLayoutChange.dispose();for(const e of this.groups)e.dispose();this.gridview.dispose()}}class pe extends c{get isFocused(){return this._isFocused}get isActive(){return this._isActive}get isVisible(){return this._isVisible}get width(){return this._width}get height(){return this._height}constructor(e){super(),this.id=e,this._isFocused=!1,this._isActive=!1,this._isVisible=!0,this._width=0,this._height=0,this.panelUpdatesDisposable=new u,this._onDidDimensionChange=new h({replay:!0}),this.onDidDimensionsChange=this._onDidDimensionChange.event,this._onDidChangeFocus=new h({replay:!0}),this.onDidFocusChange=this._onDidChangeFocus.event,this._onFocusEvent=new h,this.onFocusEvent=this._onFocusEvent.event,this._onDidVisibilityChange=new h({replay:!0}),this.onDidVisibilityChange=this._onDidVisibilityChange.event,this._onVisibilityChange=new h,this.onVisibilityChange=this._onVisibilityChange.event,this._onDidActiveChange=new h({replay:!0}),this.onDidActiveChange=this._onDidActiveChange.event,this._onActiveChange=new h,this.onActiveChange=this._onActiveChange.event,this._onUpdateParameters=new h,this.onUpdateParameters=this._onUpdateParameters.event,this.addDisposables(this.panelUpdatesDisposable,this._onDidDimensionChange,this._onDidChangeFocus,this._onDidVisibilityChange,this._onDidActiveChange,this._onFocusEvent,this._onActiveChange,this._onVisibilityChange,this._onUpdateParameters,this.onDidFocusChange((e=>{this._isFocused=e.isFocused})),this.onDidActiveChange((e=>{this._isActive=e.isActive})),this.onDidVisibilityChange((e=>{this._isVisible=e.isVisible})),this.onDidDimensionsChange((e=>{this._width=e.width,this._height=e.height})))}initialize(e){this.panelUpdatesDisposable.value=this._onUpdateParameters.event((i=>{e.update({params:{params:i}})}))}setVisible(e){this._onVisibilityChange.fire({isVisible:e})}setActive(){this._onActiveChange.fire()}updateParameters(e){this._onUpdateParameters.fire(e)}dispose(){super.dispose()}}class ce extends pe{constructor(e){super(e),this._onDidConstraintsChangeInternal=new h,this.onDidConstraintsChangeInternal=this._onDidConstraintsChangeInternal.event,this._onDidConstraintsChange=new h({replay:!0}),this.onDidConstraintsChange=this._onDidConstraintsChange.event,this._onDidSizeChange=new h,this.onDidSizeChange=this._onDidSizeChange.event,this.addDisposables(this._onDidConstraintsChangeInternal,this._onDidConstraintsChange,this._onDidSizeChange)}setConstraints(e){this._onDidConstraintsChangeInternal.fire(e)}setSize(e){this._onDidSizeChange.fire(e)}}class ue extends ce{set pane(e){this._pane=e}constructor(e){super(e),this._onDidExpansionChange=new h({replay:!0}),this.onDidExpansionChange=this._onDidExpansionChange.event,this._onMouseEnter=new h({}),this.onMouseEnter=this._onMouseEnter.event,this._onMouseLeave=new h({}),this.onMouseLeave=this._onMouseLeave.event,this.addDisposables(this._onDidExpansionChange,this._onMouseEnter,this._onMouseLeave)}setExpanded(e){var i;null===(i=this._pane)||void 0===i||i.setExpanded(e)}get isExpanded(){var e;return!!(null===(e=this._pane)||void 0===e?void 0:e.isExpanded())}}class me extends c{get element(){return this._element}get width(){return this._width}get height(){return this._height}get params(){var e;return null===(e=this._params)||void 0===e?void 0:e.params}constructor(e,i,t){super(),this.id=e,this.component=i,this.api=t,this._height=0,this._width=0,this._element=document.createElement("div"),this._element.tabIndex=-1,this._element.style.outline="none",this._element.style.height="100%",this._element.style.width="100%",this._element.style.overflow="hidden";const{onDidFocus:n,onDidBlur:o}=f(this._element);this.addDisposables(this.api,n((()=>{this.api._onDidChangeFocus.fire({isFocused:!0})})),o((()=>{this.api._onDidChangeFocus.fire({isFocused:!1})})))}focus(){this.api._onFocusEvent.fire()}layout(e,i){this._width=e,this._height=i,this.api._onDidDimensionChange.fire({width:e,height:i}),this.part&&this._params&&this.part.update(this._params.params)}init(e){this._params=e,this.part=this.getComponent()}update(e){var i,t;this._params=Object.assign(Object.assign({},this._params),{params:Object.assign(Object.assign({},null===(i=this._params)||void 0===i?void 0:i.params),e.params)}),null===(t=this.part)||void 0===t||t.update({params:this._params.params})}toJSON(){var e,i;const t=null!==(i=null===(e=this._params)||void 0===e?void 0:e.params)&&void 0!==i?i:{};return{id:this.id,component:this.component,params:Object.keys(t).length>0?t:void 0}}dispose(){var e;super.dispose(),this.api.dispose(),null===(e=this.part)||void 0===e||e.dispose()}}class ve extends me{set orientation(e){this._orientation=e}get orientation(){return this._orientation}get minimumSize(){return this.headerSize+(this.isExpanded()?this._minimumBodySize:0)}get maximumSize(){return this.headerSize+(this.isExpanded()?this._maximumBodySize:0)}get size(){return this._size}get orthogonalSize(){return this._orthogonalSize}set orthogonalSize(e){this._orthogonalSize=e}get minimumBodySize(){return this._minimumBodySize}set minimumBodySize(e){this._minimumBodySize="number"==typeof e?e:0}get maximumBodySize(){return this._maximumBodySize}set maximumBodySize(e){this._maximumBodySize="number"==typeof e?e:Number.POSITIVE_INFINITY}get headerVisible(){return this._headerVisible}set headerVisible(e){this._headerVisible=e,this.header.style.display=e?"":"none"}constructor(e,i,t,n,o,s){super(e,i,new ue(e)),this.headerComponent=t,this._onDidChangeExpansionState=new h({replay:!0}),this.onDidChangeExpansionState=this._onDidChangeExpansionState.event,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this.headerSize=22,this._orthogonalSize=0,this._size=0,this._minimumBodySize=100,this._maximumBodySize=Number.POSITIVE_INFINITY,this._isExpanded=!1,this.expandedSize=0,this.api.pane=this,this.api.initialize(this),this._isExpanded=o,this._headerVisible=s,this._onDidChangeExpansionState.fire(this.isExpanded()),this._orientation=n,this.element.classList.add("pane"),this.addDisposables(this.api.onDidSizeChange((e=>{this._onDidChange.fire({size:e.size})})),l(this.element,"mouseenter",(e=>{this.api._onMouseEnter.fire(e)})),l(this.element,"mouseleave",(e=>{this.api._onMouseLeave.fire(e)}))),this.addDisposables(this._onDidChangeExpansionState,this.onDidChangeExpansionState((e=>{this.api._onDidExpansionChange.fire({isExpanded:e})})),this.api.onDidFocusChange((e=>{this.header&&(e.isFocused?v(this.header,"focused"):m(this.header,"focused"))}))),this.renderOnce()}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}isExpanded(){return this._isExpanded}setExpanded(e){this._isExpanded!==e&&(this._isExpanded=e,e?(this.animationTimer&&clearTimeout(this.animationTimer),this.body&&this.element.appendChild(this.body)):this.animationTimer=setTimeout((()=>{var e;null===(e=this.body)||void 0===e||e.remove()}),200),this._onDidChange.fire(e?{size:this.width}:{}),this._onDidChangeExpansionState.fire(e))}layout(i,t){this._size=i,this._orthogonalSize=t;const[n,o]=this.orientation===e.Orientation.HORIZONTAL?[i,t]:[t,i];this.isExpanded()&&(this.expandedSize=n),super.layout(n,o)}init(e){var i,t;super.init(e),"number"==typeof e.minimumBodySize&&(this.minimumBodySize=e.minimumBodySize),"number"==typeof e.maximumBodySize&&(this.maximumBodySize=e.maximumBodySize),this.bodyPart=this.getBodyComponent(),this.headerPart=this.getHeaderComponent(),this.bodyPart.init(Object.assign(Object.assign({},e),{api:this.api})),this.headerPart.init(Object.assign(Object.assign({},e),{api:this.api})),null===(i=this.body)||void 0===i||i.append(this.bodyPart.element),null===(t=this.header)||void 0===t||t.append(this.headerPart.element),"boolean"==typeof e.isExpanded&&this.setExpanded(e.isExpanded)}toJSON(){const e=this._params;return Object.assign(Object.assign({},super.toJSON()),{headerComponent:this.headerComponent,title:e.title})}renderOnce(){this.header=document.createElement("div"),this.header.tabIndex=0,this.header.className="pane-header",this.header.style.height=`${this.headerSize}px`,this.header.style.lineHeight=`${this.headerSize}px`,this.header.style.minHeight=`${this.headerSize}px`,this.header.style.maxHeight=`${this.headerSize}px`,this.element.appendChild(this.header),this.body=document.createElement("div"),this.body.className="pane-body",this.element.appendChild(this.body)}getComponent(){return{update:e=>{var i,t;null===(i=this.bodyPart)||void 0===i||i.update({params:e}),null===(t=this.headerPart)||void 0===t||t.update({params:e})},dispose:()=>{var e,i;null===(e=this.bodyPart)||void 0===e||e.dispose(),null===(i=this.headerPart)||void 0===i||i.dispose()}}}}class ge extends ve{constructor(e,i,t,n,o,s,a){super(i,t,n,o,s,!0),this.accessor=e,this._onDidDrop=new h,this.onDidDrop=this._onDidDrop.event,a||this.initDragFeatures()}initDragFeatures(){if(!this.header)return;const e=this.id,i=this.accessor.id;this.header.draggable=!0,this.handler=new class extends te{getData(){return s.getInstance().setData([new o(i,e)],o.prototype),{dispose:()=>{s.getInstance().clearData(o.prototype)}}}}(this.header),this.target=new K(this.element,{acceptedTargetZones:["top","bottom"],overlayModel:{activationSize:{type:"percentage",value:50}},canDisplayOverlay:e=>{const i=r();return!(!i||i.paneId===this.id||i.viewId!==this.accessor.id)||!!this.accessor.options.showDndOverlay&&this.accessor.options.showDndOverlay({nativeEvent:e,getData:r,panel:this})}}),this.addDisposables(this._onDidDrop,this.handler,this.target,this.target.onDrop((e=>{this.onDrop(e)})))}onDrop(e){const i=r();if(!i||i.viewId!==this.accessor.id)return void this._onDidDrop.fire(Object.assign(Object.assign({},e),{panel:this,api:new Y(this.accessor),getData:r}));const t=this._params.containerApi,n=i.paneId,o=t.getPanel(n);if(!o)return void this._onDidDrop.fire(Object.assign(Object.assign({},e),{panel:this,getData:r,api:new Y(this.accessor)}));const s=t.panels,a=s.indexOf(o);let h=t.panels.indexOf(this);"left"!==e.position&&"top"!==e.position||(h=Math.max(0,h-1)),"right"!==e.position&&"bottom"!==e.position||(a>h&&h++,h=Math.min(s.length-1,h)),t.movePanel(a,h)}}class we extends pe{constructor(e,i){super(e),this._onDidConstraintsChangeInternal=new h,this.onDidConstraintsChangeInternal=this._onDidConstraintsChangeInternal.event,this._onDidConstraintsChange=new h({replay:!0}),this.onDidConstraintsChange=this._onDidConstraintsChange.event,this._onDidSizeChange=new h,this.onDidSizeChange=this._onDidSizeChange.event,this.addDisposables(this._onDidConstraintsChangeInternal,this._onDidConstraintsChange,this._onDidSizeChange),i&&this.initialize(i)}setConstraints(e){this._onDidConstraintsChangeInternal.fire(e)}setSize(e){this._onDidSizeChange.fire(e)}}class be extends me{get priority(){return this._priority}get snap(){return this._snap}get minimumWidth(){const e="function"==typeof this._minimumWidth?this._minimumWidth():this._minimumWidth;return e!==this._evaluatedMinimumWidth&&(this._evaluatedMinimumWidth=e,this.updateConstraints()),e}get minimumHeight(){const e="function"==typeof this._minimumHeight?this._minimumHeight():this._minimumHeight;return e!==this._evaluatedMinimumHeight&&(this._evaluatedMinimumHeight=e,this.updateConstraints()),e}get maximumHeight(){const e="function"==typeof this._maximumHeight?this._maximumHeight():this._maximumHeight;return e!==this._evaluatedMaximumHeight&&(this._evaluatedMaximumHeight=e,this.updateConstraints()),e}get maximumWidth(){const e="function"==typeof this._maximumWidth?this._maximumWidth():this._maximumWidth;return e!==this._evaluatedMaximumWidth&&(this._evaluatedMaximumWidth=e,this.updateConstraints()),e}get isActive(){return this.api.isActive}constructor(e,i,t){super(e,i,new we(e)),this._evaluatedMinimumWidth=0,this._evaluatedMaximumWidth=Number.MAX_SAFE_INTEGER,this._evaluatedMinimumHeight=0,this._evaluatedMaximumHeight=Number.MAX_SAFE_INTEGER,this._minimumWidth=0,this._minimumHeight=0,this._maximumWidth=Number.MAX_SAFE_INTEGER,this._maximumHeight=Number.MAX_SAFE_INTEGER,this._snap=!1,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,"number"==typeof(null==t?void 0:t.minimumWidth)&&(this._minimumWidth=t.minimumWidth),"number"==typeof(null==t?void 0:t.maximumWidth)&&(this._maximumWidth=t.maximumWidth),"number"==typeof(null==t?void 0:t.minimumHeight)&&(this._minimumHeight=t.minimumHeight),"number"==typeof(null==t?void 0:t.maximumHeight)&&(this._maximumHeight=t.maximumHeight),this.api.initialize(this),this.addDisposables(this._onDidChange,this.api.onVisibilityChange((e=>{const{isVisible:i}=e,{accessor:t}=this._params;t.setVisible(this,i)})),this.api.onActiveChange((()=>{const{accessor:e}=this._params;e.setActive(this)})),this.api.onDidConstraintsChangeInternal((e=>{"number"!=typeof e.minimumWidth&&"function"!=typeof e.minimumWidth||(this._minimumWidth=e.minimumWidth),"number"!=typeof e.minimumHeight&&"function"!=typeof e.minimumHeight||(this._minimumHeight=e.minimumHeight),"number"!=typeof e.maximumWidth&&"function"!=typeof e.maximumWidth||(this._maximumWidth=e.maximumWidth),"number"!=typeof e.maximumHeight&&"function"!=typeof e.maximumHeight||(this._maximumHeight=e.maximumHeight)})),this.api.onDidSizeChange((e=>{this._onDidChange.fire({height:e.height,width:e.width})})))}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}init(e){e.maximumHeight&&(this._maximumHeight=e.maximumHeight),e.minimumHeight&&(this._minimumHeight=e.minimumHeight),e.maximumWidth&&(this._maximumWidth=e.maximumWidth),e.minimumWidth&&(this._minimumWidth=e.minimumWidth),this._priority=e.priority,this._snap=!!e.snap,super.init(e),"boolean"==typeof e.isVisible&&this.setVisible(e.isVisible)}updateConstraints(){this.api._onDidConstraintsChange.fire({minimumWidth:this._evaluatedMinimumWidth,maximumWidth:this._evaluatedMaximumWidth,minimumHeight:this._evaluatedMinimumHeight,maximumHeight:this._evaluatedMaximumHeight})}toJSON(){const e=super.toJSON(),i=e=>e===Number.MAX_SAFE_INTEGER?void 0:e,t=e=>e<=0?void 0:e;return Object.assign(Object.assign({},e),{minimumHeight:t(this.minimumHeight),maximumHeight:i(this.maximumHeight),minimumWidth:t(this.minimumWidth),maximumWidth:i(this.maximumWidth),snap:this.snap,priority:this.priority})}}class fe extends be{get panels(){return this._model.panels}get activePanel(){return this._model.activePanel}get size(){return this._model.size}get model(){return this._model}get locked(){return this._model.locked}set locked(e){this._model.locked=e}get header(){return this._model.header}constructor(e,i,t){super(i,"groupview_default",{minimumHeight:100,minimumWidth:100}),this._model=new re(this.element,e,i,t,this)}initialize(){this._model.initialize()}setActive(e){super.setActive(e),this.model.setActive(e)}layout(e,i){super.layout(e,i),this.model.layout(e,i)}getComponent(){return this._model}toJSON(){return this.model.toJSON()}}function _e(e){return!!e.referencePanel}function De(e){return!!e.referenceGroup}function ye(e){return!!e.referencePanel}function Ce(e){return!!e.referenceGroup}class ze extends we{get title(){return this.panel.title}get isGroupActive(){var e;return!!(null===(e=this.group)||void 0===e?void 0:e.isActive)}set group(e){const i=this.isGroupActive;this._group=e,this._onDidGroupChange.fire(),this._group&&(this.disposable.value=this._group.api.onDidActiveChange((()=>{this._onDidActiveGroupChange.fire()})),this.isGroupActive!==i&&this._onDidActiveGroupChange.fire())}get group(){return this._group}constructor(e,i){super(e.id),this.panel=e,this._onDidTitleChange=new h,this.onDidTitleChange=this._onDidTitleChange.event,this._onDidActiveGroupChange=new h,this.onDidActiveGroupChange=this._onDidActiveGroupChange.event,this._onDidGroupChange=new h,this.onDidGroupChange=this._onDidGroupChange.event,this.disposable=new u,this.initialize(e),this._group=i,this.addDisposables(this.disposable,this._onDidTitleChange,this._onDidGroupChange,this._onDidActiveGroupChange)}setTitle(e){this.panel.update({params:{title:e}})}close(){this.group.model.closePanel(this.panel)}}class xe extends c{get params(){return this._params}get title(){return this._title}get group(){return this._group}constructor(e,i,t,n,o){super(),this.id=e,this.containerApi=t,this.view=o,this._title="",this._group=n,this.api=new ze(this,this._group),this.addDisposables(this.api.onActiveChange((()=>{i.setActivePanel(this)})),this.api.onDidSizeChange((e=>{this.group.api.setSize(e)})))}init(e){var i;this._params=e.params,this.setTitle(e.title),null===(i=this.view)||void 0===i||i.init(Object.assign(Object.assign({},e),{api:this.api,containerApi:this.containerApi}))}focus(){this.api._onFocusEvent.fire()}toJSON(){return{id:this.id,contentComponent:this.view.contentComponent,tabComponent:this.view.tabComponent,params:Object.keys(this._params||{}).length>0?this._params:void 0,title:this.title}}setTitle(e){var i,t;e!==(null===(i=this._params)||void 0===i?void 0:i.title)&&(this._title=e,null===(t=this.view)||void 0===t||t.update({params:{params:this._params,title:this.title}}),this.api._onDidTitleChange.fire({title:e}))}update(e){var i;const t=e.params;this._params=Object.assign(Object.assign({},this._params||{}),e.params.params),t.title!==this.title&&(this._title=t.title,this.api._onDidTitleChange.fire({title:this.title})),null===(i=this.view)||void 0===i||i.update({params:{params:this._params,title:this.title}})}updateParentGroup(e,i){this._group=e,this.api.group=e;const t=this._group.model.isPanelActive(this);this.api._onDidActiveChange.fire({isActive:i&&t}),this.api._onDidVisibilityChange.fire({isVisible:t}),this.view.updateParentGroup(this._group,this._group.model.isPanelActive(this))}layout(e,i){var t;this.api._onDidDimensionChange.fire({width:e,height:i-(this.group.model.header.height||0)}),null===(t=this.view)||void 0===t||t.layout(e,i)}dispose(){var e;this.api.dispose(),null===(e=this.view)||void 0===e||e.dispose()}}const Se=e=>{const i=document.createElementNS("http://www.w3.org/2000/svg","svg");i.setAttributeNS(null,"height",e.height),i.setAttributeNS(null,"width",e.width),i.setAttributeNS(null,"viewBox",e.viewbox),i.setAttributeNS(null,"aria-hidden","false"),i.setAttributeNS(null,"focusable","false"),i.classList.add("dockview-svg");const t=document.createElementNS("http://www.w3.org/2000/svg","path");return t.setAttributeNS(null,"d",e.path),i.appendChild(t),i},Pe=()=>Se({width:"11",height:"11",viewbox:"0 0 28 28",path:"M2.1 27.3L0 25.2L11.55 13.65L0 2.1L2.1 0L13.65 11.55L25.2 0L27.3 2.1L15.75 13.65L27.3 25.2L25.2 27.3L13.65 15.75L2.1 27.3Z"});class Ee extends c{get element(){return this._element}constructor(){super(),this.params={},this._element=document.createElement("div"),this._element.className="default-tab",this._content=document.createElement("div"),this._content.className="tab-content",this._actionContainer=document.createElement("div"),this._actionContainer.className="action-container",this._list=document.createElement("ul"),this._list.className="tab-list",this.action=document.createElement("div"),this.action.className="tab-action",this.action.appendChild(Pe()),this._element.appendChild(this._content),this._element.appendChild(this._actionContainer),this._actionContainer.appendChild(this._list),this._list.appendChild(this.action),this.addDisposables(l(this._actionContainer,"mousedown",(e=>{e.preventDefault()}))),this.render()}update(e){this.params=Object.assign(Object.assign({},this.params),e.params),this.render()}focus(){}init(e){this.params=e,this._content.textContent=e.title,l(this.action,"click",(e=>{e.preventDefault(),this.params.api.close()}))}onGroupChange(e){this.render()}onPanelVisibleChange(e){this.render()}layout(e,i){}render(){this._content.textContent!==this.params.title&&(this._content.textContent=this.params.title)}}class Ae{get content(){return this._content}get tab(){return this._tab}constructor(e,i,t,n){var o;this.accessor=e,this.id=i,this.contentComponent=t,this.tabComponent=n,this._group=null,this._isPanelVisible=null,this._content=this.createContentComponent(this.id,t),this._tab=null!==(o=this.createTabComponent(this.id,n))&&void 0!==o?o:new Ee}init(e){this.content.init(Object.assign(Object.assign({},e),{tab:this.tab})),this.tab.init(e)}updateParentGroup(e,i){e!==this._group&&(this._group=e,this._content.onGroupChange&&this._content.onGroupChange(e),this._tab.onGroupChange&&this._tab.onGroupChange(e)),i!==this._isPanelVisible&&(this._isPanelVisible=i,this._content.onPanelVisibleChange&&this._content.onPanelVisibleChange(i),this._tab.onPanelVisibleChange&&this._tab.onPanelVisibleChange(i))}layout(e,i){var t,n;null===(n=(t=this.content).layout)||void 0===n||n.call(t,e,i)}update(e){var i,t,n,o;null===(t=(i=this.content).update)||void 0===t||t.call(i,e),null===(o=(n=this.tab).update)||void 0===o||o.call(n,e)}dispose(){var e,i,t,n;null===(i=(e=this.content).dispose)||void 0===i||i.call(e),null===(n=(t=this.tab).dispose)||void 0===n||n.call(t)}createContentComponent(e,i){var t;return D(e,i,this.accessor.options.components||{},this.accessor.options.frameworkComponents,null===(t=this.accessor.options.frameworkComponentFactory)||void 0===t?void 0:t.content)}createTabComponent(e,i){var t;return D(e,i,this.accessor.options.tabComponents||{},this.accessor.options.frameworkTabComponents,null===(t=this.accessor.options.frameworkComponentFactory)||void 0===t?void 0:t.tab,(()=>new Ee))}}class ke{constructor(e){this.layout=e}fromJSON(e,i){var t,n,o;const s=e.id,a=e.params,r=e.title,h=e.view,d=h?h.content.id:e.contentComponent||"unknown",l=h?null===(t=h.tab)||void 0===t?void 0:t.id:e.tabComponent;l?D(s,l,this.layout.options.tabComponents,this.layout.options.frameworkTabComponents,null===(n=this.layout.options.frameworkComponentFactory)||void 0===n?void 0:n.tab,(()=>new Ee)):this.layout.options.defaultTabComponent?D(s,this.layout.options.defaultTabComponent,this.layout.options.tabComponents,this.layout.options.frameworkTabComponents,null===(o=this.layout.options.frameworkComponentFactory)||void 0===o?void 0:o.tab,(()=>new Ee)):new Ee;const p=new Ae(this.layout,s,d,l),c=new xe(s,this.layout,new X(this.layout),i,p);return c.init({title:r||s,params:a||{}}),c}}class Oe extends c{get element(){return this._element}constructor(){super(),this._element=document.createElement("div"),this._element.className="watermark";const e=document.createElement("div");e.className="watermark-title";const i=document.createElement("span");i.style.flexGrow="1";const t=document.createElement("div");t.className="watermark-content",this._element.appendChild(e),this._element.appendChild(t);const n=document.createElement("div");n.className="actions-container";const o=document.createElement("div");o.className="close-action",o.appendChild(Pe()),n.appendChild(o),e.appendChild(i),e.appendChild(n),this.addDisposables(l(o,"click",(e=>{var i;e.preventDefault(),this.group&&(null===(i=this.params)||void 0===i||i.containerApi.removeGroup(this.group))})))}update(e){}focus(){}layout(e,i){}init(e){this.render()}updateParentGroup(e,i){this.group=e,this.render()}dispose(){super.dispose()}render(){const e=!!(this.params&&this.params.containerApi.size<=1);g(this.element,"has-actions",e)}}class Ie extends c{get element(){return this._element}constructor(){super(),this._expandedIcon=Se({width:"11",height:"11",viewbox:"0 0 24 15",path:"M12 14.15L0 2.15L2.15 0L12 9.9L21.85 0.0499992L24 2.2L12 14.15Z"}),this._collapsedIcon=Se({width:"11",height:"11",viewbox:"0 0 15 25",path:"M2.15 24.1L0 21.95L9.9 12.05L0 2.15L2.15 0L14.2 12.05L2.15 24.1Z"}),this.disposable=new u,this.apiRef={api:null},this._element=document.createElement("div"),this.element.className="default-header",this._content=document.createElement("span"),this._expander=document.createElement("div"),this._expander.className="dockview-pane-header-icon",this.element.appendChild(this._expander),this.element.appendChild(this._content),this.addDisposables(l(this._element,"click",(()=>{var e;null===(e=this.apiRef.api)||void 0===e||e.setExpanded(!this.apiRef.api.isExpanded)})))}init(e){this.apiRef.api=e.api,this._content.textContent=e.title,this.updateIcon(),this.disposable.value=e.api.onDidExpansionChange((()=>{this.updateIcon()}))}updateIcon(){var e;const i=!!(null===(e=this.apiRef.api)||void 0===e?void 0:e.isExpanded);g(this._expander,"collapsed",!i),i?(this._expander.contains(this._collapsedIcon)&&this._collapsedIcon.remove(),this._expander.contains(this._expandedIcon)||this._expander.appendChild(this._expandedIcon)):(this._expander.contains(this._expandedIcon)&&this._expandedIcon.remove(),this._expander.contains(this._collapsedIcon)||this._expander.appendChild(this._collapsedIcon))}update(e){}dispose(){this.disposable.dispose(),super.dispose()}}const Ve=P();class Ne extends ge{constructor(e){super(e.accessor,e.id,e.component,e.headerComponent,e.orientation,e.isExpanded,e.disableDnd),this.options=e}getBodyComponent(){return this.options.body}getHeaderComponent(){return this.options.header}}e.BaseGrid=le,e.ContentContainer=ee,e.DefaultDockviewDeserialzier=ke,e.DefaultTab=Ee,e.DockviewApi=X,e.DockviewComponent=class extends le{get orientation(){return this.gridview.orientation}get totalPanels(){return this.panels.length}get panels(){return this.groups.flatMap((e=>e.panels))}get options(){return this._options}get activePanel(){const e=this.activeGroup;if(e)return e.activePanel}set tabHeight(e){this.options.tabHeight=e,this._groups.forEach((i=>{i.value.model.header.height=e}))}get tabHeight(){return this.options.tabHeight}constructor(i,t){super(i,{proportionalLayout:!0,orientation:t.orientation||e.Orientation.HORIZONTAL,styles:t.styles}),this.nextGroupId=P(),this._deserializer=new ke(this),this.watermark=null,this._onDidDrop=new h,this.onDidDrop=this._onDidDrop.event,this._onDidRemovePanel=new h,this.onDidRemovePanel=this._onDidRemovePanel.event,this._onDidAddPanel=new h,this.onDidAddPanel=this._onDidAddPanel.event,this._onDidLayoutFromJSON=new h,this.onDidLayoutFromJSON=this._onDidLayoutFromJSON.event,this._onDidActivePanelChange=new h,this.onDidActivePanelChange=this._onDidActivePanelChange.event,this.element.classList.add("dv-dockview"),this.addDisposables(this._onDidDrop,e.DockviewEvent.any(this.onDidAddGroup,this.onDidRemoveGroup)((()=>{this.updateWatermark()})),e.DockviewEvent.any(this.onDidAddPanel,this.onDidRemovePanel,this.onDidActivePanelChange)((()=>{this._bufferOnDidLayoutChange.fire()}))),this._options=t,this.options.components||(this.options.components={}),this.options.frameworkComponents||(this.options.frameworkComponents={}),this.options.frameworkTabComponents||(this.options.frameworkTabComponents={}),this.options.tabComponents||(this.options.tabComponents={}),this.options.watermarkComponent||this.options.watermarkFrameworkComponent||(this.options.watermarkComponent=Oe);const n=new K(this.element,{canDisplayOverlay:(i,t)=>{const n=a();return n?n.viewId===this.id:!!this.options.showDndOverlay&&this.options.showDndOverlay({nativeEvent:i,position:t,target:e.DockviewDropTargets.Edge,getData:a})},acceptedTargetZones:["top","bottom","left","right"],overlayModel:{activationSize:{type:"pixels",value:10},size:{type:"pixels",value:20}}});this.addDisposables(n,n.onDrop((e=>{const i=a();i?this.moveGroupOrPanel(this.orthogonalize(e.position),i.groupId,i.panelId||void 0,"center"):this._onDidDrop.fire(Object.assign(Object.assign({},e),{api:this._api,group:null,getData:a}))}))),this._api=new X(this),this.updateWatermark()}orthogonalize(i){switch(i){case"top":case"bottom":this.gridview.orientation===e.Orientation.HORIZONTAL&&this.gridview.insertOrthogonalSplitviewAtRoot();break;case"left":case"right":this.gridview.orientation===e.Orientation.VERTICAL&&this.gridview.insertOrthogonalSplitviewAtRoot()}switch(i){case"top":case"left":return this.createGroupAtLocation([0]);case"bottom":case"right":return this.createGroupAtLocation([this.gridview.length]);default:throw new Error(`unsupported position ${i}`)}}updateOptions(e){const i="string"==typeof e.orientation&&this.gridview.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),i&&(this.gridview.orientation=e.orientation),this.layout(this.gridview.width,this.gridview.height,!0)}focus(){var e;null===(e=this.activeGroup)||void 0===e||e.focus()}getGroupPanel(e){return this.panels.find((i=>i.id===e))}setActivePanel(e){this.doSetGroupActive(e.group),e.group.model.openPanel(e)}moveToNext(e={}){var i;if(!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}if(e.includePanel&&e.group&&e.group.activePanel!==e.group.panels[e.group.panels.length-1])return void e.group.model.moveToNext({suppressRoll:!0});const t=F(e.group.element),n=null===(i=this.gridview.next(t))||void 0===i?void 0:i.view;this.doSetGroupActive(n)}moveToPrevious(e={}){var i;if(!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}if(e.includePanel&&e.group&&e.group.activePanel!==e.group.panels[0])return void e.group.model.moveToPrevious({suppressRoll:!0});const t=F(e.group.element),n=null===(i=this.gridview.previous(t))||void 0===i?void 0:i.view;n&&this.doSetGroupActive(n)}toJSON(){var e;return{grid:this.gridview.serialize(),panels:this.panels.reduce(((e,i)=>(e[i.id]=i.toJSON(),e)),{}),activeGroup:null===(e=this.activeGroup)||void 0===e?void 0:e.id,options:{tabHeight:this.tabHeight}}}fromJSON(e){this.clear();const{grid:i,panels:t,options:n,activeGroup:o}=e;if("number"==typeof(null==n?void 0:n.tabHeight)&&(this.tabHeight=n.tabHeight),"branch"!==i.root.type||!Array.isArray(i.root.data))throw new Error("root must be of type branch");if(this.gridview.deserialize(i,{fromJSON:e=>{const{id:i,locked:n,hideHeader:o,views:s,activeView:a}=e.data,r=this.createGroup({id:i,locked:!!n,hideHeader:!!o});this._onDidAddGroup.fire(r);for(const e of s){const i=this._deserializer.fromJSON(t[e],r),n="string"==typeof a&&a===i.id;r.model.openPanel(i,{skipSetPanelActive:!n,skipSetGroupActive:!0})}return!r.activePanel&&r.panels.length>0&&r.model.openPanel(r.panels[r.panels.length-1],{skipSetGroupActive:!0}),r}}),"string"==typeof o){const e=this.getPanel(o);e&&this.doSetGroupActive(e)}this.gridview.layout(this.width,this.height),this._onDidLayoutFromJSON.fire()}clear(){const e=Array.from(this._groups.values()).map((e=>e.value)),i=!!this.activeGroup,t=!!this.activePanel;for(const i of e)this.removeGroup(i,!0);i&&this.doSetGroupActive(void 0),t&&this._onDidActivePanelChange.fire(void 0),this.gridview.clear()}closeAllGroups(){for(const e of this._groups.entries()){const[i,t]=e;t.value.model.closeAllPanels()}}addPanel(e){var i,t;if(this.panels.find((i=>i.id===e.id)))throw new Error(`panel with id ${e.id} already exists`);let n,o;if(e.position)if(_e(e.position)){const i="string"==typeof e.position.referencePanel?this.getGroupPanel(e.position.referencePanel):e.position.referencePanel;if(!i)throw new Error(`referencePanel ${e.position.referencePanel} does not exist`);n=this.findGroup(i)}else{if(!De(e.position)){const i=this.orthogonalize(q(e.position.direction)),t=this.createPanel(e,i);return i.model.openPanel(t),t}if(n="string"==typeof e.position.referenceGroup?null===(i=this._groups.get(e.position.referenceGroup))||void 0===i?void 0:i.value:e.position.referenceGroup,!n)throw new Error(`referencePanel ${e.position.referenceGroup} does not exist`)}else n=this.activeGroup;if(n){const i=de((null===(t=e.position)||void 0===t?void 0:t.direction)||"within");if("center"===i)o=this.createPanel(e,n),n.model.openPanel(o);else{const t=F(n.element),s=W(this.gridview.orientation,t,i),a=this.createGroupAtLocation(s);o=this.createPanel(e,a),a.model.openPanel(o)}}else{const i=this.createGroupAtLocation();o=this.createPanel(e,i),i.model.openPanel(o)}return o}removePanel(e,i={removeEmptyGroup:!0,skipDispose:!1}){const t=e.group;if(!t)throw new Error(`cannot remove panel ${e.id}. it's missing a group.`);t.model.removePanel(e),e.dispose(),0===t.size&&i.removeEmptyGroup&&this.removeGroup(t)}createWatermarkComponent(){var e;return D("watermark-id","watermark-name",this.options.watermarkComponent?{"watermark-name":this.options.watermarkComponent}:{},this.options.watermarkFrameworkComponent?{"watermark-name":this.options.watermarkFrameworkComponent}:{},null===(e=this.options.frameworkComponentFactory)||void 0===e?void 0:e.watermark)}updateWatermark(){var e,i;if(0===this.groups.length){if(!this.watermark){this.watermark=this.createWatermarkComponent(),this.watermark.init({containerApi:new X(this)});const e=document.createElement("div");e.className="dv-watermark-container",e.appendChild(this.watermark.element),this.element.appendChild(e)}}else this.watermark&&(this.watermark.element.parentElement.remove(),null===(i=(e=this.watermark).dispose)||void 0===i||i.call(e),this.watermark=null)}addGroup(e){var i;const t=this.createGroup();if(e){let n;if(ye(e)){const i="string"==typeof e.referencePanel?this.panels.find((i=>i.id===e.referencePanel)):e.referencePanel;if(!i)throw new Error(`reference panel ${e.referencePanel} does not exist`);if(n=this.findGroup(i),!n)throw new Error(`reference group for reference panel ${e.referencePanel} does not exist`)}else{if(!Ce(e)){return this.orthogonalize(q(e.direction))}if(n="string"==typeof e.referenceGroup?null===(i=this._groups.get(e.referenceGroup))||void 0===i?void 0:i.value:e.referenceGroup,!n)throw new Error(`reference group ${e.referenceGroup} does not exist`)}const o=de(e.direction||"within"),s=F(n.element),a=W(this.gridview.orientation,s,o);return this.doAddGroup(t,a),t}return this.doAddGroup(t),t}removeGroup(e,i=!1){const t=[...e.panels];for(const e of t)this.removePanel(e,{removeEmptyGroup:!1,skipDispose:!1});super.doRemoveGroup(e,{skipActive:i})}moveGroupOrPanel(e,i,t,n,o){var s;const a=i?null===(s=this._groups.get(i))||void 0===s?void 0:s.value:void 0;if(void 0!==t)if(n&&"center"!==n){const i=F(e.element),o=W(this.gridview.orientation,i,n);if(a&&a.size<2){const[i,t]=y(o),s=F(a.element),[r,h]=y(s);if(C(r,i))this.gridview.moveView(r,h,t);else{const i=this.doRemoveGroup(a,{skipActive:!0,skipDispose:!0}),t=F(e.element),o=W(this.gridview.orientation,t,n);this.doAddGroup(i,o)}}else{const e=(null==a?void 0:a.model.removePanel(t))||this.panels.find((e=>e.id===t));if(!e)throw new Error(`No panel with id ${t}`);const o=W(this.gridview.orientation,i,n);this.createGroupAtLocation(o).model.openPanel(e)}}else{const i=(null==a?void 0:a.model.removePanel(t))||this.panels.find((e=>e.id===t));if(!i)throw new Error(`No panel with id ${t}`);0===(null==a?void 0:a.model.size)&&this.doRemoveGroup(a),e.model.openPanel(i,{index:o})}else a&&this.moveGroup(a,e,n)}moveGroup(i,t,n){if(i)if(n&&"center"!==n){this.gridview.removeView(F(i.element));const o=F(t.element),s=W(this.gridview.orientation,o,n);this.gridview.addView(i,e.Sizing.Distribute,s)}else{const e=i.activePanel,n=[...i.panels].map((e=>i.model.removePanel(e.id)));0===(null==i?void 0:i.model.size)&&this.doRemoveGroup(i);for(const i of n)t.model.openPanel(i,{skipSetPanelActive:i!==e})}}doSetGroupActive(e,i){var t,n;const o=this._activeGroup===e;super.doSetGroupActive(e,i),!o&&(null===(t=this._activeGroup)||void 0===t?void 0:t.activePanel)&&this._onDidActivePanelChange.fire(null===(n=this._activeGroup)||void 0===n?void 0:n.activePanel)}createGroup(e){e||(e={tabHeight:this.tabHeight}),"number"!=typeof e.tabHeight&&(e.tabHeight=this.tabHeight);let i=null==e?void 0:e.id;if(i&&this._groups.has(e.id)&&(console.warn(`Duplicate group id ${null==e?void 0:e.id}. reassigning group id to avoid errors`),i=void 0),!i)for(i=this.nextGroupId.next();this._groups.has(i);)i=this.nextGroupId.next();const t=new fe(this,i,e);if(t.init({params:{},accessor:null}),!this._groups.has(t.id)){const e=new c(t.model.onMove((e=>{const{groupId:i,itemId:n,target:o,index:s}=e;this.moveGroupOrPanel(t,i,n,o,s)})),t.model.onDidDrop((e=>{this._onDidDrop.fire(Object.assign(Object.assign({},e),{api:this._api,group:t}))})),t.model.onDidAddPanel((e=>{this._onDidAddPanel.fire(e.panel)})),t.model.onDidRemovePanel((e=>{this._onDidRemovePanel.fire(e.panel)})),t.model.onDidActivePanelChange((e=>{this._onDidActivePanelChange.fire(e.panel)})));this._groups.set(t.id,{value:t,disposable:e})}return t.initialize(),"number"==typeof this.options.tabHeight&&(t.model.header.height=this.options.tabHeight),t}createPanel(e,i){const t=e.component,n=e.tabComponent||this.options.defaultTabComponent,o=new Ae(this,e.id,t,n),s=new xe(e.id,this,this._api,i,o);return s.init({title:e.title||e.id,params:(null==e?void 0:e.params)||{}}),s}createGroupAtLocation(e=[0]){const i=this.createGroup();return this.doAddGroup(i,e),i}findGroup(e){var i;return null===(i=Array.from(this._groups.values()).find((i=>i.value.model.containsPanel(e))))||void 0===i?void 0:i.value}dispose(){super.dispose(),this._onDidActivePanelChange.dispose(),this._onDidAddPanel.dispose(),this._onDidRemovePanel.dispose(),this._onDidLayoutFromJSON.dispose()}},e.DockviewCompositeDisposable=c,e.DockviewEmitter=h,e.DockviewGroupPanel=fe,e.DockviewGroupPanelModel=re,e.DockviewMutableDisposable=u,e.DockviewPanel=xe,e.DraggablePaneviewPanel=ge,e.Gridview=U,e.GridviewApi=class{get minimumHeight(){return this.component.minimumHeight}get maximumHeight(){return this.component.maximumHeight}get minimumWidth(){return this.component.minimumWidth}get maximumWidth(){return this.component.maximumWidth}get width(){return this.component.width}get height(){return this.component.height}get onDidLayoutChange(){return this.component.onDidLayoutChange}get onDidAddPanel(){return this.component.onDidAddGroup}get onDidRemovePanel(){return this.component.onDidRemoveGroup}get onDidActivePanelChange(){return this.component.onDidActiveGroupChange}get onDidLayoutFromJSON(){return this.component.onDidLayoutFromJSON}get panels(){return this.component.groups}get orientation(){return this.component.orientation}set orientation(e){this.component.updateOptions({orientation:e})}constructor(e){this.component=e}focus(){this.component.focus()}layout(e,i,t=!1){this.component.layout(e,i,t)}addPanel(e){return this.component.addPanel(e)}removePanel(e,i){this.component.removePanel(e,i)}movePanel(e,i){this.component.movePanel(e,i)}getPanel(e){return this.component.getPanel(e)}fromJSON(e){return this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}clear(){this.component.clear()}},e.GridviewComponent=class extends le{get orientation(){return this.gridview.orientation}set orientation(e){this.gridview.orientation=e}get options(){return this._options}get deserializer(){return this._deserializer}set deserializer(e){this._deserializer=e}constructor(e,i){super(e,{proportionalLayout:i.proportionalLayout,orientation:i.orientation,styles:i.styles}),this._onDidLayoutfromJSON=new h,this.onDidLayoutFromJSON=this._onDidLayoutfromJSON.event,this._options=i,this.options.components||(this.options.components={}),this.options.frameworkComponents||(this.options.frameworkComponents={})}updateOptions(e){const i="string"==typeof e.orientation&&this.gridview.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),i&&(this.gridview.orientation=e.orientation),this.layout(this.gridview.width,this.gridview.height,!0)}removePanel(e){this.removeGroup(e)}toJSON(){var e;return{grid:this.gridview.serialize(),activePanel:null===(e=this.activeGroup)||void 0===e?void 0:e.id}}setVisible(e,i){this.gridview.setViewVisible(F(e.element),i)}setActive(e){this._groups.forEach(((i,t)=>{i.value.setActive(e===i.value)}))}focus(){var e;null===(e=this.activeGroup)||void 0===e||e.focus()}fromJSON(e){this.clear();const{grid:i,activePanel:t}=e,n=[];if(this.gridview.deserialize(i,{fromJSON:e=>{const{data:i}=e,t=D(i.id,i.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkComponentFactory?{createComponent:this.options.frameworkComponentFactory.createComponent}:void 0);return n.push((()=>t.init({params:i.params,minimumWidth:i.minimumWidth,maximumWidth:i.maximumWidth,minimumHeight:i.minimumHeight,maximumHeight:i.maximumHeight,priority:i.priority,snap:!!i.snap,accessor:this,isVisible:e.visible}))),this._onDidAddGroup.fire(t),this.registerPanel(t),t}}),this.layout(this.width,this.height,!0),n.forEach((e=>e())),"string"==typeof t){const e=this.getPanel(t);e&&this.doSetGroupActive(e)}this._onDidLayoutfromJSON.fire()}clear(){const e=this.activeGroup,i=Array.from(this._groups.values());for(const e of i)e.disposable.dispose(),this.doRemoveGroup(e.value,{skipActive:!0});e&&this.doSetGroupActive(void 0),this.gridview.clear()}movePanel(e,i){var t;let n;const o=this.gridview.remove(e),s=null===(t=this._groups.get(i.reference))||void 0===t?void 0:t.value;if(!s)throw new Error(`reference group ${i.reference} does not exist`);const a=de(i.direction);if("center"===a)throw new Error(`${a} not supported as an option`);{const e=F(s.element);n=W(this.gridview.orientation,e,a)}this.doAddGroup(o,n,i.size)}addPanel(e){var i,t;let n=e.location||[0];if(null===(i=e.position)||void 0===i?void 0:i.referencePanel){const i=null===(t=this._groups.get(e.position.referencePanel))||void 0===t?void 0:t.value;if(!i)throw new Error(`reference group ${e.position.referencePanel} does not exist`);const o=de(e.position.direction);if("center"===o)throw new Error(`${o} not supported as an option`);{const e=F(i.element);n=W(this.gridview.orientation,e,o)}}const o=D(e.id,e.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkComponentFactory?{createComponent:this.options.frameworkComponentFactory.createComponent}:void 0);return o.init({params:e.params||{},minimumWidth:e.minimumWidth,maximumWidth:e.maximumWidth,minimumHeight:e.minimumHeight,maximumHeight:e.maximumHeight,priority:e.priority,snap:!!e.snap,accessor:this,isVisible:!0}),this.registerPanel(o),this.doAddGroup(o,n,e.size),o}registerPanel(e){const i=new c(e.api.onDidFocusChange((i=>{i.isFocused&&this._groups.forEach((i=>{const t=i.value;t!==e?t.setActive(!1):t.setActive(!0)}))})));this._groups.set(e.id,{value:e,disposable:i})}moveGroup(e,i,t){const n=this.getPanel(i);if(!n)throw new Error("invalid operation");const o=F(e.element),s=W(this.gridview.orientation,o,t),[a,r]=y(s),h=F(n.element),[d,l]=y(h);if(C(d,a))return void this.gridview.moveView(d,l,r);const p=this.doRemoveGroup(n,{skipActive:!0,skipDispose:!0}),c=F(e.element),u=W(this.gridview.orientation,c,t);this.doAddGroup(p,u)}removeGroup(e){super.removeGroup(e)}dispose(){super.dispose(),this._onDidLayoutfromJSON.dispose()}},e.GridviewPanel=be,e.LocalSelectionTransfer=s,e.PaneFramework=Ne,e.PaneTransfer=o,e.PanelTransfer=n,e.Paneview=L,e.PaneviewApi=Y,e.PaneviewComponent=class extends c{get id(){return this._id}get panels(){return this.paneview.getPanes()}set paneview(e){this._paneview=e,this._disposable.value=new c(this._paneview.onDidChange((()=>{this._onDidLayoutChange.fire(void 0)})),this._paneview.onDidAddView((e=>this._onDidAddView.fire(e))),this._paneview.onDidRemoveView((e=>this._onDidRemoveView.fire(e))))}get paneview(){return this._paneview}get minimumSize(){return this.paneview.minimumSize}get maximumSize(){return this.paneview.maximumSize}get height(){return this.paneview.orientation===e.Orientation.HORIZONTAL?this.paneview.orthogonalSize:this.paneview.size}get width(){return this.paneview.orientation===e.Orientation.HORIZONTAL?this.paneview.size:this.paneview.orthogonalSize}get options(){return this._options}constructor(i,t){super(),this.element=i,this._id=Ve.next(),this._disposable=new u,this._viewDisposables=new Map,this._onDidLayoutfromJSON=new h,this.onDidLayoutFromJSON=this._onDidLayoutfromJSON.event,this._onDidLayoutChange=new h,this.onDidLayoutChange=this._onDidLayoutChange.event,this._onDidDrop=new h,this.onDidDrop=this._onDidDrop.event,this._onDidAddView=new h,this.onDidAddView=this._onDidAddView.event,this._onDidRemoveView=new h,this.onDidRemoveView=this._onDidRemoveView.event,this.addDisposables(this._onDidLayoutChange,this._onDidLayoutfromJSON,this._onDidDrop,this._onDidAddView,this._onDidRemoveView),this._options=t,t.components||(t.components={}),t.frameworkComponents||(t.frameworkComponents={}),this.paneview=new L(this.element,{orientation:e.Orientation.VERTICAL}),this.addDisposables(this._disposable)}focus(){}updateOptions(e){this._options=Object.assign(Object.assign({},this.options),e)}addPanel(i){const t=D(i.id,i.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.body.createComponent}:void 0);let n;n=i.headerComponent?D(i.id,i.headerComponent,this.options.headerComponents||{},this.options.headerframeworkComponents,this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.header.createComponent}:void 0):new Ie;const o=new Ne({id:i.id,component:i.component,headerComponent:i.headerComponent,header:n,body:t,orientation:e.Orientation.VERTICAL,isExpanded:!!i.isExpanded,disableDnd:!!this.options.disableDnd,accessor:this});this.doAddPanel(o);const s="number"==typeof i.size?i.size:e.Sizing.Distribute,a="number"==typeof i.index?i.index:void 0;return o.init({params:i.params||{},minimumBodySize:i.minimumBodySize,maximumBodySize:i.maximumBodySize,isExpanded:i.isExpanded,title:i.title,containerApi:new Y(this)}),this.paneview.addPane(o,s,a),o.orientation=this.paneview.orientation,o}removePanel(e){const i=this.panels.findIndex((i=>i===e));this.paneview.removePane(i),this.doRemovePanel(e)}movePanel(e,i){this.paneview.moveView(e,i)}getPanel(e){return this.panels.find((i=>i.id===e))}layout(i,t){const[n,o]=this.paneview.orientation===e.Orientation.HORIZONTAL?[i,t]:[t,i];this.paneview.layout(n,o)}toJSON(){const e=e=>e===Number.MAX_SAFE_INTEGER||e===Number.POSITIVE_INFINITY?void 0:e;return{views:this.paneview.getPanes().map(((i,t)=>{return{size:this.paneview.getViewSize(t),data:i.toJSON(),minimumSize:(n=i.minimumBodySize,n<=0?void 0:n),maximumSize:e(i.maximumBodySize),expanded:i.isExpanded()};var n})),size:this.paneview.size}}fromJSON(i){this.clear();const{views:t,size:n}=i,o=[];this.paneview=new L(this.element,{orientation:e.Orientation.VERTICAL,descriptor:{size:n,views:t.map((i=>{const t=i.data,n=D(t.id,t.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.body.createComponent}:void 0);let s;s=t.headerComponent?D(t.id,t.headerComponent,this.options.headerComponents||{},this.options.headerframeworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.header.createComponent}:void 0):new Ie;const a=new Ne({id:t.id,component:t.component,headerComponent:t.headerComponent,header:s,body:n,orientation:e.Orientation.VERTICAL,isExpanded:!!i.expanded,disableDnd:!!this.options.disableDnd,accessor:this});return this.doAddPanel(a),o.push((()=>{a.init({params:t.params||{},minimumBodySize:i.minimumSize,maximumBodySize:i.maximumSize,title:t.title,isExpanded:!!i.expanded,containerApi:new Y(this)}),a.orientation=this.paneview.orientation})),setTimeout((()=>{this._onDidAddView.fire(a)}),0),{size:i.size,view:a}}))}}),this.layout(this.width,this.height),o.forEach((e=>e())),this._onDidLayoutfromJSON.fire()}clear(){for(const[e,i]of this._viewDisposables.entries())i.dispose();this._viewDisposables.clear(),this.paneview.dispose()}doAddPanel(e){const i=e.onDidDrop((e=>{this._onDidDrop.fire(e)}));this._viewDisposables.set(e.id,i)}doRemovePanel(e){const i=this._viewDisposables.get(e.id);i&&(i.dispose(),this._viewDisposables.delete(e.id))}dispose(){super.dispose();for(const[e,i]of this._viewDisposables.entries())i.dispose();this._viewDisposables.clear(),this.paneview.dispose()}},e.PaneviewPanel=ve,e.Splitview=N,e.SplitviewApi=class{get minimumSize(){return this.component.minimumSize}get maximumSize(){return this.component.maximumSize}get height(){return this.component.height}get width(){return this.component.width}get length(){return this.component.length}get orientation(){return this.component.orientation}get panels(){return this.component.panels}get onDidLayoutFromJSON(){return this.component.onDidLayoutFromJSON}get onDidLayoutChange(){return this.component.onDidLayoutChange}get onDidAddView(){return this.component.onDidAddView}get onDidRemoveView(){return this.component.onDidRemoveView}constructor(e){this.component=e}updateOptions(e){this.component.updateOptions(e)}removePanel(e,i){this.component.removePanel(e,i)}focus(){this.component.focus()}getPanel(e){return this.component.getPanel(e)}layout(e,i){return this.component.layout(e,i)}addPanel(e){return this.component.addPanel(e)}movePanel(e,i){this.component.movePanel(e,i)}fromJSON(e){this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}clear(){this.component.clear()}},e.SplitviewComponent=class extends c{get panels(){return this.splitview.getViews()}get options(){return this._options}get length(){return this._panels.size}get orientation(){return this.splitview.orientation}get splitview(){return this._splitview}set splitview(e){this._splitview=e,this._disposable.value=new c(this._splitview.onDidSashEnd((()=>{this._onDidLayoutChange.fire(void 0)})),this._splitview.onDidAddView((e=>this._onDidAddView.fire(e))),this._splitview.onDidRemoveView((e=>this._onDidRemoveView.fire(e))))}get minimumSize(){return this.splitview.minimumSize}get maximumSize(){return this.splitview.maximumSize}get height(){return this.splitview.orientation===e.Orientation.HORIZONTAL?this.splitview.orthogonalSize:this.splitview.size}get width(){return this.splitview.orientation===e.Orientation.HORIZONTAL?this.splitview.size:this.splitview.orthogonalSize}constructor(e,i){super(),this.element=e,this._disposable=new u,this._panels=new Map,this._onDidLayoutfromJSON=new h,this.onDidLayoutFromJSON=this._onDidLayoutfromJSON.event,this._onDidAddView=new h,this.onDidAddView=this._onDidAddView.event,this._onDidRemoveView=new h,this.onDidRemoveView=this._onDidRemoveView.event,this._onDidLayoutChange=new h,this.onDidLayoutChange=this._onDidLayoutChange.event,this._options=i,i.components||(i.components={}),i.frameworkComponents||(i.frameworkComponents={}),this.splitview=new N(this.element,i),this.addDisposables(this._disposable,this._onDidAddView,this._onDidLayoutfromJSON,this._onDidRemoveView,this._onDidLayoutChange)}updateOptions(e){const i="string"==typeof e.orientation&&this.options.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),i&&(this.splitview.orientation=e.orientation),this.splitview.layout(this.splitview.size,this.splitview.orthogonalSize)}focus(){var e;null===(e=this._activePanel)||void 0===e||e.focus()}movePanel(e,i){this.splitview.moveView(e,i)}setVisible(e,i){const t=this.panels.indexOf(e);this.splitview.setViewVisible(t,i)}setActive(e,i){this._activePanel=e,this.panels.filter((i=>i!==e)).forEach((e=>{e.api._onDidActiveChange.fire({isActive:!1}),i||e.focus()})),e.api._onDidActiveChange.fire({isActive:!0}),i||e.focus()}removePanel(e,i){const t=this._panels.get(e.id);if(!t)throw new Error(`unknown splitview panel ${e.id}`);t.disposable.dispose(),t.value.dispose(),this._panels.delete(e.id);const n=this.panels.findIndex((i=>i===e));this.splitview.removeView(n,i);const o=this.panels;o.length>0&&this.setActive(o[o.length-1])}getPanel(e){return this.panels.find((i=>i.id===e))}addPanel(i){if(this._panels.has(i.id))throw new Error(`panel ${i.id} already exists`);const t=D(i.id,i.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.createComponent}:void 0);t.orientation=this.splitview.orientation,t.init({params:i.params||{},minimumSize:i.minimumSize,maximumSize:i.maximumSize,snap:i.snap,priority:i.priority,accessor:this});const n="number"==typeof i.size?i.size:e.Sizing.Distribute,o="number"==typeof i.index?i.index:void 0;return this.splitview.addView(t,n,o),this.doAddView(t),this.setActive(t),t}layout(i,t){const[n,o]=this.splitview.orientation===e.Orientation.HORIZONTAL?[i,t]:[t,i];this.splitview.layout(n,o)}doAddView(e){const i=e.api.onDidFocusChange((i=>{i.isFocused&&this.setActive(e,!0)}));this._panels.set(e.id,{disposable:i,value:e})}toJSON(){var e;return{views:this.splitview.getViews().map(((e,i)=>({size:this.splitview.getViewSize(i),data:e.toJSON(),snap:!!e.snap,priority:e.priority}))),activeView:null===(e=this._activePanel)||void 0===e?void 0:e.id,size:this.splitview.size,orientation:this.splitview.orientation}}fromJSON(e){this.clear();const{views:i,orientation:t,size:n,activeView:o}=e,s=[];if(this.splitview=new N(this.element,{orientation:t,proportionalLayout:this.options.proportionalLayout,descriptor:{size:n,views:i.map((e=>{const i=e.data;if(this._panels.has(i.id))throw new Error(`panel ${i.id} already exists`);const n=D(i.id,i.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.createComponent}:void 0);return s.push((()=>{n.init({params:i.params||{},minimumSize:i.minimumSize,maximumSize:i.maximumSize,snap:e.snap,priority:e.priority,accessor:this})})),n.orientation=t,this.doAddView(n),setTimeout((()=>{this._onDidAddView.fire(n)}),0),{size:e.size,view:n}}))}}),this.layout(this.width,this.height),s.forEach((e=>e())),"string"==typeof o){const e=this.getPanel(o);e&&this.setActive(e)}this._onDidLayoutfromJSON.fire()}clear(){for(const[e,i]of this._panels.entries())i.disposable.dispose(),i.value.dispose();this._panels.clear(),this.splitview.dispose()}dispose(){for(const[e,i]of this._panels.entries())i.disposable.dispose(),i.value.dispose();this._panels.clear(),this.splitview.dispose(),super.dispose()}},e.SplitviewPanel=class extends me{get priority(){return this._priority}set orientation(e){this._orientation=e}get orientation(){return this._orientation}get minimumSize(){const e="function"==typeof this._minimumSize?this._minimumSize():this._minimumSize;return e!==this._evaluatedMinimumSize&&(this._evaluatedMinimumSize=e,this.updateConstraints()),e}get maximumSize(){const e="function"==typeof this._maximumSize?this._maximumSize():this._maximumSize;return e!==this._evaluatedMaximumSize&&(this._evaluatedMaximumSize=e,this.updateConstraints()),e}get snap(){return this._snap}constructor(e,i){super(e,i,new ce(e)),this._evaluatedMinimumSize=0,this._evaluatedMaximumSize=Number.POSITIVE_INFINITY,this._minimumSize=0,this._maximumSize=Number.POSITIVE_INFINITY,this._snap=!1,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this.api.initialize(this),this.addDisposables(this._onDidChange,this.api.onVisibilityChange((e=>{const{isVisible:i}=e,{accessor:t}=this._params;t.setVisible(this,i)})),this.api.onActiveChange((()=>{const{accessor:e}=this._params;e.setActive(this)})),this.api.onDidConstraintsChangeInternal((e=>{"number"!=typeof e.minimumSize&&"function"!=typeof e.minimumSize||(this._minimumSize=e.minimumSize),"number"!=typeof e.maximumSize&&"function"!=typeof e.maximumSize||(this._maximumSize=e.maximumSize),this.updateConstraints()})),this.api.onDidSizeChange((e=>{this._onDidChange.fire({size:e.size})})))}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}layout(i,t){const[n,o]=this.orientation===e.Orientation.HORIZONTAL?[i,t]:[t,i];super.layout(n,o)}init(e){super.init(e),this._priority=e.priority,e.minimumSize&&(this._minimumSize=e.minimumSize),e.maximumSize&&(this._maximumSize=e.maximumSize),e.snap&&(this._snap=e.snap)}toJSON(){return Object.assign(Object.assign({},super.toJSON()),{minimumSize:(e=this.minimumSize,e<=0?void 0:e),maximumSize:(e=>e===Number.MAX_SAFE_INTEGER||e===Number.POSITIVE_INFINITY?void 0:e)(this.maximumSize)});var e}updateConstraints(){this.api._onDidConstraintsChange.fire({maximumSize:this._evaluatedMaximumSize,minimumSize:this._evaluatedMinimumSize})}},e.Tab=ne,e.createComponent=D,e.directionToPosition=q,e.getDirectionOrientation=J,e.getGridLocation=F,e.getLocationOrientation=B,e.getPaneData=r,e.getPanelData=a,e.getRelativeLocation=W,e.indexInParent=M,e.isGridBranchNode=j,e.isGroupOptionsWithGroup=Ce,e.isGroupOptionsWithPanel=ye,e.isPanelOptionsWithGroup=De,e.isPanelOptionsWithPanel=_e,e.orthogonal=$,e.positionToDirection=function(e){switch(e){case"top":return"above";case"bottom":return"below";case"left":return"left";case"right":return"right";case"center":return"within";default:throw new Error(`invalid position '${e}'`)}},e.toTarget=de,e.watchElementResize=function(e,i){const t=new ResizeObserver((e=>{const t=e[0];i(t)}));return t.observe(e),{dispose:()=>{t.unobserve(e),t.disconnect()}}}}));
7
+ !function(e,i){"object"==typeof exports&&"undefined"!=typeof module?i(exports):"function"==typeof define&&define.amd?define(["exports"],i):i((e="undefined"!=typeof globalThis?globalThis:e||self)["dockview-core"]={})}(this,(function(e){"use strict";var i;!function(e,i){void 0===i&&(i={});var t=i.insertAt;if(e&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],o=document.createElement("style");o.type="text/css","top"===t&&n.firstChild?n.insertBefore(o,n.firstChild):n.appendChild(o),o.styleSheet?o.styleSheet.cssText=e:o.appendChild(document.createTextNode(e))}}('.dockview-svg {\n display: inline-block;\n fill: currentcolor;\n line-height: 1;\n stroke: currentcolor;\n stroke-width: 0;\n}\n.dockview-theme-dark {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: #1e1e1e;\n --dv-tabs-and-actions-container-background-color: #252526;\n --dv-activegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-activegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-inactivegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-tab-divider-color: #1e1e1e;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: #969696;\n --dv-inactivegroup-visiblepanel-tab-color: #8f8f8f;\n --dv-inactivegroup-hiddenpanel-tab-color: #626262;\n --dv-separator-border: rgb(68, 68, 68);\n --dv-paneview-header-border-color: rgba(204, 204, 204, 0.2);\n}\n\n.dockview-theme-light {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: white;\n --dv-tabs-and-actions-container-background-color: #f3f3f3;\n --dv-activegroup-visiblepanel-tab-background-color: white;\n --dv-activegroup-hiddenpanel-tab-background-color: #ececec;\n --dv-inactivegroup-visiblepanel-tab-background-color: white;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #ececec;\n --dv-tab-divider-color: white;\n --dv-activegroup-visiblepanel-tab-color: rgb(51, 51, 51);\n --dv-activegroup-hiddenpanel-tab-color: rgba(51, 51, 51, 0.7);\n --dv-inactivegroup-visiblepanel-tab-color: rgba(51, 51, 51, 0.7);\n --dv-inactivegroup-hiddenpanel-tab-color: rgba(51, 51, 51, 0.35);\n --dv-separator-border: rgba(128, 128, 128, 0.35);\n --dv-paneview-header-border-color: rgb(51, 51, 51);\n}\n\n.dockview-theme-vs {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: #1e1e1e;\n --dv-tabs-and-actions-container-background-color: #252526;\n --dv-activegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-activegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-inactivegroup-visiblepanel-tab-background-color: #1e1e1e;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #2d2d2d;\n --dv-tab-divider-color: #1e1e1e;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: #969696;\n --dv-inactivegroup-visiblepanel-tab-color: #8f8f8f;\n --dv-inactivegroup-hiddenpanel-tab-color: #626262;\n --dv-separator-border: rgb(68, 68, 68);\n --dv-paneview-header-border-color: rgba(204, 204, 204, 0.2);\n --dv-tabs-and-actions-container-background-color: #2d2d30;\n --dv-tabs-and-actions-container-height: 20px;\n --dv-tabs-and-actions-container-font-size: 11px;\n --dv-activegroup-visiblepanel-tab-background-color: #007acc;\n --dv-inactivegroup-visiblepanel-tab-background-color: #3f3f46;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: white;\n --dv-inactivegroup-visiblepanel-tab-color: white;\n --dv-inactivegroup-hiddenpanel-tab-color: white;\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container {\n box-sizing: content-box;\n border-bottom: 2px solid var(--dv-activegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container .tab.active-tab {\n border-top: 2px solid var(--dv-activegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.active-group > .tabs-and-actions-container .tab.inactive-tab {\n border-top: 2px solid var(--dv-activegroup-hiddenpanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container {\n box-sizing: content-box;\n border-bottom: 2px solid var(--dv-inactivegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container .tab.active-tab {\n border-top: 2px solid var(--dv-inactivegroup-visiblepanel-tab-background-color);\n}\n.dockview-theme-vs .groupview.inactive-group > .tabs-and-actions-container .tab.inactive-tab {\n border-top: 2px solid var(--dv-inactivegroup-hiddenpanel-tab-background-color);\n}\n\n.dockview-theme-abyss {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: #000c18;\n --dv-tabs-and-actions-container-background-color: #1c1c2a;\n --dv-activegroup-visiblepanel-tab-background-color: #000c18;\n --dv-activegroup-hiddenpanel-tab-background-color: #10192c;\n --dv-inactivegroup-visiblepanel-tab-background-color: #000c18;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #10192c;\n --dv-tab-divider-color: #2b2b4a;\n --dv-activegroup-visiblepanel-tab-color: white;\n --dv-activegroup-hiddenpanel-tab-color: rgba(255, 255, 255, 0.5);\n --dv-inactivegroup-visiblepanel-tab-color: rgba(255, 255, 255, 0.5);\n --dv-inactivegroup-hiddenpanel-tab-color: rgba(255, 255, 255, 0.25);\n --dv-separator-border: #2b2b4a;\n --dv-paneview-header-border-color: #2b2b4a;\n --dv-paneview-active-outline-color: #596f99;\n}\n\n.dockview-theme-dracula {\n --dv-background-color: black;\n --dv-paneview-active-outline-color: dodgerblue;\n --dv-tabs-and-actions-container-font-size: 13px;\n --dv-tabs-and-actions-container-height: 35px;\n --dv-drag-over-background-color: rgba(83, 89, 93, 0.5);\n --dv-drag-over-border-color: white;\n --dv-tabs-container-scrollbar-color: #888;\n --dv-icon-hover-background-color: rgba(90, 93, 94, 0.31);\n --dv-group-view-background-color: #282a36;\n --dv-tabs-and-actions-container-background-color: #191a21;\n --dv-activegroup-visiblepanel-tab-background-color: #282a36;\n --dv-activegroup-hiddenpanel-tab-background-color: #21222c;\n --dv-inactivegroup-visiblepanel-tab-background-color: #282a36;\n --dv-inactivegroup-hiddenpanel-tab-background-color: #21222c;\n --dv-tab-divider-color: #191a21;\n --dv-activegroup-visiblepanel-tab-color: rgb(248, 248, 242);\n --dv-activegroup-hiddenpanel-tab-color: rgb(98, 114, 164);\n --dv-inactivegroup-visiblepanel-tab-color: rgba(248, 248, 242, 0.5);\n --dv-inactivegroup-hiddenpanel-tab-color: rgba(98, 114, 164, 0.5);\n --dv-separator-border: #bd93f9;\n --dv-paneview-header-border-color: #bd93f9;\n --dv-paneview-active-outline-color: #6272a4;\n}\n.dockview-theme-dracula .groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n position: relative;\n}\n.dockview-theme-dracula .groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab::after {\n position: absolute;\n left: 0px;\n top: 0px;\n content: "";\n width: 100%;\n height: 1px;\n background-color: #94527e;\n z-index: 999;\n}\n.dockview-theme-dracula .groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n position: relative;\n}\n.dockview-theme-dracula .groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab::after {\n position: absolute;\n left: 0px;\n bottom: 0px;\n content: "";\n width: 100%;\n height: 1px;\n background-color: #5e3d5a;\n z-index: 999;\n}\n.drop-target {\n position: relative;\n}\n.drop-target > .drop-target-dropzone {\n position: absolute;\n left: 0px;\n top: 0px;\n height: 100%;\n width: 100%;\n z-index: 10000;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection {\n position: relative;\n box-sizing: border-box;\n height: 100%;\n width: 100%;\n background-color: var(--dv-drag-over-background-color);\n transition: top 70ms ease-out, left 70ms ease-out, width 70ms ease-out, height 70ms ease-out, opacity 0.15s ease-out;\n will-change: transform;\n pointer-events: none;\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-top {\n border-top: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-bottom {\n border-bottom: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-left {\n border-left: 1px solid var(--dv-drag-over-border-color);\n}\n.drop-target > .drop-target-dropzone > .drop-target-selection.small-right {\n border-right: 1px solid var(--dv-drag-over-border-color);\n}\n.dv-dockview {\n position: relative;\n background-color: var(--dv-group-view-background-color);\n}\n.dv-dockview .dv-watermark-container {\n position: absolute;\n top: 0px;\n left: 0px;\n height: 100%;\n width: 100%;\n}\n\n.groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n background-color: var(--dv-activegroup-visiblepanel-tab-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.groupview.active-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab {\n background-color: var(--dv-activegroup-hiddenpanel-tab-background-color);\n color: var(--dv-activegroup-hiddenpanel-tab-color);\n}\n.groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.active-tab {\n background-color: var(--dv-inactivegroup-visiblepanel-tab-background-color);\n color: var(--dv-inactivegroup-visiblepanel-tab-color);\n}\n.groupview.inactive-group > .tabs-and-actions-container > .tabs-container > .tab.inactive-tab {\n background-color: var(--dv-inactivegroup-hiddenpanel-tab-background-color);\n color: var(--dv-inactivegroup-hiddenpanel-tab-color);\n}\n\n/**\n * when a tab is dragged we lose the above stylings because they are conditional on parent elements\n * therefore we also set some stylings for the dragging event\n **/\n.tab.dv-tab-dragging {\n background-color: var(--dv-activegroup-visiblepanel-tab-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.groupview {\n display: flex;\n flex-direction: column;\n height: 100%;\n background-color: var(--dv-group-view-background-color);\n overflow: hidden;\n}\n.groupview:focus {\n outline: none;\n}\n.groupview.empty > .tabs-and-actions-container {\n display: none;\n}\n.groupview > .content-container {\n flex-grow: 1;\n overflow: hidden;\n outline: none;\n}\n.grid-view,\n.branch-node {\n height: 100%;\n width: 100%;\n}\n.pane-container {\n height: 100%;\n width: 100%;\n}\n.pane-container.animated .view {\n transition-duration: 0.15s;\n transition-timing-function: ease-out;\n}\n.pane-container .view {\n overflow: hidden;\n display: flex;\n flex-direction: column;\n padding: 0px !important;\n}\n.pane-container .view:not(:first-child)::before {\n background-color: transparent !important;\n}\n.pane-container .view:not(:first-child) .pane > .pane-header {\n border-top: 1px solid var(--dv-paneview-header-border-color);\n}\n.pane-container .view .default-header {\n background-color: var(--dv-group-view-background-color);\n color: var(--dv-activegroup-visiblepanel-tab-color);\n display: flex;\n padding: 0px 8px;\n cursor: pointer;\n}\n.pane-container .view .default-header .dockview-pane-header-icon {\n display: flex;\n justify-content: center;\n align-items: center;\n}\n.pane-container .view .default-header > span {\n padding-left: 8px;\n flex-grow: 1;\n}\n.pane-container:first-of-type > .pane > .pane-header {\n border-top: none !important;\n}\n.pane-container .pane {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n height: 100%;\n}\n.pane-container .pane .pane-header {\n box-sizing: border-box;\n user-select: none;\n position: relative;\n outline: none;\n}\n.pane-container .pane .pane-header.pane-draggable {\n cursor: pointer;\n}\n.pane-container .pane .pane-header:focus:before, .pane-container .pane .pane-header:focus-within:before {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 5;\n content: "";\n pointer-events: none;\n outline: 1px solid;\n outline-width: -1px;\n outline-style: solid;\n outline-offset: -1px;\n outline-color: var(--dv-paneview-active-outline-color);\n}\n.pane-container .pane .pane-body {\n overflow-y: auto;\n overflow-x: hidden;\n flex-grow: 1;\n position: relative;\n outline: none;\n}\n.pane-container .pane .pane-body:focus:before, .pane-container .pane .pane-body:focus-within:before {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 5;\n content: "";\n pointer-events: none;\n outline: 1px solid;\n outline-width: -1px;\n outline-style: solid;\n outline-offset: -1px;\n outline-color: var(--dv-paneview-active-outline-color);\n}\n.split-view-container {\n position: relative;\n overflow: hidden;\n height: 100%;\n width: 100%;\n}\n.split-view-container.animation .view,\n.split-view-container.animation .sash {\n transition-duration: 0.15s;\n transition-timing-function: ease-out;\n}\n.split-view-container.horizontal {\n height: 100%;\n}\n.split-view-container.horizontal > .sash-container > .sash {\n height: 100%;\n width: 4px;\n}\n.split-view-container.horizontal > .sash-container > .sash.enabled {\n cursor: ew-resize;\n}\n.split-view-container.horizontal > .sash-container > .sash.disabled {\n cursor: default;\n}\n.split-view-container.horizontal > .sash-container > .sash.maximum {\n cursor: w-resize;\n}\n.split-view-container.horizontal > .sash-container > .sash.minimum {\n cursor: e-resize;\n}\n.split-view-container.horizontal > .view-container > .view:not(:first-child)::before {\n height: 100%;\n width: 1px;\n}\n.split-view-container.vertical {\n width: 100%;\n}\n.split-view-container.vertical > .sash-container > .sash {\n width: 100%;\n height: 4px;\n}\n.split-view-container.vertical > .sash-container > .sash.enabled {\n cursor: ns-resize;\n}\n.split-view-container.vertical > .sash-container > .sash.disabled {\n cursor: default;\n}\n.split-view-container.vertical > .sash-container > .sash.maximum {\n cursor: n-resize;\n}\n.split-view-container.vertical > .sash-container > .sash.minimum {\n cursor: s-resize;\n}\n.split-view-container.vertical > .view-container > .view {\n width: 100%;\n}\n.split-view-container.vertical > .view-container > .view:not(:first-child)::before {\n height: 1px;\n width: 100%;\n}\n.split-view-container .sash-container {\n height: 100%;\n width: 100%;\n position: absolute;\n}\n.split-view-container .sash-container .sash {\n position: absolute;\n z-index: 99;\n outline: none;\n}\n.split-view-container .sash-container .sash:active {\n transition: background-color 0.1s ease-in-out;\n background-color: var(--dv-active-sash-color, transparent);\n}\n.split-view-container .sash-container .sash:hover {\n background-color: var(--dv-active-sash-color, transparent);\n transition: background-color 0.1s ease-in-out;\n transition-delay: 0.5s;\n}\n.split-view-container .view-container {\n position: relative;\n height: 100%;\n width: 100%;\n background-color: var(--dv-background-color);\n}\n.split-view-container .view-container .view {\n height: 100%;\n box-sizing: border-box;\n overflow: auto;\n position: absolute;\n}\n.split-view-container.separator-border .view:not(:first-child)::before {\n content: " ";\n position: absolute;\n top: 0;\n left: 0;\n z-index: 5;\n pointer-events: none;\n background-color: var(--dv-separator-border);\n}\n.tabs-and-actions-container {\n display: flex;\n background-color: var(--dv-tabs-and-actions-container-background-color);\n flex-shrink: 0;\n box-sizing: border-box;\n height: var(--dv-tabs-and-actions-container-height);\n font-size: var(--dv-tabs-and-actions-container-font-size);\n}\n.tabs-and-actions-container.hidden {\n display: none;\n}\n.tabs-and-actions-container.dv-single-tab.dv-full-width-single-tab .tabs-container {\n flex-grow: 1;\n}\n.tabs-and-actions-container.dv-single-tab.dv-full-width-single-tab .tabs-container .tab {\n flex-grow: 1;\n}\n.tabs-and-actions-container.dv-single-tab.dv-full-width-single-tab .void-container {\n flex-grow: 0;\n}\n.tabs-and-actions-container .void-container {\n display: flex;\n flex-grow: 1;\n cursor: grab;\n}\n.tabs-and-actions-container .tabs-container {\n display: flex;\n overflow-x: overlay;\n overflow-y: hidden;\n scrollbar-width: thin;\n /* Track */\n /* Handle */\n}\n.tabs-and-actions-container .tabs-container::-webkit-scrollbar {\n height: 3px;\n}\n.tabs-and-actions-container .tabs-container::-webkit-scrollbar-track {\n background: transparent;\n}\n.tabs-and-actions-container .tabs-container::-webkit-scrollbar-thumb {\n background: var(--dv-tabs-container-scrollbar-color);\n}\n.tabs-and-actions-container .tabs-container .tab {\n -webkit-user-drag: element;\n outline: none;\n min-width: 75px;\n cursor: pointer;\n position: relative;\n box-sizing: border-box;\n}\n.tabs-and-actions-container .tabs-container .tab:not(:first-child)::before {\n content: " ";\n position: absolute;\n top: 0;\n left: 0;\n z-index: 5;\n pointer-events: none;\n background-color: var(--dv-tab-divider-color);\n width: 1px;\n height: 100%;\n}\n.dv-dragged {\n transform: translate3d(0px, 0px, 0px); /* forces tab to be drawn on a separate layer (see https://github.com/microsoft/vscode/issues/18733) */\n}\n\n.tab {\n flex-shrink: 0;\n}\n.tab.dv-tab-dragging .tab-action {\n background-color: var(--dv-activegroup-visiblepanel-tab-color);\n}\n.tab.active-tab > .default-tab .tab-action {\n visibility: visible;\n}\n.tab.inactive-tab > .default-tab .tab-action {\n visibility: hidden;\n}\n.tab.inactive-tab > .default-tab:hover .tab-action {\n visibility: visible;\n}\n.tab .default-tab {\n position: relative;\n height: 100%;\n display: flex;\n min-width: 80px;\n align-items: center;\n padding: 0px 8px;\n white-space: nowrap;\n text-overflow: elipsis;\n}\n.tab .default-tab .tab-content {\n padding: 0px 8px;\n flex-grow: 1;\n}\n.tab .default-tab .action-container {\n text-align: right;\n display: flex;\n}\n.tab .default-tab .action-container .tab-list {\n display: flex;\n padding: 0px;\n margin: 0px;\n justify-content: flex-end;\n}\n.tab .default-tab .action-container .tab-list .tab-action {\n padding: 4px;\n display: flex;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n}\n.tab .default-tab .action-container .tab-list .tab-action:hover {\n border-radius: 2px;\n background-color: var(--dv-icon-hover-background-color);\n}\n.watermark {\n display: flex;\n width: 100%;\n}\n.watermark.has-actions .watermark-title .actions-container {\n display: none;\n}\n.watermark .watermark-title {\n height: 35px;\n width: 100%;\n display: flex;\n}\n.watermark .watermark-content {\n flex-grow: 1;\n}\n.watermark .actions-container {\n display: flex;\n align-items: center;\n padding: 0px 8px;\n}\n.watermark .actions-container .close-action {\n padding: 4px;\n display: flex;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n cursor: pointer;\n color: var(--dv-activegroup-hiddenpanel-tab-color);\n}\n.watermark .actions-container .close-action:hover {\n border-radius: 2px;\n background-color: var(--dv-icon-hover-background-color);\n}');class t{constructor(){}}class n extends t{constructor(e,i,t){super(),this.viewId=e,this.groupId=i,this.panelId=t}}class o extends t{constructor(e,i){super(),this.viewId=e,this.paneId=i}}class s{constructor(){}static getInstance(){return s.INSTANCE}hasData(e){return e&&e===this.proto}clearData(e){this.hasData(e)&&(this.proto=void 0,this.data=void 0)}getData(e){if(this.hasData(e))return this.data}setData(e,i){i&&(this.data=e,this.proto=i)}}function a(){const e=s.getInstance();if(e.hasData(n.prototype))return e.getData(n.prototype)[0]}function r(){const e=s.getInstance();if(e.hasData(o.prototype))return e.getData(o.prototype)[0]}s.INSTANCE=new s,e.DockviewEvent=void 0,(e.DockviewEvent||(e.DockviewEvent={})).any=(...e)=>i=>{const t=e.map((e=>e(i)));return{dispose:()=>{t.forEach((e=>{e.dispose()}))}}};class h{constructor(e){this.options=e,this._listeners=[],this._disposed=!1}get event(){return this._event||(this._event=e=>{var i;return(null===(i=this.options)||void 0===i?void 0:i.replay)&&void 0!==this._last&&e(this._last),this._listeners.push(e),{dispose:()=>{const i=this._listeners.indexOf(e);i>-1&&this._listeners.splice(i,1)}}}),this._event}fire(e){this._last=e;for(const i of this._listeners)i(e)}dispose(){this._listeners=[],this._disposed=!0}}function d(e,i,t,n){return e.addEventListener(i,t,n),{dispose:()=>{e.removeEventListener(i,t)}}}function l(e,i,t,n){return e.addEventListener(i,t,n),{dispose:()=>{e.removeEventListener(i,t)}}}class p{constructor(){this._onFired=new h,this.onEvent=this._onFired.event}fire(){this.timer&&clearTimeout(this.timer),this.timer=setTimeout((()=>{this._onFired.fire(),clearTimeout(this.timer)}))}dispose(){this._onFired.dispose()}}!function(e){e.NONE={dispose:()=>{}}}(i||(i={}));class c{get isDisposed(){return this._isDisposed}static from(...e){return new c(...e)}constructor(...e){this._isDisposed=!1,this.disposables=e}addDisposables(...e){e.forEach((e=>this.disposables.push(e)))}dispose(){this.disposables.forEach((e=>e.dispose())),this._isDisposed=!0}}class u{constructor(){this._disposable=i.NONE}set value(e){this._disposable&&this._disposable.dispose(),this._disposable=e}dispose(){this._disposable&&(this._disposable.dispose(),this._disposable=i.NONE)}}function m(e,i){const t=new ResizeObserver((e=>{requestAnimationFrame((()=>{const t=e[0];i(t)}))}));return t.observe(e),{dispose:()=>{t.unobserve(e),t.disconnect()}}}const v=(e,...i)=>{for(const t of i)e.classList.contains(t)&&e.classList.remove(t)},g=(e,...i)=>{for(const t of i)e.classList.contains(t)||e.classList.add(t)},w=(e,i,t)=>{const n=e.classList.contains(i);t&&!n&&e.classList.add(i),!t&&n&&e.classList.remove(i)};function b(e,i){for(;e;){if(e===i)return!0;e=e.parentNode}return!1}function f(e){return Array.prototype.slice.call(document.getElementsByTagName(e),0)}function _(e){return new D(e)}class D extends c{constructor(e){super(),this._onDidFocus=new h,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new h,this.onDidBlur=this._onDidBlur.event;let i=b(document.activeElement,e),t=!1;const n=()=>{t=!1,i||(i=!0,this._onDidFocus.fire())},o=()=>{i&&(t=!0,window.setTimeout((()=>{t&&(t=!1,i=!1,this._onDidBlur.fire())}),0))};this._refreshStateHandler=()=>{b(document.activeElement,e)!==i&&(i?o():n())},e instanceof HTMLElement?(this.addDisposables(l(e,"focus",n,!0)),this.addDisposables(l(e,"blur",o,!0))):(this.addDisposables(d(e,"focus",n,!0)),this.addDisposables(d(e,"blur",o,!0)))}refreshState(){this._refreshStateHandler()}dispose(){super.dispose(),this._onDidBlur.dispose(),this._onDidFocus.dispose()}}function y(e,i,t={},n={},o,s){const a="string"==typeof i?t[i]:void 0,r="string"==typeof i?n[i]:void 0;if(a&&r)throw new Error(`Cannot create '${e}'. component '${i}' registered as both a component and frameworkComponent`);if(r){if(!o)throw new Error(`Cannot create '${e}' for framework component '${i}'. you must register a frameworkPanelWrapper to use framework components`);return o.createComponent(e,i,r)}if(!a){if(s)return s();throw new Error(`Cannot create '${e}', no component '${i}' provided`)}return new a(e,i)}function C(e){if(0===e.length)throw new Error("Invalid tail call");return[e.slice(0,e.length-1),e[e.length-1]]}function z(e,i){if(e.length!==i.length)return!1;for(let t=0;t<e.length;t++)if(e[t]!==i[t])return!1;return!0}function x(e,i){const t=e.indexOf(i);t>-1&&(e.splice(t,1),e.unshift(i))}function S(e,i){const t=e.indexOf(i);t>-1&&(e.splice(t,1),e.push(i))}const E=(e,i,t)=>{if(i>t)throw new Error(`${i} > ${t} is an invalid condition`);return Math.min(t,Math.max(e,i))},P=()=>{let e=1;return{next:()=>(e++).toString()}},A=(e,i)=>{const t=[];if("number"!=typeof i&&(i=e,e=0),e<=i)for(let n=e;n<i;n++)t.push(n);else for(let n=e;n>i;n--)t.push(n);return t};class k{set size(e){this._size=e}get size(){return this._size}get cachedVisibleSize(){return this._cachedVisibleSize}get visible(){return void 0===this._cachedVisibleSize}get minimumSize(){return this.visible?this.view.minimumSize:0}get viewMinimumSize(){return this.view.minimumSize}get maximumSize(){return this.visible?this.view.maximumSize:0}get viewMaximumSize(){return this.view.maximumSize}get priority(){return this.view.priority}get snap(){return!!this.view.snap}set enabled(e){this.container.style.pointerEvents=e?"":"none"}constructor(e,i,t,n){this.container=e,this.view=i,this.disposable=n,this._cachedVisibleSize=void 0,"number"==typeof t?(this._size=t,this._cachedVisibleSize=void 0,e.classList.add("visible")):(this._size=0,this._cachedVisibleSize=t.cachedVisibleSize)}setVisible(e,i){var t;e!==this.visible&&(e?(this.size=E(null!==(t=this._cachedVisibleSize)&&void 0!==t?t:0,this.viewMinimumSize,this.viewMaximumSize),this._cachedVisibleSize=void 0):(this._cachedVisibleSize="number"==typeof i?i:this.size,this.size=0),this.container.classList.toggle("visible",e),this.view.setVisible&&this.view.setVisible(e))}dispose(){return this.disposable.dispose(),this.view}}var O,I,V,N;e.Orientation=void 0,(O=e.Orientation||(e.Orientation={})).HORIZONTAL="HORIZONTAL",O.VERTICAL="VERTICAL",e.SashState=void 0,(I=e.SashState||(e.SashState={}))[I.MAXIMUM=0]="MAXIMUM",I[I.MINIMUM=1]="MINIMUM",I[I.DISABLED=2]="DISABLED",I[I.ENABLED=3]="ENABLED",e.LayoutPriority=void 0,(V=e.LayoutPriority||(e.LayoutPriority={})).Low="low",V.High="high",V.Normal="normal",e.Sizing=void 0,(N=e.Sizing||(e.Sizing={})).Distribute={type:"distribute"},N.Split=function(e){return{type:"split",index:e}},N.Invisible=function(e){return{type:"invisible",cachedVisibleSize:e}};class L{get size(){return this._size}set size(e){this._size=e}get orthogonalSize(){return this._orthogonalSize}set orthogonalSize(e){this._orthogonalSize=e}get length(){return this.views.length}get proportions(){return this._proportions?[...this._proportions]:void 0}get orientation(){return this._orientation}set orientation(i){this._orientation=i;const t=this.size;this.size=this.orthogonalSize,this.orthogonalSize=t,v(this.element,"horizontal","vertical"),this.element.classList.add(this.orientation==e.Orientation.HORIZONTAL?"horizontal":"vertical")}get minimumSize(){return this.views.reduce(((e,i)=>e+i.minimumSize),0)}get maximumSize(){return 0===this.length?Number.POSITIVE_INFINITY:this.views.reduce(((e,i)=>e+i.maximumSize),0)}get startSnappingEnabled(){return this._startSnappingEnabled}set startSnappingEnabled(e){this._startSnappingEnabled!==e&&(this._startSnappingEnabled=e,this.updateSashEnablement())}get endSnappingEnabled(){return this._endSnappingEnabled}set endSnappingEnabled(e){this._endSnappingEnabled!==e&&(this._endSnappingEnabled=e,this.updateSashEnablement())}constructor(e,i){this.container=e,this.views=[],this.sashes=[],this._size=0,this._orthogonalSize=0,this.contentSize=0,this._proportions=void 0,this._startSnappingEnabled=!0,this._endSnappingEnabled=!0,this._onDidSashEnd=new h,this.onDidSashEnd=this._onDidSashEnd.event,this._onDidAddView=new h,this.onDidAddView=this._onDidAddView.event,this._onDidRemoveView=new h,this.onDidRemoveView=this._onDidRemoveView.event,this.resize=(e,i,t=this.views.map((e=>e.size)),n,o,s=Number.NEGATIVE_INFINITY,a=Number.POSITIVE_INFINITY,r,h)=>{if(e<0||e>this.views.length)return 0;const d=A(e,-1),l=A(e+1,this.views.length);if(o)for(const e of o)x(d,e),x(l,e);if(n)for(const e of n)S(d,e),S(l,e);const p=d.map((e=>this.views[e])),c=d.map((e=>t[e])),u=l.map((e=>this.views[e])),m=l.map((e=>t[e])),v=d.reduce(((e,i)=>e+this.views[i].minimumSize-t[i]),0),g=d.reduce(((e,i)=>e+this.views[i].maximumSize-t[i]),0),w=0===l.length?Number.POSITIVE_INFINITY:l.reduce(((e,i)=>e+t[i]-this.views[i].minimumSize),0),b=0===l.length?Number.NEGATIVE_INFINITY:l.reduce(((e,i)=>e+t[i]-this.views[i].maximumSize),0),f=Math.max(v,b),_=Math.min(w,g);let D=!1;if(r){const e=this.views[r.index],t=i>=r.limitDelta;D=t!==e.visible,e.setVisible(t,r.size)}if(!D&&h){const e=this.views[h.index],t=i<h.limitDelta;D=t!==e.visible,e.setVisible(t,h.size)}if(D)return this.resize(e,i,t,n,o,s,a);let y=0,C=E(i,f,_);for(let e=0;e<p.length;e++){const i=p[e],t=E(c[e]+C,i.minimumSize,i.maximumSize),n=t-c[e];y+=n,C-=n,i.size=t}let z=y;for(let e=0;e<u.length;e++){const i=u[e],t=E(m[e]-z,i.minimumSize,i.maximumSize);z+=t-m[e],i.size=t}return i},this._orientation=i.orientation,this.element=this.createContainer(),this.proportionalLayout=void 0===i.proportionalLayout||!!i.proportionalLayout,this.viewContainer=this.createViewContainer(),this.sashContainer=this.createSashContainer(),this.element.appendChild(this.sashContainer),this.element.appendChild(this.viewContainer),this.container.appendChild(this.element),this.style(i.styles),i.descriptor&&(this._size=i.descriptor.size,i.descriptor.views.forEach(((e,i)=>{const t=void 0===e.visible||e.visible?e.size:{type:"invisible",cachedVisibleSize:e.size},n=e.view;this.addView(n,t,i,!0)})),this.contentSize=this.views.reduce(((e,i)=>e+i.size),0),this.saveProportions())}style(e){"transparent"===(null==e?void 0:e.separatorBorder)?(v(this.element,"separator-border"),this.element.style.removeProperty("--dv-separator-border")):(g(this.element,"separator-border"),(null==e?void 0:e.separatorBorder)&&this.element.style.setProperty("--dv-separator-border",e.separatorBorder))}isViewVisible(e){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");return this.views[e].visible}setViewVisible(e,i){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");w(this.container,"visible",i);const t=this.views[e];w(this.container,"visible",i),t.setVisible(i,t.size),this.distributeEmptySpace(e),this.layoutViews(),this.saveProportions()}getViewSize(e){return e<0||e>=this.views.length?-1:this.views[e].size}resizeView(i,t){if(i<0||i>=this.views.length)return;const n=A(this.views.length).filter((e=>e!==i)),o=[...n.filter((i=>this.views[i].priority===e.LayoutPriority.Low)),i],s=n.filter((i=>this.views[i].priority===e.LayoutPriority.High)),a=this.views[i];t=Math.round(t),t=E(t,a.minimumSize,Math.min(a.maximumSize,this._size)),a.size=t,this.relayout(o,s)}getViews(){return this.views.map((e=>e.view))}onDidChange(e,i){const t=this.views.indexOf(e);t<0||t>=this.views.length||(i="number"==typeof i?i:e.size,i=E(i,e.minimumSize,e.maximumSize),e.size=i,this.relayout([t]))}addView(i,t={type:"distribute"},n=this.views.length,o){const s=document.createElement("div");let a;s.className="view",s.appendChild(i.element),a="number"==typeof t?t:"split"===t.type?this.getViewSize(t.index)/2:"invisible"===t.type?{cachedVisibleSize:t.cachedVisibleSize}:i.minimumSize;const r=i.onDidChange((e=>this.onDidChange(h,e.size))),h=new k(s,i,a,{dispose:()=>{null==r||r.dispose(),this.viewContainer.removeChild(s)}});if(n===this.views.length?this.viewContainer.appendChild(s):this.viewContainer.insertBefore(s,this.viewContainer.children.item(n)),this.views.splice(n,0,h),this.views.length>1){const i=document.createElement("div");i.className="sash";const t=t=>{for(const e of this.views)e.enabled=!1;const n=[...f("iframe"),...f("webview")];for(const e of n)e.style.pointerEvents="none";const o=this._orientation===e.Orientation.HORIZONTAL?t.clientX:t.clientY,s=function(e,i){for(let t=0;t<e.length;t++)if(i(e[t]))return t;return-1}(this.sashes,(e=>e.container===i)),a=this.views.map((e=>e.size));let r,h;const d=A(s,-1),l=A(s+1,this.views.length),p=d.reduce(((e,i)=>e+(this.views[i].minimumSize-a[i])),0),c=d.reduce(((e,i)=>e+(this.views[i].viewMaximumSize-a[i])),0),u=0===l.length?Number.POSITIVE_INFINITY:l.reduce(((e,i)=>e+(a[i]-this.views[i].minimumSize)),0),m=0===l.length?Number.NEGATIVE_INFINITY:l.reduce(((e,i)=>e+(a[i]-this.views[i].viewMaximumSize)),0),v=Math.max(p,m),g=Math.min(u,c),w=this.findFirstSnapIndex(d),b=this.findFirstSnapIndex(l);if("number"==typeof w){const e=this.views[w],i=Math.floor(e.viewMinimumSize/2);r={index:w,limitDelta:e.visible?v-i:v+i,size:e.size}}if("number"==typeof b){const e=this.views[b],i=Math.floor(e.viewMinimumSize/2);h={index:b,limitDelta:e.visible?g+i:g-i,size:e.size}}const _=i=>{const t=(this._orientation===e.Orientation.HORIZONTAL?i.clientX:i.clientY)-o;this.resize(s,t,a,void 0,void 0,v,g,r,h),this.distributeEmptySpace(),this.layoutViews()},D=()=>{for(const e of this.views)e.enabled=!0;for(const e of n)e.style.pointerEvents="auto";this.saveProportions(),document.removeEventListener("mousemove",_),document.removeEventListener("mouseup",D),document.removeEventListener("mouseend",D),this._onDidSashEnd.fire(void 0)};document.addEventListener("mousemove",_),document.addEventListener("mouseup",D),document.addEventListener("mouseend",D)};i.addEventListener("mousedown",t);const n={container:i,disposable:()=>{i.removeEventListener("mousedown",t),this.sashContainer.removeChild(i)}};this.sashContainer.appendChild(i),this.sashes.push(n)}o||this.relayout([n]),o||"number"==typeof t||"distribute"!==t.type||this.distributeViewSizes(),this._onDidAddView.fire(i)}distributeViewSizes(){const i=[];let t=0;for(const e of this.views)e.maximumSize-e.minimumSize>0&&(i.push(e),t+=e.size);const n=Math.floor(t/i.length);for(const e of i)e.size=E(n,e.minimumSize,e.maximumSize);const o=A(this.views.length),s=o.filter((i=>this.views[i].priority===e.LayoutPriority.Low)),a=o.filter((i=>this.views[i].priority===e.LayoutPriority.High));this.relayout(s,a)}removeView(e,i,t=!1){const n=this.views.splice(e,1)[0];if(n.dispose(),this.views.length>=1){const i=Math.max(e-1,0);this.sashes.splice(i,1)[0].disposable()}return t||this.relayout(),i&&"distribute"===i.type&&this.distributeViewSizes(),this._onDidRemoveView.fire(n.view),n.view}getViewCachedVisibleSize(e){if(e<0||e>=this.views.length)throw new Error("Index out of bounds");return this.views[e].cachedVisibleSize}moveView(i,t){const n=this.getViewCachedVisibleSize(i),o=void 0===n?this.getViewSize(i):e.Sizing.Invisible(n),s=this.removeView(i,void 0,!0);this.addView(s,o,t)}layout(i,t){const n=Math.max(this.size,this.contentSize);if(this.size=i,this.orthogonalSize=t,this.proportions)for(let e=0;e<this.views.length;e++){const t=this.views[e];t.size=E(Math.round(this.proportions[e]*i),t.minimumSize,t.maximumSize)}else{const t=A(this.views.length),o=t.filter((i=>this.views[i].priority===e.LayoutPriority.Low)),s=t.filter((i=>this.views[i].priority===e.LayoutPriority.High));this.resize(this.views.length-1,i-n,void 0,o,s)}this.distributeEmptySpace(),this.layoutViews()}relayout(e,i){const t=this.views.reduce(((e,i)=>e+i.size),0);this.resize(this.views.length-1,this._size-t,void 0,e,i),this.distributeEmptySpace(),this.layoutViews(),this.saveProportions()}distributeEmptySpace(i){const t=this.views.reduce(((e,i)=>e+i.size),0);let n=this.size-t;const o=A(this.views.length-1,-1),s=o.filter((i=>this.views[i].priority===e.LayoutPriority.Low)),a=o.filter((i=>this.views[i].priority===e.LayoutPriority.High));for(const e of a)x(o,e);for(const e of s)S(o,e);"number"==typeof i&&S(o,i);for(let e=0;0!==n&&e<o.length;e++){const i=this.views[o[e]],t=E(i.size+n,i.minimumSize,i.maximumSize);n-=t-i.size,i.size=t}}saveProportions(){this.proportionalLayout&&this.contentSize>0&&(this._proportions=this.views.map((e=>e.size/this.contentSize)))}layoutViews(){this.contentSize=this.views.reduce(((e,i)=>e+i.size),0);let i=0;const t=[];this.updateSashEnablement();for(let n=0;n<this.views.length-1;n++){i+=this.views[n].size,t.push(i);const o=Math.min(Math.max(0,i-2),this.size-4);this._orientation===e.Orientation.HORIZONTAL&&(this.sashes[n].container.style.left=`${o}px`,this.sashes[n].container.style.top="0px"),this._orientation===e.Orientation.VERTICAL&&(this.sashes[n].container.style.left="0px",this.sashes[n].container.style.top=`${o}px`)}this.views.forEach(((i,n)=>{this._orientation===e.Orientation.HORIZONTAL&&(i.container.style.width=`${i.size}px`,i.container.style.left=0==n?"0px":`${t[n-1]}px`,i.container.style.top="",i.container.style.height=""),this._orientation===e.Orientation.VERTICAL&&(i.container.style.height=`${i.size}px`,i.container.style.top=0==n?"0px":`${t[n-1]}px`,i.container.style.width="",i.container.style.left=""),i.view.layout(i.size,this._orthogonalSize)}))}findFirstSnapIndex(e){for(const i of e){const e=this.views[i];if(e.visible&&e.snap)return i}for(const i of e){const e=this.views[i];if(e.visible&&e.maximumSize-e.minimumSize>0)return;if(!e.visible&&e.snap)return i}}updateSashEnablement(){let i=!1;const t=this.views.map((e=>i=e.size-e.minimumSize>0||i));i=!1;const n=this.views.map((e=>i=e.maximumSize-e.size>0||i)),o=[...this.views].reverse();i=!1;const s=o.map((e=>i=e.size-e.minimumSize>0||i)).reverse();i=!1;const a=o.map((e=>i=e.maximumSize-e.size>0||i)).reverse();let r=0;for(let i=0;i<this.sashes.length;i++){const o=this.sashes[i];r+=this.views[i].size;const h=!(t[i]&&a[i+1]),d=!(n[i]&&s[i+1]);if(h&&d){const n=A(i,-1),a=A(i+1,this.views.length),h=this.findFirstSnapIndex(n),d=this.findFirstSnapIndex(a),l="number"==typeof h&&!this.views[h].visible,p="number"==typeof d&&!this.views[d].visible;l&&s[i]&&(r>0||this.startSnappingEnabled)?this.updateSash(o,e.SashState.MINIMUM):p&&t[i]&&(r<this.contentSize||this.endSnappingEnabled)?this.updateSash(o,e.SashState.MAXIMUM):this.updateSash(o,e.SashState.DISABLED)}else h&&!d?this.updateSash(o,e.SashState.MINIMUM):!h&&d?this.updateSash(o,e.SashState.MAXIMUM):this.updateSash(o,e.SashState.ENABLED)}}updateSash(i,t){w(i.container,"disabled",t===e.SashState.DISABLED),w(i.container,"enabled",t===e.SashState.ENABLED),w(i.container,"maximum",t===e.SashState.MAXIMUM),w(i.container,"minimum",t===e.SashState.MINIMUM)}createViewContainer(){const e=document.createElement("div");return e.className="view-container",e}createSashContainer(){const e=document.createElement("div");return e.className="sash-container",e}createContainer(){const i=document.createElement("div"),t=this._orientation===e.Orientation.HORIZONTAL?"horizontal":"vertical";return i.className=`split-view-container ${t}`,i}dispose(){this._onDidSashEnd.dispose(),this._onDidAddView.dispose(),this._onDidRemoveView.dispose();for(let e=0;e<this.element.children.length;e++)if(this.element.children.item(e)===this.element){this.element.removeChild(this.element);break}this.element.remove()}}class G extends c{get onDidAddView(){return this.splitview.onDidAddView}get onDidRemoveView(){return this.splitview.onDidRemoveView}get minimumSize(){return this.splitview.minimumSize}get maximumSize(){return this.splitview.maximumSize}get orientation(){return this.splitview.orientation}get size(){return this.splitview.size}get orthogonalSize(){return this.splitview.orthogonalSize}constructor(i,t){var n;super(),this.paneItems=[],this.skipAnimation=!1,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this._orientation=null!==(n=t.orientation)&&void 0!==n?n:e.Orientation.VERTICAL,this.element=document.createElement("div"),this.element.className="pane-container",i.appendChild(this.element),this.splitview=new L(this.element,{orientation:this._orientation,proportionalLayout:!1,descriptor:t.descriptor}),this.getPanes().forEach((e=>{const i=new c(e.onDidChangeExpansionState((()=>{this.setupAnimation(),this._onDidChange.fire(void 0)}))),t={pane:e,disposable:{dispose:()=>{i.dispose()}}};this.paneItems.push(t),e.orthogonalSize=this.splitview.orthogonalSize})),this.addDisposables(this._onDidChange,this.splitview.onDidSashEnd((()=>{this._onDidChange.fire(void 0)})),this.splitview.onDidAddView((()=>{this._onDidChange.fire()})),this.splitview.onDidRemoveView((()=>{this._onDidChange.fire()})))}addPane(e,i,t=this.splitview.length,n=!1){const o=e.onDidChangeExpansionState((()=>{this.setupAnimation(),this._onDidChange.fire(void 0)})),s={pane:e,disposable:{dispose:()=>{o.dispose()}}};this.paneItems.splice(t,0,s),e.orthogonalSize=this.splitview.orthogonalSize,this.splitview.addView(e,i,t,n)}getViewSize(e){return this.splitview.getViewSize(e)}getPanes(){return this.splitview.getViews()}removePane(e,i={skipDispose:!1}){const t=this.paneItems.splice(e,1)[0];return this.splitview.removeView(e),i.skipDispose||(t.disposable.dispose(),t.pane.dispose()),t}moveView(e,i){if(e===i)return;const t=this.removePane(e,{skipDispose:!0});this.skipAnimation=!0;try{this.addPane(t.pane,t.pane.size,i,!1)}finally{this.skipAnimation=!1}}layout(e,i){this.splitview.layout(e,i)}setupAnimation(){this.skipAnimation||(this.animationTimer&&(clearTimeout(this.animationTimer),this.animationTimer=void 0),g(this.element,"animated"),this.animationTimer=setTimeout((()=>{this.animationTimer=void 0,v(this.element,"animated")}),200))}dispose(){super.dispose(),this.animationTimer&&(clearTimeout(this.animationTimer),this.animationTimer=void 0),this.paneItems.forEach((e=>{e.disposable.dispose(),e.pane.dispose()})),this.paneItems=[],this.splitview.dispose(),this.element.remove()}}class T{get minimumWidth(){return this.view.minimumWidth}get maximumWidth(){return this.view.maximumWidth}get minimumHeight(){return this.view.minimumHeight}get maximumHeight(){return this.view.maximumHeight}get priority(){return this.view.priority}get snap(){return this.view.snap}get minimumSize(){return this.orientation===e.Orientation.HORIZONTAL?this.minimumHeight:this.minimumWidth}get maximumSize(){return this.orientation===e.Orientation.HORIZONTAL?this.maximumHeight:this.maximumWidth}get minimumOrthogonalSize(){return this.orientation===e.Orientation.HORIZONTAL?this.minimumWidth:this.minimumHeight}get maximumOrthogonalSize(){return this.orientation===e.Orientation.HORIZONTAL?this.maximumWidth:this.maximumHeight}get orthogonalSize(){return this._orthogonalSize}get size(){return this._size}get element(){return this.view.element}get width(){return this.orientation===e.Orientation.HORIZONTAL?this.orthogonalSize:this.size}get height(){return this.orientation===e.Orientation.HORIZONTAL?this.size:this.orthogonalSize}constructor(i,t,n,o=0){this.view=i,this.orientation=t,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this._orthogonalSize=n,this._size=o,this._disposable=this.view.onDidChange((i=>{i?this._onDidChange.fire({size:this.orientation===e.Orientation.VERTICAL?i.width:i.height,orthogonalSize:this.orientation===e.Orientation.VERTICAL?i.height:i.width}):this._onDidChange.fire({})}))}setVisible(e){this.view.setVisible&&(this.view.setVisible(e),this._onDidChange.fire({}))}layout(e,i){this._size=e,this._orthogonalSize=i,this.view.layout(this.width,this.height)}dispose(){this._onDidChange.dispose(),this._disposable.dispose()}}class R extends c{get width(){return this.orientation===e.Orientation.HORIZONTAL?this.size:this.orthogonalSize}get height(){return this.orientation===e.Orientation.HORIZONTAL?this.orthogonalSize:this.size}get minimumSize(){return 0===this.children.length?0:Math.max(...this.children.map((e=>e.minimumOrthogonalSize)))}get maximumSize(){return Math.min(...this.children.map((e=>e.maximumOrthogonalSize)))}get minimumOrthogonalSize(){return this.splitview.minimumSize}get maximumOrthogonalSize(){return this.splitview.maximumSize}get orthogonalSize(){return this._orthogonalSize}get size(){return this._size}get minimumWidth(){return this.orientation===e.Orientation.HORIZONTAL?this.minimumOrthogonalSize:this.minimumSize}get minimumHeight(){return this.orientation===e.Orientation.HORIZONTAL?this.minimumSize:this.minimumOrthogonalSize}get maximumWidth(){return this.orientation===e.Orientation.HORIZONTAL?this.maximumOrthogonalSize:this.maximumSize}get maximumHeight(){return this.orientation===e.Orientation.HORIZONTAL?this.maximumSize:this.maximumOrthogonalSize}get priority(){if(0===this.children.length)return e.LayoutPriority.Normal;const i=this.children.map((i=>void 0===i.priority?e.LayoutPriority.Normal:i.priority));return i.some((i=>i===e.LayoutPriority.High))?e.LayoutPriority.High:i.some((i=>i===e.LayoutPriority.Low))?e.LayoutPriority.Low:e.LayoutPriority.Normal}constructor(e,t,n,o,s,a){if(super(),this.orientation=e,this.proportionalLayout=t,this.styles=n,this._childrenDisposable=i.NONE,this.children=[],this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this._orthogonalSize=s,this._size=o,this.element=document.createElement("div"),this.element.className="branch-node",a){const e={views:a.map((e=>({view:e.node,size:e.node.size,visible:!(e.node instanceof T&&void 0!==e.visible)||e.visible}))),size:this.size};this.children=a.map((e=>e.node)),this.splitview=new L(this.element,{orientation:this.orientation,descriptor:e,proportionalLayout:t})}else this.splitview=new L(this.element,{orientation:this.orientation,proportionalLayout:t,styles:n}),this.splitview.layout(this.size,this.orthogonalSize);this.addDisposables(this._onDidChange,this.splitview.onDidSashEnd((()=>{this._onDidChange.fire({})}))),this.setupChildrenEvents()}setVisible(e){for(const i of this.children)i.setVisible(e)}isChildVisible(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.isViewVisible(e)}setChildVisible(e,i){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.isViewVisible(e)!==i&&this.splitview.setViewVisible(e,i)}moveChild(e,i){if(e===i)return;if(e<0||e>=this.children.length)throw new Error("Invalid from index");e<i&&i--,this.splitview.moveView(e,i);const t=this._removeChild(e);this._addChild(t,i)}getChildSize(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.getViewSize(e)}resizeChild(e,i){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.resizeView(e,i)}layout(e,i){this._size=i,this._orthogonalSize=e,this.splitview.layout(this.size,this.orthogonalSize)}addChild(e,i,t,n){if(t<0||t>this.children.length)throw new Error("Invalid index");this.splitview.addView(e,i,t,n),this._addChild(e,t)}getChildCachedVisibleSize(e){if(e<0||e>=this.children.length)throw new Error("Invalid index");return this.splitview.getViewCachedVisibleSize(e)}removeChild(e,i){if(e<0||e>=this.children.length)throw new Error("Invalid index");this.splitview.removeView(e,i),this._removeChild(e)}_addChild(e,i){this.children.splice(i,0,e),this.setupChildrenEvents()}_removeChild(e){const[i]=this.children.splice(e,1);return this.setupChildrenEvents(),i}setupChildrenEvents(){this._childrenDisposable.dispose(),this._childrenDisposable=e.DockviewEvent.any(...this.children.map((e=>e.onDidChange)))((e=>{this._onDidChange.fire({size:e.orthogonalSize})}))}dispose(){super.dispose(),this._childrenDisposable.dispose(),this.children.forEach((e=>e.dispose())),this.splitview.dispose()}}function H(e,i){if(e instanceof T)return e;if(e instanceof R)return H(e.children[i?e.children.length-1:0],i);throw new Error("invalid node")}function M(e,i,t){if(e instanceof R){const n=new R(j(e.orientation),e.proportionalLayout,e.styles,i,t);let o=0;for(let s=e.children.length-1;s>=0;s--){const a=e.children[s],r=a instanceof R?a.orthogonalSize:a.size;let h=0===e.size?0:Math.round(i*r/e.size);o+=h,0===s&&(h+=i-o),n.addChild(M(a,t,h),h,0,!0)}return n}return new T(e.view,j(e.orientation),t)}function F(e){const i=e.parentElement;if(!i)throw new Error("Invalid grid element");let t=i.firstElementChild,n=0;for(;t!==e&&t!==i.lastElementChild&&t;)t=t.nextElementSibling,n++;return n}function W(e){const i=e.parentElement;if(!i)throw new Error("Invalid grid element");if(/\bgrid-view\b/.test(i.className))return[];const t=F(i);return[...W(i.parentElement.parentElement.parentElement),t]}function J(e,i,t){if($(e,i)===B(t)){const[e,n]=C(i);let o=n;return"right"!==t&&"bottom"!==t||(o+=1),[...e,o]}{const e="right"===t||"bottom"===t?1:0;return[...i,e]}}function B(i){return"top"===i||"bottom"===i?e.Orientation.VERTICAL:e.Orientation.HORIZONTAL}function $(e,i){return i.length%2==0?j(e):e}const j=i=>i===e.Orientation.HORIZONTAL?e.Orientation.VERTICAL:e.Orientation.HORIZONTAL;function Z(e){return!!e.children}const U=(i,t)=>{const n=t===e.Orientation.VERTICAL?i.box.width:i.box.height;return Z(i)?{type:"branch",data:i.children.map((e=>U(e,j(t)))),size:n}:"number"==typeof i.cachedVisibleSize?{type:"leaf",data:i.view.toJSON(),size:i.cachedVisibleSize,visible:!1}:{type:"leaf",data:i.view.toJSON(),size:n}};class Y{get length(){return this._root?this._root.children.length:0}get orientation(){return this.root.orientation}set orientation(e){if(this.root.orientation===e)return;const{size:i,orthogonalSize:t}=this.root;this.root=M(this.root,t,i),this.root.layout(i,t)}get width(){return this.root.width}get height(){return this.root.height}get minimumWidth(){return this.root.minimumWidth}get minimumHeight(){return this.root.minimumHeight}get maximumWidth(){return this.root.maximumHeight}get maximumHeight(){return this.root.maximumHeight}serialize(){return{root:U(this.getView(),this.orientation),width:this.width,height:this.height,orientation:this.orientation}}dispose(){this.disposable.dispose(),this._onDidChange.dispose(),this.root.dispose(),this.element.remove()}clear(){const e=this.root.orientation;this.root=new R(e,this.proportionalLayout,this.styles,this.root.size,this.root.orthogonalSize)}deserialize(i,t){const n=i.orientation,o=n===e.Orientation.VERTICAL?i.height:i.width;this._deserialize(i.root,n,t,o)}_deserialize(e,i,t,n){this.root=this._deserializeNode(e,i,t,n,!0)}_deserializeNode(e,i,t,n,o=!1){let s;if("branch"===e.type){const a=e.data.map((n=>({node:this._deserializeNode(n,j(i),t,e.size),visible:n.visible})));s=new R(i,this.proportionalLayout,this.styles,o?n:e.size,o?e.size:n,a)}else s=new T(t.fromJSON(e),i,n,e.size);return s}get root(){return this._root}set root(e){const i=this._root;i&&(i.dispose(),this.element.removeChild(i.element)),this._root=e,this.element.appendChild(this._root.element),this.disposable.value=this._root.onDidChange((e=>{this._onDidChange.fire(e)}))}insertOrthogonalSplitviewAtRoot(){if(!this._root)return;const i=this.root;if(i.element.remove(),this._root=new R(j(i.orientation),this.proportionalLayout,this.styles,this.root.orthogonalSize,this.root.size),1===i.children.length){const t=i.children[0];i.removeChild(0),i.dispose(),this._root.addChild(M(t,t.orthogonalSize,t.size),e.Sizing.Distribute,0)}else this._root.addChild(i,e.Sizing.Distribute,0);this.element.appendChild(this._root.element),this.disposable.value=this._root.onDidChange((e=>{this._onDidChange.fire(e)}))}next(e){return this.progmaticSelect(e)}previous(e){return this.progmaticSelect(e,!0)}getView(e){const i=e?this.getNode(e)[1]:this.root;return this._getViews(i,this.orientation)}_getViews(e,i,t){const n={height:e.height,width:e.width};if(e instanceof T)return{box:n,view:e.view,cachedVisibleSize:t};const o=[];for(let t=0;t<e.children.length;t++){const n=e.children[t],s=e.getChildCachedVisibleSize(t);o.push(this._getViews(n,j(i),s))}return{box:n,children:o}}progmaticSelect(e,i=!1){const[t,n]=this.getNode(e);if(!(n instanceof T))throw new Error("invalid location");for(let n=t.length-1;n>-1;n--){const o=t[n],s=e[n]||0;if(i?s-1>-1:s+1<o.children.length)return H(o.children[i?s-1:s+1],i)}return H(this.root,i)}constructor(e,i,t){this.proportionalLayout=e,this.styles=i,this.disposable=new u,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this.element=document.createElement("div"),this.element.className="grid-view",this.root=new R(t,e,i,0,0)}isViewVisible(e){const[i,t]=C(e),[,n]=this.getNode(i);if(!(n instanceof R))throw new Error("Invalid from location");return n.isChildVisible(t)}setViewVisible(e,i){const[t,n]=C(e),[,o]=this.getNode(t);if(!(o instanceof R))throw new Error("Invalid from location");o.setChildVisible(n,i)}moveView(e,i,t){const[,n]=this.getNode(e);if(!(n instanceof R))throw new Error("Invalid location");n.moveChild(i,t)}addView(i,t,n){const[o,s]=C(n),[a,r]=this.getNode(o);if(r instanceof R){const e=new T(i,j(r.orientation),r.orthogonalSize);r.addChild(e,t,s)}else{const[n,...h]=[...a].reverse(),[d,...l]=[...o].reverse();let p=0;const c=n.getChildCachedVisibleSize(d);"number"==typeof c&&(p=e.Sizing.Invisible(c)),n.removeChild(d);const u=new R(r.orientation,this.proportionalLayout,this.styles,r.size,r.orthogonalSize);n.addChild(u,r.size,d);const m=new T(r.view,n.orientation,r.size);u.addChild(m,p,0),"number"!=typeof t&&"split"===t.type&&(t={type:"split",index:0});const v=new T(i,n.orientation,r.size);u.addChild(v,t,s)}}remove(e,i){const t=W(e.element);return this.removeView(t,i)}removeView(i,t){const[n,o]=C(i),[s,a]=this.getNode(n);if(!(a instanceof R))throw new Error("Invalid location");const r=a.children[o];if(!(r instanceof T))throw new Error("Invalid location");if(a.removeChild(o,t),0===a.children.length)return r.view;if(a.children.length>1)return r.view;const h=a.children[0];if(0===s.length)return h instanceof T||(a.removeChild(0,t),this.root=h),r.view;const[d,...l]=[...s].reverse(),[p,...c]=[...n].reverse(),u=a.isChildVisible(0);a.removeChild(0,t);const m=d.children.map(((e,i)=>d.getChildSize(i)));if(d.removeChild(p,t),h instanceof R){m.splice(p,1,...h.children.map((e=>e.size)));for(let e=0;e<h.children.length;e++){const i=h.children[e];d.addChild(i,i.size,p+e)}}else{const i=new T(h.view,j(h.orientation),h.size),t=u?h.orthogonalSize:e.Sizing.Invisible(h.orthogonalSize);d.addChild(i,t,p)}for(let e=0;e<m.length;e++)d.resizeChild(e,m[e]);return r.view}layout(i,t){const[n,o]=this.root.orientation===e.Orientation.HORIZONTAL?[t,i]:[i,t];this.root.layout(n,o)}getNode(e,i=this.root,t=[]){if(0===e.length)return[t,i];if(!(i instanceof R))throw new Error("Invalid location");const[n,...o]=e;if(n<0||n>=i.children.length)throw new Error("Invalid location");const s=i.children[n];return t.push(i),this.getNode(o,s,t)}}class X{get minimumSize(){return this.component.minimumSize}get maximumSize(){return this.component.maximumSize}get height(){return this.component.height}get width(){return this.component.width}get panels(){return this.component.panels}get onDidLayoutChange(){return this.component.onDidLayoutChange}get onDidLayoutFromJSON(){return this.component.onDidLayoutFromJSON}get onDidAddView(){return this.component.onDidAddView}get onDidRemoveView(){return this.component.onDidRemoveView}get onDidDrop(){const e=new h,i=this.component.onDidDrop((i=>{e.fire(Object.assign(Object.assign({},i),{api:this}))}));return e.dispose=()=>{i.dispose(),e.dispose()},e.event}constructor(e){this.component=e}removePanel(e){this.component.removePanel(e)}getPanel(e){return this.component.getPanel(e)}movePanel(e,i){this.component.movePanel(e,i)}focus(){this.component.focus()}layout(e,i){this.component.layout(e,i)}addPanel(e){return this.component.addPanel(e)}fromJSON(e){this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}clear(){this.component.clear()}}class Q{get id(){return this.component.id}get width(){return this.component.width}get height(){return this.component.height}get minimumHeight(){return this.component.minimumHeight}get maximumHeight(){return this.component.maximumHeight}get minimumWidth(){return this.component.minimumWidth}get maximumWidth(){return this.component.maximumWidth}get size(){return this.component.size}get totalPanels(){return this.component.totalPanels}get onDidActiveGroupChange(){return this.component.onDidActiveGroupChange}get onDidAddGroup(){return this.component.onDidAddGroup}get onDidRemoveGroup(){return this.component.onDidRemoveGroup}get onDidActivePanelChange(){return this.component.onDidActivePanelChange}get onDidAddPanel(){return this.component.onDidAddPanel}get onDidRemovePanel(){return this.component.onDidRemovePanel}get onDidLayoutFromJSON(){return this.component.onDidLayoutFromJSON}get onDidLayoutChange(){return this.component.onDidLayoutChange}get onDidDrop(){return this.component.onDidDrop}get panels(){return this.component.panels}get groups(){return this.component.groups}get activePanel(){return this.component.activePanel}get activeGroup(){return this.component.activeGroup}constructor(e){this.component=e}focus(){this.component.focus()}getPanel(e){return this.component.getGroupPanel(e)}layout(e,i,t=!1){this.component.layout(e,i,t)}addPanel(e){return this.component.addPanel(e)}addGroup(e){return this.component.addGroup(e)}moveToNext(e){this.component.moveToNext(e)}moveToPrevious(e){this.component.moveToPrevious(e)}closeAllGroups(){return this.component.closeAllGroups()}removeGroup(e){this.component.removeGroup(e)}getGroup(e){return this.component.getPanel(e)}fromJSON(e){this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}clear(){this.component.clear()}}class q extends c{constructor(e,i){super(),this.element=e,this.callbacks=i,this.target=null,this.registerListeners()}registerListeners(){this.addDisposables(l(this.element,"dragenter",(e=>{this.target=e.target,this.callbacks.onDragEnter(e)}),!0)),this.addDisposables(l(this.element,"dragover",(e=>{e.preventDefault(),this.callbacks.onDragOver&&this.callbacks.onDragOver(e)}),!0)),this.addDisposables(l(this.element,"dragleave",(e=>{this.target===e.target&&(this.target=null,this.callbacks.onDragLeave(e))}))),this.addDisposables(l(this.element,"dragend",(e=>{this.target=null,this.callbacks.onDragEnd(e)}))),this.addDisposables(l(this.element,"drop",(e=>{this.callbacks.onDrop(e)})))}}function K(e){switch(e){case"above":return"top";case"below":return"bottom";case"left":return"left";case"right":return"right";case"within":return"center";default:throw new Error(`invalid direction '${e}'`)}}class ee extends c{get state(){return this._state}constructor(e,i){super(),this.element=e,this.options=i,this._onDrop=new h,this.onDrop=this._onDrop.event;const t=new Set(this.options.acceptedTargetZones);this.addDisposables(this._onDrop,new q(this.element,{onDragEnter:()=>{},onDragOver:e=>{const i=this.element.clientWidth,n=this.element.clientHeight;if(0===i||0===n)return;const o=e.currentTarget.getBoundingClientRect(),s=e.clientX-o.left,a=e.clientY-o.top,r=this.calculateQuadrant(t,s,a,i,n);if(null!==r){if("boolean"==typeof this.options.canDisplayOverlay){if(!this.options.canDisplayOverlay)return}else if(!this.options.canDisplayOverlay(e,r))return;this.targetElement||(this.targetElement=document.createElement("div"),this.targetElement.className="drop-target-dropzone",this.overlayElement=document.createElement("div"),this.overlayElement.className="drop-target-selection",this._state="center",this.targetElement.appendChild(this.overlayElement),this.element.classList.add("drop-target"),this.element.append(this.targetElement)),0!==this.options.acceptedTargetZones.length&&this.targetElement&&this.overlayElement&&(this.toggleClasses(r,i,n),this.setState(r))}else this.removeDropTarget()},onDragLeave:()=>{this.removeDropTarget()},onDragEnd:()=>{this.removeDropTarget()},onDrop:e=>{e.preventDefault();const i=this._state;this.removeDropTarget(),i&&(e.stopPropagation(),this._onDrop.fire({position:i,nativeEvent:e}))}}))}dispose(){this.removeDropTarget()}toggleClasses(e,i,t){var n,o,s,a;if(!this.overlayElement)return;const r=i<100,h=t<100,d="left"===e,l="right"===e,p="top"===e,c="bottom"===e,u=!r&&l,m=!r&&d,v=!h&&p,g=!h&&c;let b=.5;"percentage"===(null===(o=null===(n=this.options.overlayModel)||void 0===n?void 0:n.size)||void 0===o?void 0:o.type)&&(b=E(this.options.overlayModel.size.value,0,100)/100),"pixels"===(null===(a=null===(s=this.options.overlayModel)||void 0===s?void 0:s.size)||void 0===a?void 0:a.type)&&((u||m)&&(b=E(0,this.options.overlayModel.size.value,i)/i),(v||g)&&(b=E(0,this.options.overlayModel.size.value,t)/t));const f=(1-b)/2;let _;_=u?`translateX(${100*f}%) scaleX(${b})`:m?`translateX(-${100*f}%) scaleX(${b})`:v?`translateY(-${100*f}%) scaleY(${b})`:g?`translateY(${100*f}%) scaleY(${b})`:"",this.overlayElement.style.transform=_,w(this.overlayElement,"small-right",r&&l),w(this.overlayElement,"small-left",r&&d),w(this.overlayElement,"small-top",h&&p),w(this.overlayElement,"small-bottom",h&&c)}setState(e){switch(e){case"top":this._state="top";break;case"left":this._state="left";break;case"bottom":this._state="bottom";break;case"right":this._state="right";break;case"center":this._state="center"}}calculateQuadrant(e,i,t,n,o){var s,a,r,h,d,l;const p=void 0===(null===(s=this.options.overlayModel)||void 0===s?void 0:s.activationSize)||"percentage"===(null===(r=null===(a=this.options.overlayModel)||void 0===a?void 0:a.activationSize)||void 0===r?void 0:r.type),c=(u=null===(l=null===(d=null===(h=this.options)||void 0===h?void 0:h.overlayModel)||void 0===d?void 0:d.activationSize)||void 0===l?void 0:l.value,m=20,"number"==typeof u?u:m);var u,m;return p?function(e,i,t,n,o,s){const a=100*i/n,r=100*t/o;if(e.has("left")&&a<s)return"left";if(e.has("right")&&a>100-s)return"right";if(e.has("top")&&r<s)return"top";if(e.has("bottom")&&r>100-s)return"bottom";if(!e.has("center"))return null;return"center"}(e,i,t,n,o,c):function(e,i,t,n,o,s){if(e.has("left")&&i<s)return"left";if(e.has("right")&&i>n-s)return"right";if(e.has("top")&&t<s)return"top";if(e.has("bottom")&&t>o-s)return"bottom";if(!e.has("center"))return null;return"center"}(e,i,t,n,o,c)}removeDropTarget(){this.targetElement&&(this._state=void 0,this.element.removeChild(this.targetElement),this.targetElement=void 0,this.overlayElement=void 0,this.element.classList.remove("drop-target"))}}class ie extends c{get element(){return this._element}constructor(){super(),this.disposable=new u,this._onDidFocus=new h,this.onDidFocus=this._onDidFocus.event,this._onDidBlur=new h,this.onDidBlur=this._onDidBlur.event,this._element=document.createElement("div"),this._element.className="content-container",this._element.tabIndex=-1,this.addDisposables(this._onDidFocus,this._onDidBlur)}show(){this.element.style.display=""}hide(){this.element.style.display="none"}openPanel(e){var i;if(this.panel===e)return;this.panel&&((null===(i=this.panel.view)||void 0===i?void 0:i.content)&&this._element.removeChild(this.panel.view.content.element),this.panel=void 0),this.panel=e;const t=new c;if(this.panel.view){const e=this.panel.view.content.onDidFocus,i=this.panel.view.content.onDidBlur,{onDidFocus:n,onDidBlur:o}=_(this._element);t.addDisposables(n((()=>this._onDidFocus.fire())),o((()=>this._onDidBlur.fire()))),e&&t.addDisposables(e((()=>this._onDidFocus.fire()))),i&&t.addDisposables(i((()=>this._onDidBlur.fire()))),this._element.appendChild(this.panel.view.content.element)}this.disposable.value=t}layout(e,i){}closePanel(){var e,i,t;(null===(t=null===(i=null===(e=this.panel)||void 0===e?void 0:e.view)||void 0===i?void 0:i.content)||void 0===t?void 0:t.element)&&(this._element.removeChild(this.panel.view.content.element),this.panel=void 0)}dispose(){this.disposable.dispose(),super.dispose()}}var te;e.DockviewDropTargets=void 0,(te=e.DockviewDropTargets||(e.DockviewDropTargets={}))[te.Tab=0]="Tab",te[te.Panel=1]="Panel",te[te.TabContainer=2]="TabContainer",te[te.Edge=3]="Edge";class ne extends c{constructor(e){super(),this.el=e,this.disposable=new u,this._onDragStart=new h,this.onDragStart=this._onDragStart.event,this.iframes=[],this.configure()}configure(){this.addDisposables(this._onDragStart,l(this.el,"dragstart",(e=>{this.iframes=[...f("iframe"),...f("webview")];for(const e of this.iframes)e.style.pointerEvents="none";this.el.classList.add("dv-dragged"),setTimeout((()=>this.el.classList.remove("dv-dragged")),0),this.disposable.value=this.getData(e.dataTransfer),e.dataTransfer&&(e.dataTransfer.effectAllowed="move",e.dataTransfer.setData("text/plain","__dockview_internal_drag_event__"))})),l(this.el,"dragend",(()=>{for(const e of this.iframes)e.style.pointerEvents="auto";this.iframes=[],this.disposable.dispose()})))}}class oe extends c{get element(){return this._element}constructor(i,t,o){super(),this.panelId=i,this.accessor=t,this.group=o,this._onChanged=new h,this.onChanged=this._onChanged.event,this._onDropped=new h,this.onDrop=this._onDropped.event,this.addDisposables(this._onChanged,this._onDropped),this._element=document.createElement("div"),this._element.className="tab",this._element.tabIndex=0,this._element.draggable=!0,w(this.element,"inactive-tab",!0),this.addDisposables(new class extends ne{constructor(){super(...arguments),this.panelTransfer=s.getInstance()}getData(){return this.panelTransfer.setData([new n(t.id,o.id,i)],n.prototype),{dispose:()=>{this.panelTransfer.clearData(n.prototype)}}}dispose(){}}(this._element)),this.addDisposables(l(this._element,"mousedown",(e=>{e.defaultPrevented||(e.stopPropagation(),this._onChanged.fire(e))}))),this.droptarget=new ee(this._element,{acceptedTargetZones:["center"],canDisplayOverlay:(i,t)=>{if(this.group.locked)return!1;const n=a();return n&&this.accessor.id===n.viewId?(null!==n.panelId||n.groupId!==this.group.id)&&this.panelId!==n.panelId:this.group.model.canDisplayOverlay(i,t,e.DockviewDropTargets.Tab)}}),this.addDisposables(this.droptarget.onDrop((e=>{this._onDropped.fire(e)})))}setActive(e){w(this.element,"active-tab",e),w(this.element,"inactive-tab",!e)}setContent(e){this.content&&this._element.removeChild(this.content.element),this.content=e,this._element.appendChild(this.content.element)}dispose(){super.dispose(),this.droptarget.dispose()}}class se extends ne{constructor(e,i,t){super(e),this.accessorId=i,this.group=t,this.panelTransfer=s.getInstance()}getData(e){this.panelTransfer.setData([new n(this.accessorId,this.group.id,null)],n.prototype);const i=window.getComputedStyle(this.el),t=i.getPropertyValue("--dv-activegroup-visiblepanel-tab-background-color"),o=i.getPropertyValue("--dv-activegroup-visiblepanel-tab-color");if(e){const i=document.createElement("div");i.style.backgroundColor=t,i.style.color=o,i.style.padding="2px 8px",i.style.height="24px",i.style.fontSize="11px",i.style.lineHeight="20px",i.style.borderRadius="12px",i.style.position="absolute",i.textContent=`Multiple Panels (${this.group.size})`,function(e,i){g(i,"dv-dragged"),document.body.appendChild(i),e.setDragImage(i,0,0),setTimeout((()=>{v(i,"dv-dragged"),i.remove()}),0)}(e,i)}return{dispose:()=>{this.panelTransfer.clearData(n.prototype)}}}dispose(){}}class ae extends c{get element(){return this._element}constructor(i,t){super(),this.accessor=i,this.group=t,this._onDrop=new h,this.onDrop=this._onDrop.event,this._element=document.createElement("div"),this._element.className="void-container",this._element.tabIndex=0,this._element.draggable=!0,this.addDisposables(this._onDrop,l(this._element,"click",(()=>{this.accessor.doSetGroupActive(this.group)})));const n=new se(this._element,i.id,t);this.voidDropTarget=new ee(this._element,{acceptedTargetZones:["center"],canDisplayOverlay:(i,n)=>{var o;const s=a();return s&&this.accessor.id===s.viewId?(null!==s.panelId||s.groupId!==this.group.id)&&(null===(o=(r=this.group.panels).length>0?r[r.length-1]:void 0)||void 0===o?void 0:o.id)!==s.panelId:t.model.canDisplayOverlay(i,n,e.DockviewDropTargets.Panel);var r}}),this.addDisposables(n,this.voidDropTarget.onDrop((e=>{this._onDrop.fire(e)})),this.voidDropTarget)}}class re extends c{get panels(){return this.tabs.map((e=>e.value.panelId))}get size(){return this.tabs.length}get hidden(){return this._hidden}set hidden(e){this._hidden=e,this.element.style.display=e?"none":""}show(){this.hidden||(this.element.style.display="")}hide(){this._element.style.display="none"}setActionElement(e){this.actions!==e&&(this.actions&&(this.actions.remove(),this.actions=void 0),e&&(this.actionContainer.appendChild(e),this.actions=e))}get element(){return this._element}isActive(e){return this.selectedIndex>-1&&this.tabs[this.selectedIndex].value===e}indexOf(e){return this.tabs.findIndex((i=>i.value.panelId===e))}constructor(e,i){super(),this.accessor=e,this.group=i,this.tabs=[],this.selectedIndex=-1,this._hidden=!1,this._onDrop=new h,this.onDrop=this._onDrop.event,this.addDisposables(this._onDrop),this._element=document.createElement("div"),this._element.className="tabs-and-actions-container",w(this._element,"dv-full-width-single-tab","fullwidth"===this.accessor.options.singleTabMode),this.addDisposables(this.accessor.onDidAddPanel((e=>{e.api.group===this.group&&w(this._element,"dv-single-tab",1===this.size)})),this.accessor.onDidRemovePanel((e=>{e.api.group===this.group&&w(this._element,"dv-single-tab",1===this.size)}))),this.actionContainer=document.createElement("div"),this.actionContainer.className="action-container",this.tabContainer=document.createElement("div"),this.tabContainer.className="tabs-container",this.voidContainer=new ae(this.accessor,this.group),this._element.appendChild(this.tabContainer),this._element.appendChild(this.voidContainer.element),this._element.appendChild(this.actionContainer),this.addDisposables(this.voidContainer,this.voidContainer.onDrop((e=>{this._onDrop.fire({event:e.nativeEvent,index:this.tabs.length})})),l(this.tabContainer,"mousedown",(e=>{if(e.defaultPrevented)return;0===e.button&&this.accessor.doSetGroupActive(this.group)})))}setActive(e){}addTab(e,i=this.tabs.length){if(i<0||i>this.tabs.length)throw new Error("invalid location");this.tabContainer.insertBefore(e.value.element,this.tabContainer.children[i]),this.tabs=[...this.tabs.slice(0,i),e,...this.tabs.slice(i)],this.selectedIndex<0&&(this.selectedIndex=i)}delete(e){const i=this.tabs.findIndex((i=>i.value.panelId===e)),t=this.tabs.splice(i,1)[0],{value:n,disposable:o}=t;o.dispose(),n.element.remove()}setActivePanel(e){this.tabs.forEach((i=>{const t=e.id===i.value.panelId;i.value.setActive(t)}))}openPanel(e,i=this.tabs.length){var t;if(this.tabs.find((i=>i.value.panelId===e.id)))return;const n=new oe(e.id,this.accessor,this.group);if(!(null===(t=e.view)||void 0===t?void 0:t.tab))throw new Error("invalid header component");n.setContent(e.view.tab);const o=c.from(n.onChanged((i=>{var t;const n=e.id===(null===(t=this.group.model.activePanel)||void 0===t?void 0:t.id)&&this.group.model.isContentFocused;0===i.button&&!i.defaultPrevented&&this.group.model.openPanel(e,{skipFocus:n})})),n.onDrop((e=>{this._onDrop.fire({event:e.nativeEvent,index:this.tabs.findIndex((e=>e.value===n))})}))),s={value:n,disposable:o};this.addTab(s,i)}closePanel(e){this.delete(e.id)}dispose(){super.dispose(),this.tabs.forEach((e=>{e.disposable.dispose()})),this.tabs=[]}}class he extends c{get element(){throw new Error("not supported")}get activePanel(){return this._activePanel}get locked(){return this._locked}set locked(e){this._locked=e,w(this.container,"locked-groupview",e)}get isActive(){return this._isGroupActive}get panels(){return this._panels}get size(){return this._panels.length}get isEmpty(){return 0===this._panels.length}get hasWatermark(){return!(!this.watermark||!this.container.contains(this.watermark.element))}get header(){return this.tabsContainer}get isContentFocused(){return!!document.activeElement&&b(document.activeElement,this.contentContainer.element)}constructor(i,t,n,o,s){super(),this.container=i,this.accessor=t,this.id=n,this.options=o,this.groupPanel=s,this._isGroupActive=!1,this._locked=!1,this.mostRecentlyUsed=[],this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this._width=0,this._height=0,this._panels=[],this._onMove=new h,this.onMove=this._onMove.event,this._onDidDrop=new h,this.onDidDrop=this._onDidDrop.event,this._onDidAddPanel=new h,this.onDidAddPanel=this._onDidAddPanel.event,this._onDidRemovePanel=new h,this.onDidRemovePanel=this._onDidRemovePanel.event,this._onDidActivePanelChange=new h,this.onDidActivePanelChange=this._onDidActivePanelChange.event,this.container.classList.add("groupview"),this.tabsContainer=new re(this.accessor,this.groupPanel),this.contentContainer=new ie,this.dropTarget=new ee(this.contentContainer.element,{acceptedTargetZones:["top","bottom","left","right","center"],canDisplayOverlay:(i,t)=>{if(this.locked&&"center"===t)return!1;const n=a();if(n&&n.viewId===this.accessor.id){if(n.groupId===this.id){if("center"===t)return!1;if(null===n.panelId)return!1}return!(1===this._panels.length&&n.groupId===this.id)}return this.canDisplayOverlay(i,t,e.DockviewDropTargets.Panel)}}),i.append(this.tabsContainer.element,this.contentContainer.element),this.header.hidden=!!o.hideHeader,this.locked=!!o.locked,this.addDisposables(this._onMove,this._onDidChange,this._onDidDrop,this._onDidAddPanel,this._onDidRemovePanel,this._onDidActivePanelChange,this.tabsContainer.onDrop((e=>{this.handleDropEvent(e.event,"center",e.index)})),this.contentContainer.onDidFocus((()=>{this.accessor.doSetGroupActive(this.groupPanel,!0)})),this.contentContainer.onDidBlur((()=>{})),this.dropTarget.onDrop((e=>{this.handleDropEvent(e.nativeEvent,e.position)})))}initialize(){var e,i;(null===(e=this.options)||void 0===e?void 0:e.panels)&&this.options.panels.forEach((e=>{this.doAddPanel(e)})),(null===(i=this.options)||void 0===i?void 0:i.activePanel)&&this.openPanel(this.options.activePanel),this.setActive(this.isActive,!0,!0),this.updateContainer(),this.accessor.options.createGroupControlElement&&(this._control=this.accessor.options.createGroupControlElement(this.groupPanel),this.addDisposables(this._control),this._control.init({containerApi:new Q(this.accessor),api:this.groupPanel.api}),this.tabsContainer.setActionElement(this._control.element))}indexOf(e){return this.tabsContainer.indexOf(e.id)}toJSON(){var e;const i={views:this.tabsContainer.panels,activeView:null===(e=this._activePanel)||void 0===e?void 0:e.id,id:this.id};return this.locked&&(i.locked=!0),this.header.hidden&&(i.hideHeader=!0),i}moveToNext(e){e||(e={}),e.panel||(e.panel=this.activePanel);const i=e.panel?this.panels.indexOf(e.panel):-1;let t;if(i<this.panels.length-1)t=i+1;else{if(e.suppressRoll)return;t=0}this.openPanel(this.panels[t])}moveToPrevious(e){if(e||(e={}),e.panel||(e.panel=this.activePanel),!e.panel)return;const i=this.panels.indexOf(e.panel);let t;if(i>0)t=i-1;else{if(e.suppressRoll)return;t=this.panels.length-1}this.openPanel(this.panels[t])}containsPanel(e){return this.panels.includes(e)}init(e){}update(e){}focus(){var e,i;null===(i=null===(e=this._activePanel)||void 0===e?void 0:e.focus)||void 0===i||i.call(e)}openPanel(e,i={}){("number"!=typeof i.index||i.index>this.panels.length)&&(i.index=this.panels.length);const t=!!i.skipSetPanelActive,n=!!i.skipSetGroupActive;e.updateParentGroup(this.groupPanel,!0),this._activePanel!==e?(this.doAddPanel(e,i.index,t),t||this.doSetActivePanel(e),n||this.accessor.doSetGroupActive(this.groupPanel,!!i.skipFocus),this.updateContainer()):n||this.accessor.doSetGroupActive(this.groupPanel)}removePanel(e){const i="string"==typeof e?e:e.id,t=this._panels.find((e=>e.id===i));if(!t)throw new Error("invalid operation");return this._removePanel(t)}closeAllPanels(){if(this.panels.length>0){const e=[...this.panels];for(const i of e)this.doClose(i)}else this.accessor.removeGroup(this.groupPanel)}closePanel(e){this.doClose(e)}doClose(e){this.accessor.removePanel(e)}isPanelActive(e){return this._activePanel===e}updateActions(e){this.tabsContainer.setActionElement(e)}setActive(e,i=!1,t=!1){var n,o,s,a;t||this.isActive!==e?(this._isGroupActive=e,w(this.container,"active-group",e),w(this.container,"inactive-group",!e),this.tabsContainer.setActive(this.isActive),!this._activePanel&&this.panels.length>0&&this.doSetActivePanel(this.panels[0]),this.updateContainer(),e&&(i||null===(a=null===(s=this._activePanel)||void 0===s?void 0:s.focus)||void 0===a||a.call(s))):i||null===(o=null===(n=this._activePanel)||void 0===n?void 0:n.focus)||void 0===o||o.call(n)}layout(e,i){var t;this._width=e,this._height=i,this.contentContainer.layout(this._width,this._height),(null===(t=this._activePanel)||void 0===t?void 0:t.layout)&&this._activePanel.layout(this._width,this._height)}_removePanel(e){const i=this._activePanel===e;if(this.doRemovePanel(e),i&&this.panels.length>0){const e=this.mostRecentlyUsed[0];this.openPanel(e)}return this._activePanel&&0===this.panels.length&&this.doSetActivePanel(void 0),this.updateContainer(),e}doRemovePanel(e){const i=this.panels.indexOf(e);this._activePanel===e&&this.contentContainer.closePanel(),this.tabsContainer.delete(e.id),this._panels.splice(i,1),this.mostRecentlyUsed.includes(e)&&this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(e),1),this._onDidRemovePanel.fire({panel:e})}doAddPanel(e,i=this.panels.length,t=!1){const n=this._panels.indexOf(e)>-1;this.tabsContainer.openPanel(e,i),t||this.contentContainer.openPanel(e),this.tabsContainer.show(),this.contentContainer.show(),n||(this.updateMru(e),this.panels.splice(i,0,e),this._onDidAddPanel.fire({panel:e}))}doSetActivePanel(e){this._activePanel=e,e&&(this.tabsContainer.setActivePanel(e),e.layout(this._width,this._height),this.updateMru(e),this._onDidActivePanelChange.fire({panel:e}))}updateMru(e){this.mostRecentlyUsed.includes(e)&&this.mostRecentlyUsed.splice(this.mostRecentlyUsed.indexOf(e),1),this.mostRecentlyUsed=[e,...this.mostRecentlyUsed]}updateContainer(){var e,i;if(w(this.container,"empty",this.isEmpty),this.panels.forEach((e=>e.updateParentGroup(this.groupPanel,this.isActive))),this.isEmpty&&!this.watermark){const e=this.accessor.createWatermarkComponent();e.init({containerApi:new Q(this.accessor),group:this.groupPanel}),this.watermark=e,l(this.watermark.element,"click",(()=>{this.isActive||this.accessor.doSetGroupActive(this.groupPanel)})),this.tabsContainer.hide(),this.contentContainer.element.appendChild(this.watermark.element),this.watermark.updateParentGroup(this.groupPanel,!0)}!this.isEmpty&&this.watermark&&(this.watermark.element.remove(),null===(i=(e=this.watermark).dispose)||void 0===i||i.call(e),this.watermark=void 0,this.tabsContainer.show())}canDisplayOverlay(e,i,t){return!!this.accessor.options.showDndOverlay&&this.accessor.options.showDndOverlay({nativeEvent:e,target:t,group:this.accessor.getPanel(this.id),position:i,getData:a})}handleDropEvent(e,i,t){const n=a();if(n&&n.viewId===this.accessor.id){if(null===n.panelId){const{groupId:e}=n;return void this._onMove.fire({target:i,groupId:e,index:t})}if(-1!==this.tabsContainer.indexOf(n.panelId)&&1===this.tabsContainer.size)return;const{groupId:e,panelId:o}=n;if(this.id===e&&!i){if(this.tabsContainer.indexOf(o)===t)return}this._onMove.fire({target:i,groupId:n.groupId,itemId:n.panelId,index:t})}else this._onDidDrop.fire({nativeEvent:e,position:i,index:t,getData:()=>a()})}dispose(){var e,i;super.dispose(),null===(i=null===(e=this.watermark)||void 0===e?void 0:e.dispose)||void 0===i||i.call(e);for(const e of this.panels)e.dispose();this.dropTarget.dispose(),this.tabsContainer.dispose(),this.contentContainer.dispose()}}class de extends c{get element(){return this._element}constructor(e){super(),e?this._element=e:(this._element=document.createElement("div"),this._element.style.height="100%",this._element.style.width="100%",this._element.className="dv-resizable-container"),this.addDisposables(m(this._element,(e=>{if(this.isDisposed)return;const{width:i,height:t}=e.contentRect;this.layout(i,t)})))}}const le=P();function pe(e){switch(e){case"left":return"left";case"right":return"right";case"above":return"top";case"below":return"bottom";default:return"center"}}class ce extends de{get id(){return this._id}get size(){return this._groups.size}get groups(){return Array.from(this._groups.values()).map((e=>e.value))}get width(){return this.gridview.width}get height(){return this.gridview.height}get minimumHeight(){return this.gridview.minimumHeight}get maximumHeight(){return this.gridview.maximumHeight}get minimumWidth(){return this.gridview.minimumWidth}get maximumWidth(){return this.gridview.maximumWidth}get activeGroup(){return this._activeGroup}constructor(i){super(i.parentElement),this._id=le.next(),this._groups=new Map,this._onDidLayoutChange=new h,this.onDidLayoutChange=this._onDidLayoutChange.event,this._onDidRemoveGroup=new h,this.onDidRemoveGroup=this._onDidRemoveGroup.event,this._onDidAddGroup=new h,this.onDidAddGroup=this._onDidAddGroup.event,this._onDidActiveGroupChange=new h,this.onDidActiveGroupChange=this._onDidActiveGroupChange.event,this._bufferOnDidLayoutChange=new p,this.gridview=new Y(!!i.proportionalLayout,i.styles,i.orientation),this.element.appendChild(this.gridview.element),this.layout(0,0,!0),this.addDisposables(this.gridview.onDidChange((()=>{this._bufferOnDidLayoutChange.fire()}))),this.addDisposables(e.DockviewEvent.any(this.onDidAddGroup,this.onDidRemoveGroup,this.onDidActiveGroupChange)((()=>{this._bufferOnDidLayoutChange.fire()})),this._bufferOnDidLayoutChange.onEvent((()=>{this._onDidLayoutChange.fire()})),this._bufferOnDidLayoutChange)}setVisible(e,i){this.gridview.setViewVisible(W(e.element),i),this._onDidLayoutChange.fire()}isVisible(e){return this.gridview.isViewVisible(W(e.element))}doAddGroup(i,t=[0],n){this.gridview.addView(i,null!=n?n:e.Sizing.Distribute,t),this._onDidAddGroup.fire(i),this.doSetGroupActive(i)}doRemoveGroup(i,t){if(!this._groups.has(i.id))throw new Error("invalid operation");const n=this._groups.get(i.id),o=this.gridview.remove(i,e.Sizing.Distribute);if(n&&!(null==t?void 0:t.skipDispose)&&(n.disposable.dispose(),n.value.dispose(),this._groups.delete(i.id)),this._onDidRemoveGroup.fire(i),!(null==t?void 0:t.skipActive)&&this._activeGroup===i){const e=Array.from(this._groups.values());this.doSetGroupActive(e.length>0?e[0].value:void 0)}return o}getPanel(e){var i;return null===(i=this._groups.get(e))||void 0===i?void 0:i.value}doSetGroupActive(e,i){var t,n,o;this._activeGroup!==e&&(this._activeGroup&&(this._activeGroup.setActive(!1),i||null===(n=(t=this._activeGroup).focus)||void 0===n||n.call(t)),e&&(e.setActive(!0),i||null===(o=e.focus)||void 0===o||o.call(e)),this._activeGroup=e,this._onDidActiveGroupChange.fire(e))}removeGroup(e){this.doRemoveGroup(e)}moveToNext(e){var i;if(e||(e={}),!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}const t=W(e.group.element),n=null===(i=this.gridview.next(t))||void 0===i?void 0:i.view;this.doSetGroupActive(n)}moveToPrevious(e){var i;if(e||(e={}),!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}const t=W(e.group.element),n=null===(i=this.gridview.previous(t))||void 0===i?void 0:i.view;this.doSetGroupActive(n)}layout(e,i,t){(t||e!==this.width||i!==this.height)&&(this.gridview.element.style.height=`${i}px`,this.gridview.element.style.width=`${e}px`,this.gridview.layout(e,i))}dispose(){super.dispose(),this._onDidActiveGroupChange.dispose(),this._onDidAddGroup.dispose(),this._onDidRemoveGroup.dispose(),this._onDidLayoutChange.dispose();for(const e of this.groups)e.dispose();this.gridview.dispose()}}class ue extends c{get isFocused(){return this._isFocused}get isActive(){return this._isActive}get isVisible(){return this._isVisible}get width(){return this._width}get height(){return this._height}constructor(e){super(),this.id=e,this._isFocused=!1,this._isActive=!1,this._isVisible=!0,this._width=0,this._height=0,this.panelUpdatesDisposable=new u,this._onDidDimensionChange=new h({replay:!0}),this.onDidDimensionsChange=this._onDidDimensionChange.event,this._onDidChangeFocus=new h({replay:!0}),this.onDidFocusChange=this._onDidChangeFocus.event,this._onFocusEvent=new h,this.onFocusEvent=this._onFocusEvent.event,this._onDidVisibilityChange=new h({replay:!0}),this.onDidVisibilityChange=this._onDidVisibilityChange.event,this._onVisibilityChange=new h,this.onVisibilityChange=this._onVisibilityChange.event,this._onDidActiveChange=new h({replay:!0}),this.onDidActiveChange=this._onDidActiveChange.event,this._onActiveChange=new h,this.onActiveChange=this._onActiveChange.event,this._onUpdateParameters=new h,this.onUpdateParameters=this._onUpdateParameters.event,this.addDisposables(this.panelUpdatesDisposable,this._onDidDimensionChange,this._onDidChangeFocus,this._onDidVisibilityChange,this._onDidActiveChange,this._onFocusEvent,this._onActiveChange,this._onVisibilityChange,this._onUpdateParameters,this.onDidFocusChange((e=>{this._isFocused=e.isFocused})),this.onDidActiveChange((e=>{this._isActive=e.isActive})),this.onDidVisibilityChange((e=>{this._isVisible=e.isVisible})),this.onDidDimensionsChange((e=>{this._width=e.width,this._height=e.height})))}initialize(e){this.panelUpdatesDisposable.value=this._onUpdateParameters.event((i=>{e.update({params:{params:i}})}))}setVisible(e){this._onVisibilityChange.fire({isVisible:e})}setActive(){this._onActiveChange.fire()}updateParameters(e){this._onUpdateParameters.fire(e)}dispose(){super.dispose()}}class me extends ue{constructor(e){super(e),this._onDidConstraintsChangeInternal=new h,this.onDidConstraintsChangeInternal=this._onDidConstraintsChangeInternal.event,this._onDidConstraintsChange=new h({replay:!0}),this.onDidConstraintsChange=this._onDidConstraintsChange.event,this._onDidSizeChange=new h,this.onDidSizeChange=this._onDidSizeChange.event,this.addDisposables(this._onDidConstraintsChangeInternal,this._onDidConstraintsChange,this._onDidSizeChange)}setConstraints(e){this._onDidConstraintsChangeInternal.fire(e)}setSize(e){this._onDidSizeChange.fire(e)}}class ve extends me{set pane(e){this._pane=e}constructor(e){super(e),this._onDidExpansionChange=new h({replay:!0}),this.onDidExpansionChange=this._onDidExpansionChange.event,this._onMouseEnter=new h({}),this.onMouseEnter=this._onMouseEnter.event,this._onMouseLeave=new h({}),this.onMouseLeave=this._onMouseLeave.event,this.addDisposables(this._onDidExpansionChange,this._onMouseEnter,this._onMouseLeave)}setExpanded(e){var i;null===(i=this._pane)||void 0===i||i.setExpanded(e)}get isExpanded(){var e;return!!(null===(e=this._pane)||void 0===e?void 0:e.isExpanded())}}class ge extends c{get element(){return this._element}get width(){return this._width}get height(){return this._height}get params(){var e;return null===(e=this._params)||void 0===e?void 0:e.params}constructor(e,i,t){super(),this.id=e,this.component=i,this.api=t,this._height=0,this._width=0,this._element=document.createElement("div"),this._element.tabIndex=-1,this._element.style.outline="none",this._element.style.height="100%",this._element.style.width="100%",this._element.style.overflow="hidden";const{onDidFocus:n,onDidBlur:o}=_(this._element);this.addDisposables(this.api,n((()=>{this.api._onDidChangeFocus.fire({isFocused:!0})})),o((()=>{this.api._onDidChangeFocus.fire({isFocused:!1})})))}focus(){this.api._onFocusEvent.fire()}layout(e,i){this._width=e,this._height=i,this.api._onDidDimensionChange.fire({width:e,height:i}),this.part&&this._params&&this.part.update(this._params.params)}init(e){this._params=e,this.part=this.getComponent()}update(e){var i,t;this._params=Object.assign(Object.assign({},this._params),{params:Object.assign(Object.assign({},null===(i=this._params)||void 0===i?void 0:i.params),e.params)}),null===(t=this.part)||void 0===t||t.update({params:this._params.params})}toJSON(){var e,i;const t=null!==(i=null===(e=this._params)||void 0===e?void 0:e.params)&&void 0!==i?i:{};return{id:this.id,component:this.component,params:Object.keys(t).length>0?t:void 0}}dispose(){var e;super.dispose(),this.api.dispose(),null===(e=this.part)||void 0===e||e.dispose()}}class we extends ge{set orientation(e){this._orientation=e}get orientation(){return this._orientation}get minimumSize(){return this.headerSize+(this.isExpanded()?this._minimumBodySize:0)}get maximumSize(){return this.headerSize+(this.isExpanded()?this._maximumBodySize:0)}get size(){return this._size}get orthogonalSize(){return this._orthogonalSize}set orthogonalSize(e){this._orthogonalSize=e}get minimumBodySize(){return this._minimumBodySize}set minimumBodySize(e){this._minimumBodySize="number"==typeof e?e:0}get maximumBodySize(){return this._maximumBodySize}set maximumBodySize(e){this._maximumBodySize="number"==typeof e?e:Number.POSITIVE_INFINITY}get headerVisible(){return this._headerVisible}set headerVisible(e){this._headerVisible=e,this.header.style.display=e?"":"none"}constructor(e,i,t,n,o,s){super(e,i,new ve(e)),this.headerComponent=t,this._onDidChangeExpansionState=new h({replay:!0}),this.onDidChangeExpansionState=this._onDidChangeExpansionState.event,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this.headerSize=22,this._orthogonalSize=0,this._size=0,this._minimumBodySize=100,this._maximumBodySize=Number.POSITIVE_INFINITY,this._isExpanded=!1,this.expandedSize=0,this.api.pane=this,this.api.initialize(this),this._isExpanded=o,this._headerVisible=s,this._onDidChangeExpansionState.fire(this.isExpanded()),this._orientation=n,this.element.classList.add("pane"),this.addDisposables(this.api.onDidSizeChange((e=>{this._onDidChange.fire({size:e.size})})),l(this.element,"mouseenter",(e=>{this.api._onMouseEnter.fire(e)})),l(this.element,"mouseleave",(e=>{this.api._onMouseLeave.fire(e)}))),this.addDisposables(this._onDidChangeExpansionState,this.onDidChangeExpansionState((e=>{this.api._onDidExpansionChange.fire({isExpanded:e})})),this.api.onDidFocusChange((e=>{this.header&&(e.isFocused?g(this.header,"focused"):v(this.header,"focused"))}))),this.renderOnce()}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}isExpanded(){return this._isExpanded}setExpanded(e){this._isExpanded!==e&&(this._isExpanded=e,e?(this.animationTimer&&clearTimeout(this.animationTimer),this.body&&this.element.appendChild(this.body)):this.animationTimer=setTimeout((()=>{var e;null===(e=this.body)||void 0===e||e.remove()}),200),this._onDidChange.fire(e?{size:this.width}:{}),this._onDidChangeExpansionState.fire(e))}layout(i,t){this._size=i,this._orthogonalSize=t;const[n,o]=this.orientation===e.Orientation.HORIZONTAL?[i,t]:[t,i];this.isExpanded()&&(this.expandedSize=n),super.layout(n,o)}init(e){var i,t;super.init(e),"number"==typeof e.minimumBodySize&&(this.minimumBodySize=e.minimumBodySize),"number"==typeof e.maximumBodySize&&(this.maximumBodySize=e.maximumBodySize),this.bodyPart=this.getBodyComponent(),this.headerPart=this.getHeaderComponent(),this.bodyPart.init(Object.assign(Object.assign({},e),{api:this.api})),this.headerPart.init(Object.assign(Object.assign({},e),{api:this.api})),null===(i=this.body)||void 0===i||i.append(this.bodyPart.element),null===(t=this.header)||void 0===t||t.append(this.headerPart.element),"boolean"==typeof e.isExpanded&&this.setExpanded(e.isExpanded)}toJSON(){const e=this._params;return Object.assign(Object.assign({},super.toJSON()),{headerComponent:this.headerComponent,title:e.title})}renderOnce(){this.header=document.createElement("div"),this.header.tabIndex=0,this.header.className="pane-header",this.header.style.height=`${this.headerSize}px`,this.header.style.lineHeight=`${this.headerSize}px`,this.header.style.minHeight=`${this.headerSize}px`,this.header.style.maxHeight=`${this.headerSize}px`,this.element.appendChild(this.header),this.body=document.createElement("div"),this.body.className="pane-body",this.element.appendChild(this.body)}getComponent(){return{update:e=>{var i,t;null===(i=this.bodyPart)||void 0===i||i.update({params:e}),null===(t=this.headerPart)||void 0===t||t.update({params:e})},dispose:()=>{var e,i;null===(e=this.bodyPart)||void 0===e||e.dispose(),null===(i=this.headerPart)||void 0===i||i.dispose()}}}}class be extends we{constructor(e,i,t,n,o,s,a){super(i,t,n,o,s,!0),this.accessor=e,this._onDidDrop=new h,this.onDidDrop=this._onDidDrop.event,a||this.initDragFeatures()}initDragFeatures(){if(!this.header)return;const e=this.id,i=this.accessor.id;this.header.draggable=!0,this.handler=new class extends ne{getData(){return s.getInstance().setData([new o(i,e)],o.prototype),{dispose:()=>{s.getInstance().clearData(o.prototype)}}}}(this.header),this.target=new ee(this.element,{acceptedTargetZones:["top","bottom"],overlayModel:{activationSize:{type:"percentage",value:50}},canDisplayOverlay:e=>{const i=r();return!(!i||i.paneId===this.id||i.viewId!==this.accessor.id)||!!this.accessor.options.showDndOverlay&&this.accessor.options.showDndOverlay({nativeEvent:e,getData:r,panel:this})}}),this.addDisposables(this._onDidDrop,this.handler,this.target,this.target.onDrop((e=>{this.onDrop(e)})))}onDrop(e){const i=r();if(!i||i.viewId!==this.accessor.id)return void this._onDidDrop.fire(Object.assign(Object.assign({},e),{panel:this,api:new X(this.accessor),getData:r}));const t=this._params.containerApi,n=i.paneId,o=t.getPanel(n);if(!o)return void this._onDidDrop.fire(Object.assign(Object.assign({},e),{panel:this,getData:r,api:new X(this.accessor)}));const s=t.panels,a=s.indexOf(o);let h=t.panels.indexOf(this);"left"!==e.position&&"top"!==e.position||(h=Math.max(0,h-1)),"right"!==e.position&&"bottom"!==e.position||(a>h&&h++,h=Math.min(s.length-1,h)),t.movePanel(a,h)}}class fe extends ue{constructor(e,i){super(e),this._onDidConstraintsChangeInternal=new h,this.onDidConstraintsChangeInternal=this._onDidConstraintsChangeInternal.event,this._onDidConstraintsChange=new h({replay:!0}),this.onDidConstraintsChange=this._onDidConstraintsChange.event,this._onDidSizeChange=new h,this.onDidSizeChange=this._onDidSizeChange.event,this.addDisposables(this._onDidConstraintsChangeInternal,this._onDidConstraintsChange,this._onDidSizeChange),i&&this.initialize(i)}setConstraints(e){this._onDidConstraintsChangeInternal.fire(e)}setSize(e){this._onDidSizeChange.fire(e)}}class _e extends ge{get priority(){return this._priority}get snap(){return this._snap}get minimumWidth(){const e="function"==typeof this._minimumWidth?this._minimumWidth():this._minimumWidth;return e!==this._evaluatedMinimumWidth&&(this._evaluatedMinimumWidth=e,this.updateConstraints()),e}get minimumHeight(){const e="function"==typeof this._minimumHeight?this._minimumHeight():this._minimumHeight;return e!==this._evaluatedMinimumHeight&&(this._evaluatedMinimumHeight=e,this.updateConstraints()),e}get maximumHeight(){const e="function"==typeof this._maximumHeight?this._maximumHeight():this._maximumHeight;return e!==this._evaluatedMaximumHeight&&(this._evaluatedMaximumHeight=e,this.updateConstraints()),e}get maximumWidth(){const e="function"==typeof this._maximumWidth?this._maximumWidth():this._maximumWidth;return e!==this._evaluatedMaximumWidth&&(this._evaluatedMaximumWidth=e,this.updateConstraints()),e}get isActive(){return this.api.isActive}constructor(e,i,t){super(e,i,new fe(e)),this._evaluatedMinimumWidth=0,this._evaluatedMaximumWidth=Number.MAX_SAFE_INTEGER,this._evaluatedMinimumHeight=0,this._evaluatedMaximumHeight=Number.MAX_SAFE_INTEGER,this._minimumWidth=0,this._minimumHeight=0,this._maximumWidth=Number.MAX_SAFE_INTEGER,this._maximumHeight=Number.MAX_SAFE_INTEGER,this._snap=!1,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,"number"==typeof(null==t?void 0:t.minimumWidth)&&(this._minimumWidth=t.minimumWidth),"number"==typeof(null==t?void 0:t.maximumWidth)&&(this._maximumWidth=t.maximumWidth),"number"==typeof(null==t?void 0:t.minimumHeight)&&(this._minimumHeight=t.minimumHeight),"number"==typeof(null==t?void 0:t.maximumHeight)&&(this._maximumHeight=t.maximumHeight),this.api.initialize(this),this.addDisposables(this._onDidChange,this.api.onVisibilityChange((e=>{const{isVisible:i}=e,{accessor:t}=this._params;t.setVisible(this,i)})),this.api.onActiveChange((()=>{const{accessor:e}=this._params;e.setActive(this)})),this.api.onDidConstraintsChangeInternal((e=>{"number"!=typeof e.minimumWidth&&"function"!=typeof e.minimumWidth||(this._minimumWidth=e.minimumWidth),"number"!=typeof e.minimumHeight&&"function"!=typeof e.minimumHeight||(this._minimumHeight=e.minimumHeight),"number"!=typeof e.maximumWidth&&"function"!=typeof e.maximumWidth||(this._maximumWidth=e.maximumWidth),"number"!=typeof e.maximumHeight&&"function"!=typeof e.maximumHeight||(this._maximumHeight=e.maximumHeight)})),this.api.onDidSizeChange((e=>{this._onDidChange.fire({height:e.height,width:e.width})})))}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}init(e){e.maximumHeight&&(this._maximumHeight=e.maximumHeight),e.minimumHeight&&(this._minimumHeight=e.minimumHeight),e.maximumWidth&&(this._maximumWidth=e.maximumWidth),e.minimumWidth&&(this._minimumWidth=e.minimumWidth),this._priority=e.priority,this._snap=!!e.snap,super.init(e),"boolean"==typeof e.isVisible&&this.setVisible(e.isVisible)}updateConstraints(){this.api._onDidConstraintsChange.fire({minimumWidth:this._evaluatedMinimumWidth,maximumWidth:this._evaluatedMaximumWidth,minimumHeight:this._evaluatedMinimumHeight,maximumHeight:this._evaluatedMaximumHeight})}toJSON(){const e=super.toJSON(),i=e=>e===Number.MAX_SAFE_INTEGER?void 0:e,t=e=>e<=0?void 0:e;return Object.assign(Object.assign({},e),{minimumHeight:t(this.minimumHeight),maximumHeight:i(this.maximumHeight),minimumWidth:t(this.minimumWidth),maximumWidth:i(this.maximumWidth),snap:this.snap,priority:this.priority})}}class De extends _e{get panels(){return this._model.panels}get activePanel(){return this._model.activePanel}get size(){return this._model.size}get model(){return this._model}get locked(){return this._model.locked}set locked(e){this._model.locked=e}get header(){return this._model.header}constructor(e,i,t){super(i,"groupview_default",{minimumHeight:100,minimumWidth:100}),this._model=new he(this.element,e,i,t,this)}initialize(){this._model.initialize()}setActive(e){super.setActive(e),this.model.setActive(e)}layout(e,i){super.layout(e,i),this.model.layout(e,i)}getComponent(){return this._model}toJSON(){return this.model.toJSON()}}function ye(e){return!!e.referencePanel}function Ce(e){return!!e.referenceGroup}function ze(e){return!!e.referencePanel}function xe(e){return!!e.referenceGroup}class Se extends fe{get title(){return this.panel.title}get isGroupActive(){var e;return!!(null===(e=this.group)||void 0===e?void 0:e.isActive)}set group(e){const i=this.isGroupActive;this._group=e,this._onDidGroupChange.fire(),this._group&&(this.disposable.value=this._group.api.onDidActiveChange((()=>{this._onDidActiveGroupChange.fire()})),this.isGroupActive!==i&&this._onDidActiveGroupChange.fire())}get group(){return this._group}constructor(e,i){super(e.id),this.panel=e,this._onDidTitleChange=new h,this.onDidTitleChange=this._onDidTitleChange.event,this._onDidActiveGroupChange=new h,this.onDidActiveGroupChange=this._onDidActiveGroupChange.event,this._onDidGroupChange=new h,this.onDidGroupChange=this._onDidGroupChange.event,this.disposable=new u,this.initialize(e),this._group=i,this.addDisposables(this.disposable,this._onDidTitleChange,this._onDidGroupChange,this._onDidActiveGroupChange)}setTitle(e){this.panel.update({params:{title:e}})}close(){this.group.model.closePanel(this.panel)}}class Ee extends c{get params(){return this._params}get title(){return this._title}get group(){return this._group}constructor(e,i,t,n,o){super(),this.id=e,this.containerApi=t,this.view=o,this._title="",this._group=n,this.api=new Se(this,this._group),this.addDisposables(this.api.onActiveChange((()=>{i.setActivePanel(this)})),this.api.onDidSizeChange((e=>{this.group.api.setSize(e)})))}init(e){this._params=e.params,this.setTitle(e.title),this.view.init(Object.assign(Object.assign({},e),{api:this.api,containerApi:this.containerApi}))}focus(){this.api._onFocusEvent.fire()}toJSON(){return{id:this.id,contentComponent:this.view.contentComponent,tabComponent:this.view.tabComponent,params:Object.keys(this._params||{}).length>0?this._params:void 0,title:this.title}}setTitle(e){var i,t;e!==(null===(i=this._params)||void 0===i?void 0:i.title)&&(this._title=e,null===(t=this.view)||void 0===t||t.update({params:{params:this._params,title:this.title}}),this.api._onDidTitleChange.fire({title:e}))}update(e){var i;const t=e.params;this._params=Object.assign(Object.assign({},this._params||{}),e.params.params),t.title!==this.title&&(this._title=t.title,this.api._onDidTitleChange.fire({title:this.title})),null===(i=this.view)||void 0===i||i.update({params:{params:this._params,title:this.title}})}updateParentGroup(e,i){this._group=e,this.api.group=e;const t=this._group.model.isPanelActive(this);this.api._onDidActiveChange.fire({isActive:i&&t}),this.api._onDidVisibilityChange.fire({isVisible:t}),this.view.updateParentGroup(this._group,this._group.model.isPanelActive(this))}layout(e,i){this.api._onDidDimensionChange.fire({width:e,height:i}),this.view.layout(e,i)}dispose(){this.api.dispose(),this.view.dispose()}}const Pe=e=>{const i=document.createElementNS("http://www.w3.org/2000/svg","svg");i.setAttributeNS(null,"height",e.height),i.setAttributeNS(null,"width",e.width),i.setAttributeNS(null,"viewBox",e.viewbox),i.setAttributeNS(null,"aria-hidden","false"),i.setAttributeNS(null,"focusable","false"),i.classList.add("dockview-svg");const t=document.createElementNS("http://www.w3.org/2000/svg","path");return t.setAttributeNS(null,"d",e.path),i.appendChild(t),i},Ae=()=>Pe({width:"11",height:"11",viewbox:"0 0 28 28",path:"M2.1 27.3L0 25.2L11.55 13.65L0 2.1L2.1 0L13.65 11.55L25.2 0L27.3 2.1L15.75 13.65L27.3 25.2L25.2 27.3L13.65 15.75L2.1 27.3Z"});class ke extends c{get element(){return this._element}constructor(){super(),this.params={},this._element=document.createElement("div"),this._element.className="default-tab",this._content=document.createElement("div"),this._content.className="tab-content",this._actionContainer=document.createElement("div"),this._actionContainer.className="action-container",this._list=document.createElement("ul"),this._list.className="tab-list",this.action=document.createElement("div"),this.action.className="tab-action",this.action.appendChild(Ae()),this._element.appendChild(this._content),this._element.appendChild(this._actionContainer),this._actionContainer.appendChild(this._list),this._list.appendChild(this.action),this.addDisposables(l(this._actionContainer,"mousedown",(e=>{e.preventDefault()}))),this.render()}update(e){this.params=Object.assign(Object.assign({},this.params),e.params),this.render()}focus(){}init(e){this.params=e,this._content.textContent=e.title,l(this.action,"click",(e=>{e.preventDefault(),this.params.api.close()}))}onGroupChange(e){this.render()}onPanelVisibleChange(e){this.render()}layout(e,i){}render(){this._content.textContent!==this.params.title&&(this._content.textContent=this.params.title)}}class Oe{get content(){return this._content}get tab(){return this._tab}constructor(e,i,t,n){var o;this.accessor=e,this.id=i,this.contentComponent=t,this.tabComponent=n,this._group=null,this._isPanelVisible=null,this._content=this.createContentComponent(this.id,t),this._tab=null!==(o=this.createTabComponent(this.id,n))&&void 0!==o?o:new ke}init(e){this.content.init(Object.assign(Object.assign({},e),{tab:this.tab})),this.tab.init(e)}updateParentGroup(e,i){e!==this._group&&(this._group=e,this._content.onGroupChange&&this._content.onGroupChange(e),this._tab.onGroupChange&&this._tab.onGroupChange(e)),i!==this._isPanelVisible&&(this._isPanelVisible=i,this._content.onPanelVisibleChange&&this._content.onPanelVisibleChange(i),this._tab.onPanelVisibleChange&&this._tab.onPanelVisibleChange(i))}layout(e,i){var t,n;null===(n=(t=this.content).layout)||void 0===n||n.call(t,e,i)}update(e){var i,t,n,o;null===(t=(i=this.content).update)||void 0===t||t.call(i,e),null===(o=(n=this.tab).update)||void 0===o||o.call(n,e)}dispose(){var e,i,t,n;null===(i=(e=this.content).dispose)||void 0===i||i.call(e),null===(n=(t=this.tab).dispose)||void 0===n||n.call(t)}createContentComponent(e,i){var t;return y(e,i,this.accessor.options.components||{},this.accessor.options.frameworkComponents,null===(t=this.accessor.options.frameworkComponentFactory)||void 0===t?void 0:t.content)}createTabComponent(e,i){var t;return y(e,i,this.accessor.options.tabComponents||{},this.accessor.options.frameworkTabComponents,null===(t=this.accessor.options.frameworkComponentFactory)||void 0===t?void 0:t.tab,(()=>new ke))}}class Ie{constructor(e){this.layout=e}fromJSON(e,i){var t,n,o;const s=e.id,a=e.params,r=e.title,h=e.view,d=h?h.content.id:e.contentComponent||"unknown",l=h?null===(t=h.tab)||void 0===t?void 0:t.id:e.tabComponent;l?y(s,l,this.layout.options.tabComponents,this.layout.options.frameworkTabComponents,null===(n=this.layout.options.frameworkComponentFactory)||void 0===n?void 0:n.tab,(()=>new ke)):this.layout.options.defaultTabComponent?y(s,this.layout.options.defaultTabComponent,this.layout.options.tabComponents,this.layout.options.frameworkTabComponents,null===(o=this.layout.options.frameworkComponentFactory)||void 0===o?void 0:o.tab,(()=>new ke)):new ke;const p=new Oe(this.layout,s,d,l),c=new Ee(s,this.layout,new Q(this.layout),i,p);return c.init({title:r||s,params:a||{}}),c}}class Ve extends c{get element(){return this._element}constructor(){super(),this._element=document.createElement("div"),this._element.className="watermark";const e=document.createElement("div");e.className="watermark-title";const i=document.createElement("span");i.style.flexGrow="1";const t=document.createElement("div");t.className="watermark-content",this._element.appendChild(e),this._element.appendChild(t);const n=document.createElement("div");n.className="actions-container";const o=document.createElement("div");o.className="close-action",o.appendChild(Ae()),n.appendChild(o),e.appendChild(i),e.appendChild(n),this.addDisposables(l(o,"click",(e=>{var i;e.preventDefault(),this._group&&(null===(i=this._api)||void 0===i||i.removeGroup(this._group))})))}update(e){}focus(){}layout(e,i){}init(e){this._api=e.containerApi,this.render()}updateParentGroup(e,i){this._group=e,this.render()}dispose(){super.dispose()}render(){const e=!!(this._api&&this._api.size<=1);w(this.element,"has-actions",e)}}class Ne extends c{get element(){return this._element}constructor(){super(),this._expandedIcon=Pe({width:"11",height:"11",viewbox:"0 0 24 15",path:"M12 14.15L0 2.15L2.15 0L12 9.9L21.85 0.0499992L24 2.2L12 14.15Z"}),this._collapsedIcon=Pe({width:"11",height:"11",viewbox:"0 0 15 25",path:"M2.15 24.1L0 21.95L9.9 12.05L0 2.15L2.15 0L14.2 12.05L2.15 24.1Z"}),this.disposable=new u,this.apiRef={api:null},this._element=document.createElement("div"),this.element.className="default-header",this._content=document.createElement("span"),this._expander=document.createElement("div"),this._expander.className="dockview-pane-header-icon",this.element.appendChild(this._expander),this.element.appendChild(this._content),this.addDisposables(l(this._element,"click",(()=>{var e;null===(e=this.apiRef.api)||void 0===e||e.setExpanded(!this.apiRef.api.isExpanded)})))}init(e){this.apiRef.api=e.api,this._content.textContent=e.title,this.updateIcon(),this.disposable.value=e.api.onDidExpansionChange((()=>{this.updateIcon()}))}updateIcon(){var e;const i=!!(null===(e=this.apiRef.api)||void 0===e?void 0:e.isExpanded);w(this._expander,"collapsed",!i),i?(this._expander.contains(this._collapsedIcon)&&this._collapsedIcon.remove(),this._expander.contains(this._expandedIcon)||this._expander.appendChild(this._expandedIcon)):(this._expander.contains(this._expandedIcon)&&this._expandedIcon.remove(),this._expander.contains(this._collapsedIcon)||this._expander.appendChild(this._collapsedIcon))}update(e){}dispose(){this.disposable.dispose(),super.dispose()}}const Le=P();class Ge extends be{constructor(e){super(e.accessor,e.id,e.component,e.headerComponent,e.orientation,e.isExpanded,e.disableDnd),this.options=e}getBodyComponent(){return this.options.body}getHeaderComponent(){return this.options.header}}e.BaseGrid=ce,e.ContentContainer=ie,e.DefaultDockviewDeserialzier=Ie,e.DefaultTab=ke,e.DockviewApi=Q,e.DockviewComponent=class extends ce{get orientation(){return this.gridview.orientation}get totalPanels(){return this.panels.length}get panels(){return this.groups.flatMap((e=>e.panels))}get options(){return this._options}get activePanel(){const e=this.activeGroup;if(e)return e.activePanel}constructor(i){super({proportionalLayout:!0,orientation:i.orientation||e.Orientation.HORIZONTAL,styles:i.styles,parentElement:i.parentElement}),this.nextGroupId=P(),this._deserializer=new Ie(this),this.watermark=null,this._onDidDrop=new h,this.onDidDrop=this._onDidDrop.event,this._onDidRemovePanel=new h,this.onDidRemovePanel=this._onDidRemovePanel.event,this._onDidAddPanel=new h,this.onDidAddPanel=this._onDidAddPanel.event,this._onDidLayoutFromJSON=new h,this.onDidLayoutFromJSON=this._onDidLayoutFromJSON.event,this._onDidActivePanelChange=new h,this.onDidActivePanelChange=this._onDidActivePanelChange.event,this.element.classList.add("dv-dockview"),this.addDisposables(this._onDidDrop,e.DockviewEvent.any(this.onDidAddGroup,this.onDidRemoveGroup)((()=>{this.updateWatermark()})),e.DockviewEvent.any(this.onDidAddPanel,this.onDidRemovePanel,this.onDidActivePanelChange)((()=>{this._bufferOnDidLayoutChange.fire()}))),this._options=i,this.options.components||(this.options.components={}),this.options.frameworkComponents||(this.options.frameworkComponents={}),this.options.frameworkTabComponents||(this.options.frameworkTabComponents={}),this.options.tabComponents||(this.options.tabComponents={}),this.options.watermarkComponent||this.options.watermarkFrameworkComponent||(this.options.watermarkComponent=Ve);const t=new ee(this.element,{canDisplayOverlay:(i,t)=>{const n=a();return n?n.viewId===this.id:!!this.options.showDndOverlay&&this.options.showDndOverlay({nativeEvent:i,position:t,target:e.DockviewDropTargets.Edge,getData:a})},acceptedTargetZones:["top","bottom","left","right"],overlayModel:{activationSize:{type:"pixels",value:10},size:{type:"pixels",value:20}}});this.addDisposables(t,t.onDrop((e=>{const i=a();i?this.moveGroupOrPanel(this.orthogonalize(e.position),i.groupId,i.panelId||void 0,"center"):this._onDidDrop.fire(Object.assign(Object.assign({},e),{api:this._api,group:null,getData:a}))}))),this._api=new Q(this),this.updateWatermark()}orthogonalize(i){switch(i){case"top":case"bottom":this.gridview.orientation===e.Orientation.HORIZONTAL&&this.gridview.insertOrthogonalSplitviewAtRoot();break;case"left":case"right":this.gridview.orientation===e.Orientation.VERTICAL&&this.gridview.insertOrthogonalSplitviewAtRoot()}switch(i){case"top":case"left":return this.createGroupAtLocation([0]);case"bottom":case"right":return this.createGroupAtLocation([this.gridview.length]);default:throw new Error(`unsupported position ${i}`)}}updateOptions(e){const i="string"==typeof e.orientation&&this.gridview.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),i&&(this.gridview.orientation=e.orientation),this.layout(this.gridview.width,this.gridview.height,!0)}focus(){var e;null===(e=this.activeGroup)||void 0===e||e.focus()}getGroupPanel(e){return this.panels.find((i=>i.id===e))}setActivePanel(e){this.doSetGroupActive(e.group),e.group.model.openPanel(e)}moveToNext(e={}){var i;if(!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}if(e.includePanel&&e.group&&e.group.activePanel!==e.group.panels[e.group.panels.length-1])return void e.group.model.moveToNext({suppressRoll:!0});const t=W(e.group.element),n=null===(i=this.gridview.next(t))||void 0===i?void 0:i.view;this.doSetGroupActive(n)}moveToPrevious(e={}){var i;if(!e.group){if(!this.activeGroup)return;e.group=this.activeGroup}if(e.includePanel&&e.group&&e.group.activePanel!==e.group.panels[0])return void e.group.model.moveToPrevious({suppressRoll:!0});const t=W(e.group.element),n=null===(i=this.gridview.previous(t))||void 0===i?void 0:i.view;n&&this.doSetGroupActive(n)}toJSON(){var e;return{grid:this.gridview.serialize(),panels:this.panels.reduce(((e,i)=>(e[i.id]=i.toJSON(),e)),{}),activeGroup:null===(e=this.activeGroup)||void 0===e?void 0:e.id}}fromJSON(e){this.clear();const{grid:i,panels:t,activeGroup:n}=e;if("branch"!==i.root.type||!Array.isArray(i.root.data))throw new Error("root must be of type branch");if(this.gridview.deserialize(i,{fromJSON:e=>{const{id:i,locked:n,hideHeader:o,views:s,activeView:a}=e.data,r=this.createGroup({id:i,locked:!!n,hideHeader:!!o});this._onDidAddGroup.fire(r);for(const e of s){const i=this._deserializer.fromJSON(t[e],r),n="string"==typeof a&&a===i.id;r.model.openPanel(i,{skipSetPanelActive:!n,skipSetGroupActive:!0})}return!r.activePanel&&r.panels.length>0&&r.model.openPanel(r.panels[r.panels.length-1],{skipSetGroupActive:!0}),r}}),"string"==typeof n){const e=this.getPanel(n);e&&this.doSetGroupActive(e)}this.gridview.layout(this.width,this.height),this._onDidLayoutFromJSON.fire()}clear(){const e=Array.from(this._groups.values()).map((e=>e.value)),i=!!this.activeGroup,t=!!this.activePanel;for(const i of e)this.removeGroup(i,!0);i&&this.doSetGroupActive(void 0),t&&this._onDidActivePanelChange.fire(void 0),this.gridview.clear()}closeAllGroups(){for(const e of this._groups.entries()){const[i,t]=e;t.value.model.closeAllPanels()}}addPanel(e){var i,t;if(this.panels.find((i=>i.id===e.id)))throw new Error(`panel with id ${e.id} already exists`);let n,o;if(e.position)if(ye(e.position)){const i="string"==typeof e.position.referencePanel?this.getGroupPanel(e.position.referencePanel):e.position.referencePanel;if(!i)throw new Error(`referencePanel ${e.position.referencePanel} does not exist`);n=this.findGroup(i)}else{if(!Ce(e.position)){const i=this.orthogonalize(K(e.position.direction)),t=this.createPanel(e,i);return i.model.openPanel(t),t}if(n="string"==typeof e.position.referenceGroup?null===(i=this._groups.get(e.position.referenceGroup))||void 0===i?void 0:i.value:e.position.referenceGroup,!n)throw new Error(`referencePanel ${e.position.referenceGroup} does not exist`)}else n=this.activeGroup;if(n){const i=pe((null===(t=e.position)||void 0===t?void 0:t.direction)||"within");if("center"===i)o=this.createPanel(e,n),n.model.openPanel(o);else{const t=W(n.element),s=J(this.gridview.orientation,t,i),a=this.createGroupAtLocation(s);o=this.createPanel(e,a),a.model.openPanel(o)}}else{const i=this.createGroupAtLocation();o=this.createPanel(e,i),i.model.openPanel(o)}return o}removePanel(e,i={removeEmptyGroup:!0,skipDispose:!1}){const t=e.group;if(!t)throw new Error(`cannot remove panel ${e.id}. it's missing a group.`);t.model.removePanel(e),e.dispose(),0===t.size&&i.removeEmptyGroup&&this.removeGroup(t)}createWatermarkComponent(){var e;return y("watermark-id","watermark-name",this.options.watermarkComponent?{"watermark-name":this.options.watermarkComponent}:{},this.options.watermarkFrameworkComponent?{"watermark-name":this.options.watermarkFrameworkComponent}:{},null===(e=this.options.frameworkComponentFactory)||void 0===e?void 0:e.watermark)}updateWatermark(){var e,i;if(0===this.groups.length){if(!this.watermark){this.watermark=this.createWatermarkComponent(),this.watermark.init({containerApi:new Q(this)});const e=document.createElement("div");e.className="dv-watermark-container",e.appendChild(this.watermark.element),this.element.appendChild(e)}}else this.watermark&&(this.watermark.element.parentElement.remove(),null===(i=(e=this.watermark).dispose)||void 0===i||i.call(e),this.watermark=null)}addGroup(e){var i;const t=this.createGroup();if(e){let n;if(ze(e)){const i="string"==typeof e.referencePanel?this.panels.find((i=>i.id===e.referencePanel)):e.referencePanel;if(!i)throw new Error(`reference panel ${e.referencePanel} does not exist`);if(n=this.findGroup(i),!n)throw new Error(`reference group for reference panel ${e.referencePanel} does not exist`)}else{if(!xe(e)){return this.orthogonalize(K(e.direction))}if(n="string"==typeof e.referenceGroup?null===(i=this._groups.get(e.referenceGroup))||void 0===i?void 0:i.value:e.referenceGroup,!n)throw new Error(`reference group ${e.referenceGroup} does not exist`)}const o=pe(e.direction||"within"),s=W(n.element),a=J(this.gridview.orientation,s,o);return this.doAddGroup(t,a),t}return this.doAddGroup(t),t}removeGroup(e,i=!1){const t=[...e.panels];for(const e of t)this.removePanel(e,{removeEmptyGroup:!1,skipDispose:!1});super.doRemoveGroup(e,{skipActive:i})}moveGroupOrPanel(e,i,t,n,o){var s;const a=i?null===(s=this._groups.get(i))||void 0===s?void 0:s.value:void 0;if(void 0!==t)if(n&&"center"!==n){const i=W(e.element),o=J(this.gridview.orientation,i,n);if(a&&a.size<2){const[i,t]=C(o),s=W(a.element),[r,h]=C(s);if(z(r,i))this.gridview.moveView(r,h,t);else{const i=this.doRemoveGroup(a,{skipActive:!0,skipDispose:!0}),t=W(e.element),o=J(this.gridview.orientation,t,n);this.doAddGroup(i,o)}}else{const e=(null==a?void 0:a.model.removePanel(t))||this.panels.find((e=>e.id===t));if(!e)throw new Error(`No panel with id ${t}`);const o=J(this.gridview.orientation,i,n);this.createGroupAtLocation(o).model.openPanel(e)}}else{const i=(null==a?void 0:a.model.removePanel(t))||this.panels.find((e=>e.id===t));if(!i)throw new Error(`No panel with id ${t}`);0===(null==a?void 0:a.model.size)&&this.doRemoveGroup(a),e.model.openPanel(i,{index:o})}else a&&this.moveGroup(a,e,n)}moveGroup(i,t,n){if(i)if(n&&"center"!==n){this.gridview.removeView(W(i.element));const o=W(t.element),s=J(this.gridview.orientation,o,n);this.gridview.addView(i,e.Sizing.Distribute,s)}else{const e=i.activePanel,n=[...i.panels].map((e=>i.model.removePanel(e.id)));0===(null==i?void 0:i.model.size)&&this.doRemoveGroup(i);for(const i of n)t.model.openPanel(i,{skipSetPanelActive:i!==e})}}doSetGroupActive(e,i){var t,n;const o=this._activeGroup===e;super.doSetGroupActive(e,i),!o&&(null===(t=this._activeGroup)||void 0===t?void 0:t.activePanel)&&this._onDidActivePanelChange.fire(null===(n=this._activeGroup)||void 0===n?void 0:n.activePanel)}createGroup(e){e||(e={});let i=null==e?void 0:e.id;if(i&&this._groups.has(e.id)&&(console.warn(`Duplicate group id ${null==e?void 0:e.id}. reassigning group id to avoid errors`),i=void 0),!i)for(i=this.nextGroupId.next();this._groups.has(i);)i=this.nextGroupId.next();const t=new De(this,i,e);if(t.init({params:{},accessor:null}),!this._groups.has(t.id)){const e=new c(t.model.onMove((e=>{const{groupId:i,itemId:n,target:o,index:s}=e;this.moveGroupOrPanel(t,i,n,o,s)})),t.model.onDidDrop((e=>{this._onDidDrop.fire(Object.assign(Object.assign({},e),{api:this._api,group:t}))})),t.model.onDidAddPanel((e=>{this._onDidAddPanel.fire(e.panel)})),t.model.onDidRemovePanel((e=>{this._onDidRemovePanel.fire(e.panel)})),t.model.onDidActivePanelChange((e=>{this._onDidActivePanelChange.fire(e.panel)})));this._groups.set(t.id,{value:t,disposable:e})}return t.initialize(),t}createPanel(e,i){const t=e.component,n=e.tabComponent||this.options.defaultTabComponent,o=new Oe(this,e.id,t,n),s=new Ee(e.id,this,this._api,i,o);return s.init({title:e.title||e.id,params:(null==e?void 0:e.params)||{}}),s}createGroupAtLocation(e=[0]){const i=this.createGroup();return this.doAddGroup(i,e),i}findGroup(e){var i;return null===(i=Array.from(this._groups.values()).find((i=>i.value.model.containsPanel(e))))||void 0===i?void 0:i.value}dispose(){super.dispose(),this._onDidActivePanelChange.dispose(),this._onDidAddPanel.dispose(),this._onDidRemovePanel.dispose(),this._onDidLayoutFromJSON.dispose()}},e.DockviewCompositeDisposable=c,e.DockviewEmitter=h,e.DockviewGroupPanel=De,e.DockviewGroupPanelModel=he,e.DockviewMutableDisposable=u,e.DockviewPanel=Ee,e.DraggablePaneviewPanel=be,e.Gridview=Y,e.GridviewApi=class{get minimumHeight(){return this.component.minimumHeight}get maximumHeight(){return this.component.maximumHeight}get minimumWidth(){return this.component.minimumWidth}get maximumWidth(){return this.component.maximumWidth}get width(){return this.component.width}get height(){return this.component.height}get onDidLayoutChange(){return this.component.onDidLayoutChange}get onDidAddPanel(){return this.component.onDidAddGroup}get onDidRemovePanel(){return this.component.onDidRemoveGroup}get onDidActivePanelChange(){return this.component.onDidActiveGroupChange}get onDidLayoutFromJSON(){return this.component.onDidLayoutFromJSON}get panels(){return this.component.groups}get orientation(){return this.component.orientation}set orientation(e){this.component.updateOptions({orientation:e})}constructor(e){this.component=e}focus(){this.component.focus()}layout(e,i,t=!1){this.component.layout(e,i,t)}addPanel(e){return this.component.addPanel(e)}removePanel(e,i){this.component.removePanel(e,i)}movePanel(e,i){this.component.movePanel(e,i)}getPanel(e){return this.component.getPanel(e)}fromJSON(e){return this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}clear(){this.component.clear()}},e.GridviewComponent=class extends ce{get orientation(){return this.gridview.orientation}set orientation(e){this.gridview.orientation=e}get options(){return this._options}get deserializer(){return this._deserializer}set deserializer(e){this._deserializer=e}constructor(e){super({parentElement:e.parentElement,proportionalLayout:e.proportionalLayout,orientation:e.orientation,styles:e.styles}),this._onDidLayoutfromJSON=new h,this.onDidLayoutFromJSON=this._onDidLayoutfromJSON.event,this._options=e,this.options.components||(this.options.components={}),this.options.frameworkComponents||(this.options.frameworkComponents={})}updateOptions(e){const i="string"==typeof e.orientation&&this.gridview.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),i&&(this.gridview.orientation=e.orientation),this.layout(this.gridview.width,this.gridview.height,!0)}removePanel(e){this.removeGroup(e)}toJSON(){var e;return{grid:this.gridview.serialize(),activePanel:null===(e=this.activeGroup)||void 0===e?void 0:e.id}}setVisible(e,i){this.gridview.setViewVisible(W(e.element),i)}setActive(e){this._groups.forEach(((i,t)=>{i.value.setActive(e===i.value)}))}focus(){var e;null===(e=this.activeGroup)||void 0===e||e.focus()}fromJSON(e){this.clear();const{grid:i,activePanel:t}=e,n=[];if(this.gridview.deserialize(i,{fromJSON:e=>{const{data:i}=e,t=y(i.id,i.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkComponentFactory?{createComponent:this.options.frameworkComponentFactory.createComponent}:void 0);return n.push((()=>t.init({params:i.params,minimumWidth:i.minimumWidth,maximumWidth:i.maximumWidth,minimumHeight:i.minimumHeight,maximumHeight:i.maximumHeight,priority:i.priority,snap:!!i.snap,accessor:this,isVisible:e.visible}))),this._onDidAddGroup.fire(t),this.registerPanel(t),t}}),this.layout(this.width,this.height,!0),n.forEach((e=>e())),"string"==typeof t){const e=this.getPanel(t);e&&this.doSetGroupActive(e)}this._onDidLayoutfromJSON.fire()}clear(){const e=this.activeGroup,i=Array.from(this._groups.values());for(const e of i)e.disposable.dispose(),this.doRemoveGroup(e.value,{skipActive:!0});e&&this.doSetGroupActive(void 0),this.gridview.clear()}movePanel(e,i){var t;let n;const o=this.gridview.remove(e),s=null===(t=this._groups.get(i.reference))||void 0===t?void 0:t.value;if(!s)throw new Error(`reference group ${i.reference} does not exist`);const a=pe(i.direction);if("center"===a)throw new Error(`${a} not supported as an option`);{const e=W(s.element);n=J(this.gridview.orientation,e,a)}this.doAddGroup(o,n,i.size)}addPanel(e){var i,t;let n=e.location||[0];if(null===(i=e.position)||void 0===i?void 0:i.referencePanel){const i=null===(t=this._groups.get(e.position.referencePanel))||void 0===t?void 0:t.value;if(!i)throw new Error(`reference group ${e.position.referencePanel} does not exist`);const o=pe(e.position.direction);if("center"===o)throw new Error(`${o} not supported as an option`);{const e=W(i.element);n=J(this.gridview.orientation,e,o)}}const o=y(e.id,e.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkComponentFactory?{createComponent:this.options.frameworkComponentFactory.createComponent}:void 0);return o.init({params:e.params||{},minimumWidth:e.minimumWidth,maximumWidth:e.maximumWidth,minimumHeight:e.minimumHeight,maximumHeight:e.maximumHeight,priority:e.priority,snap:!!e.snap,accessor:this,isVisible:!0}),this.registerPanel(o),this.doAddGroup(o,n,e.size),o}registerPanel(e){const i=new c(e.api.onDidFocusChange((i=>{i.isFocused&&this._groups.forEach((i=>{const t=i.value;t!==e?t.setActive(!1):t.setActive(!0)}))})));this._groups.set(e.id,{value:e,disposable:i})}moveGroup(e,i,t){const n=this.getPanel(i);if(!n)throw new Error("invalid operation");const o=W(e.element),s=J(this.gridview.orientation,o,t),[a,r]=C(s),h=W(n.element),[d,l]=C(h);if(z(d,a))return void this.gridview.moveView(d,l,r);const p=this.doRemoveGroup(n,{skipActive:!0,skipDispose:!0}),c=W(e.element),u=J(this.gridview.orientation,c,t);this.doAddGroup(p,u)}removeGroup(e){super.removeGroup(e)}dispose(){super.dispose(),this._onDidLayoutfromJSON.dispose()}},e.GridviewPanel=_e,e.LocalSelectionTransfer=s,e.PaneFramework=Ge,e.PaneTransfer=o,e.PanelTransfer=n,e.Paneview=G,e.PaneviewApi=X,e.PaneviewComponent=class extends de{get id(){return this._id}get panels(){return this.paneview.getPanes()}set paneview(e){this._paneview=e,this._disposable.value=new c(this._paneview.onDidChange((()=>{this._onDidLayoutChange.fire(void 0)})),this._paneview.onDidAddView((e=>this._onDidAddView.fire(e))),this._paneview.onDidRemoveView((e=>this._onDidRemoveView.fire(e))))}get paneview(){return this._paneview}get minimumSize(){return this.paneview.minimumSize}get maximumSize(){return this.paneview.maximumSize}get height(){return this.paneview.orientation===e.Orientation.HORIZONTAL?this.paneview.orthogonalSize:this.paneview.size}get width(){return this.paneview.orientation===e.Orientation.HORIZONTAL?this.paneview.size:this.paneview.orthogonalSize}get options(){return this._options}constructor(i){super(i.parentElement),this._id=Le.next(),this._disposable=new u,this._viewDisposables=new Map,this._onDidLayoutfromJSON=new h,this.onDidLayoutFromJSON=this._onDidLayoutfromJSON.event,this._onDidLayoutChange=new h,this.onDidLayoutChange=this._onDidLayoutChange.event,this._onDidDrop=new h,this.onDidDrop=this._onDidDrop.event,this._onDidAddView=new h,this.onDidAddView=this._onDidAddView.event,this._onDidRemoveView=new h,this.onDidRemoveView=this._onDidRemoveView.event,this.addDisposables(this._onDidLayoutChange,this._onDidLayoutfromJSON,this._onDidDrop,this._onDidAddView,this._onDidRemoveView),this._options=i,i.components||(i.components={}),i.frameworkComponents||(i.frameworkComponents={}),this.paneview=new G(this.element,{orientation:e.Orientation.VERTICAL}),this.addDisposables(this._disposable)}focus(){}updateOptions(e){this._options=Object.assign(Object.assign({},this.options),e)}addPanel(i){const t=y(i.id,i.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.body.createComponent}:void 0);let n;n=i.headerComponent?y(i.id,i.headerComponent,this.options.headerComponents||{},this.options.headerframeworkComponents,this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.header.createComponent}:void 0):new Ne;const o=new Ge({id:i.id,component:i.component,headerComponent:i.headerComponent,header:n,body:t,orientation:e.Orientation.VERTICAL,isExpanded:!!i.isExpanded,disableDnd:!!this.options.disableDnd,accessor:this});this.doAddPanel(o);const s="number"==typeof i.size?i.size:e.Sizing.Distribute,a="number"==typeof i.index?i.index:void 0;return o.init({params:i.params||{},minimumBodySize:i.minimumBodySize,maximumBodySize:i.maximumBodySize,isExpanded:i.isExpanded,title:i.title,containerApi:new X(this)}),this.paneview.addPane(o,s,a),o.orientation=this.paneview.orientation,o}removePanel(e){const i=this.panels.findIndex((i=>i===e));this.paneview.removePane(i),this.doRemovePanel(e)}movePanel(e,i){this.paneview.moveView(e,i)}getPanel(e){return this.panels.find((i=>i.id===e))}layout(i,t){const[n,o]=this.paneview.orientation===e.Orientation.HORIZONTAL?[i,t]:[t,i];this.paneview.layout(n,o)}toJSON(){const e=e=>e===Number.MAX_SAFE_INTEGER||e===Number.POSITIVE_INFINITY?void 0:e;return{views:this.paneview.getPanes().map(((i,t)=>{return{size:this.paneview.getViewSize(t),data:i.toJSON(),minimumSize:(n=i.minimumBodySize,n<=0?void 0:n),maximumSize:e(i.maximumBodySize),expanded:i.isExpanded()};var n})),size:this.paneview.size}}fromJSON(i){this.clear();const{views:t,size:n}=i,o=[];this.paneview=new G(this.element,{orientation:e.Orientation.VERTICAL,descriptor:{size:n,views:t.map((i=>{const t=i.data,n=y(t.id,t.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.body.createComponent}:void 0);let s;s=t.headerComponent?y(t.id,t.headerComponent,this.options.headerComponents||{},this.options.headerframeworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.header.createComponent}:void 0):new Ne;const a=new Ge({id:t.id,component:t.component,headerComponent:t.headerComponent,header:s,body:n,orientation:e.Orientation.VERTICAL,isExpanded:!!i.expanded,disableDnd:!!this.options.disableDnd,accessor:this});return this.doAddPanel(a),o.push((()=>{a.init({params:t.params||{},minimumBodySize:i.minimumSize,maximumBodySize:i.maximumSize,title:t.title,isExpanded:!!i.expanded,containerApi:new X(this)}),a.orientation=this.paneview.orientation})),setTimeout((()=>{this._onDidAddView.fire(a)}),0),{size:i.size,view:a}}))}}),this.layout(this.width,this.height),o.forEach((e=>e())),this._onDidLayoutfromJSON.fire()}clear(){for(const[e,i]of this._viewDisposables.entries())i.dispose();this._viewDisposables.clear(),this.paneview.dispose()}doAddPanel(e){const i=e.onDidDrop((e=>{this._onDidDrop.fire(e)}));this._viewDisposables.set(e.id,i)}doRemovePanel(e){const i=this._viewDisposables.get(e.id);i&&(i.dispose(),this._viewDisposables.delete(e.id))}dispose(){super.dispose();for(const[e,i]of this._viewDisposables.entries())i.dispose();this._viewDisposables.clear(),this.paneview.dispose()}},e.PaneviewPanel=we,e.Splitview=L,e.SplitviewApi=class{get minimumSize(){return this.component.minimumSize}get maximumSize(){return this.component.maximumSize}get height(){return this.component.height}get width(){return this.component.width}get length(){return this.component.length}get orientation(){return this.component.orientation}get panels(){return this.component.panels}get onDidLayoutFromJSON(){return this.component.onDidLayoutFromJSON}get onDidLayoutChange(){return this.component.onDidLayoutChange}get onDidAddView(){return this.component.onDidAddView}get onDidRemoveView(){return this.component.onDidRemoveView}constructor(e){this.component=e}updateOptions(e){this.component.updateOptions(e)}removePanel(e,i){this.component.removePanel(e,i)}focus(){this.component.focus()}getPanel(e){return this.component.getPanel(e)}layout(e,i){return this.component.layout(e,i)}addPanel(e){return this.component.addPanel(e)}movePanel(e,i){this.component.movePanel(e,i)}fromJSON(e){this.component.fromJSON(e)}toJSON(){return this.component.toJSON()}clear(){this.component.clear()}},e.SplitviewComponent=class extends de{get panels(){return this.splitview.getViews()}get options(){return this._options}get length(){return this._panels.size}get orientation(){return this.splitview.orientation}get splitview(){return this._splitview}set splitview(e){this._splitview=e,this._disposable.value=new c(this._splitview.onDidSashEnd((()=>{this._onDidLayoutChange.fire(void 0)})),this._splitview.onDidAddView((e=>this._onDidAddView.fire(e))),this._splitview.onDidRemoveView((e=>this._onDidRemoveView.fire(e))))}get minimumSize(){return this.splitview.minimumSize}get maximumSize(){return this.splitview.maximumSize}get height(){return this.splitview.orientation===e.Orientation.HORIZONTAL?this.splitview.orthogonalSize:this.splitview.size}get width(){return this.splitview.orientation===e.Orientation.HORIZONTAL?this.splitview.size:this.splitview.orthogonalSize}constructor(e){super(e.parentElement),this._disposable=new u,this._panels=new Map,this._onDidLayoutfromJSON=new h,this.onDidLayoutFromJSON=this._onDidLayoutfromJSON.event,this._onDidAddView=new h,this.onDidAddView=this._onDidAddView.event,this._onDidRemoveView=new h,this.onDidRemoveView=this._onDidRemoveView.event,this._onDidLayoutChange=new h,this.onDidLayoutChange=this._onDidLayoutChange.event,this._options=e,e.components||(e.components={}),e.frameworkComponents||(e.frameworkComponents={}),this.splitview=new L(this.element,e),this.addDisposables(this._disposable,this._onDidAddView,this._onDidLayoutfromJSON,this._onDidRemoveView,this._onDidLayoutChange)}updateOptions(e){const i="string"==typeof e.orientation&&this.options.orientation!==e.orientation;this._options=Object.assign(Object.assign({},this.options),e),i&&(this.splitview.orientation=e.orientation),this.splitview.layout(this.splitview.size,this.splitview.orthogonalSize)}focus(){var e;null===(e=this._activePanel)||void 0===e||e.focus()}movePanel(e,i){this.splitview.moveView(e,i)}setVisible(e,i){const t=this.panels.indexOf(e);this.splitview.setViewVisible(t,i)}setActive(e,i){this._activePanel=e,this.panels.filter((i=>i!==e)).forEach((e=>{e.api._onDidActiveChange.fire({isActive:!1}),i||e.focus()})),e.api._onDidActiveChange.fire({isActive:!0}),i||e.focus()}removePanel(e,i){const t=this._panels.get(e.id);if(!t)throw new Error(`unknown splitview panel ${e.id}`);t.disposable.dispose(),t.value.dispose(),this._panels.delete(e.id);const n=this.panels.findIndex((i=>i===e));this.splitview.removeView(n,i);const o=this.panels;o.length>0&&this.setActive(o[o.length-1])}getPanel(e){return this.panels.find((i=>i.id===e))}addPanel(i){if(this._panels.has(i.id))throw new Error(`panel ${i.id} already exists`);const t=y(i.id,i.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.createComponent}:void 0);t.orientation=this.splitview.orientation,t.init({params:i.params||{},minimumSize:i.minimumSize,maximumSize:i.maximumSize,snap:i.snap,priority:i.priority,accessor:this});const n="number"==typeof i.size?i.size:e.Sizing.Distribute,o="number"==typeof i.index?i.index:void 0;return this.splitview.addView(t,n,o),this.doAddView(t),this.setActive(t),t}layout(i,t){const[n,o]=this.splitview.orientation===e.Orientation.HORIZONTAL?[i,t]:[t,i];this.splitview.layout(n,o)}doAddView(e){const i=e.api.onDidFocusChange((i=>{i.isFocused&&this.setActive(e,!0)}));this._panels.set(e.id,{disposable:i,value:e})}toJSON(){var e;return{views:this.splitview.getViews().map(((e,i)=>({size:this.splitview.getViewSize(i),data:e.toJSON(),snap:!!e.snap,priority:e.priority}))),activeView:null===(e=this._activePanel)||void 0===e?void 0:e.id,size:this.splitview.size,orientation:this.splitview.orientation}}fromJSON(e){this.clear();const{views:i,orientation:t,size:n,activeView:o}=e,s=[];if(this.splitview=new L(this.element,{orientation:t,proportionalLayout:this.options.proportionalLayout,descriptor:{size:n,views:i.map((e=>{const i=e.data;if(this._panels.has(i.id))throw new Error(`panel ${i.id} already exists`);const n=y(i.id,i.component,this.options.components||{},this.options.frameworkComponents||{},this.options.frameworkWrapper?{createComponent:this.options.frameworkWrapper.createComponent}:void 0);return s.push((()=>{n.init({params:i.params||{},minimumSize:i.minimumSize,maximumSize:i.maximumSize,snap:e.snap,priority:e.priority,accessor:this})})),n.orientation=t,this.doAddView(n),setTimeout((()=>{this._onDidAddView.fire(n)}),0),{size:e.size,view:n}}))}}),this.layout(this.width,this.height),s.forEach((e=>e())),"string"==typeof o){const e=this.getPanel(o);e&&this.setActive(e)}this._onDidLayoutfromJSON.fire()}clear(){for(const[e,i]of this._panels.entries())i.disposable.dispose(),i.value.dispose();this._panels.clear(),this.splitview.dispose()}dispose(){for(const[e,i]of this._panels.entries())i.disposable.dispose(),i.value.dispose();this._panels.clear(),this.splitview.dispose(),super.dispose()}},e.SplitviewPanel=class extends ge{get priority(){return this._priority}set orientation(e){this._orientation=e}get orientation(){return this._orientation}get minimumSize(){const e="function"==typeof this._minimumSize?this._minimumSize():this._minimumSize;return e!==this._evaluatedMinimumSize&&(this._evaluatedMinimumSize=e,this.updateConstraints()),e}get maximumSize(){const e="function"==typeof this._maximumSize?this._maximumSize():this._maximumSize;return e!==this._evaluatedMaximumSize&&(this._evaluatedMaximumSize=e,this.updateConstraints()),e}get snap(){return this._snap}constructor(e,i){super(e,i,new me(e)),this._evaluatedMinimumSize=0,this._evaluatedMaximumSize=Number.POSITIVE_INFINITY,this._minimumSize=0,this._maximumSize=Number.POSITIVE_INFINITY,this._snap=!1,this._onDidChange=new h,this.onDidChange=this._onDidChange.event,this.api.initialize(this),this.addDisposables(this._onDidChange,this.api.onVisibilityChange((e=>{const{isVisible:i}=e,{accessor:t}=this._params;t.setVisible(this,i)})),this.api.onActiveChange((()=>{const{accessor:e}=this._params;e.setActive(this)})),this.api.onDidConstraintsChangeInternal((e=>{"number"!=typeof e.minimumSize&&"function"!=typeof e.minimumSize||(this._minimumSize=e.minimumSize),"number"!=typeof e.maximumSize&&"function"!=typeof e.maximumSize||(this._maximumSize=e.maximumSize),this.updateConstraints()})),this.api.onDidSizeChange((e=>{this._onDidChange.fire({size:e.size})})))}setVisible(e){this.api._onDidVisibilityChange.fire({isVisible:e})}setActive(e){this.api._onDidActiveChange.fire({isActive:e})}layout(i,t){const[n,o]=this.orientation===e.Orientation.HORIZONTAL?[i,t]:[t,i];super.layout(n,o)}init(e){super.init(e),this._priority=e.priority,e.minimumSize&&(this._minimumSize=e.minimumSize),e.maximumSize&&(this._maximumSize=e.maximumSize),e.snap&&(this._snap=e.snap)}toJSON(){return Object.assign(Object.assign({},super.toJSON()),{minimumSize:(e=this.minimumSize,e<=0?void 0:e),maximumSize:(e=>e===Number.MAX_SAFE_INTEGER||e===Number.POSITIVE_INFINITY?void 0:e)(this.maximumSize)});var e}updateConstraints(){this.api._onDidConstraintsChange.fire({maximumSize:this._evaluatedMaximumSize,minimumSize:this._evaluatedMinimumSize})}},e.Tab=oe,e.createComponent=y,e.directionToPosition=K,e.getDirectionOrientation=B,e.getGridLocation=W,e.getLocationOrientation=$,e.getPaneData=r,e.getPanelData=a,e.getRelativeLocation=J,e.indexInParent=F,e.isGridBranchNode=Z,e.isGroupOptionsWithGroup=xe,e.isGroupOptionsWithPanel=ze,e.isPanelOptionsWithGroup=Ce,e.isPanelOptionsWithPanel=ye,e.orthogonal=j,e.positionToDirection=function(e){switch(e){case"top":return"above";case"bottom":return"below";case"left":return"left";case"right":return"right";case"center":return"within";default:throw new Error(`invalid position '${e}'`)}},e.toTarget=pe,e.watchElementResize=m}));