dockview 1.5.1 → 1.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (378) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +52 -52
  3. package/dist/cjs/actionbar/actionsContainer.d.ts +7 -7
  4. package/dist/cjs/actionbar/actionsContainer.js +26 -26
  5. package/dist/cjs/api/component.api.d.ts +145 -144
  6. package/dist/cjs/api/component.api.js +578 -571
  7. package/dist/cjs/api/component.api.js.map +1 -1
  8. package/dist/cjs/api/{groupPanelApi.d.ts → dockviewPanelApi.d.ts} +34 -34
  9. package/dist/cjs/api/{groupPanelApi.js → dockviewPanelApi.js} +84 -86
  10. package/dist/cjs/api/dockviewPanelApi.js.map +1 -0
  11. package/dist/cjs/api/gridviewPanelApi.d.ts +37 -36
  12. package/dist/cjs/api/gridviewPanelApi.js +47 -47
  13. package/dist/cjs/api/gridviewPanelApi.js.map +1 -1
  14. package/dist/cjs/api/panelApi.d.ts +88 -81
  15. package/dist/cjs/api/panelApi.js +137 -121
  16. package/dist/cjs/api/panelApi.js.map +1 -1
  17. package/dist/cjs/api/paneviewPanelApi.d.ts +26 -26
  18. package/dist/cjs/api/paneviewPanelApi.js +57 -57
  19. package/dist/cjs/api/splitviewPanelApi.d.ts +32 -32
  20. package/dist/cjs/api/splitviewPanelApi.js +47 -47
  21. package/dist/cjs/array.d.ts +13 -13
  22. package/dist/cjs/array.js +77 -77
  23. package/dist/cjs/dnd/abstractDragHandler.d.ts +11 -11
  24. package/dist/cjs/dnd/abstractDragHandler.js +115 -115
  25. package/dist/cjs/dnd/abstractDragHandler.js.map +1 -1
  26. package/dist/cjs/dnd/dataTransfer.d.ts +31 -31
  27. package/dist/cjs/dnd/dataTransfer.js +100 -100
  28. package/dist/cjs/dnd/dataTransfer.js.map +1 -1
  29. package/dist/cjs/dnd/dnd.d.ts +27 -27
  30. package/dist/cjs/dnd/dnd.js +59 -64
  31. package/dist/cjs/dnd/dnd.js.map +1 -1
  32. package/dist/cjs/dnd/droptarget.d.ts +42 -37
  33. package/dist/cjs/dnd/droptarget.js +279 -201
  34. package/dist/cjs/dnd/droptarget.js.map +1 -1
  35. package/dist/cjs/dnd/ghost.d.ts +1 -0
  36. package/dist/cjs/dnd/ghost.js +15 -0
  37. package/dist/cjs/dnd/ghost.js.map +1 -0
  38. package/dist/cjs/dnd/groupDragHandler.d.ts +11 -0
  39. package/dist/cjs/dnd/groupDragHandler.js +62 -0
  40. package/dist/cjs/dnd/groupDragHandler.js.map +1 -0
  41. package/dist/cjs/dockview/components/tab/defaultTab.d.ts +27 -27
  42. package/dist/cjs/dockview/components/tab/defaultTab.js +121 -121
  43. package/dist/cjs/dockview/components/watermark/watermark.d.ts +20 -20
  44. package/dist/cjs/dockview/components/watermark/watermark.js +101 -101
  45. package/dist/cjs/dockview/defaultGroupPanelView.d.ts +29 -29
  46. package/dist/cjs/dockview/defaultGroupPanelView.js +68 -68
  47. package/dist/cjs/dockview/deserializer.d.ts +6 -5
  48. package/dist/cjs/dockview/deserializer.js +2 -2
  49. package/dist/cjs/dockview/dockviewComponent.d.ts +133 -125
  50. package/dist/cjs/dockview/dockviewComponent.js +795 -614
  51. package/dist/cjs/dockview/dockviewComponent.js.map +1 -1
  52. package/dist/{esm/dockview/dockviewGroupPanel.d.ts → cjs/dockview/dockviewPanel.d.ts} +42 -31
  53. package/dist/cjs/dockview/{dockviewGroupPanel.js → dockviewPanel.js} +161 -157
  54. package/dist/cjs/dockview/dockviewPanel.js.map +1 -0
  55. package/dist/cjs/dockview/options.d.ts +110 -88
  56. package/dist/cjs/dockview/options.js +31 -2
  57. package/dist/cjs/dockview/options.js.map +1 -1
  58. package/dist/cjs/dockview/validation.d.ts +2 -0
  59. package/dist/cjs/dockview/validation.js +135 -0
  60. package/dist/cjs/dockview/validation.js.map +1 -0
  61. package/dist/cjs/dom.d.ts +14 -14
  62. package/dist/cjs/dom.js +182 -182
  63. package/dist/cjs/events.d.ts +30 -30
  64. package/dist/cjs/events.js +129 -129
  65. package/dist/cjs/gridview/baseComponentGridview.d.ts +87 -87
  66. package/dist/cjs/gridview/baseComponentGridview.js +278 -279
  67. package/dist/cjs/gridview/baseComponentGridview.js.map +1 -1
  68. package/dist/cjs/gridview/basePanelView.d.ts +43 -43
  69. package/dist/cjs/gridview/basePanelView.js +123 -123
  70. package/dist/cjs/gridview/branchNode.d.ts +49 -46
  71. package/dist/cjs/gridview/branchNode.js +342 -342
  72. package/dist/cjs/gridview/branchNode.js.map +1 -1
  73. package/dist/cjs/gridview/gridview.d.ts +132 -123
  74. package/dist/cjs/gridview/gridview.js +510 -479
  75. package/dist/cjs/gridview/gridview.js.map +1 -1
  76. package/dist/cjs/gridview/gridviewComponent.d.ts +85 -85
  77. package/dist/cjs/gridview/gridviewComponent.js +324 -325
  78. package/dist/cjs/gridview/gridviewComponent.js.map +1 -1
  79. package/dist/cjs/gridview/gridviewPanel.d.ts +60 -60
  80. package/dist/cjs/gridview/gridviewPanel.js +201 -202
  81. package/dist/cjs/gridview/gridviewPanel.js.map +1 -1
  82. package/dist/cjs/gridview/leafNode.d.ts +34 -31
  83. package/dist/cjs/gridview/leafNode.js +170 -165
  84. package/dist/cjs/gridview/leafNode.js.map +1 -1
  85. package/dist/cjs/gridview/options.d.ts +18 -18
  86. package/dist/cjs/gridview/options.js +2 -2
  87. package/dist/cjs/gridview/types.d.ts +3 -3
  88. package/dist/cjs/gridview/types.js +2 -2
  89. package/dist/cjs/groupview/dnd.d.ts +6 -5
  90. package/dist/cjs/groupview/dnd.js +10 -9
  91. package/dist/cjs/groupview/dnd.js.map +1 -1
  92. package/dist/cjs/groupview/groupview.d.ts +177 -177
  93. package/dist/cjs/groupview/groupview.js +607 -589
  94. package/dist/cjs/groupview/groupview.js.map +1 -1
  95. package/dist/cjs/groupview/groupviewPanel.d.ts +35 -35
  96. package/dist/cjs/groupview/groupviewPanel.js +128 -128
  97. package/dist/cjs/groupview/panel/content.d.ts +30 -30
  98. package/dist/cjs/groupview/panel/content.js +100 -100
  99. package/dist/cjs/groupview/tab.d.ts +31 -41
  100. package/dist/cjs/groupview/tab.js +124 -120
  101. package/dist/cjs/groupview/tab.js.map +1 -1
  102. package/dist/cjs/groupview/titlebar/tabsContainer.d.ts +65 -68
  103. package/dist/cjs/groupview/titlebar/tabsContainer.js +251 -258
  104. package/dist/cjs/groupview/titlebar/tabsContainer.js.map +1 -1
  105. package/dist/cjs/groupview/titlebar/voidContainer.d.ts +15 -0
  106. package/dist/cjs/groupview/titlebar/voidContainer.js +74 -0
  107. package/dist/cjs/groupview/titlebar/voidContainer.js.map +1 -0
  108. package/dist/cjs/groupview/types.d.ts +68 -52
  109. package/dist/cjs/groupview/types.js +2 -2
  110. package/dist/cjs/hostedContainer.d.ts +23 -23
  111. package/dist/cjs/hostedContainer.js +73 -73
  112. package/dist/cjs/index.d.ts +30 -30
  113. package/dist/cjs/index.js +47 -46
  114. package/dist/cjs/index.js.map +1 -1
  115. package/dist/cjs/lifecycle.d.ts +22 -22
  116. package/dist/cjs/lifecycle.js +88 -88
  117. package/dist/cjs/math.d.ts +4 -4
  118. package/dist/cjs/math.js +15 -15
  119. package/dist/cjs/panel/componentFactory.d.ts +8 -8
  120. package/dist/cjs/panel/componentFactory.js +30 -30
  121. package/dist/cjs/panel/types.d.ts +33 -33
  122. package/dist/cjs/panel/types.js +2 -2
  123. package/dist/cjs/paneview/defaultPaneviewHeader.d.ts +21 -21
  124. package/dist/cjs/paneview/defaultPaneviewHeader.js +90 -90
  125. package/dist/cjs/paneview/draggablePaneviewPanel.d.ts +19 -19
  126. package/dist/cjs/paneview/draggablePaneviewPanel.js +130 -129
  127. package/dist/cjs/paneview/draggablePaneviewPanel.js.map +1 -1
  128. package/dist/cjs/paneview/options.d.ts +27 -27
  129. package/dist/cjs/paneview/options.js +2 -2
  130. package/dist/cjs/paneview/paneview.d.ts +40 -40
  131. package/dist/cjs/paneview/paneview.js +201 -201
  132. package/dist/cjs/paneview/paneviewComponent.d.ts +129 -129
  133. package/dist/cjs/paneview/paneviewComponent.js +394 -394
  134. package/dist/cjs/paneview/paneviewComponent.js.map +1 -1
  135. package/dist/cjs/paneview/paneviewPanel.d.ts +92 -89
  136. package/dist/cjs/paneview/paneviewPanel.js +275 -274
  137. package/dist/cjs/paneview/paneviewPanel.js.map +1 -1
  138. package/dist/cjs/react/deserializer.d.ts +10 -9
  139. package/dist/cjs/react/deserializer.js +43 -43
  140. package/dist/cjs/react/deserializer.js.map +1 -1
  141. package/dist/cjs/react/dockview/defaultTab.d.ts +4 -4
  142. package/dist/cjs/react/dockview/defaultTab.js +72 -72
  143. package/dist/cjs/react/dockview/dockview.d.ts +35 -34
  144. package/dist/cjs/react/dockview/dockview.js +213 -212
  145. package/dist/cjs/react/dockview/dockview.js.map +1 -1
  146. package/dist/cjs/react/dockview/groupControlsRenderer.d.ts +43 -43
  147. package/dist/cjs/react/dockview/groupControlsRenderer.js +86 -86
  148. package/dist/cjs/react/dockview/reactContentPart.d.ts +30 -30
  149. package/dist/cjs/react/dockview/reactContentPart.js +58 -58
  150. package/dist/cjs/react/dockview/reactHeaderPart.d.ts +26 -26
  151. package/dist/cjs/react/dockview/reactHeaderPart.js +55 -55
  152. package/dist/cjs/react/dockview/reactWatermarkPart.d.ts +29 -29
  153. package/dist/cjs/react/dockview/reactWatermarkPart.js +65 -65
  154. package/dist/cjs/react/dockview/v2/reactContentRenderer.d.ts +29 -29
  155. package/dist/cjs/react/dockview/v2/reactContentRenderer.js +87 -87
  156. package/dist/cjs/react/dockview/v2/reactGroupPanelView.d.ts +7 -7
  157. package/dist/cjs/react/dockview/v2/reactGroupPanelView.js +34 -34
  158. package/dist/cjs/react/dockview/v2/webviewContentRenderer.d.ts +18 -18
  159. package/dist/cjs/react/dockview/v2/webviewContentRenderer.js +45 -45
  160. package/dist/cjs/react/gridview/gridview.d.ts +24 -24
  161. package/dist/cjs/react/gridview/gridview.js +112 -112
  162. package/dist/cjs/react/gridview/view.d.ts +11 -11
  163. package/dist/cjs/react/gridview/view.js +41 -40
  164. package/dist/cjs/react/gridview/view.js.map +1 -1
  165. package/dist/cjs/react/index.d.ts +9 -9
  166. package/dist/cjs/react/index.js +23 -23
  167. package/dist/cjs/react/paneview/paneview.d.ts +30 -30
  168. package/dist/cjs/react/paneview/paneview.js +155 -155
  169. package/dist/cjs/react/paneview/view.d.ts +20 -20
  170. package/dist/cjs/react/paneview/view.js +44 -44
  171. package/dist/cjs/react/react.d.ts +36 -36
  172. package/dist/cjs/react/react.js +194 -194
  173. package/dist/cjs/react/splitview/splitview.d.ts +24 -24
  174. package/dist/cjs/react/splitview/splitview.js +108 -108
  175. package/dist/cjs/react/splitview/view.d.ts +10 -10
  176. package/dist/cjs/react/splitview/view.js +40 -40
  177. package/dist/cjs/react/svg.d.ts +3 -3
  178. package/dist/cjs/react/svg.js +35 -35
  179. package/dist/cjs/react/types.d.ts +7 -7
  180. package/dist/cjs/react/types.js +2 -2
  181. package/dist/cjs/splitview/core/options.d.ts +26 -26
  182. package/dist/cjs/splitview/core/options.js +2 -2
  183. package/dist/cjs/splitview/core/splitview.d.ts +127 -124
  184. package/dist/cjs/splitview/core/splitview.js +908 -908
  185. package/dist/cjs/splitview/core/splitview.js.map +1 -1
  186. package/dist/cjs/splitview/core/viewItem.d.ts +25 -25
  187. package/dist/cjs/splitview/core/viewItem.js +124 -124
  188. package/dist/cjs/splitview/splitviewComponent.d.ts +101 -101
  189. package/dist/cjs/splitview/splitviewComponent.js +373 -373
  190. package/dist/cjs/splitview/splitviewComponent.js.map +1 -1
  191. package/dist/cjs/splitview/splitviewPanel.d.ts +45 -42
  192. package/dist/cjs/splitview/splitviewPanel.js +179 -178
  193. package/dist/cjs/splitview/splitviewPanel.js.map +1 -1
  194. package/dist/cjs/svg.d.ts +3 -3
  195. package/dist/cjs/svg.js +43 -43
  196. package/dist/cjs/types.d.ts +8 -7
  197. package/dist/cjs/types.js +7 -2
  198. package/dist/cjs/types.js.map +1 -1
  199. package/dist/dockview.amd.js +7168 -6739
  200. package/dist/dockview.amd.min.js +2 -2
  201. package/dist/dockview.amd.min.noStyle.js +2 -2
  202. package/dist/dockview.amd.noStyle.js +7176 -6747
  203. package/dist/dockview.cjs.js +7167 -6738
  204. package/dist/dockview.esm.js +7152 -6726
  205. package/dist/dockview.esm.min.js +2 -2
  206. package/dist/dockview.js +7168 -6739
  207. package/dist/dockview.min.js +2 -2
  208. package/dist/dockview.min.noStyle.js +2 -2
  209. package/dist/dockview.noStyle.js +7176 -6747
  210. package/dist/esm/actionbar/actionsContainer.d.ts +7 -7
  211. package/dist/esm/actionbar/actionsContainer.js +17 -17
  212. package/dist/esm/api/component.api.d.ts +145 -144
  213. package/dist/esm/api/component.api.js +329 -326
  214. package/dist/esm/api/{groupPanelApi.d.ts → dockviewPanelApi.d.ts} +34 -34
  215. package/dist/esm/api/{groupPanelApi.js → dockviewPanelApi.js} +48 -50
  216. package/dist/esm/api/gridviewPanelApi.d.ts +37 -36
  217. package/dist/esm/api/gridviewPanelApi.js +25 -25
  218. package/dist/esm/api/panelApi.d.ts +88 -81
  219. package/dist/esm/api/panelApi.js +95 -79
  220. package/dist/esm/api/paneviewPanelApi.d.ts +26 -26
  221. package/dist/esm/api/paneviewPanelApi.js +27 -27
  222. package/dist/esm/api/splitviewPanelApi.d.ts +32 -32
  223. package/dist/esm/api/splitviewPanelApi.js +25 -25
  224. package/dist/esm/array.d.ts +13 -13
  225. package/dist/esm/array.js +67 -67
  226. package/dist/esm/dnd/abstractDragHandler.d.ts +11 -11
  227. package/dist/esm/dnd/abstractDragHandler.js +37 -37
  228. package/dist/esm/dnd/dataTransfer.d.ts +31 -31
  229. package/dist/esm/dnd/dataTransfer.js +69 -69
  230. package/dist/esm/dnd/dnd.d.ts +27 -27
  231. package/dist/esm/dnd/dnd.js +36 -41
  232. package/dist/esm/dnd/droptarget.d.ts +42 -37
  233. package/dist/esm/dnd/droptarget.js +249 -167
  234. package/dist/esm/dnd/ghost.d.ts +1 -0
  235. package/dist/esm/dnd/ghost.js +10 -0
  236. package/dist/esm/dnd/groupDragHandler.d.ts +11 -0
  237. package/dist/esm/dnd/groupDragHandler.js +38 -0
  238. package/dist/esm/dockview/components/tab/defaultTab.d.ts +27 -27
  239. package/dist/esm/dockview/components/tab/defaultTab.js +79 -79
  240. package/dist/esm/dockview/components/watermark/watermark.d.ts +20 -20
  241. package/dist/esm/dockview/components/watermark/watermark.js +70 -70
  242. package/dist/esm/dockview/defaultGroupPanelView.d.ts +29 -29
  243. package/dist/esm/dockview/defaultGroupPanelView.js +44 -44
  244. package/dist/esm/dockview/deserializer.d.ts +6 -5
  245. package/dist/esm/dockview/deserializer.js +1 -1
  246. package/dist/esm/dockview/dockviewComponent.d.ts +133 -125
  247. package/dist/esm/dockview/dockviewComponent.js +632 -468
  248. package/dist/{cjs/dockview/dockviewGroupPanel.d.ts → esm/dockview/dockviewPanel.d.ts} +42 -31
  249. package/dist/esm/dockview/{dockviewGroupPanel.js → dockviewPanel.js} +111 -107
  250. package/dist/esm/dockview/options.d.ts +110 -88
  251. package/dist/esm/dockview/options.js +24 -1
  252. package/dist/esm/dockview/validation.d.ts +2 -0
  253. package/dist/esm/dockview/validation.js +86 -0
  254. package/dist/esm/dom.d.ts +14 -14
  255. package/dist/esm/dom.js +113 -113
  256. package/dist/esm/events.d.ts +30 -30
  257. package/dist/esm/events.js +88 -88
  258. package/dist/esm/gridview/baseComponentGridview.d.ts +87 -87
  259. package/dist/esm/gridview/baseComponentGridview.js +188 -189
  260. package/dist/esm/gridview/basePanelView.d.ts +43 -43
  261. package/dist/esm/gridview/basePanelView.js +74 -74
  262. package/dist/esm/gridview/branchNode.d.ts +49 -46
  263. package/dist/esm/gridview/branchNode.js +218 -218
  264. package/dist/esm/gridview/gridview.d.ts +132 -123
  265. package/dist/esm/gridview/gridview.js +423 -397
  266. package/dist/esm/gridview/gridviewComponent.d.ts +85 -85
  267. package/dist/esm/gridview/gridviewComponent.js +237 -238
  268. package/dist/esm/gridview/gridviewPanel.d.ts +60 -60
  269. package/dist/esm/gridview/gridviewPanel.js +138 -138
  270. package/dist/esm/gridview/leafNode.d.ts +34 -31
  271. package/dist/esm/gridview/leafNode.js +103 -98
  272. package/dist/esm/gridview/options.d.ts +18 -18
  273. package/dist/esm/gridview/options.js +1 -1
  274. package/dist/esm/gridview/types.d.ts +3 -3
  275. package/dist/esm/gridview/types.js +1 -1
  276. package/dist/esm/groupview/dnd.d.ts +6 -5
  277. package/dist/esm/groupview/dnd.js +7 -6
  278. package/dist/esm/groupview/groupview.d.ts +177 -177
  279. package/dist/esm/groupview/groupview.js +462 -444
  280. package/dist/esm/groupview/groupviewPanel.d.ts +35 -35
  281. package/dist/esm/groupview/groupviewPanel.js +61 -61
  282. package/dist/esm/groupview/panel/content.d.ts +30 -30
  283. package/dist/esm/groupview/panel/content.js +73 -73
  284. package/dist/esm/groupview/tab.d.ts +31 -41
  285. package/dist/esm/groupview/tab.js +94 -90
  286. package/dist/esm/groupview/titlebar/tabsContainer.d.ts +65 -68
  287. package/dist/esm/groupview/titlebar/tabsContainer.js +183 -190
  288. package/dist/esm/groupview/titlebar/voidContainer.d.ts +15 -0
  289. package/dist/esm/groupview/titlebar/voidContainer.js +47 -0
  290. package/dist/esm/groupview/types.d.ts +68 -52
  291. package/dist/esm/groupview/types.js +1 -1
  292. package/dist/esm/hostedContainer.d.ts +23 -23
  293. package/dist/esm/hostedContainer.js +63 -63
  294. package/dist/esm/index.d.ts +30 -30
  295. package/dist/esm/index.js +23 -23
  296. package/dist/esm/lifecycle.d.ts +22 -22
  297. package/dist/esm/lifecycle.js +39 -39
  298. package/dist/esm/math.d.ts +4 -4
  299. package/dist/esm/math.js +10 -10
  300. package/dist/esm/panel/componentFactory.d.ts +8 -8
  301. package/dist/esm/panel/componentFactory.js +24 -24
  302. package/dist/esm/panel/types.d.ts +33 -33
  303. package/dist/esm/panel/types.js +1 -1
  304. package/dist/esm/paneview/defaultPaneviewHeader.d.ts +21 -21
  305. package/dist/esm/paneview/defaultPaneviewHeader.js +63 -63
  306. package/dist/esm/paneview/draggablePaneviewPanel.d.ts +19 -19
  307. package/dist/esm/paneview/draggablePaneviewPanel.js +91 -90
  308. package/dist/esm/paneview/options.d.ts +27 -27
  309. package/dist/esm/paneview/options.js +1 -1
  310. package/dist/esm/paneview/paneview.d.ts +40 -40
  311. package/dist/esm/paneview/paneview.js +145 -145
  312. package/dist/esm/paneview/paneviewComponent.d.ts +129 -129
  313. package/dist/esm/paneview/paneviewComponent.js +270 -270
  314. package/dist/esm/paneview/paneviewPanel.d.ts +92 -89
  315. package/dist/esm/paneview/paneviewPanel.js +192 -191
  316. package/dist/esm/react/deserializer.d.ts +10 -9
  317. package/dist/esm/react/deserializer.js +38 -38
  318. package/dist/esm/react/dockview/defaultTab.d.ts +4 -4
  319. package/dist/esm/react/dockview/defaultTab.js +34 -34
  320. package/dist/esm/react/dockview/dockview.d.ts +35 -34
  321. package/dist/esm/react/dockview/dockview.js +158 -157
  322. package/dist/esm/react/dockview/groupControlsRenderer.d.ts +43 -43
  323. package/dist/esm/react/dockview/groupControlsRenderer.js +68 -68
  324. package/dist/esm/react/dockview/reactContentPart.d.ts +30 -30
  325. package/dist/esm/react/dockview/reactContentPart.js +49 -49
  326. package/dist/esm/react/dockview/reactHeaderPart.d.ts +26 -26
  327. package/dist/esm/react/dockview/reactHeaderPart.js +46 -46
  328. package/dist/esm/react/dockview/reactWatermarkPart.d.ts +29 -29
  329. package/dist/esm/react/dockview/reactWatermarkPart.js +55 -55
  330. package/dist/esm/react/dockview/v2/reactContentRenderer.d.ts +29 -29
  331. package/dist/esm/react/dockview/v2/reactContentRenderer.js +69 -69
  332. package/dist/esm/react/dockview/v2/reactGroupPanelView.d.ts +7 -7
  333. package/dist/esm/react/dockview/v2/reactGroupPanelView.js +12 -12
  334. package/dist/esm/react/dockview/v2/webviewContentRenderer.d.ts +18 -18
  335. package/dist/esm/react/dockview/v2/webviewContentRenderer.js +36 -36
  336. package/dist/esm/react/gridview/gridview.d.ts +24 -24
  337. package/dist/esm/react/gridview/gridview.js +70 -70
  338. package/dist/esm/react/gridview/view.d.ts +11 -11
  339. package/dist/esm/react/gridview/view.js +19 -18
  340. package/dist/esm/react/index.d.ts +9 -9
  341. package/dist/esm/react/index.js +7 -7
  342. package/dist/esm/react/paneview/paneview.d.ts +30 -30
  343. package/dist/esm/react/paneview/paneview.js +100 -100
  344. package/dist/esm/react/paneview/view.d.ts +20 -20
  345. package/dist/esm/react/paneview/view.js +35 -35
  346. package/dist/esm/react/react.d.ts +36 -36
  347. package/dist/esm/react/react.js +125 -125
  348. package/dist/esm/react/splitview/splitview.d.ts +24 -24
  349. package/dist/esm/react/splitview/splitview.js +66 -66
  350. package/dist/esm/react/splitview/view.d.ts +10 -10
  351. package/dist/esm/react/splitview/view.js +18 -18
  352. package/dist/esm/react/svg.d.ts +3 -3
  353. package/dist/esm/react/svg.js +7 -7
  354. package/dist/esm/react/types.d.ts +7 -7
  355. package/dist/esm/react/types.js +1 -1
  356. package/dist/esm/splitview/core/options.d.ts +26 -26
  357. package/dist/esm/splitview/core/options.js +1 -1
  358. package/dist/esm/splitview/core/splitview.d.ts +127 -124
  359. package/dist/esm/splitview/core/splitview.js +689 -689
  360. package/dist/esm/splitview/core/viewItem.d.ts +25 -25
  361. package/dist/esm/splitview/core/viewItem.js +79 -79
  362. package/dist/esm/splitview/splitviewComponent.d.ts +101 -101
  363. package/dist/esm/splitview/splitviewComponent.js +249 -249
  364. package/dist/esm/splitview/splitviewPanel.d.ts +45 -42
  365. package/dist/esm/splitview/splitviewPanel.js +108 -107
  366. package/dist/esm/svg.d.ts +3 -3
  367. package/dist/esm/svg.js +31 -31
  368. package/dist/esm/types.d.ts +8 -7
  369. package/dist/esm/types.js +3 -1
  370. package/dist/styles/dockview.css +23 -26
  371. package/package.json +12 -16
  372. package/dist/cjs/api/groupPanelApi.js.map +0 -1
  373. package/dist/cjs/dockview/dockviewGroupPanel.js.map +0 -1
  374. package/dist/cjs/groupview/groupPanel.d.ts +0 -32
  375. package/dist/cjs/groupview/groupPanel.js +0 -3
  376. package/dist/cjs/groupview/groupPanel.js.map +0 -1
  377. package/dist/esm/groupview/groupPanel.d.ts +0 -32
  378. package/dist/esm/groupview/groupPanel.js +0 -1
