dockview-core 1.8.4 → 1.8.5

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 (334) hide show
  1. package/README.md +51 -51
  2. package/dist/cjs/api/component.api.d.ts +455 -152
  3. package/dist/cjs/api/component.api.d.ts.map +1 -1
  4. package/dist/cjs/api/component.api.js +895 -592
  5. package/dist/cjs/api/component.api.js.map +1 -1
  6. package/dist/cjs/api/dockviewGroupPanelApi.d.ts +29 -29
  7. package/dist/cjs/api/dockviewGroupPanelApi.js +53 -53
  8. package/dist/cjs/api/dockviewPanelApi.d.ts +47 -47
  9. package/dist/cjs/api/dockviewPanelApi.js +88 -88
  10. package/dist/cjs/api/gridviewPanelApi.d.ts +37 -37
  11. package/dist/cjs/api/gridviewPanelApi.js +47 -47
  12. package/dist/cjs/api/panelApi.d.ts +88 -88
  13. package/dist/cjs/api/panelApi.js +135 -135
  14. package/dist/cjs/api/paneviewPanelApi.d.ts +26 -26
  15. package/dist/cjs/api/paneviewPanelApi.js +57 -57
  16. package/dist/cjs/api/splitviewPanelApi.d.ts +32 -32
  17. package/dist/cjs/api/splitviewPanelApi.js +47 -47
  18. package/dist/cjs/array.d.ts +13 -13
  19. package/dist/cjs/array.js +67 -67
  20. package/dist/cjs/dnd/abstractDragHandler.d.ts +12 -12
  21. package/dist/cjs/dnd/abstractDragHandler.js +141 -141
  22. package/dist/cjs/dnd/dataTransfer.d.ts +30 -31
  23. package/dist/cjs/dnd/dataTransfer.d.ts.map +1 -1
  24. package/dist/cjs/dnd/dataTransfer.js +99 -100
  25. package/dist/cjs/dnd/dataTransfer.js.map +1 -1
  26. package/dist/cjs/dnd/dnd.d.ts +27 -27
  27. package/dist/cjs/dnd/dnd.js +59 -59
  28. package/dist/cjs/dnd/droptarget.d.ts +53 -53
  29. package/dist/cjs/dnd/droptarget.js +304 -304
  30. package/dist/cjs/dnd/droptarget.js.map +1 -1
  31. package/dist/cjs/dnd/ghost.d.ts +1 -1
  32. package/dist/cjs/dnd/ghost.js +15 -15
  33. package/dist/cjs/dnd/groupDragHandler.d.ts +12 -12
  34. package/dist/cjs/dnd/groupDragHandler.js +77 -77
  35. package/dist/cjs/dnd/overlay.d.ts +43 -43
  36. package/dist/cjs/dnd/overlay.d.ts.map +1 -1
  37. package/dist/cjs/dnd/overlay.js +412 -412
  38. package/dist/cjs/dnd/overlay.js.map +1 -1
  39. package/dist/cjs/dockview/components/panel/content.d.ts +30 -30
  40. package/dist/cjs/dockview/components/panel/content.js +100 -100
  41. package/dist/cjs/dockview/components/tab/defaultTab.d.ts +21 -21
  42. package/dist/cjs/dockview/components/tab/defaultTab.js +105 -105
  43. package/dist/cjs/dockview/components/tab/tab.d.ts +34 -34
  44. package/dist/cjs/dockview/components/tab/tab.js +120 -120
  45. package/dist/cjs/dockview/components/titlebar/tabsContainer.d.ts +81 -81
  46. package/dist/cjs/dockview/components/titlebar/tabsContainer.js +325 -325
  47. package/dist/cjs/dockview/components/titlebar/voidContainer.d.ts +17 -17
  48. package/dist/cjs/dockview/components/titlebar/voidContainer.js +77 -77
  49. package/dist/cjs/dockview/components/watermark/watermark.d.ts +18 -18
  50. package/dist/cjs/dockview/components/watermark/watermark.js +87 -87
  51. package/dist/cjs/dockview/deserializer.d.ts +12 -12
  52. package/dist/cjs/dockview/deserializer.js +33 -33
  53. package/dist/cjs/dockview/deserializer.js.map +1 -1
  54. package/dist/cjs/dockview/dockviewComponent.d.ts +159 -159
  55. package/dist/cjs/dockview/dockviewComponent.d.ts.map +1 -1
  56. package/dist/cjs/dockview/dockviewComponent.js +1170 -1156
  57. package/dist/cjs/dockview/dockviewComponent.js.map +1 -1
  58. package/dist/cjs/dockview/dockviewFloatingGroupPanel.d.ts +23 -23
  59. package/dist/cjs/dockview/dockviewFloatingGroupPanel.js +34 -34
  60. package/dist/cjs/dockview/dockviewGroupPanel.d.ts +30 -30
  61. package/dist/cjs/dockview/dockviewGroupPanel.js +97 -97
  62. package/dist/cjs/dockview/dockviewGroupPanelModel.d.ts +185 -185
  63. package/dist/cjs/dockview/dockviewGroupPanelModel.js +632 -631
  64. package/dist/cjs/dockview/dockviewGroupPanelModel.js.map +1 -1
  65. package/dist/cjs/dockview/dockviewPanel.d.ts +41 -41
  66. package/dist/cjs/dockview/dockviewPanel.js +172 -171
  67. package/dist/cjs/dockview/dockviewPanel.js.map +1 -1
  68. package/dist/cjs/dockview/dockviewPanelModel.d.ts +35 -35
  69. package/dist/cjs/dockview/dockviewPanelModel.js +98 -98
  70. package/dist/cjs/dockview/dockviewPanelModel.js.map +1 -1
  71. package/dist/cjs/dockview/options.d.ts +133 -136
  72. package/dist/cjs/dockview/options.d.ts.map +1 -1
  73. package/dist/cjs/dockview/options.js +31 -31
  74. package/dist/cjs/dockview/types.d.ts +63 -63
  75. package/dist/cjs/dockview/types.js +10 -10
  76. package/dist/cjs/dockview/types.js.map +1 -1
  77. package/dist/cjs/dom.d.ts +16 -16
  78. package/dist/cjs/dom.js +197 -197
  79. package/dist/cjs/events.d.ts +47 -47
  80. package/dist/cjs/events.js +216 -216
  81. package/dist/cjs/events.js.map +1 -1
  82. package/dist/cjs/gridview/baseComponentGridview.d.ts +88 -87
  83. package/dist/cjs/gridview/baseComponentGridview.d.ts.map +1 -1
  84. package/dist/cjs/gridview/baseComponentGridview.js +270 -270
  85. package/dist/cjs/gridview/baseComponentGridview.js.map +1 -1
  86. package/dist/cjs/gridview/basePanelView.d.ts +40 -40
  87. package/dist/cjs/gridview/basePanelView.js +156 -156
  88. package/dist/cjs/gridview/branchNode.d.ts +49 -49
  89. package/dist/cjs/gridview/branchNode.js +343 -343
  90. package/dist/cjs/gridview/gridview.d.ts +133 -133
  91. package/dist/cjs/gridview/gridview.js +547 -547
  92. package/dist/cjs/gridview/gridviewComponent.d.ts +80 -80
  93. package/dist/cjs/gridview/gridviewComponent.d.ts.map +1 -1
  94. package/dist/cjs/gridview/gridviewComponent.js +362 -360
  95. package/dist/cjs/gridview/gridviewComponent.js.map +1 -1
  96. package/dist/cjs/gridview/gridviewPanel.d.ts +65 -65
  97. package/dist/cjs/gridview/gridviewPanel.js +214 -214
  98. package/dist/cjs/gridview/leafNode.d.ts +34 -34
  99. package/dist/cjs/gridview/leafNode.js +170 -170
  100. package/dist/cjs/gridview/leafNode.js.map +1 -1
  101. package/dist/cjs/gridview/options.d.ts +17 -18
  102. package/dist/cjs/gridview/options.d.ts.map +1 -1
  103. package/dist/cjs/gridview/options.js +2 -2
  104. package/dist/cjs/gridview/types.d.ts +3 -3
  105. package/dist/cjs/gridview/types.js +2 -2
  106. package/dist/cjs/index.d.ts +42 -42
  107. package/dist/cjs/index.js +61 -61
  108. package/dist/cjs/lifecycle.d.ts +23 -23
  109. package/dist/cjs/lifecycle.js +65 -65
  110. package/dist/cjs/lifecycle.js.map +1 -1
  111. package/dist/cjs/math.d.ts +5 -5
  112. package/dist/cjs/math.js +34 -34
  113. package/dist/cjs/panel/componentFactory.d.ts +11 -10
  114. package/dist/cjs/panel/componentFactory.d.ts.map +1 -1
  115. package/dist/cjs/panel/componentFactory.js +30 -30
  116. package/dist/cjs/panel/componentFactory.js.map +1 -1
  117. package/dist/cjs/panel/types.d.ts +33 -33
  118. package/dist/cjs/panel/types.js +2 -2
  119. package/dist/cjs/paneview/defaultPaneviewHeader.d.ts +21 -21
  120. package/dist/cjs/paneview/defaultPaneviewHeader.js +90 -90
  121. package/dist/cjs/paneview/draggablePaneviewPanel.d.ts +21 -21
  122. package/dist/cjs/paneview/draggablePaneviewPanel.js +131 -131
  123. package/dist/cjs/paneview/options.d.ts +25 -28
  124. package/dist/cjs/paneview/options.d.ts.map +1 -1
  125. package/dist/cjs/paneview/options.js +2 -2
  126. package/dist/cjs/paneview/paneview.d.ts +40 -40
  127. package/dist/cjs/paneview/paneview.d.ts.map +1 -1
  128. package/dist/cjs/paneview/paneview.js +200 -201
  129. package/dist/cjs/paneview/paneview.js.map +1 -1
  130. package/dist/cjs/paneview/paneviewComponent.d.ts +128 -128
  131. package/dist/cjs/paneview/paneviewComponent.js +400 -397
  132. package/dist/cjs/paneview/paneviewComponent.js.map +1 -1
  133. package/dist/cjs/paneview/paneviewPanel.d.ts +92 -92
  134. package/dist/cjs/paneview/paneviewPanel.d.ts.map +1 -1
  135. package/dist/cjs/paneview/paneviewPanel.js +275 -275
  136. package/dist/cjs/resizable.d.ts +10 -7
  137. package/dist/cjs/resizable.d.ts.map +1 -1
  138. package/dist/cjs/resizable.js +79 -64
  139. package/dist/cjs/resizable.js.map +1 -1
  140. package/dist/cjs/splitview/options.d.ts +26 -27
  141. package/dist/cjs/splitview/options.d.ts.map +1 -1
  142. package/dist/cjs/splitview/options.js +2 -2
  143. package/dist/cjs/splitview/splitview.d.ts +128 -128
  144. package/dist/cjs/splitview/splitview.js +936 -936
  145. package/dist/cjs/splitview/splitview.js.map +1 -1
  146. package/dist/cjs/splitview/splitviewComponent.d.ts +101 -101
  147. package/dist/cjs/splitview/splitviewComponent.js +395 -392
  148. package/dist/cjs/splitview/splitviewComponent.js.map +1 -1
  149. package/dist/cjs/splitview/splitviewPanel.d.ts +45 -45
  150. package/dist/cjs/splitview/splitviewPanel.d.ts.map +1 -1
  151. package/dist/cjs/splitview/splitviewPanel.js +179 -179
  152. package/dist/cjs/splitview/splitviewPanel.js.map +1 -1
  153. package/dist/cjs/splitview/viewItem.d.ts +25 -25
  154. package/dist/cjs/splitview/viewItem.js +119 -119
  155. package/dist/cjs/svg.d.ts +3 -3
  156. package/dist/cjs/svg.js +43 -43
  157. package/dist/cjs/types.d.ts +2 -2
  158. package/dist/cjs/types.js +2 -2
  159. package/dist/dockview-core.amd.js +7650 -7316
  160. package/dist/dockview-core.amd.js.map +1 -1
  161. package/dist/dockview-core.amd.min.js +2 -2
  162. package/dist/dockview-core.amd.min.js.map +1 -1
  163. package/dist/dockview-core.amd.min.noStyle.js +2 -2
  164. package/dist/dockview-core.amd.min.noStyle.js.map +1 -1
  165. package/dist/dockview-core.amd.noStyle.js +7601 -7267
  166. package/dist/dockview-core.amd.noStyle.js.map +1 -1
  167. package/dist/dockview-core.cjs.js +7650 -7316
  168. package/dist/dockview-core.cjs.js.map +1 -1
  169. package/dist/dockview-core.esm.js +7650 -7316
  170. package/dist/dockview-core.esm.js.map +1 -1
  171. package/dist/dockview-core.esm.min.js +2 -2
  172. package/dist/dockview-core.esm.min.js.map +1 -1
  173. package/dist/dockview-core.js +7650 -7316
  174. package/dist/dockview-core.js.map +1 -1
  175. package/dist/dockview-core.min.js +2 -2
  176. package/dist/dockview-core.min.js.map +1 -1
  177. package/dist/dockview-core.min.noStyle.js +2 -2
  178. package/dist/dockview-core.min.noStyle.js.map +1 -1
  179. package/dist/dockview-core.noStyle.js +7601 -7267
  180. package/dist/dockview-core.noStyle.js.map +1 -1
  181. package/dist/esm/api/component.api.d.ts +455 -152
  182. package/dist/esm/api/component.api.d.ts.map +1 -1
  183. package/dist/esm/api/component.api.js +638 -335
  184. package/dist/esm/api/component.api.js.map +1 -1
  185. package/dist/esm/api/dockviewGroupPanelApi.d.ts +29 -29
  186. package/dist/esm/api/dockviewGroupPanelApi.js +27 -27
  187. package/dist/esm/api/dockviewPanelApi.d.ts +47 -47
  188. package/dist/esm/api/dockviewPanelApi.js +53 -53
  189. package/dist/esm/api/gridviewPanelApi.d.ts +37 -37
  190. package/dist/esm/api/gridviewPanelApi.js +25 -25
  191. package/dist/esm/api/panelApi.d.ts +88 -88
  192. package/dist/esm/api/panelApi.js +93 -93
  193. package/dist/esm/api/paneviewPanelApi.d.ts +26 -26
  194. package/dist/esm/api/paneviewPanelApi.js +27 -27
  195. package/dist/esm/api/splitviewPanelApi.d.ts +32 -32
  196. package/dist/esm/api/splitviewPanelApi.js +25 -25
  197. package/dist/esm/array.d.ts +13 -13
  198. package/dist/esm/array.js +57 -57
  199. package/dist/esm/dnd/abstractDragHandler.d.ts +12 -12
  200. package/dist/esm/dnd/abstractDragHandler.js +63 -63
  201. package/dist/esm/dnd/dataTransfer.d.ts +30 -31
  202. package/dist/esm/dnd/dataTransfer.d.ts.map +1 -1
  203. package/dist/esm/dnd/dataTransfer.js +66 -69
  204. package/dist/esm/dnd/dataTransfer.js.map +1 -1
  205. package/dist/esm/dnd/dnd.d.ts +27 -27
  206. package/dist/esm/dnd/dnd.js +36 -36
  207. package/dist/esm/dnd/droptarget.d.ts +53 -53
  208. package/dist/esm/dnd/droptarget.js +274 -274
  209. package/dist/esm/dnd/droptarget.js.map +1 -1
  210. package/dist/esm/dnd/ghost.d.ts +1 -1
  211. package/dist/esm/dnd/ghost.js +11 -11
  212. package/dist/esm/dnd/groupDragHandler.d.ts +12 -12
  213. package/dist/esm/dnd/groupDragHandler.js +54 -54
  214. package/dist/esm/dnd/overlay.d.ts +43 -43
  215. package/dist/esm/dnd/overlay.d.ts.map +1 -1
  216. package/dist/esm/dnd/overlay.js +304 -304
  217. package/dist/esm/dnd/overlay.js.map +1 -1
  218. package/dist/esm/dockview/components/panel/content.d.ts +30 -30
  219. package/dist/esm/dockview/components/panel/content.js +73 -73
  220. package/dist/esm/dockview/components/tab/defaultTab.d.ts +21 -21
  221. package/dist/esm/dockview/components/tab/defaultTab.js +67 -67
  222. package/dist/esm/dockview/components/tab/tab.d.ts +34 -34
  223. package/dist/esm/dockview/components/tab/tab.js +90 -90
  224. package/dist/esm/dockview/components/titlebar/tabsContainer.d.ts +81 -81
  225. package/dist/esm/dockview/components/titlebar/tabsContainer.js +239 -239
  226. package/dist/esm/dockview/components/titlebar/voidContainer.d.ts +17 -17
  227. package/dist/esm/dockview/components/titlebar/voidContainer.js +51 -51
  228. package/dist/esm/dockview/components/watermark/watermark.d.ts +18 -18
  229. package/dist/esm/dockview/components/watermark/watermark.js +61 -61
  230. package/dist/esm/dockview/deserializer.d.ts +12 -12
  231. package/dist/esm/dockview/deserializer.js +28 -28
  232. package/dist/esm/dockview/deserializer.js.map +1 -1
  233. package/dist/esm/dockview/dockviewComponent.d.ts +159 -159
  234. package/dist/esm/dockview/dockviewComponent.d.ts.map +1 -1
  235. package/dist/esm/dockview/dockviewComponent.js +932 -918
  236. package/dist/esm/dockview/dockviewComponent.js.map +1 -1
  237. package/dist/esm/dockview/dockviewFloatingGroupPanel.d.ts +23 -23
  238. package/dist/esm/dockview/dockviewFloatingGroupPanel.js +12 -12
  239. package/dist/esm/dockview/dockviewGroupPanel.d.ts +30 -30
  240. package/dist/esm/dockview/dockviewGroupPanel.js +51 -51
  241. package/dist/esm/dockview/dockviewGroupPanelModel.d.ts +185 -185
  242. package/dist/esm/dockview/dockviewGroupPanelModel.js +499 -498
  243. package/dist/esm/dockview/dockviewGroupPanelModel.js.map +1 -1
  244. package/dist/esm/dockview/dockviewPanel.d.ts +41 -41
  245. package/dist/esm/dockview/dockviewPanel.js +105 -104
  246. package/dist/esm/dockview/dockviewPanel.js.map +1 -1
  247. package/dist/esm/dockview/dockviewPanelModel.d.ts +35 -35
  248. package/dist/esm/dockview/dockviewPanelModel.js +74 -74
  249. package/dist/esm/dockview/dockviewPanelModel.js.map +1 -1
  250. package/dist/esm/dockview/options.d.ts +133 -136
  251. package/dist/esm/dockview/options.d.ts.map +1 -1
  252. package/dist/esm/dockview/options.js +24 -24
  253. package/dist/esm/dockview/types.d.ts +63 -63
  254. package/dist/esm/dockview/types.js +7 -7
  255. package/dist/esm/dom.d.ts +16 -16
  256. package/dist/esm/dom.js +126 -126
  257. package/dist/esm/events.d.ts +47 -47
  258. package/dist/esm/events.js +156 -156
  259. package/dist/esm/events.js.map +1 -1
  260. package/dist/esm/gridview/baseComponentGridview.d.ts +88 -87
  261. package/dist/esm/gridview/baseComponentGridview.d.ts.map +1 -1
  262. package/dist/esm/gridview/baseComponentGridview.js +184 -184
  263. package/dist/esm/gridview/baseComponentGridview.js.map +1 -1
  264. package/dist/esm/gridview/basePanelView.d.ts +40 -40
  265. package/dist/esm/gridview/basePanelView.js +85 -85
  266. package/dist/esm/gridview/branchNode.d.ts +49 -49
  267. package/dist/esm/gridview/branchNode.js +219 -219
  268. package/dist/esm/gridview/gridview.d.ts +133 -133
  269. package/dist/esm/gridview/gridview.js +461 -461
  270. package/dist/esm/gridview/gridviewComponent.d.ts +80 -80
  271. package/dist/esm/gridview/gridviewComponent.d.ts.map +1 -1
  272. package/dist/esm/gridview/gridviewComponent.js +264 -262
  273. package/dist/esm/gridview/gridviewComponent.js.map +1 -1
  274. package/dist/esm/gridview/gridviewPanel.d.ts +65 -65
  275. package/dist/esm/gridview/gridviewPanel.js +151 -151
  276. package/dist/esm/gridview/leafNode.d.ts +34 -34
  277. package/dist/esm/gridview/leafNode.js +103 -103
  278. package/dist/esm/gridview/options.d.ts +17 -18
  279. package/dist/esm/gridview/options.d.ts.map +1 -1
  280. package/dist/esm/gridview/options.js +1 -1
  281. package/dist/esm/gridview/types.d.ts +3 -3
  282. package/dist/esm/gridview/types.js +1 -1
  283. package/dist/esm/index.d.ts +42 -42
  284. package/dist/esm/index.js +34 -34
  285. package/dist/esm/lifecycle.d.ts +23 -23
  286. package/dist/esm/lifecycle.js +41 -41
  287. package/dist/esm/math.d.ts +5 -5
  288. package/dist/esm/math.js +28 -28
  289. package/dist/esm/panel/componentFactory.d.ts +11 -10
  290. package/dist/esm/panel/componentFactory.d.ts.map +1 -1
  291. package/dist/esm/panel/componentFactory.js +24 -24
  292. package/dist/esm/panel/componentFactory.js.map +1 -1
  293. package/dist/esm/panel/types.d.ts +33 -33
  294. package/dist/esm/panel/types.js +1 -1
  295. package/dist/esm/paneview/defaultPaneviewHeader.d.ts +21 -21
  296. package/dist/esm/paneview/defaultPaneviewHeader.js +63 -63
  297. package/dist/esm/paneview/draggablePaneviewPanel.d.ts +21 -21
  298. package/dist/esm/paneview/draggablePaneviewPanel.js +92 -92
  299. package/dist/esm/paneview/options.d.ts +25 -28
  300. package/dist/esm/paneview/options.d.ts.map +1 -1
  301. package/dist/esm/paneview/options.js +1 -1
  302. package/dist/esm/paneview/paneview.d.ts +40 -40
  303. package/dist/esm/paneview/paneview.d.ts.map +1 -1
  304. package/dist/esm/paneview/paneview.js +145 -145
  305. package/dist/esm/paneview/paneviewComponent.d.ts +128 -128
  306. package/dist/esm/paneview/paneviewComponent.js +276 -273
  307. package/dist/esm/paneview/paneviewComponent.js.map +1 -1
  308. package/dist/esm/paneview/paneviewPanel.d.ts +92 -92
  309. package/dist/esm/paneview/paneviewPanel.d.ts.map +1 -1
  310. package/dist/esm/paneview/paneviewPanel.js +192 -192
  311. package/dist/esm/resizable.d.ts +10 -7
  312. package/dist/esm/resizable.d.ts.map +1 -1
  313. package/dist/esm/resizable.js +48 -38
  314. package/dist/esm/resizable.js.map +1 -1
  315. package/dist/esm/splitview/options.d.ts +26 -27
  316. package/dist/esm/splitview/options.d.ts.map +1 -1
  317. package/dist/esm/splitview/options.js +1 -1
  318. package/dist/esm/splitview/splitview.d.ts +128 -128
  319. package/dist/esm/splitview/splitview.js +704 -704
  320. package/dist/esm/splitview/splitviewComponent.d.ts +101 -101
  321. package/dist/esm/splitview/splitviewComponent.js +261 -258
  322. package/dist/esm/splitview/splitviewComponent.js.map +1 -1
  323. package/dist/esm/splitview/splitviewPanel.d.ts +45 -45
  324. package/dist/esm/splitview/splitviewPanel.d.ts.map +1 -1
  325. package/dist/esm/splitview/splitviewPanel.js +108 -108
  326. package/dist/esm/splitview/splitviewPanel.js.map +1 -1
  327. package/dist/esm/splitview/viewItem.d.ts +25 -25
  328. package/dist/esm/splitview/viewItem.js +74 -74
  329. package/dist/esm/svg.d.ts +3 -3
  330. package/dist/esm/svg.js +31 -31
  331. package/dist/esm/types.d.ts +2 -2
  332. package/dist/esm/types.js +1 -1
  333. package/package.json +30 -42
  334. package/LICENSE +0 -21
