flexlayout-react 0.8.11 → 0.8.13

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 (473) hide show
  1. package/README.md +16 -5
  2. package/declarations/Attribute.d.ts +25 -1
  3. package/declarations/AttributeDefinitions.d.ts +18 -1
  4. package/declarations/DockLocation.d.ts +22 -0
  5. package/declarations/I18nLabel.d.ts +2 -1
  6. package/declarations/Orientation.d.ts +4 -0
  7. package/declarations/Rect.d.ts +3 -0
  8. package/declarations/index.d.ts +1 -0
  9. package/declarations/model/BorderNode.d.ts +53 -0
  10. package/declarations/model/BorderSet.d.ts +28 -0
  11. package/declarations/model/IDraggable.d.ts +4 -0
  12. package/declarations/model/IDropTarget.d.ts +10 -0
  13. package/declarations/model/LayoutWindow.d.ts +16 -0
  14. package/declarations/model/Model.d.ts +55 -0
  15. package/declarations/model/Node.d.ts +61 -0
  16. package/declarations/model/RowNode.d.ts +67 -0
  17. package/declarations/model/TabNode.d.ts +79 -0
  18. package/declarations/model/TabSetNode.d.ts +60 -0
  19. package/declarations/model/Utils.d.ts +8 -0
  20. package/declarations/view/BorderButton.d.ts +13 -1
  21. package/declarations/view/BorderTab.d.ts +8 -0
  22. package/declarations/view/BorderTabSet.d.ts +10 -1
  23. package/declarations/view/DragContainer.d.ts +9 -1
  24. package/declarations/view/ErrorBoundary.d.ts +22 -1
  25. package/declarations/view/Icons.d.ts +1 -0
  26. package/declarations/view/Layout.d.ts +143 -1
  27. package/declarations/view/Overlay.d.ts +8 -1
  28. package/declarations/view/PopoutWindow.d.ts +14 -1
  29. package/declarations/view/PopupMenu.d.ts +12 -1
  30. package/declarations/view/Row.d.ts +9 -1
  31. package/declarations/view/Splitter.d.ts +14 -1
  32. package/declarations/view/Tab.d.ts +11 -1
  33. package/declarations/view/TabButton.d.ts +11 -1
  34. package/declarations/view/TabButtonStamp.d.ts +9 -1
  35. package/declarations/view/TabOverflowHook.d.ts +16 -1
  36. package/declarations/view/TabSet.d.ts +9 -1
  37. package/declarations/view/Utils.d.ts +13 -0
  38. package/lib/index.js +6410 -22
  39. package/package.json +34 -26
  40. package/ChangeLog.txt +0 -370
  41. package/declarations/DragDrop.d.ts +0 -15
  42. package/declarations/PopupMenu.d.ts +0 -1
  43. package/declarations/model/SplitterNode.d.ts +0 -5
  44. package/declarations/model/WindowLayout.d.ts +0 -24
  45. package/declarations/src/Attribute.d.ts +0 -1
  46. package/declarations/src/AttributeDefinitions.d.ts +0 -1
  47. package/declarations/src/DockLocation.d.ts +0 -12
  48. package/declarations/src/DropInfo.d.ts +0 -12
  49. package/declarations/src/I18nLabel.d.ts +0 -10
  50. package/declarations/src/Orientation.d.ts +0 -7
  51. package/declarations/src/PopupMenu.d.ts +0 -1
  52. package/declarations/src/Rect.d.ts +0 -31
  53. package/declarations/src/Types.d.ts +0 -92
  54. package/declarations/src/index.d.ts +0 -20
  55. package/declarations/src/model/Action.d.ts +0 -5
  56. package/declarations/src/model/Actions.d.ts +0 -110
  57. package/declarations/src/model/BorderNode.d.ts +0 -28
  58. package/declarations/src/model/BorderSet.d.ts +0 -3
  59. package/declarations/src/model/ICloseType.d.ts +0 -5
  60. package/declarations/src/model/IDraggable.d.ts +0 -2
  61. package/declarations/src/model/IDropTarget.d.ts +0 -2
  62. package/declarations/src/model/IJsonModel.d.ts +0 -153
  63. package/declarations/src/model/Model.d.ts +0 -98
  64. package/declarations/src/model/Node.d.ts +0 -16
  65. package/declarations/src/model/RowNode.d.ts +0 -11
  66. package/declarations/src/model/TabNode.d.ts +0 -36
  67. package/declarations/src/model/TabSetNode.d.ts +0 -37
  68. package/declarations/src/model/Utils.d.ts +0 -1
  69. package/declarations/src/view/BorderButton.d.ts +0 -1
  70. package/declarations/src/view/BorderTab.d.ts +0 -2
  71. package/declarations/src/view/BorderTabSet.d.ts +0 -1
  72. package/declarations/src/view/DragContainer.d.ts +0 -1
  73. package/declarations/src/view/ErrorBoundary.d.ts +0 -1
  74. package/declarations/src/view/FloatingWindow.d.ts +0 -1
  75. package/declarations/src/view/Icons.d.ts +0 -7
  76. package/declarations/src/view/Layout.d.ts +0 -113
  77. package/declarations/src/view/Overlay.d.ts +0 -1
  78. package/declarations/src/view/PopupMenu.d.ts +0 -1
  79. package/declarations/src/view/Row.d.ts +0 -1
  80. package/declarations/src/view/Splitter.d.ts +0 -1
  81. package/declarations/src/view/Tab.d.ts +0 -1
  82. package/declarations/src/view/TabButton.d.ts +0 -1
  83. package/declarations/src/view/TabButtonStamp.d.ts +0 -1
  84. package/declarations/src/view/TabOverflowHook.d.ts +0 -1
  85. package/declarations/src/view/TabSet.d.ts +0 -1
  86. package/declarations/src/view/Utils.d.ts +0 -4
  87. package/declarations/view/ExtendedResizeObserver.d.ts +0 -23
  88. package/declarations/view/FloatingWindow.d.ts +0 -1
  89. package/declarations/view/FloatingWindowTab.d.ts +0 -1
  90. package/declarations/view/TabFloating.d.ts +0 -1
  91. package/dist/flexlayout.js +0 -610
  92. package/dist/flexlayout_min.js +0 -2
  93. package/dist/flexlayout_min.js.LICENSE.txt +0 -29
  94. package/dist/src/Attribute.js +0 -43
  95. package/dist/src/Attribute.js.map +0 -1
  96. package/dist/src/AttributeDefinitions.js +0 -132
  97. package/dist/src/AttributeDefinitions.js.map +0 -1
  98. package/dist/src/DockLocation.js +0 -121
  99. package/dist/src/DockLocation.js.map +0 -1
  100. package/dist/src/DropInfo.js +0 -10
  101. package/dist/src/DropInfo.js.map +0 -1
  102. package/dist/src/I18nLabel.js +0 -14
  103. package/dist/src/I18nLabel.js.map +0 -1
  104. package/dist/src/Orientation.js +0 -23
  105. package/dist/src/Orientation.js.map +0 -1
  106. package/dist/src/Rect.js +0 -111
  107. package/dist/src/Rect.js.map +0 -1
  108. package/dist/src/Types.js +0 -95
  109. package/dist/src/Types.js.map +0 -1
  110. package/dist/src/index.js +0 -22
  111. package/dist/src/index.js.map +0 -1
  112. package/dist/src/model/Action.js +0 -7
  113. package/dist/src/model/Action.js.map +0 -1
  114. package/dist/src/model/Actions.js +0 -170
  115. package/dist/src/model/Actions.js.map +0 -1
  116. package/dist/src/model/BorderNode.js +0 -390
  117. package/dist/src/model/BorderNode.js.map +0 -1
  118. package/dist/src/model/BorderSet.js +0 -67
  119. package/dist/src/model/BorderSet.js.map +0 -1
  120. package/dist/src/model/ICloseType.js +0 -7
  121. package/dist/src/model/ICloseType.js.map +0 -1
  122. package/dist/src/model/IDraggable.js +0 -2
  123. package/dist/src/model/IDraggable.js.map +0 -1
  124. package/dist/src/model/IDropTarget.js +0 -2
  125. package/dist/src/model/IDropTarget.js.map +0 -1
  126. package/dist/src/model/IJsonModel.js +0 -2
  127. package/dist/src/model/IJsonModel.js.map +0 -1
  128. package/dist/src/model/LayoutWindow.js +0 -81
  129. package/dist/src/model/LayoutWindow.js.map +0 -1
  130. package/dist/src/model/Model.js +0 -608
  131. package/dist/src/model/Model.js.map +0 -1
  132. package/dist/src/model/Node.js +0 -218
  133. package/dist/src/model/Node.js.map +0 -1
  134. package/dist/src/model/RowNode.js +0 -492
  135. package/dist/src/model/RowNode.js.map +0 -1
  136. package/dist/src/model/TabNode.js +0 -293
  137. package/dist/src/model/TabNode.js.map +0 -1
  138. package/dist/src/model/TabSetNode.js +0 -469
  139. package/dist/src/model/TabSetNode.js.map +0 -1
  140. package/dist/src/model/Utils.js +0 -48
  141. package/dist/src/model/Utils.js.map +0 -1
  142. package/dist/src/view/BorderButton.js +0 -126
  143. package/dist/src/view/BorderButton.js.map +0 -1
  144. package/dist/src/view/BorderTab.js +0 -44
  145. package/dist/src/view/BorderTab.js.map +0 -1
  146. package/dist/src/view/BorderTabSet.js +0 -138
  147. package/dist/src/view/BorderTabSet.js.map +0 -1
  148. package/dist/src/view/DragContainer.js +0 -16
  149. package/dist/src/view/DragContainer.js.map +0 -1
  150. package/dist/src/view/ErrorBoundary.js +0 -24
  151. package/dist/src/view/ErrorBoundary.js.map +0 -1
  152. package/dist/src/view/Icons.js +0 -29
  153. package/dist/src/view/Icons.js.map +0 -1
  154. package/dist/src/view/Layout.js +0 -881
  155. package/dist/src/view/Layout.js.map +0 -1
  156. package/dist/src/view/Overlay.js +0 -9
  157. package/dist/src/view/Overlay.js.map +0 -1
  158. package/dist/src/view/PopoutWindow.js +0 -129
  159. package/dist/src/view/PopoutWindow.js.map +0 -1
  160. package/dist/src/view/PopupMenu.js +0 -89
  161. package/dist/src/view/PopupMenu.js.map +0 -1
  162. package/dist/src/view/Row.js +0 -46
  163. package/dist/src/view/Row.js.map +0 -1
  164. package/dist/src/view/SizeTracker.js +0 -12
  165. package/dist/src/view/SizeTracker.js.map +0 -1
  166. package/dist/src/view/Splitter.js +0 -192
  167. package/dist/src/view/Splitter.js.map +0 -1
  168. package/dist/src/view/Tab.js +0 -91
  169. package/dist/src/view/Tab.js.map +0 -1
  170. package/dist/src/view/TabButton.js +0 -124
  171. package/dist/src/view/TabButton.js.map +0 -1
  172. package/dist/src/view/TabButtonStamp.js +0 -15
  173. package/dist/src/view/TabButtonStamp.js.map +0 -1
  174. package/dist/src/view/TabOverflowHook.js +0 -266
  175. package/dist/src/view/TabOverflowHook.js.map +0 -1
  176. package/dist/src/view/TabSet.js +0 -256
  177. package/dist/src/view/TabSet.js.map +0 -1
  178. package/dist/src/view/Utils.js +0 -110
  179. package/dist/src/view/Utils.js.map +0 -1
  180. package/lib/Attribute.js +0 -43
  181. package/lib/Attribute.js.map +0 -1
  182. package/lib/AttributeDefinitions.js +0 -132
  183. package/lib/AttributeDefinitions.js.map +0 -1
  184. package/lib/DockLocation.js +0 -121
  185. package/lib/DockLocation.js.map +0 -1
  186. package/lib/DropInfo.js +0 -10
  187. package/lib/DropInfo.js.map +0 -1
  188. package/lib/I18nLabel.js +0 -14
  189. package/lib/I18nLabel.js.map +0 -1
  190. package/lib/Orientation.js +0 -23
  191. package/lib/Orientation.js.map +0 -1
  192. package/lib/Rect.js +0 -111
  193. package/lib/Rect.js.map +0 -1
  194. package/lib/Types.js +0 -95
  195. package/lib/Types.js.map +0 -1
  196. package/lib/index.js.map +0 -1
  197. package/lib/model/Action.js +0 -7
  198. package/lib/model/Action.js.map +0 -1
  199. package/lib/model/Actions.js +0 -170
  200. package/lib/model/Actions.js.map +0 -1
  201. package/lib/model/BorderNode.js +0 -390
  202. package/lib/model/BorderNode.js.map +0 -1
  203. package/lib/model/BorderSet.js +0 -67
  204. package/lib/model/BorderSet.js.map +0 -1
  205. package/lib/model/ICloseType.js +0 -7
  206. package/lib/model/ICloseType.js.map +0 -1
  207. package/lib/model/IDraggable.js +0 -2
  208. package/lib/model/IDraggable.js.map +0 -1
  209. package/lib/model/IDropTarget.js +0 -2
  210. package/lib/model/IDropTarget.js.map +0 -1
  211. package/lib/model/IJsonModel.js +0 -2
  212. package/lib/model/IJsonModel.js.map +0 -1
  213. package/lib/model/LayoutWindow.js +0 -81
  214. package/lib/model/LayoutWindow.js.map +0 -1
  215. package/lib/model/Model.js +0 -608
  216. package/lib/model/Model.js.map +0 -1
  217. package/lib/model/Node.js +0 -218
  218. package/lib/model/Node.js.map +0 -1
  219. package/lib/model/RowNode.js +0 -492
  220. package/lib/model/RowNode.js.map +0 -1
  221. package/lib/model/TabNode.js +0 -293
  222. package/lib/model/TabNode.js.map +0 -1
  223. package/lib/model/TabSetNode.js +0 -469
  224. package/lib/model/TabSetNode.js.map +0 -1
  225. package/lib/model/Utils.js +0 -48
  226. package/lib/model/Utils.js.map +0 -1
  227. package/lib/view/BorderButton.js +0 -126
  228. package/lib/view/BorderButton.js.map +0 -1
  229. package/lib/view/BorderTab.js +0 -56
  230. package/lib/view/BorderTab.js.map +0 -1
  231. package/lib/view/BorderTabSet.js +0 -138
  232. package/lib/view/BorderTabSet.js.map +0 -1
  233. package/lib/view/DragContainer.js +0 -16
  234. package/lib/view/DragContainer.js.map +0 -1
  235. package/lib/view/ErrorBoundary.js +0 -24
  236. package/lib/view/ErrorBoundary.js.map +0 -1
  237. package/lib/view/Icons.js +0 -29
  238. package/lib/view/Icons.js.map +0 -1
  239. package/lib/view/Layout.js +0 -881
  240. package/lib/view/Layout.js.map +0 -1
  241. package/lib/view/Overlay.js +0 -9
  242. package/lib/view/Overlay.js.map +0 -1
  243. package/lib/view/PopoutWindow.js +0 -129
  244. package/lib/view/PopoutWindow.js.map +0 -1
  245. package/lib/view/PopupMenu.js +0 -89
  246. package/lib/view/PopupMenu.js.map +0 -1
  247. package/lib/view/Row.js +0 -46
  248. package/lib/view/Row.js.map +0 -1
  249. package/lib/view/SizeTracker.js +0 -12
  250. package/lib/view/SizeTracker.js.map +0 -1
  251. package/lib/view/Splitter.js +0 -197
  252. package/lib/view/Splitter.js.map +0 -1
  253. package/lib/view/Tab.js +0 -91
  254. package/lib/view/Tab.js.map +0 -1
  255. package/lib/view/TabButton.js +0 -124
  256. package/lib/view/TabButton.js.map +0 -1
  257. package/lib/view/TabButtonStamp.js +0 -15
  258. package/lib/view/TabButtonStamp.js.map +0 -1
  259. package/lib/view/TabOverflowHook.js +0 -266
  260. package/lib/view/TabOverflowHook.js.map +0 -1
  261. package/lib/view/TabSet.js +0 -269
  262. package/lib/view/TabSet.js.map +0 -1
  263. package/lib/view/Utils.js +0 -110
  264. package/lib/view/Utils.js.map +0 -1
  265. package/playwright-report/data/01f8ff379b7b7c06b0f8dbd65cbd55e95f8ca470.zip +0 -0
  266. package/playwright-report/data/02a706b995d751dee8ac0429e29eafb796a23f96.zip +0 -0
  267. package/playwright-report/data/04468c5a7304bad1acbe32d3376bfc5038e172d9.zip +0 -0
  268. package/playwright-report/data/04ffe14721deea0c6402bb96c78055475f6cd687.zip +0 -0
  269. package/playwright-report/data/07e1bb8bd6407ceafa7a1051839d398f34b41a52.zip +0 -0
  270. package/playwright-report/data/0d17b99e2ddd975da4868f295b370a9fc9b55993.zip +0 -0
  271. package/playwright-report/data/108805618d29c7800d55d7dd8da36829fec366bd.zip +0 -0
  272. package/playwright-report/data/1271fd2bc76809c25b62351f4321b396e745a199.zip +0 -0
  273. package/playwright-report/data/16bd316f5e3e9ad6c9dc2a6a0388f3425c1a61d9.zip +0 -0
  274. package/playwright-report/data/1a1b06cebe59d981e21198164093230b0a1704fd.zip +0 -0
  275. package/playwright-report/data/1b3b6bba4aca415bc586b2a0abb18410af26fbf1.zip +0 -0
  276. package/playwright-report/data/1ce927369a55edf14ec99e0029d1a342cb0fcfa4.zip +0 -0
  277. package/playwright-report/data/20a694648a90f0a805a4397b73699142e5dd50c1.zip +0 -0
  278. package/playwright-report/data/211f1c8fc3f5d052d935906201f29a1e42a2fbd8.zip +0 -0
  279. package/playwright-report/data/2176124681e769fbba593a272e67331fd69e56ef.zip +0 -0
  280. package/playwright-report/data/2487db6273b09acd9a62a9ecfa8f1e411cc769df.zip +0 -0
  281. package/playwright-report/data/25abefed6606e15cac6dc83e3ea4e85896233020.zip +0 -0
  282. package/playwright-report/data/2752051b8593d432be1a623813f2dbee043dc959.zip +0 -0
  283. package/playwright-report/data/2d72001a7f57a11282fe741ca22501b34f7576a2.zip +0 -0
  284. package/playwright-report/data/308de4d252afe1db5aeda783ea3eaf09368aa812.zip +0 -0
  285. package/playwright-report/data/30f265807a34ee9bb2ddd931970be6f572a42ffe.zip +0 -0
  286. package/playwright-report/data/326599ace543d3340403f5eaa0f28ef73f7d3cfc.zip +0 -0
  287. package/playwright-report/data/3662fcf1839c6bb164e1aceea5e25b410bae6286.zip +0 -0
  288. package/playwright-report/data/38cdebbb090386af04f96f13bf45b2a23feb6cf5.zip +0 -0
  289. package/playwright-report/data/3b45c7876ca7a4208061f69fa0cce9f9e619557c.zip +0 -0
  290. package/playwright-report/data/3c6115f8ff03527f3b888e8c6626d086146bb961.zip +0 -0
  291. package/playwright-report/data/3e976a69f9bc188048c96969507a28fc5411da40.zip +0 -0
  292. package/playwright-report/data/420bd6c0ed97c53e6ee5108c11c337690ed9dd71.zip +0 -0
  293. package/playwright-report/data/424c925f1d020f7918c5b1d4e93a3aff4ffd0d35.zip +0 -0
  294. package/playwright-report/data/4459657c233583f0bb5f541ba2a56d14fc04324f.zip +0 -0
  295. package/playwright-report/data/45dbca16424f69b6af3f201fd918186e66e6a921.zip +0 -0
  296. package/playwright-report/data/4c7242437d15e34066b69d5f3a71e21f436d81bb.zip +0 -0
  297. package/playwright-report/data/56f84e2288e6485b68f0f78f79af97016d066eea.zip +0 -0
  298. package/playwright-report/data/679d4cfcb398dd2d19703be59bbf1de72f73fa3e.zip +0 -0
  299. package/playwright-report/data/686279f3ccdca1213fe91a9901f1ca469a41db4b.zip +0 -0
  300. package/playwright-report/data/69403980b98daeb052c732f3d984b7ccc51022aa.zip +0 -0
  301. package/playwright-report/data/6d91e10cd5dc95944881ea0f875bf0e531c63164.zip +0 -0
  302. package/playwright-report/data/6f362695f59905c3acdcafb6eeacfa4b068bc030.zip +0 -0
  303. package/playwright-report/data/71dd5897288168b0f7fb2e187f2b543e880733b1.zip +0 -0
  304. package/playwright-report/data/7540a41a9c123cffc1750447ccb69d9fb8cc8ba5.zip +0 -0
  305. package/playwright-report/data/78f8483a26c47ca761f43b1f142a9fb9d001b27e.zip +0 -0
  306. package/playwright-report/data/7e8bd5ba547094dcf303d450853b2f74f41749b2.zip +0 -0
  307. package/playwright-report/data/7fbec8e63ea2ee1702a94fe4d837067192e661f0.zip +0 -0
  308. package/playwright-report/data/87f2ea42a46cbd21813358d7d6e31d9999fca953.zip +0 -0
  309. package/playwright-report/data/8db527a1f9b753036cf63bb4afc96a765007fe82.zip +0 -0
  310. package/playwright-report/data/8e5ccd4bd56f3843f4e788c5e9842165221c2748.zip +0 -0
  311. package/playwright-report/data/8fc12e2795e02ee2ad773ec7be25f94b6ca697ed.zip +0 -0
  312. package/playwright-report/data/9d10ab1649ded4751d19014847e110b0b03ad126.zip +0 -0
  313. package/playwright-report/data/ab82c3994c6614fa6873fc92fd44ca78cb45f9d6.zip +0 -0
  314. package/playwright-report/data/ac554655d509fe64199a053e715def4ce4bbd618.zip +0 -0
  315. package/playwright-report/data/ad8e5a0cec5ec3369478099a58b7652c0dd636f1.zip +0 -0
  316. package/playwright-report/data/ae30baf5dea2dc0dd2ca87ffa08afb936b27fef1.zip +0 -0
  317. package/playwright-report/data/bc7631ffd4df693573a3233ec403a1f9cbcb00a9.zip +0 -0
  318. package/playwright-report/data/bcfe71e7532702969ecdde584a294907ed21525e.zip +0 -0
  319. package/playwright-report/data/bf020e09e20d0cd6e1b8aa82153e84f9d40c7f74.zip +0 -0
  320. package/playwright-report/data/c3452f499f82ef644c3d314626d3d9c762ff5c20.zip +0 -0
  321. package/playwright-report/data/c5dfbb00ea0965a4214f02cde22245958bb31c86.zip +0 -0
  322. package/playwright-report/data/c716ede7c5174d8a83653a6862605eca04783bad.zip +0 -0
  323. package/playwright-report/data/c95ca5869740edf6d1d627d120aa9ba26b1d3415.zip +0 -0
  324. package/playwright-report/data/cc17390169d327b4dfc2a9b3a8279e74ff975b1d.zip +0 -0
  325. package/playwright-report/data/d0ff6b9f342d792119f1513cc53c9f315a56251b.zip +0 -0
  326. package/playwright-report/data/d26377153bff611b5ba5a1148fc8858f7bb2cb7b.zip +0 -0
  327. package/playwright-report/data/dc0608de1b624a691f2f393bf450fc01591076ef.zip +0 -0
  328. package/playwright-report/data/dee4c585c248f4827601afbde02d3732761bdd8b.zip +0 -0
  329. package/playwright-report/data/e4cdfceef70735028de78f94f7e07a1e65fa317d.zip +0 -0
  330. package/playwright-report/data/e64d89424643af3f746a091f7567db49b0b45f3c.zip +0 -0
  331. package/playwright-report/data/e70483c7d13bb871f5c5b4aa54149172d58bf0c0.zip +0 -0
  332. package/playwright-report/data/e8333b653df262d800ee7b5329503b975d420e87.zip +0 -0
  333. package/playwright-report/data/ed1bd19a957a6165ba73a644af4959590b23eed9.zip +0 -0
  334. package/playwright-report/data/f35cf046cdf897abd96f318f79443407e58b8f0b.zip +0 -0
  335. package/playwright-report/data/f8793a7c69b939ac07422cf41aac45ebe4a86908.zip +0 -0
  336. package/playwright-report/data/fb2a383b96839380e90e0137363a574e665aed38.zip +0 -0
  337. package/playwright-report/data/fede8e774c66e329bdac055d6d67e73aa75b14fc.zip +0 -0
  338. package/playwright-report/index.html +0 -71
  339. package/playwright-report/trace/assets/codeMirrorModule-DpJ-EmBQ.js +0 -24
  340. package/playwright-report/trace/assets/defaultSettingsView-DTenqiGw.js +0 -259
  341. package/playwright-report/trace/codeMirrorModule.C3UTv-Ge.css +0 -1
  342. package/playwright-report/trace/codicon.DCmgc-ay.ttf +0 -0
  343. package/playwright-report/trace/defaultSettingsView.5fN5lw10.css +0 -1
  344. package/playwright-report/trace/index.CFOW-Ezb.css +0 -1
  345. package/playwright-report/trace/index.CUq7VgrV.js +0 -2
  346. package/playwright-report/trace/index.html +0 -43
  347. package/playwright-report/trace/playwright-logo.svg +0 -9
  348. package/playwright-report/trace/snapshot.html +0 -21
  349. package/playwright-report/trace/sw.bundle.js +0 -3
  350. package/playwright-report/trace/uiMode.BatfzHMG.css +0 -1
  351. package/playwright-report/trace/uiMode.CHJSAD7F.js +0 -5
  352. package/playwright-report/trace/uiMode.html +0 -17
  353. package/playwright-report/trace/xtermModule.Beg8tuEN.css +0 -32
  354. package/playwright.config.ts +0 -79
  355. package/screenshots/PlaywrightUI.png +0 -0
  356. package/src/Attribute.ts +0 -64
  357. package/src/AttributeDefinitions.ts +0 -144
  358. package/src/DockLocation.ts +0 -133
  359. package/src/DropInfo.ts +0 -20
  360. package/src/I18nLabel.ts +0 -12
  361. package/src/Orientation.ts +0 -28
  362. package/src/Rect.ts +0 -147
  363. package/src/Types.ts +0 -112
  364. package/src/index.ts +0 -23
  365. package/src/model/Action.ts +0 -9
  366. package/src/model/Actions.ts +0 -188
  367. package/src/model/BorderNode.ts +0 -458
  368. package/src/model/BorderSet.ts +0 -87
  369. package/src/model/ICloseType.ts +0 -5
  370. package/src/model/IDraggable.ts +0 -7
  371. package/src/model/IDropTarget.ts +0 -14
  372. package/src/model/IJsonModel.ts +0 -967
  373. package/src/model/LayoutWindow.ts +0 -119
  374. package/src/model/Model.ts +0 -704
  375. package/src/model/Node.ts +0 -280
  376. package/src/model/RowNode.ts +0 -559
  377. package/src/model/TabNode.ts +0 -424
  378. package/src/model/TabSetNode.ts +0 -592
  379. package/src/model/Utils.ts +0 -52
  380. package/src/view/BorderButton.tsx +0 -201
  381. package/src/view/BorderTab.tsx +0 -81
  382. package/src/view/BorderTabSet.tsx +0 -259
  383. package/src/view/DragContainer.tsx +0 -32
  384. package/src/view/ErrorBoundary.tsx +0 -42
  385. package/src/view/Icons.tsx +0 -57
  386. package/src/view/Layout.tsx +0 -1334
  387. package/src/view/Overlay.tsx +0 -21
  388. package/src/view/PopoutWindow.tsx +0 -152
  389. package/src/view/PopupMenu.tsx +0 -156
  390. package/src/view/Row.tsx +0 -68
  391. package/src/view/SizeTracker.tsx +0 -20
  392. package/src/view/Splitter.tsx +0 -262
  393. package/src/view/Tab.tsx +0 -128
  394. package/src/view/TabButton.tsx +0 -200
  395. package/src/view/TabButtonStamp.tsx +0 -42
  396. package/src/view/TabOverflowHook.tsx +0 -305
  397. package/src/view/TabSet.tsx +0 -475
  398. package/src/view/Utils.tsx +0 -135
  399. package/test-results/view-Add-methods-add-to-active-tabset-chromium/trace.zip +0 -0
  400. package/test-results/view-Add-methods-drag-to-border-chromium/trace.zip +0 -0
  401. package/test-results/view-Add-methods-drag-to-tabset-chromium/trace.zip +0 -0
  402. package/test-results/view-Delete-methods-delete-all-tabs-chromium/trace.zip +0 -0
  403. package/test-results/view-Delete-methods-delete-tab-chromium/trace.zip +0 -0
  404. package/test-results/view-Extended-App-onRenderTab-chromium/trace.zip +0 -0
  405. package/test-results/view-Extended-App-onRenderTab-in-border-chromium/trace.zip +0 -0
  406. package/test-results/view-Extended-App-onRenderTabSet-chromium/trace.zip +0 -0
  407. package/test-results/view-Extended-App-onRenderTabSet-for-border-chromium/trace.zip +0 -0
  408. package/test-results/view-Extended-App-onRenderTabSet-sticky-buttons-chromium/trace.zip +0 -0
  409. package/test-results/view-Extended-layout2-borders-autohide-left-chromium/trace.zip +0 -0
  410. package/test-results/view-Extended-layout2-borders-autohide-top-chromium/trace.zip +0 -0
  411. package/test-results/view-Extended-layout2-check-border-bottom-min-size-chromium/trace.zip +0 -0
  412. package/test-results/view-Extended-layout2-check-border-left-min-size-chromium/trace.zip +0 -0
  413. package/test-results/view-Extended-layout2-check-border-right-min-size-chromium/trace.zip +0 -0
  414. package/test-results/view-Extended-layout2-check-border-top-min-size-chromium/trace.zip +0 -0
  415. package/test-results/view-Extended-layout2-check-tabset-min-size-chromium/trace.zip +0 -0
  416. package/test-results/view-Extended-layout2-tabset-close-chromium/trace.zip +0 -0
  417. package/test-results/view-Maximize-methods-maximize-tabset-using-double-click-chromium/trace.zip +0 -0
  418. package/test-results/view-Maximize-methods-maximize-tabset-using-max-button-chromium/trace.zip +0 -0
  419. package/test-results/view-Others-click-on-tab-button-causes-tabset-activate-chromium/trace.zip +0 -0
  420. package/test-results/view-Others-click-on-tab-contents-causes-tabset-activate-chromium/trace.zip +0 -0
  421. package/test-results/view-Others-click-on-tabstrip-causes-tabset-activate-chromium/trace.zip +0 -0
  422. package/test-results/view-Others-rename-tab-cancelled-with-esc-chromium/trace.zip +0 -0
  423. package/test-results/view-Others-rename-tab-chromium/trace.zip +0 -0
  424. package/test-results/view-Overflow-menu-show-menu-chromium/trace.zip +0 -0
  425. package/test-results/view-Splitters-horizontal--5a358-ter-to-bottom-edge-and-back-chromium/trace.zip +0 -0
  426. package/test-results/view-Splitters-horizontal--f02d2-litter-to-top-edge-and-back-chromium/trace.zip +0 -0
  427. package/test-results/view-Splitters-horizontal-resizes-with-hsplitter-chromium/trace.zip +0 -0
  428. package/test-results/view-Splitters-vsplitter-chromium/trace.zip +0 -0
  429. package/test-results/view-Splitters-vsplitter-to-edge-chromium/trace.zip +0 -0
  430. package/test-results/view-Splitters-vsplitter-to-edge-left-chromium/trace.zip +0 -0
  431. package/test-results/view-borders-border-bottom-to-tab-chromium/trace.zip +0 -0
  432. package/test-results/view-borders-border-left-to-tab-chromium/trace.zip +0 -0
  433. package/test-results/view-borders-border-right-to-tab-chromium/trace.zip +0 -0
  434. package/test-results/view-borders-border-top-to-tab-chromium/trace.zip +0 -0
  435. package/test-results/view-borders-move-tab-in-border-bottom-chromium/trace.zip +0 -0
  436. package/test-results/view-borders-move-tab-in-border-left-chromium/trace.zip +0 -0
  437. package/test-results/view-borders-move-tab-in-border-right-chromium/trace.zip +0 -0
  438. package/test-results/view-borders-move-tab-in-border-top-chromium/trace.zip +0 -0
  439. package/test-results/view-borders-tab-to-border-bottom-chromium/trace.zip +0 -0
  440. package/test-results/view-borders-tab-to-border-left-chromium/trace.zip +0 -0
  441. package/test-results/view-borders-tab-to-border-right-chromium/trace.zip +0 -0
  442. package/test-results/view-borders-tab-to-border-top-chromium/trace.zip +0 -0
  443. package/test-results/view-borders-tab-to-open-border-bottom-center-chromium/trace.zip +0 -0
  444. package/test-results/view-borders-tab-to-open-border-bottom-chromium/trace.zip +0 -0
  445. package/test-results/view-borders-tab-to-open-border-left-center-chromium/trace.zip +0 -0
  446. package/test-results/view-borders-tab-to-open-border-left-chromium/trace.zip +0 -0
  447. package/test-results/view-borders-tab-to-open-border-right-center-chromium/trace.zip +0 -0
  448. package/test-results/view-borders-tab-to-open-border-right-chromium/trace.zip +0 -0
  449. package/test-results/view-borders-tab-to-open-border-top-center-chromium/trace.zip +0 -0
  450. package/test-results/view-borders-tab-to-open-border-top-chromium/trace.zip +0 -0
  451. package/test-results/view-drag-tests-two-tabs-tab-to-edge-chromium/trace.zip +0 -0
  452. package/test-results/view-drag-tests-two-tabs-tab-to-tab-bottom-chromium/trace.zip +0 -0
  453. package/test-results/view-drag-tests-two-tabs-tab-to-tab-center-chromium/trace.zip +0 -0
  454. package/test-results/view-drag-tests-two-tabs-tab-to-tab-left-chromium/trace.zip +0 -0
  455. package/test-results/view-drag-tests-two-tabs-tab-to-tab-right-chromium/trace.zip +0 -0
  456. package/test-results/view-drag-tests-two-tabs-tab-to-tab-top-chromium/trace.zip +0 -0
  457. package/test-results/view-tab-can-have-icon-chromium/trace.zip +0 -0
  458. package/test-results/view-three-tabs-move-tab-in-tabstrip-chromium/trace.zip +0 -0
  459. package/test-results/view-three-tabs-move-tabstrip-chromium/trace.zip +0 -0
  460. package/test-results/view-three-tabs-row-to-column-chromium/trace.zip +0 -0
  461. package/test-results/view-three-tabs-row-to-single-tabset-chromium/trace.zip +0 -0
  462. package/test-results/view-three-tabs-tab-to-edge-bottom-chromium/trace.zip +0 -0
  463. package/test-results/view-three-tabs-tab-to-edge-left-chromium/trace.zip +0 -0
  464. package/test-results/view-three-tabs-tab-to-edge-right-chromium/trace.zip +0 -0
  465. package/test-results/view-three-tabs-tab-to-edge-top-chromium/trace.zip +0 -0
  466. package/test-results/view-three-tabs-tab-to-tab-bottom-chromium/trace.zip +0 -0
  467. package/test-results/view-three-tabs-tab-to-tab-center-chromium/trace.zip +0 -0
  468. package/test-results/view-three-tabs-tab-to-tab-left-chromium/trace.zip +0 -0
  469. package/test-results/view-three-tabs-tab-to-tab-right-chromium/trace.zip +0 -0
  470. package/test-results/view-three-tabs-tab-to-tab-top-chromium/trace.zip +0 -0
  471. package/test-results/view-three-tabs-tab-to-tabset-chromium/trace.zip +0 -0
  472. package/tests-playwright/helpers.ts +0 -124
  473. package/tests-playwright/view.spec.ts +0 -911