@@ -1,167 +1,249 @@
1
- import { toggleClass } from '../dom';
2
- import { Emitter } from '../events';
3
- import { CompositeDisposable } from '../lifecycle';
4
- import { DragAndDropObserver } from './dnd';
5
- export var Position;
6
- (function (Position) {
7
- Position["Top"] = "Top";
8
- Position["Left"] = "Left";
9
- Position["Bottom"] = "Bottom";
10
- Position["Right"] = "Right";
11
- Position["Center"] = "Center";
12
- })(Position || (Position = {}));
13
- function isBooleanValue(canDisplayOverlay) {
14
- return typeof canDisplayOverlay === 'boolean';
15
- }
16
- export class Droptarget extends CompositeDisposable {
17
- constructor(element, options) {
18
- super();
19
- this.element = element;
20
- this.options = options;
21
- this._onDrop = new Emitter();
22
- this.onDrop = this._onDrop.event;
23
- this.addDisposables(this._onDrop, new DragAndDropObserver(this.element, {
24
- onDragEnter: () => undefined,
25
- onDragOver: (e) => {
26
- const width = this.element.clientWidth;
27
- const height = this.element.clientHeight;
28
- if (width === 0 || height === 0) {
29
- return; // avoid div!0
30
- }
31
- const x = e.offsetX;
32
- const y = e.offsetY;
33
- const xp = (100 * x) / width;
34
- const yp = (100 * y) / height;
35
- const quadrant = this.calculateQuadrant(this.options.validOverlays, xp, yp);
36
- if (isBooleanValue(this.options.canDisplayOverlay)) {
37
- if (!this.options.canDisplayOverlay) {
38
- return;
39
- }
40
- }
41
- else if (!this.options.canDisplayOverlay(e, quadrant)) {
42
- return;
43
- }
44
- if (!this.target) {
45
- this.target = document.createElement('div');
46
- this.target.className = 'drop-target-dropzone';
47
- this.overlay = document.createElement('div');
48
- this.overlay.className = 'drop-target-selection';
49
- this._state = Position.Center;
50
- this.target.appendChild(this.overlay);
51
- this.element.classList.add('drop-target');
52
- this.element.append(this.target);
53
- }
54
- if (this.options.validOverlays === 'none') {
55
- return;
56
- }
57
- if (!this.target || !this.overlay) {
58
- return;
59
- }
60
- const isSmallX = width < 100;
61
- const isSmallY = height < 100;
62
- this.toggleClasses(quadrant, isSmallX, isSmallY);
63
- this.setState(quadrant);
64
- },
65
- onDragLeave: () => {
66
- this.removeDropTarget();
67
- },
68
- onDragEnd: () => {
69
- this.removeDropTarget();
70
- },
71
- onDrop: (e) => {
72
- e.preventDefault();
73
- e.stopPropagation();
74
- const state = this._state;
75
- this.removeDropTarget();
76
- if (state) {
77
- this._onDrop.fire({ position: state, nativeEvent: e });
78
- }
79
- },
80
- }));
81
- }
82
- get state() {
83
- return this._state;
84
- }
85
- set validOverlays(value) {
86
- this.options.validOverlays = value;
87
- }
88
- set canDisplayOverlay(value) {
89
- this.options.canDisplayOverlay = value;
90
- }
91
- dispose() {
92
- this.removeDropTarget();
93
- }
94
- toggleClasses(quadrant, isSmallX, isSmallY) {
95
- if (!this.overlay) {
96
- return;
97
- }
98
- const isLeft = quadrant === 'left';
99
- const isRight = quadrant === 'right';
100
- const isTop = quadrant === 'top';
101
- const isBottom = quadrant === 'bottom';
102
- toggleClass(this.overlay, 'right', !isSmallX && isRight);
103
- toggleClass(this.overlay, 'left', !isSmallX && isLeft);
104
- toggleClass(this.overlay, 'top', !isSmallY && isTop);
105
- toggleClass(this.overlay, 'bottom', !isSmallY && isBottom);
106
- toggleClass(this.overlay, 'small-right', isSmallX && isRight);
107
- toggleClass(this.overlay, 'small-left', isSmallX && isLeft);
108
- toggleClass(this.overlay, 'small-top', isSmallY && isTop);
109
- toggleClass(this.overlay, 'small-bottom', isSmallY && isBottom);
110
- }
111
- setState(quadrant) {
112
- switch (quadrant) {
113
- case 'top':
114
- this._state = Position.Top;
115
- break;
116
- case 'left':
117
- this._state = Position.Left;
118
- break;
119
- case 'bottom':
120
- this._state = Position.Bottom;
121
- break;
122
- case 'right':
123
- this._state = Position.Right;
124
- break;
125
- default:
126
- this._state = Position.Center;
127
- break;
128
- }
129
- }
130
- calculateQuadrant(overlayType, xp, yp) {
131
- switch (overlayType) {
132
- case 'all':
133
- if (xp < 20) {
134
- return 'left';
135
- }
136
- if (xp > 80) {
137
- return 'right';
138
- }
139
- if (yp < 20) {
140
- return 'top';
141
- }
142
- if (yp > 80) {
143
- return 'bottom';
144
- }
145
- break;
146
- case 'vertical':
147
- if (yp < 50) {
148
- return 'top';
149
- }
150
- return 'bottom';
151
- case 'horizontal':
152
- if (xp < 50) {
153
- return 'left';
154
- }
155
- return 'right';
156
- }
157
- return null;
158
- }
159
- removeDropTarget() {
160
- if (this.target) {
161
- this._state = undefined;
162
- this.element.removeChild(this.target);
163
- this.target = undefined;
164
- this.element.classList.remove('drop-target');
165
- }
166
- }
167
- }
1
+ import { toggleClass } from '../dom';
2
+ import { Emitter } from '../events';
3
+ import { CompositeDisposable } from '../lifecycle';
4
+ import { DragAndDropObserver } from './dnd';
5
+ import { clamp } from '../math';
6
+ import { isBooleanValue } from '../types';
7
+ function numberOrFallback(maybeNumber, fallback) {
8
+ return typeof maybeNumber === 'number' ? maybeNumber : fallback;
9
+ }
10
+ export function directionToPosition(direction) {
11
+ switch (direction) {
12
+ case 'above':
13
+ return 'top';
14
+ case 'below':
15
+ return 'bottom';
16
+ case 'left':
17
+ return 'left';
18
+ case 'right':
19
+ return 'right';
20
+ case 'within':
21
+ return 'center';
22
+ default:
23
+ throw new Error(`invalid direction '${direction}'`);
24
+ }
25
+ }
26
+ export function positionToDirection(position) {
27
+ switch (position) {
28
+ case 'top':
29
+ return 'above';
30
+ case 'bottom':
31
+ return 'below';
32
+ case 'left':
33
+ return 'left';
34
+ case 'right':
35
+ return 'right';
36
+ case 'center':
37
+ return 'within';
38
+ default:
39
+ throw new Error(`invalid position '${position}'`);
40
+ }
41
+ }
42
+ export class Droptarget extends CompositeDisposable {
43
+ get state() {
44
+ return this._state;
45
+ }
46
+ constructor(element, options) {
47
+ super();
48
+ this.element = element;
49
+ this.options = options;
50
+ this._onDrop = new Emitter();
51
+ this.onDrop = this._onDrop.event;
52
+ // use a set to take advantage of #<set>.has
53
+ const acceptedTargetZonesSet = new Set(this.options.acceptedTargetZones);
54
+ this.addDisposables(this._onDrop, new DragAndDropObserver(this.element, {
55
+ onDragEnter: () => undefined,
56
+ onDragOver: (e) => {
57
+ const width = this.element.clientWidth;
58
+ const height = this.element.clientHeight;
59
+ if (width === 0 || height === 0) {
60
+ return; // avoid div!0
61
+ }
62
+ const rect = e.currentTarget.getBoundingClientRect();
63
+ const x = e.clientX - rect.left;
64
+ const y = e.clientY - rect.top;
65
+ const quadrant = this.calculateQuadrant(acceptedTargetZonesSet, x, y, width, height);
66
+ if (quadrant === null) {
67
+ // no drop target should be displayed
68
+ this.removeDropTarget();
69
+ return;
70
+ }
71
+ if (isBooleanValue(this.options.canDisplayOverlay)) {
72
+ if (!this.options.canDisplayOverlay) {
73
+ return;
74
+ }
75
+ }
76
+ else if (!this.options.canDisplayOverlay(e, quadrant)) {
77
+ return;
78
+ }
79
+ if (!this.target) {
80
+ this.target = document.createElement('div');
81
+ this.target.className = 'drop-target-dropzone';
82
+ this.overlay = document.createElement('div');
83
+ this.overlay.className = 'drop-target-selection';
84
+ this._state = 'center';
85
+ this.target.appendChild(this.overlay);
86
+ this.element.classList.add('drop-target');
87
+ this.element.append(this.target);
88
+ }
89
+ if (this.options.acceptedTargetZones.length === 0) {
90
+ return;
91
+ }
92
+ if (!this.target || !this.overlay) {
93
+ return;
94
+ }
95
+ this.toggleClasses(quadrant, width, height);
96
+ this.setState(quadrant);
97
+ },
98
+ onDragLeave: () => {
99
+ this.removeDropTarget();
100
+ },
101
+ onDragEnd: () => {
102
+ this.removeDropTarget();
103
+ },
104
+ onDrop: (e) => {
105
+ e.preventDefault();
106
+ e.stopPropagation();
107
+ const state = this._state;
108
+ this.removeDropTarget();
109
+ if (state) {
110
+ this._onDrop.fire({ position: state, nativeEvent: e });
111
+ }
112
+ },
113
+ }));
114
+ }
115
+ dispose() {
116
+ this.removeDropTarget();
117
+ }
118
+ toggleClasses(quadrant, width, height) {
119
+ var _a, _b, _c, _d;
120
+ if (!this.overlay) {
121
+ return;
122
+ }
123
+ const isSmallX = width < 100;
124
+ const isSmallY = height < 100;
125
+ const isLeft = quadrant === 'left';
126
+ const isRight = quadrant === 'right';
127
+ const isTop = quadrant === 'top';
128
+ const isBottom = quadrant === 'bottom';
129
+ const rightClass = !isSmallX && isRight;
130
+ const leftClass = !isSmallX && isLeft;
131
+ const topClass = !isSmallY && isTop;
132
+ const bottomClass = !isSmallY && isBottom;
133
+ let size = 0.5;
134
+ if (((_b = (_a = this.options.overlayModel) === null || _a === void 0 ? void 0 : _a.size) === null || _b === void 0 ? void 0 : _b.type) === 'percentage') {
135
+ size = clamp(this.options.overlayModel.size.value, 0, 100) / 100;
136
+ }
137
+ if (((_d = (_c = this.options.overlayModel) === null || _c === void 0 ? void 0 : _c.size) === null || _d === void 0 ? void 0 : _d.type) === 'pixels') {
138
+ if (rightClass || leftClass) {
139
+ size =
140
+ clamp(0, this.options.overlayModel.size.value, width) /
141
+ width;
142
+ }
143
+ if (topClass || bottomClass) {
144
+ size =
145
+ clamp(0, this.options.overlayModel.size.value, height) /
146
+ height;
147
+ }
148
+ }
149
+ const translate = (1 - size) / 2;
150
+ const scale = size;
151
+ let transform;
152
+ if (rightClass) {
153
+ transform = `translateX(${100 * translate}%) scaleX(${scale})`;
154
+ }
155
+ else if (leftClass) {
156
+ transform = `translateX(-${100 * translate}%) scaleX(${scale})`;
157
+ }
158
+ else if (topClass) {
159
+ transform = `translateY(-${100 * translate}%) scaleY(${scale})`;
160
+ }
161
+ else if (bottomClass) {
162
+ transform = `translateY(${100 * translate}%) scaleY(${scale})`;
163
+ }
164
+ else {
165
+ transform = '';
166
+ }
167
+ this.overlay.style.transform = transform;
168
+ toggleClass(this.overlay, 'small-right', isSmallX && isRight);
169
+ toggleClass(this.overlay, 'small-left', isSmallX && isLeft);
170
+ toggleClass(this.overlay, 'small-top', isSmallY && isTop);
171
+ toggleClass(this.overlay, 'small-bottom', isSmallY && isBottom);
172
+ }
173
+ setState(quadrant) {
174
+ switch (quadrant) {
175
+ case 'top':
176
+ this._state = 'top';
177
+ break;
178
+ case 'left':
179
+ this._state = 'left';
180
+ break;
181
+ case 'bottom':
182
+ this._state = 'bottom';
183
+ break;
184
+ case 'right':
185
+ this._state = 'right';
186
+ break;
187
+ case 'center':
188
+ this._state = 'center';
189
+ break;
190
+ }
191
+ }
192
+ calculateQuadrant(overlayType, x, y, width, height) {
193
+ var _a, _b, _c, _d, _e, _f;
194
+ const isPercentage = ((_a = this.options.overlayModel) === null || _a === void 0 ? void 0 : _a.activationSize) === undefined ||
195
+ ((_c = (_b = this.options.overlayModel) === null || _b === void 0 ? void 0 : _b.activationSize) === null || _c === void 0 ? void 0 : _c.type) === 'percentage';
196
+ const value = numberOrFallback((_f = (_e = (_d = this.options) === null || _d === void 0 ? void 0 : _d.overlayModel) === null || _e === void 0 ? void 0 : _e.activationSize) === null || _f === void 0 ? void 0 : _f.value, 20);
197
+ if (isPercentage) {
198
+ return calculateQuadrantAsPercentage(overlayType, x, y, width, height, value);
199
+ }
200
+ return calculateQuadrantAsPixels(overlayType, x, y, width, height, value);
201
+ }
202
+ removeDropTarget() {
203
+ if (this.target) {
204
+ this._state = undefined;
205
+ this.element.removeChild(this.target);
206
+ this.target = undefined;
207
+ this.overlay = undefined;
208
+ this.element.classList.remove('drop-target');
209
+ }
210
+ }
211
+ }
212
+ export function calculateQuadrantAsPercentage(overlayType, x, y, width, height, threshold) {
213
+ const xp = (100 * x) / width;
214
+ const yp = (100 * y) / height;
215
+ if (overlayType.has('left') && xp < threshold) {
216
+ return 'left';
217
+ }
218
+ if (overlayType.has('right') && xp > 100 - threshold) {
219
+ return 'right';
220
+ }
221
+ if (overlayType.has('top') && yp < threshold) {
222
+ return 'top';
223
+ }
224
+ if (overlayType.has('bottom') && yp > 100 - threshold) {
225
+ return 'bottom';
226
+ }
227
+ if (!overlayType.has('center')) {
228
+ return null;
229
+ }
230
+ return 'center';
231
+ }
232
+ export function calculateQuadrantAsPixels(overlayType, x, y, width, height, threshold) {
233
+ if (overlayType.has('left') && x < threshold) {
234
+ return 'left';
235
+ }
236
+ if (overlayType.has('right') && x > width - threshold) {
237
+ return 'right';
238
+ }
239
+ if (overlayType.has('top') && y < threshold) {
240
+ return 'top';
241
+ }
242
+ if (overlayType.has('bottom') && y > height - threshold) {
243
+ return 'bottom';
244
+ }
245
+ if (!overlayType.has('center')) {
246
+ return null;
247
+ }
248
+ return 'center';
249
+ }
@@ -0,0 +1 @@
1
+ export declare function addGhostImage(dataTransfer: DataTransfer, ghostElement: HTMLElement): void;
@@ -0,0 +1,10 @@
1
+ import { addClasses } from '../dom';
2
+ export function addGhostImage(dataTransfer, ghostElement) {
3
+ // class dockview provides to force ghost image to be drawn on a different layer and prevent weird rendering issues
4
+ addClasses(ghostElement, 'dv-dragged');
5
+ document.body.appendChild(ghostElement);
6
+ dataTransfer.setDragImage(ghostElement, 0, 0);
7
+ setTimeout(() => {
8
+ ghostElement.remove();
9
+ }, 0);
10
+ }
@@ -0,0 +1,11 @@
1
+ import { GroupPanel } from '../groupview/groupviewPanel';
2
+ import { IDisposable } from '../lifecycle';
3
+ import { DragHandler } from './abstractDragHandler';
4
+ export declare class GroupDragHandler extends DragHandler {
5
+ private readonly accessorId;
6
+ private readonly group;
7
+ private readonly panelTransfer;
8
+ constructor(element: HTMLElement, accessorId: string, group: GroupPanel);
9
+ getData(dataTransfer: DataTransfer | null): IDisposable;
10
+ dispose(): void;
11
+ }
@@ -0,0 +1,38 @@
1
+ import { DragHandler } from './abstractDragHandler';
2
+ import { LocalSelectionTransfer, PanelTransfer } from './dataTransfer';
3
+ import { addGhostImage } from './ghost';
4
+ export class GroupDragHandler extends DragHandler {
5
+ constructor(element, accessorId, group) {
6
+ super(element);
7
+ this.accessorId = accessorId;
8
+ this.group = group;
9
+ this.panelTransfer = LocalSelectionTransfer.getInstance();
10
+ }
11
+ getData(dataTransfer) {
12
+ this.panelTransfer.setData([new PanelTransfer(this.accessorId, this.group.id, null)], PanelTransfer.prototype);
13
+ const style = window.getComputedStyle(this.el);
14
+ const bgColor = style.getPropertyValue('--dv-activegroup-visiblepanel-tab-background-color');
15
+ const color = style.getPropertyValue('--dv-activegroup-visiblepanel-tab-color');
16
+ if (dataTransfer) {
17
+ const ghostElement = document.createElement('div');
18
+ ghostElement.style.backgroundColor = bgColor;
19
+ ghostElement.style.color = color;
20
+ ghostElement.style.padding = '2px 8px';
21
+ ghostElement.style.height = '24px';
22
+ ghostElement.style.fontSize = '11px';
23
+ ghostElement.style.lineHeight = '20px';
24
+ ghostElement.style.borderRadius = '12px';
25
+ ghostElement.style.position = 'absolute';
26
+ ghostElement.textContent = `Multiple Panels (${this.group.size})`;
27
+ addGhostImage(dataTransfer, ghostElement);
28
+ }
29
+ return {
30
+ dispose: () => {
31
+ this.panelTransfer.clearData(PanelTransfer.prototype);
32
+ },
33
+ };
34
+ }
35
+ dispose() {
36
+ //
37
+ }
38
+ }
@@ -1,27 +1,27 @@
1
- import { CompositeDisposable } from '../../../lifecycle';
2
- import { ITabRenderer, GroupPanelPartInitParameters } from '../../../groupview/types';
3
- import { PanelUpdateEvent } from '../../../panel/types';
4
- import { GroupPanel } from '../../../groupview/groupviewPanel';
5
- export declare const DEFAULT_TAB_IDENTIFIER = "__default__tab__";
6
- export declare class DefaultTab extends CompositeDisposable implements ITabRenderer {
7
- private _element;
8
- private _isPanelVisible;
9
- private _isGroupActive;
10
- private _content;
11
- private _actionContainer;
12
- private _list;
13
- private action;
14
- private params;
15
- get element(): HTMLElement;
16
- get id(): string;
17
- constructor();
18
- update(event: PanelUpdateEvent): void;
19
- toJSON(): {
20
- id: string;
21
- };
22
- focus(): void;
23
- init(params: GroupPanelPartInitParameters): void;
24
- updateParentGroup(group: GroupPanel, isPanelVisible: boolean): void;
25
- layout(_width: number, _height: number): void;
26
- private render;
27
- }
1
+ import { CompositeDisposable } from '../../../lifecycle';
2
+ import { ITabRenderer, GroupPanelPartInitParameters } from '../../../groupview/types';
3
+ import { PanelUpdateEvent } from '../../../panel/types';
4
+ import { GroupPanel } from '../../../groupview/groupviewPanel';
5
+ export declare const DEFAULT_TAB_IDENTIFIER = "__default__tab__";
6
+ export declare class DefaultTab extends CompositeDisposable implements ITabRenderer {
7
+ private _element;
8
+ private _isPanelVisible;
9
+ private _isGroupActive;
10
+ private _content;
11
+ private _actionContainer;
12
+ private _list;
13
+ private action;
14
+ private params;
15
+ get element(): HTMLElement;
16
+ get id(): string;
17
+ constructor();
18
+ update(event: PanelUpdateEvent): void;
19
+ toJSON(): {
20
+ id: string;
21
+ };
22
+ focus(): void;
23
+ init(params: GroupPanelPartInitParameters): void;
24
+ updateParentGroup(group: GroupPanel, isPanelVisible: boolean): void;
25
+ layout(_width: number, _height: number): void;
26
+ private render;
27
+ }