@@ -1,11 +1,12 @@
1
- export interface FrameworkFactory<T> {
2
- createComponent: (id: string, componentId: string, component: any) => T;
3
- }
4
- export declare function createComponent<T>(id: string, componentName?: string, components?: {
5
- [componentName: string]: {
6
- new (id: string, component: string): T;
7
- };
8
- }, frameworkComponents?: {
9
- [componentName: string]: any;
10
- }, createFrameworkComponent?: FrameworkFactory<T>, fallback?: () => T): T;
1
+ export interface FrameworkFactory<T> {
2
+ createComponent: (id: string, componentId: string, component: any) => T;
3
+ }
4
+ export type ComponentConstructor<T> = {
5
+ new (id: string, component: string): T;
6
+ };
7
+ export declare function createComponent<T>(id: string, componentName?: string, components?: {
8
+ [componentName: string]: ComponentConstructor<T>;
9
+ }, frameworkComponents?: {
10
+ [componentName: string]: any;
11
+ }, createFrameworkComponent?: FrameworkFactory<T>, fallback?: () => T): T;
11
12
  //# sourceMappingURL=componentFactory.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"componentFactory.d.ts","sourceRoot":"","sources":["../../../src/panel/componentFactory.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB,CAAC,CAAC;IAC/B,eAAe,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC,CAAC;CAC3E;AAED,wBAAgB,eAAe,CAAC,CAAC,EAC7B,EAAE,EAAE,MAAM,EACV,aAAa,CAAC,EAAE,MAAM,EACtB,UAAU,GAAE;IACR,CAAC,aAAa,EAAE,MAAM,GAAG;QAAE,KAAK,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,CAAC,CAAA;KAAE,CAAC;CAClE,EACN,mBAAmB,GAAE;IACjB,CAAC,aAAa,EAAE,MAAM,GAAG,GAAG,CAAC;CAC3B,EACN,wBAAwB,CAAC,EAAE,gBAAgB,CAAC,CAAC,CAAC,EAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC,GACnB,CAAC,CAsCH"}