@@ -1,881 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- import * as React from "react";
3
- import { createPortal } from "react-dom";
4
- import { createRoot } from "react-dom/client";
5
- import { DockLocation } from "../DockLocation";
6
- import { I18nLabel } from "../I18nLabel";
7
- import { Orientation } from "../Orientation";
8
- import { Rect } from "../Rect";
9
- import { CLASSES } from "../Types";
10
- import { Actions } from "../model/Actions";
11
- import { BorderNode } from "../model/BorderNode";
12
- import { Model } from "../model/Model";
13
- import { TabNode } from "../model/TabNode";
14
- import { TabSetNode } from "../model/TabSetNode";
15
- import { BorderTab } from "./BorderTab";
16
- import { BorderTabSet } from "./BorderTabSet";
17
- import { DragContainer } from "./DragContainer";
18
- import { ErrorBoundary } from "./ErrorBoundary";
19
- import { PopoutWindow } from "./PopoutWindow";
20
- import { AsterickIcon, CloseIcon, EdgeIcon, MaximizeIcon, OverflowIcon, PopoutIcon, RestoreIcon } from "./Icons";
21
- import { Overlay } from "./Overlay";
22
- import { Row } from "./Row";
23
- import { Tab } from "./Tab";
24
- import { copyInlineStyles, enablePointerOnIFrames, isDesktop, isSafari } from "./Utils";
25
- import { TabButtonStamp } from "./TabButtonStamp";
26
- import { SizeTracker } from "./SizeTracker";
27
- /**
28
- * A React component that hosts a multi-tabbed layout
29
- */
30
- export class Layout extends React.Component {
31
- /** @internal */
32
- constructor(props) {
33
- super(props);
34
- this.selfRef = React.createRef();
35
- this.revision = 0;
36
- }
37
- /** re-render the layout */
38
- redraw() {
39
- this.selfRef.current.redraw("parent " + this.revision);
40
- }
41
- /**
42
- * Adds a new tab to the given tabset
43
- * @param tabsetId the id of the tabset where the new tab will be added
44
- * @param json the json for the new tab node
45
- * @returns the added tab node or undefined
46
- */
47
- addTabToTabSet(tabsetId, json) {
48
- return this.selfRef.current.addTabToTabSet(tabsetId, json);
49
- }
50
- /**
51
- * Adds a new tab by dragging an item to the drop location, must be called from within an HTML
52
- * drag start handler. You can use the setDragComponent() method to set the drag image before calling this
53
- * method.
54
- * @param event the drag start event
55
- * @param json the json for the new tab node
56
- * @param onDrop a callback to call when the drag is complete
57
- */
58
- addTabWithDragAndDrop(event, json, onDrop) {
59
- this.selfRef.current.addTabWithDragAndDrop(event, json, onDrop);
60
- }
61
- /**
62
- * Move a tab/tabset using drag and drop, must be called from within an HTML
63
- * drag start handler
64
- * @param event the drag start event
65
- * @param node the tab or tabset to drag
66
- */
67
- moveTabWithDragAndDrop(event, node) {
68
- this.selfRef.current.moveTabWithDragAndDrop(event, node);
69
- }
70
- /**
71
- * Adds a new tab to the active tabset (if there is one)
72
- * @param json the json for the new tab node
73
- * @returns the added tab node or undefined
74
- */
75
- addTabToActiveTabSet(json) {
76
- return this.selfRef.current.addTabToActiveTabSet(json);
77
- }
78
- /**
79
- * Sets the drag image from a react component for a drag event
80
- * @param event the drag event
81
- * @param component the react component to be used for the drag image
82
- * @param x the x position of the drag cursor on the image
83
- * @param y the x position of the drag cursor on the image
84
- */
85
- setDragComponent(event, component, x, y) {
86
- this.selfRef.current.setDragComponent(event, component, x, y);
87
- }
88
- /** Get the root div element of the layout */
89
- getRootDiv() {
90
- return this.selfRef.current.getRootDiv();
91
- }
92
- /** @internal */
93
- render() {
94
- return (_jsx(LayoutInternal, Object.assign({ ref: this.selfRef }, this.props, { renderRevision: this.revision++ })));
95
- }
96
- }
97
- /** @internal */
98
- export class LayoutInternal extends React.Component {
99
- // private renderCount: any;
100
- constructor(props) {
101
- super(props);
102
- this.moveableElementMap = new Map();
103
- this.dragEnterCount = 0;
104
- this.dragging = false;
105
- this.updateLayoutMetrics = () => {
106
- if (this.findBorderBarSizeRef.current) {
107
- const borderBarSize = this.findBorderBarSizeRef.current.getBoundingClientRect().height;
108
- if (borderBarSize !== this.state.calculatedBorderBarSize) {
109
- this.setState({ calculatedBorderBarSize: borderBarSize });
110
- }
111
- }
112
- };
113
- this.onModelChange = (action) => {
114
- this.redrawInternal("model change");
115
- if (this.props.onModelChange) {
116
- this.props.onModelChange(this.props.model, action);
117
- }
118
- };
119
- this.updateRect = () => {
120
- const rect = this.getDomRect();
121
- if (!rect.equals(this.state.rect) && rect.width !== 0 && rect.height !== 0) {
122
- // console.log("updateRect", rect.floor());
123
- this.setState({ rect });
124
- if (this.windowId !== Model.MAIN_WINDOW_ID) {
125
- this.redrawInternal("rect updated");
126
- }
127
- }
128
- };
129
- this.getClassName = (defaultClassName) => {
130
- if (this.props.classNameMapper === undefined) {
131
- return defaultClassName;
132
- }
133
- else {
134
- return this.props.classNameMapper(defaultClassName);
135
- }
136
- };
137
- this.onCloseWindow = (windowLayout) => {
138
- this.doAction(Actions.closeWindow(windowLayout.windowId));
139
- };
140
- this.onSetWindow = (windowLayout, window) => {
141
- };
142
- this.showControlInPortal = (control, element) => {
143
- const portal = createPortal(control, element);
144
- this.setState({ portal });
145
- };
146
- this.hideControlInPortal = () => {
147
- this.setState({ portal: undefined });
148
- };
149
- this.getIcons = () => {
150
- return this.icons;
151
- };
152
- this.setDragNode = (event, node) => {
153
- LayoutInternal.dragState = new DragState(this.mainLayout, DragSource.Internal, node, undefined, undefined);
154
- // Note: can only set (very) limited types on android! so cannot set json
155
- // Note: must set text/plain for android to allow drag,
156
- // so just set a simple message indicating its a flexlayout drag (this is not used anywhere else)
157
- event.dataTransfer.setData('text/plain', "--flexlayout--");
158
- event.dataTransfer.effectAllowed = "copyMove";
159
- event.dataTransfer.dropEffect = "move";
160
- this.dragEnterCount = 0;
161
- if (node instanceof TabSetNode) {
162
- let rendered = false;
163
- let content = this.i18nName(I18nLabel.Move_Tabset);
164
- if (node.getChildren().length > 0) {
165
- content = this.i18nName(I18nLabel.Move_Tabs).replace("?", String(node.getChildren().length));
166
- }
167
- if (this.props.onRenderDragRect) {
168
- const dragComponent = this.props.onRenderDragRect(content, node, undefined);
169
- if (dragComponent) {
170
- this.setDragComponent(event, dragComponent, 10, 10);
171
- rendered = true;
172
- }
173
- }
174
- if (!rendered) {
175
- this.setDragComponent(event, content, 10, 10);
176
- }
177
- }
178
- else {
179
- const element = event.target;
180
- const rect = element.getBoundingClientRect();
181
- const offsetX = event.clientX - rect.left;
182
- const offsetY = event.clientY - rect.top;
183
- const parentNode = node === null || node === void 0 ? void 0 : node.getParent();
184
- const isInVerticalBorder = parentNode instanceof BorderNode && parentNode.getOrientation() === Orientation.HORZ;
185
- const x = isInVerticalBorder ? 10 : offsetX;
186
- const y = isInVerticalBorder ? 10 : offsetY;
187
- let rendered = false;
188
- if (this.props.onRenderDragRect) {
189
- const content = _jsx(TabButtonStamp, { layout: this, node: node }, node.getId());
190
- const dragComponent = this.props.onRenderDragRect(content, node, undefined);
191
- if (dragComponent) {
192
- this.setDragComponent(event, dragComponent, x, y);
193
- rendered = true;
194
- }
195
- }
196
- if (!rendered) {
197
- if (isSafari()) { // safari doesnt render the offscreen tabstamps
198
- this.setDragComponent(event, _jsx(TabButtonStamp, { node: node, layout: this }), x, y);
199
- }
200
- else {
201
- event.dataTransfer.setDragImage(node.getTabStamp(), x, y);
202
- }
203
- }
204
- }
205
- };
206
- this.onDragEnterRaw = (event) => {
207
- this.dragEnterCount++;
208
- if (this.dragEnterCount === 1) {
209
- this.onDragEnter(event);
210
- }
211
- };
212
- this.onDragLeaveRaw = (event) => {
213
- this.dragEnterCount--;
214
- if (this.dragEnterCount === 0) {
215
- this.onDragLeave(event);
216
- }
217
- };
218
- this.onDragEnter = (event) => {
219
- // console.log("onDragEnter", this.windowId, this.dragEnterCount);
220
- var _a;
221
- if (!LayoutInternal.dragState && this.props.onExternalDrag) { // not internal dragging
222
- const externalDrag = this.props.onExternalDrag(event);
223
- if (externalDrag) {
224
- const tempNode = TabNode.fromJson(externalDrag.json, this.props.model, false);
225
- LayoutInternal.dragState = new DragState(this.mainLayout, DragSource.External, tempNode, externalDrag.json, externalDrag.onDrop);
226
- }
227
- }
228
- if (LayoutInternal.dragState) {
229
- if (this.windowId !== Model.MAIN_WINDOW_ID && LayoutInternal.dragState.mainLayout === this.mainLayout) {
230
- LayoutInternal.dragState.mainLayout.setDraggingOverWindow(true);
231
- }
232
- if (LayoutInternal.dragState.mainLayout !== this.mainLayout) {
233
- return; // drag not by this layout or its popouts
234
- }
235
- event.preventDefault();
236
- this.dropInfo = undefined;
237
- const rootdiv = this.selfRef.current;
238
- this.outlineDiv = this.currentDocument.createElement("div");
239
- this.outlineDiv.className = this.getClassName(CLASSES.FLEXLAYOUT__OUTLINE_RECT);
240
- this.outlineDiv.style.visibility = "hidden";
241
- const speed = this.props.model.getAttribute("tabDragSpeed");
242
- this.outlineDiv.style.transition = `top ${speed}s, left ${speed}s, width ${speed}s, height ${speed}s`;
243
- rootdiv.appendChild(this.outlineDiv);
244
- this.dragging = true;
245
- this.showOverlay(true);
246
- // add edge indicators
247
- if (!this.isDraggingOverWindow && this.props.model.getMaximizedTabset(this.windowId) === undefined) {
248
- this.setState({ showEdges: this.props.model.isEnableEdgeDock() });
249
- }
250
- const clientRect = (_a = this.selfRef.current) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect();
251
- const r = new Rect(event.clientX - (clientRect.left), event.clientY - (clientRect.top), 1, 1);
252
- r.positionElement(this.outlineDiv);
253
- }
254
- };
255
- this.onDragOver = (event) => {
256
- var _a, _b, _c;
257
- if (this.dragging && !this.isDraggingOverWindow) {
258
- // console.log("onDragOver");
259
- event.preventDefault();
260
- const clientRect = (_a = this.selfRef.current) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect();
261
- const pos = {
262
- x: event.clientX - ((_b = clientRect === null || clientRect === void 0 ? void 0 : clientRect.left) !== null && _b !== void 0 ? _b : 0),
263
- y: event.clientY - ((_c = clientRect === null || clientRect === void 0 ? void 0 : clientRect.top) !== null && _c !== void 0 ? _c : 0),
264
- };
265
- this.checkForBorderToShow(pos.x, pos.y);
266
- let dropInfo = this.props.model.findDropTargetNode(this.windowId, LayoutInternal.dragState.dragNode, pos.x, pos.y);
267
- if (dropInfo) {
268
- this.dropInfo = dropInfo;
269
- if (this.outlineDiv) {
270
- this.outlineDiv.className = this.getClassName(dropInfo.className);
271
- dropInfo.rect.positionElement(this.outlineDiv);
272
- this.outlineDiv.style.visibility = "visible";
273
- }
274
- }
275
- }
276
- };
277
- this.onDragLeave = (event) => {
278
- // console.log("onDragLeave", this.windowId, this.dragging);
279
- if (this.dragging) {
280
- if (this.windowId !== Model.MAIN_WINDOW_ID) {
281
- LayoutInternal.dragState.mainLayout.setDraggingOverWindow(false);
282
- }
283
- this.clearDragLocal();
284
- }
285
- };
286
- this.onDrop = (event) => {
287
- // console.log("ondrop", this.windowId, this.dragging, Layout.dragState);
288
- if (this.dragging) {
289
- event.preventDefault();
290
- const dragState = LayoutInternal.dragState;
291
- if (this.dropInfo) {
292
- if (dragState.dragJson !== undefined) {
293
- const newNode = this.doAction(Actions.addNode(dragState.dragJson, this.dropInfo.node.getId(), this.dropInfo.location, this.dropInfo.index));
294
- if (dragState.fnNewNodeDropped !== undefined) {
295
- dragState.fnNewNodeDropped(newNode, event);
296
- }
297
- }
298
- else if (dragState.dragNode !== undefined) {
299
- this.doAction(Actions.moveNode(dragState.dragNode.getId(), this.dropInfo.node.getId(), this.dropInfo.location, this.dropInfo.index));
300
- }
301
- }
302
- this.mainLayout.clearDragMain();
303
- }
304
- this.dragEnterCount = 0; // must set to zero here ref sublayouts
305
- };
306
- this.orderedTabIds = [];
307
- this.orderedTabMoveableIds = [];
308
- this.selfRef = React.createRef();
309
- this.moveablesRef = React.createRef();
310
- this.mainRef = React.createRef();
311
- this.findBorderBarSizeRef = React.createRef();
312
- this.supportsPopout = props.supportsPopout !== undefined ? props.supportsPopout : defaultSupportsPopout;
313
- this.popoutURL = props.popoutURL ? props.popoutURL : "popout.html";
314
- this.icons = Object.assign(Object.assign({}, defaultIcons), props.icons);
315
- this.windowId = props.windowId ? props.windowId : Model.MAIN_WINDOW_ID;
316
- this.mainLayout = this.props.mainLayout ? this.props.mainLayout : this;
317
- this.isDraggingOverWindow = false;
318
- this.layoutWindow = this.props.model.getwindowsMap().get(this.windowId);
319
- this.layoutWindow.layout = this;
320
- this.popoutWindowName = this.props.popoutWindowName || "Popout Window";
321
- // this.renderCount = 0;
322
- this.state = {
323
- rect: Rect.empty(),
324
- editingTab: undefined,
325
- showEdges: false,
326
- showOverlay: false,
327
- calculatedBorderBarSize: 29,
328
- layoutRevision: 0,
329
- forceRevision: 0,
330
- showHiddenBorder: DockLocation.CENTER
331
- };
332
- this.isMainWindow = this.windowId === Model.MAIN_WINDOW_ID;
333
- }
334
- componentDidMount() {
335
- this.updateRect();
336
- this.currentDocument = this.selfRef.current.ownerDocument;
337
- this.currentWindow = this.currentDocument.defaultView;
338
- this.layoutWindow.window = this.currentWindow;
339
- this.layoutWindow.toScreenRectFunction = (r) => this.getScreenRect(r);
340
- this.resizeObserver = new ResizeObserver(entries => {
341
- requestAnimationFrame(() => {
342
- this.updateRect();
343
- });
344
- });
345
- if (this.selfRef.current) {
346
- this.resizeObserver.observe(this.selfRef.current);
347
- }
348
- if (this.isMainWindow) {
349
- this.props.model.addChangeListener(this.onModelChange);
350
- this.updateLayoutMetrics();
351
- }
352
- else {
353
- // since resizeObserver doesn't always work as expected when observing element in another document
354
- this.currentWindow.addEventListener("resize", () => {
355
- this.updateRect();
356
- });
357
- const sourceElement = this.props.mainLayout.getRootDiv();
358
- const targetElement = this.selfRef.current;
359
- copyInlineStyles(sourceElement, targetElement);
360
- this.styleObserver = new MutationObserver(() => {
361
- const changed = copyInlineStyles(sourceElement, targetElement);
362
- if (changed) {
363
- this.redraw("mutation observer");
364
- }
365
- });
366
- // Observe changes to the source element's style attribute
367
- this.styleObserver.observe(sourceElement, { attributeFilter: ['style'] });
368
- }
369
- // allow tabs to overlay when hidden
370
- document.addEventListener('visibilitychange', () => {
371
- for (const [_, layoutWindow] of this.props.model.getwindowsMap()) {
372
- const layout = layoutWindow.layout;
373
- if (layout) {
374
- this.redraw("visibility change");
375
- }
376
- }
377
- });
378
- }
379
- componentDidUpdate() {
380
- this.currentDocument = this.selfRef.current.ownerDocument;
381
- this.currentWindow = this.currentDocument.defaultView;
382
- if (this.isMainWindow) {
383
- if (this.props.model !== this.previousModel) {
384
- if (this.previousModel !== undefined) {
385
- this.previousModel.removeChangeListener(this.onModelChange); // stop listening to old model
386
- }
387
- this.props.model.getwindowsMap().get(this.windowId).layout = this;
388
- this.props.model.addChangeListener(this.onModelChange);
389
- this.layoutWindow = this.props.model.getwindowsMap().get(this.windowId);
390
- this.layoutWindow.layout = this;
391
- this.layoutWindow.toScreenRectFunction = (r) => this.getScreenRect(r);
392
- this.previousModel = this.props.model;
393
- this.tidyMoveablesMap();
394
- }
395
- this.updateLayoutMetrics();
396
- }
397
- }
398
- componentWillUnmount() {
399
- var _a, _b;
400
- if (this.selfRef.current) {
401
- (_a = this.resizeObserver) === null || _a === void 0 ? void 0 : _a.unobserve(this.selfRef.current);
402
- }
403
- (_b = this.styleObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
404
- }
405
- render() {
406
- // console.log("render", this.windowId, this.state.revision, this.renderCount++);
407
- // first render will be used to find the size (via selfRef)
408
- if (!this.selfRef.current) {
409
- return (_jsxs("div", { ref: this.selfRef, className: this.getClassName(CLASSES.FLEXLAYOUT__LAYOUT), children: [_jsx("div", { ref: this.moveablesRef, className: this.getClassName(CLASSES.FLEXLAYOUT__LAYOUT_MOVEABLES) }, "__moveables__"), this.renderMetricsElements()] }));
410
- }
411
- const model = this.props.model;
412
- model.getRoot(this.windowId).calcMinMaxSize();
413
- model.getRoot(this.windowId).setPaths("");
414
- model.getBorderSet().setPaths();
415
- const inner = this.renderLayout();
416
- const outer = this.renderBorders(inner);
417
- const tabs = this.renderTabs();
418
- const reorderedTabs = this.reorderComponents(tabs, this.orderedTabIds);
419
- let floatingWindows = null;
420
- let reorderedTabMoveables = null;
421
- let tabStamps = null;
422
- let metricElements = null;
423
- if (this.isMainWindow) {
424
- floatingWindows = this.renderWindows();
425
- metricElements = this.renderMetricsElements();
426
- const tabMoveables = this.renderTabMoveables();
427
- reorderedTabMoveables = this.reorderComponents(tabMoveables, this.orderedTabMoveableIds);
428
- tabStamps = _jsx("div", { className: this.getClassName(CLASSES.FLEXLAYOUT__LAYOUT_TAB_STAMPS), children: this.renderTabStamps() }, "__tabStamps__");
429
- }
430
- return (_jsxs("div", { ref: this.selfRef, className: this.getClassName(CLASSES.FLEXLAYOUT__LAYOUT), onDragEnter: this.onDragEnterRaw, onDragLeave: this.onDragLeaveRaw, onDragOver: this.onDragOver, onDrop: this.onDrop, children: [_jsx("div", { ref: this.moveablesRef, className: this.getClassName(CLASSES.FLEXLAYOUT__LAYOUT_MOVEABLES) }, "__moveables__"), metricElements, _jsx(Overlay, { layout: this, show: this.state.showOverlay }, "__overlay__"), outer, reorderedTabs, reorderedTabMoveables, tabStamps, this.state.portal, floatingWindows] }));
431
- }
432
- renderBorders(inner) {
433
- const classMain = this.getClassName(CLASSES.FLEXLAYOUT__LAYOUT_MAIN);
434
- const borders = this.props.model.getBorderSet().getBorderMap();
435
- if (this.isMainWindow && borders.size > 0) {
436
- inner = (_jsx("div", { className: classMain, ref: this.mainRef, children: inner }));
437
- const borderSetComponents = new Map();
438
- const borderSetContentComponents = new Map();
439
- for (const [_, location] of DockLocation.values) {
440
- const border = borders.get(location);
441
- const showBorder = border && border.isShowing() && (!border.isAutoHide() ||
442
- (border.isAutoHide() && (border.getChildren().length > 0 || this.state.showHiddenBorder === location)));
443
- if (showBorder) {
444
- borderSetComponents.set(location, _jsx(BorderTabSet, { layout: this, border: border, size: this.state.calculatedBorderBarSize }));
445
- borderSetContentComponents.set(location, _jsx(BorderTab, { layout: this, border: border, show: border.getSelected() !== -1 }));
446
- }
447
- }
448
- const classBorderOuter = this.getClassName(CLASSES.FLEXLAYOUT__LAYOUT_BORDER_CONTAINER);
449
- const classBorderInner = this.getClassName(CLASSES.FLEXLAYOUT__LAYOUT_BORDER_CONTAINER_INNER);
450
- if (this.props.model.getBorderSet().getLayoutHorizontal()) {
451
- const innerWithBorderTabs = (_jsxs("div", { className: classBorderInner, style: { flexDirection: "column" }, children: [borderSetContentComponents.get(DockLocation.TOP), _jsxs("div", { className: classBorderInner, style: { flexDirection: "row" }, children: [borderSetContentComponents.get(DockLocation.LEFT), inner, borderSetContentComponents.get(DockLocation.RIGHT)] }), borderSetContentComponents.get(DockLocation.BOTTOM)] }));
452
- return (_jsxs("div", { className: classBorderOuter, style: { flexDirection: "column" }, children: [borderSetComponents.get(DockLocation.TOP), _jsxs("div", { className: classBorderInner, style: { flexDirection: "row" }, children: [borderSetComponents.get(DockLocation.LEFT), innerWithBorderTabs, borderSetComponents.get(DockLocation.RIGHT)] }), borderSetComponents.get(DockLocation.BOTTOM)] }));
453
- }
454
- else {
455
- const innerWithBorderTabs = (_jsxs("div", { className: classBorderInner, style: { flexDirection: "row" }, children: [borderSetContentComponents.get(DockLocation.LEFT), _jsxs("div", { className: classBorderInner, style: { flexDirection: "column" }, children: [borderSetContentComponents.get(DockLocation.TOP), inner, borderSetContentComponents.get(DockLocation.BOTTOM)] }), borderSetContentComponents.get(DockLocation.RIGHT)] }));
456
- return (_jsxs("div", { className: classBorderOuter, style: { flexDirection: "row" }, children: [borderSetComponents.get(DockLocation.LEFT), _jsxs("div", { className: classBorderInner, style: { flexDirection: "column" }, children: [borderSetComponents.get(DockLocation.TOP), innerWithBorderTabs, borderSetComponents.get(DockLocation.BOTTOM)] }), borderSetComponents.get(DockLocation.RIGHT)] }));
457
- }
458
- }
459
- else { // no borders
460
- return (_jsx("div", { className: classMain, ref: this.mainRef, style: { position: "absolute", top: 0, left: 0, bottom: 0, right: 0, display: "flex" }, children: inner }));
461
- }
462
- }
463
- renderLayout() {
464
- return (_jsxs(_Fragment, { children: [_jsx(Row, { layout: this, node: this.props.model.getRoot(this.windowId) }, "__row__"), this.renderEdgeIndicators()] }));
465
- }
466
- renderEdgeIndicators() {
467
- const edges = [];
468
- const arrowIcon = this.icons.edgeArrow;
469
- if (this.state.showEdges) {
470
- const r = this.props.model.getRoot(this.windowId).getRect();
471
- const length = edgeRectLength;
472
- const width = edgeRectWidth;
473
- const offset = edgeRectLength / 2;
474
- const className = this.getClassName(CLASSES.FLEXLAYOUT__EDGE_RECT);
475
- const radius = 50;
476
- edges.push(_jsx("div", { style: { top: 0, left: r.width / 2 - offset, width: length, height: width, borderBottomLeftRadius: radius, borderBottomRightRadius: radius }, className: className + " " + this.getClassName(CLASSES.FLEXLAYOUT__EDGE_RECT_TOP), children: _jsx("div", { style: { transform: "rotate(180deg)" }, children: arrowIcon }) }, "North"));
477
- edges.push(_jsx("div", { style: { top: r.height / 2 - offset, left: 0, width: width, height: length, borderTopRightRadius: radius, borderBottomRightRadius: radius }, className: className + " " + this.getClassName(CLASSES.FLEXLAYOUT__EDGE_RECT_LEFT), children: _jsx("div", { style: { transform: "rotate(90deg)" }, children: arrowIcon }) }, "West"));
478
- edges.push(_jsx("div", { style: { top: r.height - width, left: r.width / 2 - offset, width: length, height: width, borderTopLeftRadius: radius, borderTopRightRadius: radius }, className: className + " " + this.getClassName(CLASSES.FLEXLAYOUT__EDGE_RECT_BOTTOM), children: _jsx("div", { children: arrowIcon }) }, "South"));
479
- edges.push(_jsx("div", { style: { top: r.height / 2 - offset, left: r.width - width, width: width, height: length, borderTopLeftRadius: radius, borderBottomLeftRadius: radius }, className: className + " " + this.getClassName(CLASSES.FLEXLAYOUT__EDGE_RECT_RIGHT), children: _jsx("div", { style: { transform: "rotate(-90deg)" }, children: arrowIcon }) }, "East"));
480
- }
481
- return edges;
482
- }
483
- renderWindows() {
484
- const floatingWindows = [];
485
- if (this.supportsPopout) {
486
- const windows = this.props.model.getwindowsMap();
487
- let i = 1;
488
- for (const [windowId, layoutWindow] of windows) {
489
- if (windowId !== Model.MAIN_WINDOW_ID) {
490
- floatingWindows.push(_jsx(PopoutWindow, { layout: this, title: this.popoutWindowName + " " + i, layoutWindow: layoutWindow, url: this.popoutURL + "?id=" + windowId, onSetWindow: this.onSetWindow, onCloseWindow: this.onCloseWindow, children: _jsx("div", { className: this.props.popoutClassName, children: _jsx(LayoutInternal, Object.assign({}, this.props, { windowId: windowId, mainLayout: this })) }) }, windowId));
491
- i++;
492
- }
493
- }
494
- }
495
- return floatingWindows;
496
- }
497
- renderTabMoveables() {
498
- // const tabMoveables: React.ReactNode[] = [];
499
- const tabMoveables = new Map();
500
- this.props.model.visitNodes((node) => {
501
- if (node instanceof TabNode) {
502
- const child = node;
503
- const element = this.getMoveableElement(child.getId());
504
- child.setMoveableElement(element);
505
- const selected = child.isSelected();
506
- const rect = child.getParent().getContentRect();
507
- // only render first time if size >0
508
- const renderTab = child.isRendered() ||
509
- ((selected || !child.isEnableRenderOnDemand()) && (rect.width > 0 && rect.height > 0));
510
- if (renderTab) {
511
- // console.log("rendertab", child.getName(), this.props.renderRevision);
512
- const key = child.getId() + (child.isEnableWindowReMount() ? child.getWindowId() : "");
513
- tabMoveables.set(node.getId(), createPortal(_jsx(SizeTracker, { rect: rect, selected: child.isSelected(), forceRevision: this.state.forceRevision, tabsRevision: this.props.renderRevision, children: _jsx(ErrorBoundary, { message: this.i18nName(I18nLabel.Error_rendering_component), children: this.props.factory(child) }) }, key), element, key));
514
- child.setRendered(renderTab);
515
- }
516
- }
517
- });
518
- return tabMoveables;
519
- }
520
- renderTabStamps() {
521
- const tabStamps = [];
522
- this.props.model.visitNodes((node) => {
523
- if (node instanceof TabNode) {
524
- const child = node;
525
- // what the tab should look like when dragged (since images need to have been loaded before drag image can be taken)
526
- tabStamps.push(_jsx(DragContainer, { layout: this, node: child }, child.getId()));
527
- }
528
- });
529
- return tabStamps;
530
- }
531
- renderTabs() {
532
- const tabs = new Map();
533
- this.props.model.visitWindowNodes(this.windowId, (node) => {
534
- if (node instanceof TabNode) {
535
- const child = node;
536
- const selected = child.isSelected();
537
- const path = child.getPath();
538
- const renderTab = child.isRendered() || selected || !child.isEnableRenderOnDemand();
539
- if (renderTab) {
540
- // const rect = (child.getParent() as BorderNode | TabSetNode).getContentRect();
541
- // const key = child.getId();
542
- tabs.set(child.getId(), (
543
- // <SizeTracker rect={rect} forceRevision={this.state.forceRevision} key={key}>
544
- _jsx(Tab, { layout: this, path: path, node: child, selected: selected }, child.getId())
545
- // </SizeTracker>
546
- ));
547
- }
548
- }
549
- });
550
- return tabs;
551
- }
552
- renderMetricsElements() {
553
- return (_jsx("div", { ref: this.findBorderBarSizeRef, className: this.getClassName(CLASSES.FLEXLAYOUT__BORDER_SIZER), children: "FindBorderBarSize" }, "findBorderBarSize"));
554
- }
555
- checkForBorderToShow(x, y) {
556
- const r = this.getBoundingClientRect(this.mainRef.current);
557
- const c = r.getCenter();
558
- const margin = edgeRectWidth;
559
- const offset = edgeRectLength / 2;
560
- let overEdge = false;
561
- if (this.props.model.isEnableEdgeDock() && this.state.showHiddenBorder === DockLocation.CENTER) {
562
- if ((y > c.y - offset && y < c.y + offset) ||
563
- (x > c.x - offset && x < c.x + offset)) {
564
- overEdge = true;
565
- }
566
- }
567
- let location = DockLocation.CENTER;
568
- if (!overEdge) {
569
- if (x <= r.x + margin) {
570
- location = DockLocation.LEFT;
571
- }
572
- else if (x >= r.getRight() - margin) {
573
- location = DockLocation.RIGHT;
574
- }
575
- else if (y <= r.y + margin) {
576
- location = DockLocation.TOP;
577
- }
578
- else if (y >= r.getBottom() - margin) {
579
- location = DockLocation.BOTTOM;
580
- }
581
- }
582
- if (location !== this.state.showHiddenBorder) {
583
- this.setState({ showHiddenBorder: location });
584
- }
585
- }
586
- tidyMoveablesMap() {
587
- // console.log("tidyMoveablesMap");
588
- const tabs = new Map();
589
- this.props.model.visitNodes((node, _) => {
590
- if (node instanceof TabNode) {
591
- tabs.set(node.getId(), node);
592
- }
593
- });
594
- for (const [nodeId, element] of this.moveableElementMap) {
595
- if (!tabs.has(nodeId)) {
596
- // console.log("delete", nodeId);
597
- element.remove(); // remove from dom
598
- this.moveableElementMap.delete(nodeId); // remove map entry
599
- }
600
- }
601
- }
602
- reorderComponents(components, ids) {
603
- const nextIds = [];
604
- const nextIdsSet = new Set();
605
- let reordered = [];
606
- // Keep any previous tabs in the same DOM order as before, removing any that have been deleted
607
- for (const id of ids) {
608
- if (components.get(id)) {
609
- nextIds.push(id);
610
- nextIdsSet.add(id);
611
- }
612
- }
613
- ids.splice(0, ids.length, ...nextIds);
614
- // Add tabs that have been added to the DOM
615
- for (const [id, _] of components) {
616
- if (!nextIdsSet.has(id)) {
617
- ids.push(id);
618
- }
619
- }
620
- reordered = ids.map((id) => {
621
- return components.get(id);
622
- });
623
- return reordered;
624
- }
625
- redraw(type) {
626
- // console.log("redraw", this.windowId, type);
627
- this.mainLayout.setState((state, props) => { return { forceRevision: state.forceRevision + 1 }; });
628
- }
629
- redrawInternal(type) {
630
- // console.log("redrawInternal", this.windowId, type);
631
- this.mainLayout.setState((state, props) => { return { layoutRevision: state.layoutRevision + 1 }; });
632
- }
633
- doAction(action) {
634
- if (this.props.onAction !== undefined) {
635
- const outcome = this.props.onAction(action);
636
- if (outcome !== undefined) {
637
- return this.props.model.doAction(outcome);
638
- }
639
- return undefined;
640
- }
641
- else {
642
- return this.props.model.doAction(action);
643
- }
644
- }
645
- getBoundingClientRect(div) {
646
- const layoutRect = this.getDomRect();
647
- if (layoutRect) {
648
- return Rect.getBoundingClientRect(div).relativeTo(layoutRect);
649
- }
650
- return Rect.empty();
651
- }
652
- getMoveableContainer() {
653
- return this.moveablesRef.current;
654
- }
655
- getMoveableElement(id) {
656
- let moveableElement = this.moveableElementMap.get(id);
657
- if (moveableElement === undefined) {
658
- moveableElement = document.createElement("div");
659
- this.moveablesRef.current.appendChild(moveableElement);
660
- moveableElement.className = CLASSES.FLEXLAYOUT__TAB_MOVEABLE;
661
- this.moveableElementMap.set(id, moveableElement);
662
- }
663
- return moveableElement;
664
- }
665
- getMainLayout() {
666
- return this.mainLayout;
667
- }
668
- getCurrentDocument() {
669
- return this.currentDocument;
670
- }
671
- getDomRect() {
672
- if (this.selfRef.current) {
673
- return Rect.fromDomRect(this.selfRef.current.getBoundingClientRect());
674
- }
675
- else {
676
- return Rect.empty();
677
- }
678
- }
679
- getWindowId() {
680
- return this.windowId;
681
- }
682
- getRootDiv() {
683
- return this.selfRef.current;
684
- }
685
- getMainElement() {
686
- return this.mainRef.current;
687
- }
688
- getFactory() {
689
- return this.props.factory;
690
- }
691
- isSupportsPopout() {
692
- return this.supportsPopout;
693
- }
694
- isRealtimeResize() {
695
- var _a;
696
- return (_a = this.props.realtimeResize) !== null && _a !== void 0 ? _a : false;
697
- }
698
- getPopoutURL() {
699
- return this.popoutURL;
700
- }
701
- setEditingTab(tabNode) {
702
- this.setState({ editingTab: tabNode });
703
- }
704
- getEditingTab() {
705
- return this.state.editingTab;
706
- }
707
- getModel() {
708
- return this.props.model;
709
- }
710
- getScreenRect(inRect) {
711
- const rect = inRect.clone();
712
- const layoutRect = this.getDomRect();
713
- // Note: outerHeight can be less than innerHeight when window is zoomed, so cannot use
714
- // const navHeight = Math.min(65, this.currentWindow!.outerHeight - this.currentWindow!.innerHeight);
715
- // const navWidth = Math.min(65, this.currentWindow!.outerWidth - this.currentWindow!.innerWidth);
716
- const navHeight = 60;
717
- const navWidth = 2;
718
- // console.log(rect.y, this.currentWindow!.screenX,layoutRect.y);
719
- rect.x = this.currentWindow.screenX + this.currentWindow.scrollX + navWidth / 2 + layoutRect.x + rect.x;
720
- rect.y = this.currentWindow.screenY + this.currentWindow.scrollY + (navHeight - navWidth / 2) + layoutRect.y + rect.y;
721
- rect.height += navHeight;
722
- rect.width += navWidth;
723
- return rect;
724
- }
725
- addTabToTabSet(tabsetId, json) {
726
- const tabsetNode = this.props.model.getNodeById(tabsetId);
727
- if (tabsetNode !== undefined) {
728
- const node = this.doAction(Actions.addNode(json, tabsetId, DockLocation.CENTER, -1));
729
- return node;
730
- }
731
- return undefined;
732
- }
733
- addTabToActiveTabSet(json) {
734
- const tabsetNode = this.props.model.getActiveTabset(this.windowId);
735
- if (tabsetNode !== undefined) {
736
- const node = this.doAction(Actions.addNode(json, tabsetNode.getId(), DockLocation.CENTER, -1));
737
- return node;
738
- }
739
- return undefined;
740
- }
741
- maximize(tabsetNode) {
742
- this.doAction(Actions.maximizeToggle(tabsetNode.getId(), this.getWindowId()));
743
- }
744
- customizeTab(tabNode, renderValues) {
745
- if (this.props.onRenderTab) {
746
- this.props.onRenderTab(tabNode, renderValues);
747
- }
748
- }
749
- customizeTabSet(tabSetNode, renderValues) {
750
- if (this.props.onRenderTabSet) {
751
- this.props.onRenderTabSet(tabSetNode, renderValues);
752
- }
753
- }
754
- i18nName(id, param) {
755
- let message;
756
- if (this.props.i18nMapper) {
757
- message = this.props.i18nMapper(id, param);
758
- }
759
- if (message === undefined) {
760
- message = id + (param === undefined ? "" : param);
761
- }
762
- return message;
763
- }
764
- getShowOverflowMenu() {
765
- return this.props.onShowOverflowMenu;
766
- }
767
- getTabSetPlaceHolderCallback() {
768
- return this.props.onTabSetPlaceHolder;
769
- }
770
- showContextMenu(node, event) {
771
- if (this.props.onContextMenu) {
772
- this.props.onContextMenu(node, event);
773
- }
774
- }
775
- auxMouseClick(node, event) {
776
- if (this.props.onAuxMouseClick) {
777
- this.props.onAuxMouseClick(node, event);
778
- }
779
- }
780
- showOverlay(show) {
781
- this.setState({ showOverlay: show });
782
- enablePointerOnIFrames(!show, this.currentDocument);
783
- }
784
- // *************************** Start Drag Drop *************************************
785
- addTabWithDragAndDrop(event, json, onDrop) {
786
- const tempNode = TabNode.fromJson(json, this.props.model, false);
787
- LayoutInternal.dragState = new DragState(this.mainLayout, DragSource.Add, tempNode, json, onDrop);
788
- }
789
- moveTabWithDragAndDrop(event, node) {
790
- this.setDragNode(event, node);
791
- }
792
- setDragComponent(event, component, x, y) {
793
- let dragElement = (_jsx("div", { style: { position: "unset" }, className: this.getClassName(CLASSES.FLEXLAYOUT__LAYOUT) + " " + this.getClassName(CLASSES.FLEXLAYOUT__DRAG_RECT), children: component }));
794
- const tempDiv = this.currentDocument.createElement('div');
795
- tempDiv.setAttribute("data-layout-path", "/drag-rectangle");
796
- tempDiv.style.position = "absolute";
797
- tempDiv.style.left = "-10000px";
798
- tempDiv.style.top = "-10000px";
799
- this.currentDocument.body.appendChild(tempDiv);
800
- createRoot(tempDiv).render(dragElement);
801
- event.dataTransfer.setDragImage(tempDiv, x, y);
802
- setTimeout(() => {
803
- this.currentDocument.body.removeChild(tempDiv);
804
- }, 0);
805
- }
806
- setDraggingOverWindow(overWindow) {
807
- // console.log("setDraggingOverWindow", overWindow);
808
- if (this.isDraggingOverWindow !== overWindow) {
809
- if (this.outlineDiv) {
810
- this.outlineDiv.style.visibility = overWindow ? "hidden" : "visible";
811
- }
812
- if (overWindow) {
813
- this.setState({ showEdges: false });
814
- }
815
- else {
816
- // add edge indicators
817
- if (this.props.model.getMaximizedTabset(this.windowId) === undefined) {
818
- this.setState({ showEdges: this.props.model.isEnableEdgeDock() });
819
- }
820
- }
821
- this.isDraggingOverWindow = overWindow;
822
- }
823
- }
824
- clearDragMain() {
825
- // console.log("clear drag main");
826
- LayoutInternal.dragState = undefined;
827
- if (this.windowId === Model.MAIN_WINDOW_ID) {
828
- this.isDraggingOverWindow = false;
829
- }
830
- for (const [, layoutWindow] of this.props.model.getwindowsMap()) {
831
- // console.log(layoutWindow);
832
- layoutWindow.layout.clearDragLocal();
833
- }
834
- }
835
- clearDragLocal() {
836
- // console.log("clear drag local", this.windowId);
837
- this.setState({ showEdges: false });
838
- this.showOverlay(false);
839
- this.dragEnterCount = 0;
840
- this.dragging = false;
841
- if (this.outlineDiv) {
842
- this.selfRef.current.removeChild(this.outlineDiv);
843
- this.outlineDiv = undefined;
844
- }
845
- }
846
- }
847
- LayoutInternal.dragState = undefined;
848
- export const FlexLayoutVersion = "0.8.11";
849
- const defaultIcons = {
850
- close: _jsx(CloseIcon, {}),
851
- closeTabset: _jsx(CloseIcon, {}),
852
- popout: _jsx(PopoutIcon, {}),
853
- maximize: _jsx(MaximizeIcon, {}),
854
- restore: _jsx(RestoreIcon, {}),
855
- more: _jsx(OverflowIcon, {}),
856
- edgeArrow: _jsx(EdgeIcon, {}),
857
- activeTabset: _jsx(AsterickIcon, {})
858
- };
859
- var DragSource;
860
- (function (DragSource) {
861
- DragSource["Internal"] = "internal";
862
- DragSource["External"] = "external";
863
- DragSource["Add"] = "add";
864
- })(DragSource || (DragSource = {}));
865
- /** @internal */
866
- const defaultSupportsPopout = isDesktop();
867
- /** @internal */
868
- const edgeRectLength = 100;
869
- /** @internal */
870
- const edgeRectWidth = 10;
871
- // global layout drag state
872
- class DragState {
873
- constructor(mainLayout, dragSource, dragNode, dragJson, fnNewNodeDropped) {
874
- this.mainLayout = mainLayout;
875
- this.dragSource = dragSource;
876
- this.dragNode = dragNode;
877
- this.dragJson = dragJson;
878
- this.fnNewNodeDropped = fnNewNodeDropped;
879
- }
880
- }
881
- //# sourceMappingURL=Layout.js.map