1
+ {"version":3,"file":"componentFactory.d.ts","sourceRoot":"","sources":["../../../src/panel/componentFactory.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB,CAAC,CAAC;IAC/B,eAAe,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC,CAAC;CAC3E;AAED,MAAM,MAAM,oBAAoB,CAAC,CAAC,IAAI;IAClC,KAAK,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,CAAC,CAAC;CAC1C,CAAC;AAEF,wBAAgB,eAAe,CAAC,CAAC,EAC7B,EAAE,EAAE,MAAM,EACV,aAAa,CAAC,EAAE,MAAM,EACtB,UAAU,GAAE;IACR,CAAC,aAAa,EAAE,MAAM,GAAG,oBAAoB,CAAC,CAAC,CAAC,CAAC;CAC/C,EACN,mBAAmB,GAAE;IACjB,CAAC,aAAa,EAAE,MAAM,GAAG,GAAG,CAAC;CAC3B,EACN,wBAAwB,CAAC,EAAE,gBAAgB,CAAC,CAAC,CAAC,EAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC,GACnB,CAAC,CAsCH"}
@@ -1,25 +1,25 @@
1
- export function createComponent(id, componentName, components = {}, frameworkComponents = {}, createFrameworkComponent, fallback) {
2
- const Component = typeof componentName === 'string'
3
- ? components[componentName]
4
- : undefined;
5
- const FrameworkComponent = typeof componentName === 'string'
6
- ? frameworkComponents[componentName]
7
- : undefined;
8
- if (Component && FrameworkComponent) {
9
- throw new Error(`Cannot create '${id}'. component '${componentName}' registered as both a component and frameworkComponent`);
10
- }
11
- if (FrameworkComponent) {
12
- if (!createFrameworkComponent) {
13
- throw new Error(`Cannot create '${id}' for framework component '${componentName}'. you must register a frameworkPanelWrapper to use framework components`);
14
- }
15
- return createFrameworkComponent.createComponent(id, componentName, FrameworkComponent);
16
- }
17
- if (!Component) {
18
- if (fallback) {
19
- return fallback();
20
- }
21
- throw new Error(`Cannot create '${id}', no component '${componentName}' provided`);
22
- }
23
- return new Component(id, componentName);
24
- }
1
+ export function createComponent(id, componentName, components = {}, frameworkComponents = {}, createFrameworkComponent, fallback) {
2
+ const Component = typeof componentName === 'string'
3
+ ? components[componentName]
4
+ : undefined;
5
+ const FrameworkComponent = typeof componentName === 'string'
6
+ ? frameworkComponents[componentName]
7
+ : undefined;
8
+ if (Component && FrameworkComponent) {
9
+ throw new Error(`Cannot create '${id}'. component '${componentName}' registered as both a component and frameworkComponent`);
10
+ }
11
+ if (FrameworkComponent) {
12
+ if (!createFrameworkComponent) {
13
+ throw new Error(`Cannot create '${id}' for framework component '${componentName}'. you must register a frameworkPanelWrapper to use framework components`);
14
+ }
15
+ return createFrameworkComponent.createComponent(id, componentName, FrameworkComponent);
16
+ }
17
+ if (!Component) {
18
+ if (fallback) {
19
+ return fallback();
20
+ }
21
+ throw new Error(`Cannot create '${id}', no component '${componentName}' provided`);
22
+ }
23
+ return new Component(id, componentName);
24
+ }
25
25
  //# sourceMappingURL=componentFactory.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"componentFactory.js","sourceRoot":"","sources":["../../../src/panel/componentFactory.ts"],"names":[],"mappings":"AAIA,MAAM,UAAU,eAAe,CAC3B,EAAU,EACV,aAAsB,EACtB,aAEI,EAAE,EACN,sBAEI,EAAE,EACN,wBAA8C,EAC9C,QAAkB;IAElB,MAAM,SAAS,GACX,OAAO,aAAa,KAAK,QAAQ;QAC7B,CAAC,CAAC,UAAU,CAAC,aAAa,CAAC;QAC3B,CAAC,CAAC,SAAS,CAAC;IACpB,MAAM,kBAAkB,GACpB,OAAO,aAAa,KAAK,QAAQ;QAC7B,CAAC,CAAC,mBAAmB,CAAC,aAAa,CAAC;QACpC,CAAC,CAAC,SAAS,CAAC;IAEpB,IAAI,SAAS,IAAI,kBAAkB,EAAE;QACjC,MAAM,IAAI,KAAK,CACX,kBAAkB,EAAE,iBAAiB,aAAa,yDAAyD,CAC9G,CAAC;KACL;IACD,IAAI,kBAAkB,EAAE;QACpB,IAAI,CAAC,wBAAwB,EAAE;YAC3B,MAAM,IAAI,KAAK,CACX,kBAAkB,EAAE,8BAA8B,aAAa,0EAA0E,CAC5I,CAAC;SACL;QACD,OAAO,wBAAwB,CAAC,eAAe,CAC3C,EAAE,EACF,aAAc,EACd,kBAAkB,CACrB,CAAC;KACL;IAED,IAAI,CAAC,SAAS,EAAE;QACZ,IAAI,QAAQ,EAAE;YACV,OAAO,QAAQ,EAAE,CAAC;SACrB;QACD,MAAM,IAAI,KAAK,CACX,kBAAkB,EAAE,oBAAoB,aAAa,YAAY,CACpE,CAAC;KACL;IAED,OAAO,IAAI,SAAS,CAAC,EAAE,EAAE,aAAc,CAAC,CAAC;AAC7C,CAAC"}
1
+ {"version":3,"file":"componentFactory.js","sourceRoot":"","sources":["../../../src/panel/componentFactory.ts"],"names":[],"mappings":"AAQA,MAAM,UAAU,eAAe,CAC3B,EAAU,EACV,aAAsB,EACtB,aAEI,EAAE,EACN,sBAEI,EAAE,EACN,wBAA8C,EAC9C,QAAkB;IAElB,MAAM,SAAS,GACX,OAAO,aAAa,KAAK,QAAQ;QAC7B,CAAC,CAAC,UAAU,CAAC,aAAa,CAAC;QAC3B,CAAC,CAAC,SAAS,CAAC;IACpB,MAAM,kBAAkB,GACpB,OAAO,aAAa,KAAK,QAAQ;QAC7B,CAAC,CAAC,mBAAmB,CAAC,aAAa,CAAC;QACpC,CAAC,CAAC,SAAS,CAAC;IAEpB,IAAI,SAAS,IAAI,kBAAkB,EAAE;QACjC,MAAM,IAAI,KAAK,CACX,kBAAkB,EAAE,iBAAiB,aAAa,yDAAyD,CAC9G,CAAC;KACL;IACD,IAAI,kBAAkB,EAAE;QACpB,IAAI,CAAC,wBAAwB,EAAE;YAC3B,MAAM,IAAI,KAAK,CACX,kBAAkB,EAAE,8BAA8B,aAAa,0EAA0E,CAC5I,CAAC;SACL;QACD,OAAO,wBAAwB,CAAC,eAAe,CAC3C,EAAE,EACF,aAAc,EACd,kBAAkB,CACrB,CAAC;KACL;IAED,IAAI,CAAC,SAAS,EAAE;QACZ,IAAI,QAAQ,EAAE;YACV,OAAO,QAAQ,EAAE,CAAC;SACrB;QACD,MAAM,IAAI,KAAK,CACX,kBAAkB,EAAE,oBAAoB,aAAa,YAAY,CACpE,CAAC;KACL;IAED,OAAO,IAAI,SAAS,CAAC,EAAE,EAAE,aAAc,CAAC,CAAC;AAC7C,CAAC"}
@@ -1,34 +1,34 @@
1
- import { IDisposable } from '../lifecycle';
2
- import { LayoutPriority } from '../splitview/splitview';
3
- /**
4
- * A key-value object of anything that is a valid JavaScript Object.
5
- */
6
- export interface Parameters {
7
- [key: string]: any;
8
- }
9
- export interface PanelInitParameters {
10
- params: Parameters;
11
- }
12
- export interface PanelUpdateEvent<T extends Parameters = Parameters> {
13
- params: Partial<T>;
14
- }
15
- export interface IPanel extends IDisposable {
16
- readonly id: string;
17
- init(params: PanelInitParameters): void;
18
- layout(width: number, height: number): void;
19
- update(event: PanelUpdateEvent<Parameters>): void;
20
- toJSON(): object;
21
- focus?(): void;
22
- }
23
- export interface IFrameworkPart extends IDisposable {
24
- update(params: Parameters): void;
25
- }
26
- export interface BaseComponentOptions<T extends object = Parameters> {
27
- id: string;
28
- component: string;
29
- params?: T;
30
- snap?: boolean;
31
- priority?: LayoutPriority;
32
- size?: number;
33
- }
1
+ import { IDisposable } from '../lifecycle';
2
+ import { LayoutPriority } from '../splitview/splitview';
3
+ /**
4
+ * A key-value object of anything that is a valid JavaScript Object.
5
+ */
6
+ export interface Parameters {
7
+ [key: string]: any;
8
+ }
9
+ export interface PanelInitParameters {
10
+ params: Parameters;
11
+ }
12
+ export interface PanelUpdateEvent<T extends Parameters = Parameters> {
13
+ params: Partial<T>;
14
+ }
15
+ export interface IPanel extends IDisposable {
16
+ readonly id: string;
17
+ init(params: PanelInitParameters): void;
18
+ layout(width: number, height: number): void;
19
+ update(event: PanelUpdateEvent<Parameters>): void;
20
+ toJSON(): object;
21
+ focus?(): void;
22
+ }
23
+ export interface IFrameworkPart extends IDisposable {
24
+ update(params: Parameters): void;
25
+ }
26
+ export interface BaseComponentOptions<T extends object = Parameters> {
27
+ id: string;
28
+ component: string;
29
+ params?: T;
30
+ snap?: boolean;
31
+ priority?: LayoutPriority;
32
+ size?: number;
33
+ }
34
34
  //# sourceMappingURL=types.d.ts.map
@@ -1,2 +1,2 @@
1
- export {};
1
+ export {};
2
2
  //# sourceMappingURL=types.js.map
@@ -1,22 +1,22 @@
1
- import { PaneviewPanelApiImpl } from '../api/paneviewPanelApi';
2
- import { CompositeDisposable } from '../lifecycle';
3
- import { PanelUpdateEvent } from '../panel/types';
4
- import { IPaneHeaderPart, PanePanelInitParameter } from './paneviewPanel';
5
- export declare class DefaultHeader extends CompositeDisposable implements IPaneHeaderPart {
6
- private readonly _expandedIcon;
7
- private readonly _collapsedIcon;
8
- private readonly disposable;
9
- private readonly _element;
10
- private readonly _content;
11
- private readonly _expander;
12
- private apiRef;
13
- get element(): HTMLElement;
14
- constructor();
15
- init(params: PanePanelInitParameter & {
16
- api: PaneviewPanelApiImpl;
17
- }): void;
18
- private updateIcon;
19
- update(_params: PanelUpdateEvent): void;
20
- dispose(): void;
21
- }
1
+ import { PaneviewPanelApiImpl } from '../api/paneviewPanelApi';
2
+ import { CompositeDisposable } from '../lifecycle';
3
+ import { PanelUpdateEvent } from '../panel/types';
4
+ import { IPaneHeaderPart, PanePanelInitParameter } from './paneviewPanel';
5
+ export declare class DefaultHeader extends CompositeDisposable implements IPaneHeaderPart {
6
+ private readonly _expandedIcon;
7
+ private readonly _collapsedIcon;
8
+ private readonly disposable;
9
+ private readonly _element;
10
+ private readonly _content;
11
+ private readonly _expander;
12
+ private apiRef;
13
+ get element(): HTMLElement;
14
+ constructor();
15
+ init(params: PanePanelInitParameter & {
16
+ api: PaneviewPanelApiImpl;
17
+ }): void;
18
+ private updateIcon;
19
+ update(_params: PanelUpdateEvent): void;
20
+ dispose(): void;
21
+ }
22
22
  //# sourceMappingURL=defaultPaneviewHeader.d.ts.map
@@ -1,64 +1,64 @@
1
- import { addDisposableListener } from '../events';
2
- import { CompositeDisposable, MutableDisposable } from '../lifecycle';
3
- import { toggleClass } from '../dom';
4
- import { createChevronRightButton, createExpandMoreButton } from '../svg';
5
- export class DefaultHeader extends CompositeDisposable {
6
- get element() {
7
- return this._element;
8
- }
9
- constructor() {
10
- super();
11
- this._expandedIcon = createExpandMoreButton();
12
- this._collapsedIcon = createChevronRightButton();
13
- this.disposable = new MutableDisposable();
14
- this.apiRef = { api: null };
15
- this._element = document.createElement('div');
16
- this.element.className = 'default-header';
17
- this._content = document.createElement('span');
18
- this._expander = document.createElement('div');
19
- this._expander.className = 'dockview-pane-header-icon';
20
- this.element.appendChild(this._expander);
21
- this.element.appendChild(this._content);
22
- this.addDisposables(addDisposableListener(this._element, 'click', () => {
23
- var _a;
24
- (_a = this.apiRef.api) === null || _a === void 0 ? void 0 : _a.setExpanded(!this.apiRef.api.isExpanded);
25
- }));
26
- }
27
- init(params) {
28
- this.apiRef.api = params.api;
29
- this._content.textContent = params.title;
30
- this.updateIcon();
31
- this.disposable.value = params.api.onDidExpansionChange(() => {
32
- this.updateIcon();
33
- });
34
- }
35
- updateIcon() {
36
- var _a;
37
- const isExpanded = !!((_a = this.apiRef.api) === null || _a === void 0 ? void 0 : _a.isExpanded);
38
- toggleClass(this._expander, 'collapsed', !isExpanded);
39
- if (isExpanded) {
40
- if (this._expander.contains(this._collapsedIcon)) {
41
- this._collapsedIcon.remove();
42
- }
43
- if (!this._expander.contains(this._expandedIcon)) {
44
- this._expander.appendChild(this._expandedIcon);
45
- }
46
- }
47
- else {
48
- if (this._expander.contains(this._expandedIcon)) {
49
- this._expandedIcon.remove();
50
- }
51
- if (!this._expander.contains(this._collapsedIcon)) {
52
- this._expander.appendChild(this._collapsedIcon);
53
- }
54
- }
55
- }
56
- update(_params) {
57
- //
58
- }
59
- dispose() {
60
- this.disposable.dispose();
61
- super.dispose();
62
- }
63
- }
1
+ import { addDisposableListener } from '../events';
2
+ import { CompositeDisposable, MutableDisposable } from '../lifecycle';
3
+ import { toggleClass } from '../dom';
4
+ import { createChevronRightButton, createExpandMoreButton } from '../svg';
5
+ export class DefaultHeader extends CompositeDisposable {
6
+ get element() {
7
+ return this._element;
8
+ }
9
+ constructor() {
10
+ super();
11
+ this._expandedIcon = createExpandMoreButton();
12
+ this._collapsedIcon = createChevronRightButton();
13
+ this.disposable = new MutableDisposable();
14
+ this.apiRef = { api: null };
15
+ this._element = document.createElement('div');
16
+ this.element.className = 'default-header';
17
+ this._content = document.createElement('span');
18
+ this._expander = document.createElement('div');
19
+ this._expander.className = 'dockview-pane-header-icon';
20
+ this.element.appendChild(this._expander);
21
+ this.element.appendChild(this._content);
22
+ this.addDisposables(addDisposableListener(this._element, 'click', () => {
23
+ var _a;
24
+ (_a = this.apiRef.api) === null || _a === void 0 ? void 0 : _a.setExpanded(!this.apiRef.api.isExpanded);
25
+ }));
26
+ }
27
+ init(params) {
28
+ this.apiRef.api = params.api;
29
+ this._content.textContent = params.title;
30
+ this.updateIcon();
31
+ this.disposable.value = params.api.onDidExpansionChange(() => {
32
+ this.updateIcon();
33
+ });
34
+ }
35
+ updateIcon() {
36
+ var _a;
37
+ const isExpanded = !!((_a = this.apiRef.api) === null || _a === void 0 ? void 0 : _a.isExpanded);
38
+ toggleClass(this._expander, 'collapsed', !isExpanded);
39
+ if (isExpanded) {
40
+ if (this._expander.contains(this._collapsedIcon)) {
41
+ this._collapsedIcon.remove();
42
+ }
43
+ if (!this._expander.contains(this._expandedIcon)) {
44
+ this._expander.appendChild(this._expandedIcon);
45
+ }
46
+ }
47
+ else {
48
+ if (this._expander.contains(this._expandedIcon)) {
49
+ this._expandedIcon.remove();
50
+ }
51
+ if (!this._expander.contains(this._collapsedIcon)) {
52
+ this._expander.appendChild(this._collapsedIcon);
53
+ }
54
+ }
55
+ }
56
+ update(_params) {
57
+ //
58
+ }
59
+ dispose() {
60
+ this.disposable.dispose();
61
+ super.dispose();
62
+ }
63
+ }
64
64
  //# sourceMappingURL=defaultPaneviewHeader.js.map
@@ -1,22 +1,22 @@
1
- import { PaneviewApi } from '../api/component.api';
2
- import { PaneTransfer } from '../dnd/dataTransfer';
3
- import { DroptargetEvent } from '../dnd/droptarget';
4
- import { Orientation } from '../splitview/splitview';
5
- import { IPaneviewComponent } from './paneviewComponent';
6
- import { IPaneviewPanel, PaneviewPanel } from './paneviewPanel';
7
- export interface PaneviewDropEvent extends DroptargetEvent {
8
- panel: IPaneviewPanel;
9
- getData: () => PaneTransfer | undefined;
10
- api: PaneviewApi;
11
- }
12
- export declare abstract class DraggablePaneviewPanel extends PaneviewPanel {
13
- private readonly accessor;
14
- private handler;
15
- private target;
16
- private readonly _onDidDrop;
17
- readonly onDidDrop: import("../events").Event<PaneviewDropEvent>;
18
- constructor(accessor: IPaneviewComponent, id: string, component: string, headerComponent: string | undefined, orientation: Orientation, isExpanded: boolean, disableDnd: boolean);
19
- private initDragFeatures;
20
- private onDrop;
21
- }
1
+ import { PaneviewApi } from '../api/component.api';
2
+ import { PaneTransfer } from '../dnd/dataTransfer';
3
+ import { DroptargetEvent } from '../dnd/droptarget';
4
+ import { Orientation } from '../splitview/splitview';
5
+ import { IPaneviewComponent } from './paneviewComponent';
6
+ import { IPaneviewPanel, PaneviewPanel } from './paneviewPanel';
7
+ export interface PaneviewDropEvent extends DroptargetEvent {
8
+ panel: IPaneviewPanel;
9
+ getData: () => PaneTransfer | undefined;
10
+ api: PaneviewApi;
11
+ }
12
+ export declare abstract class DraggablePaneviewPanel extends PaneviewPanel {
13
+ private readonly accessor;
14
+ private handler;
15
+ private target;
16
+ private readonly _onDidDrop;
17
+ readonly onDidDrop: import("../events").Event<PaneviewDropEvent>;
18
+ constructor(accessor: IPaneviewComponent, id: string, component: string, headerComponent: string | undefined, orientation: Orientation, isExpanded: boolean, disableDnd: boolean);
19
+ private initDragFeatures;
20
+ private onDrop;
21
+ }
22
22
  //# sourceMappingURL=draggablePaneviewPanel.d.ts.map
@@ -1,93 +1,93 @@
1
- import { PaneviewApi } from '../api/component.api';
2
- import { DragHandler } from '../dnd/abstractDragHandler';
3
- import { getPaneData, LocalSelectionTransfer, PaneTransfer, } from '../dnd/dataTransfer';
4
- import { Droptarget } from '../dnd/droptarget';
5
- import { Emitter } from '../events';
6
- import { PaneviewPanel, } from './paneviewPanel';
7
- export class DraggablePaneviewPanel extends PaneviewPanel {
8
- constructor(accessor, id, component, headerComponent, orientation, isExpanded, disableDnd) {
9
- super(id, component, headerComponent, orientation, isExpanded, true);
10
- this.accessor = accessor;
11
- this._onDidDrop = new Emitter();
12
- this.onDidDrop = this._onDidDrop.event;
13
- if (!disableDnd) {
14
- this.initDragFeatures();
15
- }
16
- }
17
- initDragFeatures() {
18
- if (!this.header) {
19
- return;
20
- }
21
- const id = this.id;
22
- const accessorId = this.accessor.id;
23
- this.header.draggable = true;
24
- this.handler = new (class PaneDragHandler extends DragHandler {
25
- getData() {
26
- LocalSelectionTransfer.getInstance().setData([new PaneTransfer(accessorId, id)], PaneTransfer.prototype);
27
- return {
28
- dispose: () => {
29
- LocalSelectionTransfer.getInstance().clearData(PaneTransfer.prototype);
30
- },
31
- };
32
- }
33
- })(this.header);
34
- this.target = new Droptarget(this.element, {
35
- acceptedTargetZones: ['top', 'bottom'],
36
- overlayModel: {
37
- activationSize: { type: 'percentage', value: 50 },
38
- },
39
- canDisplayOverlay: (event) => {
40
- const data = getPaneData();
41
- if (data) {
42
- if (data.paneId !== this.id &&
43
- data.viewId === this.accessor.id) {
44
- return true;
45
- }
46
- }
47
- if (this.accessor.options.showDndOverlay) {
48
- return this.accessor.options.showDndOverlay({
49
- nativeEvent: event,
50
- getData: getPaneData,
51
- panel: this,
52
- });
53
- }
54
- return false;
55
- },
56
- });
57
- this.addDisposables(this._onDidDrop, this.handler, this.target, this.target.onDrop((event) => {
58
- this.onDrop(event);
59
- }));
60
- }
61
- onDrop(event) {
62
- const data = getPaneData();
63
- if (!data || data.viewId !== this.accessor.id) {
64
- // if there is no local drag event for this panel
65
- // or if the drag event was creating by another Paneview instance
66
- this._onDidDrop.fire(Object.assign(Object.assign({}, event), { panel: this, api: new PaneviewApi(this.accessor), getData: getPaneData }));
67
- return;
68
- }
69
- const containerApi = this._params
70
- .containerApi;
71
- const panelId = data.paneId;
72
- const existingPanel = containerApi.getPanel(panelId);
73
- if (!existingPanel) {
74
- // if the panel doesn't exist
75
- this._onDidDrop.fire(Object.assign(Object.assign({}, event), { panel: this, getData: getPaneData, api: new PaneviewApi(this.accessor) }));
76
- return;
77
- }
78
- const allPanels = containerApi.panels;
79
- const fromIndex = allPanels.indexOf(existingPanel);
80
- let toIndex = containerApi.panels.indexOf(this);
81
- if (event.position === 'left' || event.position === 'top') {
82
- toIndex = Math.max(0, toIndex - 1);
83
- }
84
- if (event.position === 'right' || event.position === 'bottom') {
85
- if (fromIndex > toIndex) {
86
- toIndex++;
87
- }
88
- toIndex = Math.min(allPanels.length - 1, toIndex);
89
- }
90
- containerApi.movePanel(fromIndex, toIndex);
91
- }
92
- }
1
+ import { PaneviewApi } from '../api/component.api';
2
+ import { DragHandler } from '../dnd/abstractDragHandler';
3
+ import { getPaneData, LocalSelectionTransfer, PaneTransfer, } from '../dnd/dataTransfer';
4
+ import { Droptarget } from '../dnd/droptarget';
5
+ import { Emitter } from '../events';
6
+ import { PaneviewPanel, } from './paneviewPanel';
7
+ export class DraggablePaneviewPanel extends PaneviewPanel {
8
+ constructor(accessor, id, component, headerComponent, orientation, isExpanded, disableDnd) {
9
+ super(id, component, headerComponent, orientation, isExpanded, true);
10
+ this.accessor = accessor;
11
+ this._onDidDrop = new Emitter();
12
+ this.onDidDrop = this._onDidDrop.event;
13
+ if (!disableDnd) {
14
+ this.initDragFeatures();
15
+ }
16
+ }
17
+ initDragFeatures() {
18
+ if (!this.header) {
19
+ return;
20
+ }
21
+ const id = this.id;
22
+ const accessorId = this.accessor.id;
23
+ this.header.draggable = true;
24
+ this.handler = new (class PaneDragHandler extends DragHandler {
25
+ getData() {
26
+ LocalSelectionTransfer.getInstance().setData([new PaneTransfer(accessorId, id)], PaneTransfer.prototype);
27
+ return {
28
+ dispose: () => {
29
+ LocalSelectionTransfer.getInstance().clearData(PaneTransfer.prototype);
30
+ },
31
+ };
32
+ }
33
+ })(this.header);
34
+ this.target = new Droptarget(this.element, {
35
+ acceptedTargetZones: ['top', 'bottom'],
36
+ overlayModel: {
37
+ activationSize: { type: 'percentage', value: 50 },
38
+ },
39
+ canDisplayOverlay: (event) => {
40
+ const data = getPaneData();
41
+ if (data) {
42
+ if (data.paneId !== this.id &&
43
+ data.viewId === this.accessor.id) {
44
+ return true;
45
+ }
46
+ }
47
+ if (this.accessor.options.showDndOverlay) {
48
+ return this.accessor.options.showDndOverlay({
49
+ nativeEvent: event,
50
+ getData: getPaneData,
51
+ panel: this,
52
+ });
53
+ }
54
+ return false;
55
+ },
56
+ });
57
+ this.addDisposables(this._onDidDrop, this.handler, this.target, this.target.onDrop((event) => {
58
+ this.onDrop(event);
59
+ }));
60
+ }
61
+ onDrop(event) {
62
+ const data = getPaneData();
63
+ if (!data || data.viewId !== this.accessor.id) {
64
+ // if there is no local drag event for this panel
65
+ // or if the drag event was creating by another Paneview instance
66
+ this._onDidDrop.fire(Object.assign(Object.assign({}, event), { panel: this, api: new PaneviewApi(this.accessor), getData: getPaneData }));
67
+ return;
68
+ }
69
+ const containerApi = this._params
70
+ .containerApi;
71
+ const panelId = data.paneId;
72
+ const existingPanel = containerApi.getPanel(panelId);
73
+ if (!existingPanel) {
74
+ // if the panel doesn't exist
75
+ this._onDidDrop.fire(Object.assign(Object.assign({}, event), { panel: this, getData: getPaneData, api: new PaneviewApi(this.accessor) }));
76
+ return;
77
+ }
78
+ const allPanels = containerApi.panels;
79
+ const fromIndex = allPanels.indexOf(existingPanel);
80
+ let toIndex = containerApi.panels.indexOf(this);
81
+ if (event.position === 'left' || event.position === 'top') {
82
+ toIndex = Math.max(0, toIndex - 1);
83
+ }
84
+ if (event.position === 'right' || event.position === 'bottom') {
85
+ if (fromIndex > toIndex) {
86
+ toIndex++;
87
+ }
88
+ toIndex = Math.min(allPanels.length - 1, toIndex);
89
+ }
90
+ containerApi.movePanel(fromIndex, toIndex);
91
+ }
92
+ }
93
93
  //# sourceMappingURL=draggablePaneviewPanel.js.map
@@ -1,29 +1,26 @@
1
- import { FrameworkFactory } from '../panel/componentFactory';
2
- import { PaneviewDndOverlayEvent } from './paneviewComponent';
3
- import { IPaneBodyPart, IPaneHeaderPart, PaneviewPanel } from './paneviewPanel';
4
- export interface PaneviewComponentOptions {
5
- components?: {
6
- [componentName: string]: {
7
- new (id: string, componentName: string): PaneviewPanel;
8
- };
9
- };
10
- frameworkComponents?: {
11
- [componentName: string]: any;
12
- };
13
- headerComponents?: {
14
- [componentName: string]: {
15
- new (id: string, componentName: string): PaneviewPanel;
16
- };
17
- };
18
- headerframeworkComponents?: {
19
- [componentName: string]: any;
20
- };
21
- frameworkWrapper?: {
22
- header: FrameworkFactory<IPaneHeaderPart>;
23
- body: FrameworkFactory<IPaneBodyPart>;
24
- };
25
- disableDnd?: boolean;
26
- showDndOverlay?: (event: PaneviewDndOverlayEvent) => boolean;
27
- parentElement?: HTMLElement;
28
- }
1
+ import { ComponentConstructor, FrameworkFactory } from '../panel/componentFactory';
2
+ import { PaneviewDndOverlayEvent } from './paneviewComponent';
3
+ import { IPaneBodyPart, IPaneHeaderPart, PaneviewPanel } from './paneviewPanel';
4
+ export interface PaneviewComponentOptions {
5
+ disableAutoResizing?: boolean;
6
+ components?: {
7
+ [componentName: string]: ComponentConstructor<PaneviewPanel>;
8
+ };
9
+ frameworkComponents?: {
10
+ [componentName: string]: any;
11
+ };
12
+ headerComponents?: {
13
+ [componentName: string]: ComponentConstructor<PaneviewPanel>;
14
+ };
15
+ headerframeworkComponents?: {
16
+ [componentName: string]: any;
17
+ };
18
+ frameworkWrapper?: {
19
+ header: FrameworkFactory<IPaneHeaderPart>;
20
+ body: FrameworkFactory<IPaneBodyPart>;
21
+ };
22
+ disableDnd?: boolean;
23
+ showDndOverlay?: (event: PaneviewDndOverlayEvent) => boolean;
24
+ parentElement?: HTMLElement;
25
+ }
29
26
  //# sourceMappingURL=options.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../../src/paneview/options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhF,MAAM,WAAW,wBAAwB;IACrC,UAAU,CAAC,EAAE;QACT,CAAC,aAAa,EAAE,MAAM,GAAG;YACrB,KAAK,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,aAAa,CAAC;SAC1D,CAAC;KACL,CAAC;IACF,mBAAmB,CAAC,EAAE;QAClB,CAAC,aAAa,EAAE,MAAM,GAAG,GAAG,CAAC;KAChC,CAAC;IACF,gBAAgB,CAAC,EAAE;QACf,CAAC,aAAa,EAAE,MAAM,GAAG;YACrB,KAAK,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,aAAa,CAAC;SAC1D,CAAC;KACL,CAAC;IACF,yBAAyB,CAAC,EAAE;QACxB,CAAC,aAAa,EAAE,MAAM,GAAG,GAAG,CAAC;KAChC,CAAC;IACF,gBAAgB,CAAC,EAAE;QACf,MAAM,EAAE,gBAAgB,CAAC,eAAe,CAAC,CAAC;QAC1C,IAAI,EAAE,gBAAgB,CAAC,aAAa,CAAC,CAAC;KACzC,CAAC;IACF,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,uBAAuB,KAAK,OAAO,CAAC;IAC7D,aAAa,CAAC,EAAE,WAAW,CAAC;CAC/B"}
1
+ {"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../../src/paneview/options.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,oBAAoB,EACpB,gBAAgB,EACnB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhF,MAAM,WAAW,wBAAwB;IACrC,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,UAAU,CAAC,EAAE;QACT,CAAC,aAAa,EAAE,MAAM,GAAG,oBAAoB,CAAC,aAAa,CAAC,CAAC;KAChE,CAAC;IACF,mBAAmB,CAAC,EAAE;QAClB,CAAC,aAAa,EAAE,MAAM,GAAG,GAAG,CAAC;KAChC,CAAC;IACF,gBAAgB,CAAC,EAAE;QACf,CAAC,aAAa,EAAE,MAAM,GAAG,oBAAoB,CAAC,aAAa,CAAC,CAAC;KAChE,CAAC;IACF,yBAAyB,CAAC,EAAE;QACxB,CAAC,aAAa,EAAE,MAAM,GAAG,GAAG,CAAC;KAChC,CAAC;IACF,gBAAgB,CAAC,EAAE;QACf,MAAM,EAAE,gBAAgB,CAAC,eAAe,CAAC,CAAC;QAC1C,IAAI,EAAE,gBAAgB,CAAC,aAAa,CAAC,CAAC;KACzC,CAAC;IACF,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,uBAAuB,KAAK,OAAO,CAAC;IAC7D,aAAa,CAAC,EAAE,WAAW,CAAC;CAC/B"}
@@ -1,2 +1,2 @@
1
- export {};
1
+ export {};
2
2
  //# sourceMappingURL=options.js.map