@datagrok-libraries/dock-spawn-dg 0.0.2 → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (263) hide show
  1. package/CHANGELOG.md +0 -354
  2. package/README.md +0 -3
  3. package/index.d.ts +33 -0
  4. package/index.d.ts.map +1 -0
  5. package/index.js +32 -0
  6. package/package.json +10 -17
  7. package/src/BrowserDialogHelper.d.ts.map +1 -0
  8. package/{lib → src}/BrowserDialogHelper.js +18 -12
  9. package/src/BrowserDialogHelper.ts +48 -47
  10. package/src/ContainerType.d.ts.map +1 -0
  11. package/src/ContainerType.ts +1 -1
  12. package/{lib → src}/Dialog.d.ts +7 -7
  13. package/src/Dialog.d.ts.map +1 -0
  14. package/{lib → src}/Dialog.js +46 -58
  15. package/src/Dialog.ts +253 -250
  16. package/src/DockConfig.d.ts.map +1 -0
  17. package/{lib → src}/DockConfig.js +0 -5
  18. package/src/DockConfig.ts +1 -1
  19. package/{lib → src}/DockGraphDeserializer.d.ts +6 -6
  20. package/src/DockGraphDeserializer.d.ts.map +1 -0
  21. package/src/DockGraphDeserializer.js +133 -0
  22. package/src/DockGraphDeserializer.ts +113 -108
  23. package/src/DockGraphSerializer.d.ts +14 -0
  24. package/src/DockGraphSerializer.d.ts.map +1 -0
  25. package/{lib → src}/DockGraphSerializer.js +11 -11
  26. package/src/DockGraphSerializer.ts +48 -47
  27. package/{lib → src}/DockLayoutEngine.d.ts +12 -12
  28. package/src/DockLayoutEngine.d.ts.map +1 -0
  29. package/{lib → src}/DockLayoutEngine.js +49 -53
  30. package/src/DockLayoutEngine.ts +351 -346
  31. package/{lib → src}/DockManager.d.ts +34 -34
  32. package/src/DockManager.d.ts.map +1 -0
  33. package/{lib → src}/DockManager.js +168 -151
  34. package/src/DockManager.ts +860 -834
  35. package/{lib → src}/DockManagerContext.d.ts +3 -3
  36. package/src/DockManagerContext.d.ts.map +1 -0
  37. package/{lib → src}/DockManagerContext.js +2 -5
  38. package/src/DockManagerContext.ts +5 -5
  39. package/{lib → src}/DockModel.d.ts +2 -2
  40. package/src/DockModel.d.ts.map +1 -0
  41. package/{lib → src}/DockModel.js +0 -3
  42. package/src/DockModel.ts +2 -2
  43. package/{lib → src}/DockNode.d.ts +1 -1
  44. package/src/DockNode.d.ts.map +1 -0
  45. package/{lib → src}/DockNode.js +0 -3
  46. package/src/DockNode.ts +2 -2
  47. package/{lib → src}/DockWheel.d.ts +5 -5
  48. package/src/DockWheel.d.ts.map +1 -0
  49. package/{lib → src}/DockWheel.js +3 -11
  50. package/src/DockWheel.ts +6 -6
  51. package/{lib → src}/DockWheelItem.d.ts +3 -3
  52. package/src/DockWheelItem.d.ts.map +1 -0
  53. package/{lib → src}/DockWheelItem.js +1 -8
  54. package/src/DockWheelItem.ts +4 -4
  55. package/{lib → src}/DocumentManagerContainer.d.ts +4 -4
  56. package/src/DocumentManagerContainer.d.ts.map +1 -0
  57. package/{lib → src}/DocumentManagerContainer.js +3 -3
  58. package/src/DocumentManagerContainer.ts +9 -9
  59. package/{lib → src}/DocumentTabPage.d.ts +3 -3
  60. package/src/DocumentTabPage.d.ts.map +1 -0
  61. package/{lib → src}/DocumentTabPage.js +2 -2
  62. package/src/DocumentTabPage.ts +6 -6
  63. package/{lib → src}/DraggableContainer.d.ts +7 -7
  64. package/src/DraggableContainer.d.ts.map +1 -0
  65. package/{lib → src}/DraggableContainer.js +3 -16
  66. package/src/DraggableContainer.ts +10 -10
  67. package/src/EventHandler.d.ts.map +1 -0
  68. package/{lib → src}/EventHandler.js +0 -3
  69. package/src/EventHandler.ts +1 -1
  70. package/{lib → src}/FillDockContainer.d.ts +8 -8
  71. package/src/FillDockContainer.d.ts.map +1 -0
  72. package/{lib → src}/FillDockContainer.js +4 -14
  73. package/src/FillDockContainer.ts +10 -10
  74. package/src/HorizontalDockContainer.d.ts +7 -0
  75. package/src/HorizontalDockContainer.d.ts.map +1 -0
  76. package/{lib → src}/HorizontalDockContainer.js +3 -3
  77. package/src/HorizontalDockContainer.ts +6 -6
  78. package/{lib → src}/PanelContainer.d.ts +21 -20
  79. package/src/PanelContainer.d.ts.map +1 -0
  80. package/{lib → src}/PanelContainer.js +144 -148
  81. package/src/PanelContainer.ts +590 -577
  82. package/src/Point.d.ts.map +1 -0
  83. package/{lib → src}/Point.js +0 -2
  84. package/{lib → src}/ResizableContainer.d.ts +8 -8
  85. package/src/ResizableContainer.d.ts.map +1 -0
  86. package/{lib → src}/ResizableContainer.js +4 -17
  87. package/src/ResizableContainer.ts +11 -11
  88. package/{lib → src}/ResizeHandle.d.ts +1 -1
  89. package/src/ResizeHandle.d.ts.map +1 -0
  90. package/{lib → src}/ResizeHandle.js +0 -10
  91. package/src/ResizeHandle.ts +2 -2
  92. package/{lib → src}/SplitterBar.d.ts +3 -3
  93. package/src/SplitterBar.d.ts.map +1 -0
  94. package/{lib → src}/SplitterBar.js +2 -14
  95. package/src/SplitterBar.ts +5 -5
  96. package/{lib → src}/SplitterDockContainer.d.ts +7 -7
  97. package/src/SplitterDockContainer.d.ts.map +1 -0
  98. package/{lib → src}/SplitterDockContainer.js +1 -11
  99. package/src/SplitterDockContainer.ts +8 -8
  100. package/{lib → src}/SplitterPanel.d.ts +2 -2
  101. package/src/SplitterPanel.d.ts.map +1 -0
  102. package/{lib → src}/SplitterPanel.js +2 -6
  103. package/src/SplitterPanel.ts +4 -4
  104. package/{lib → src}/TabHandle.d.ts +5 -5
  105. package/src/TabHandle.d.ts.map +1 -0
  106. package/{lib → src}/TabHandle.js +81 -95
  107. package/src/TabHandle.ts +314 -311
  108. package/{lib → src}/TabHost.d.ts +6 -6
  109. package/src/TabHost.d.ts.map +1 -0
  110. package/{lib → src}/TabHost.js +4 -19
  111. package/src/TabHost.ts +9 -9
  112. package/{lib → src}/TabPage.d.ts +4 -4
  113. package/src/TabPage.d.ts.map +1 -0
  114. package/{lib → src}/TabPage.js +3 -10
  115. package/src/TabPage.ts +6 -6
  116. package/{lib → src}/UndockInitiator.d.ts +4 -4
  117. package/src/UndockInitiator.d.ts.map +1 -0
  118. package/{lib → src}/UndockInitiator.js +2 -14
  119. package/src/UndockInitiator.ts +7 -7
  120. package/src/Utils.d.ts.map +1 -0
  121. package/{lib → src}/Utils.js +1 -1
  122. package/src/Utils.ts +1 -1
  123. package/src/VerticalDockContainer.d.ts +7 -0
  124. package/src/VerticalDockContainer.d.ts.map +1 -0
  125. package/{lib → src}/VerticalDockContainer.js +3 -3
  126. package/src/VerticalDockContainer.ts +7 -7
  127. package/src/enums/PanelType.d.ts.map +1 -0
  128. package/src/enums/PanelType.ts +1 -1
  129. package/src/enums/TabHostDirection.d.ts.map +1 -0
  130. package/src/enums/TabHostDirection.ts +1 -1
  131. package/src/enums/WheelTypes.d.ts.map +1 -0
  132. package/src/enums/WheelTypes.ts +1 -1
  133. package/src/i18n/Defaults.d.ts.map +1 -0
  134. package/src/i18n/Defaults.ts +2 -2
  135. package/{lib → src}/i18n/Localizer.d.ts +1 -1
  136. package/src/i18n/Localizer.d.ts.map +1 -0
  137. package/{lib → src}/i18n/Localizer.js +3 -3
  138. package/src/i18n/Localizer.ts +2 -2
  139. package/src/index.d.ts.map +1 -0
  140. package/{lib → src}/interfaces/IDockContainer.d.ts +4 -4
  141. package/src/interfaces/IDockContainer.d.ts.map +1 -0
  142. package/src/interfaces/IDockContainer.ts +7 -7
  143. package/src/interfaces/IDockContainerWithSize.d.ts +6 -0
  144. package/src/interfaces/IDockContainerWithSize.d.ts.map +1 -0
  145. package/src/interfaces/IDockContainerWithSize.ts +3 -3
  146. package/{lib → src}/interfaces/ILayoutEventListener.d.ts +6 -6
  147. package/src/interfaces/ILayoutEventListener.d.ts.map +1 -0
  148. package/src/interfaces/ILayoutEventListener.ts +7 -7
  149. package/src/interfaces/IMouseOrTouchEvent.d.ts.map +1 -0
  150. package/src/interfaces/IMouseOrTouchEvent.ts +1 -1
  151. package/src/interfaces/INodeInfo.d.ts +8 -0
  152. package/src/interfaces/INodeInfo.d.ts.map +1 -0
  153. package/src/interfaces/INodeInfo.ts +2 -2
  154. package/src/interfaces/IPanelInfo.d.ts +10 -0
  155. package/src/interfaces/IPanelInfo.d.ts.map +1 -0
  156. package/src/interfaces/IPanelInfo.ts +3 -3
  157. package/src/interfaces/IRectangle.d.ts.map +1 -0
  158. package/src/interfaces/IRectangle.ts +1 -1
  159. package/src/interfaces/ISize.d.ts.map +1 -0
  160. package/{lib → src}/interfaces/IState.d.ts +1 -0
  161. package/src/interfaces/IState.d.ts.map +1 -0
  162. package/src/interfaces/IState.ts +1 -0
  163. package/src/interfaces/IThickness.d.ts.map +1 -0
  164. package/src/interfaces/IThickness.ts +1 -1
  165. package/{lib → src}/webcomponent/DockSpawnTsWebcomponent.d.ts +6 -10
  166. package/src/webcomponent/DockSpawnTsWebcomponent.d.ts.map +1 -0
  167. package/src/webcomponent/DockSpawnTsWebcomponent.js +178 -0
  168. package/src/webcomponent/DockSpawnTsWebcomponent.ts +207 -243
  169. package/src/webcomponent/styles.d.ts.map +1 -0
  170. package/{lib → src}/webcomponent/styles.js +2 -1
  171. package/tsconfig.json +13 -26
  172. package/.eslintrc.json +0 -47
  173. package/lib/BrowserDialogHelper.d.ts.map +0 -1
  174. package/lib/ContainerType.d.ts.map +0 -1
  175. package/lib/Dialog.d.ts.map +0 -1
  176. package/lib/DockConfig.d.ts.map +0 -1
  177. package/lib/DockGraphDeserializer.d.ts.map +0 -1
  178. package/lib/DockGraphDeserializer.js +0 -114
  179. package/lib/DockGraphSerializer.d.ts +0 -14
  180. package/lib/DockGraphSerializer.d.ts.map +0 -1
  181. package/lib/DockLayoutEngine.d.ts.map +0 -1
  182. package/lib/DockManager.d.ts.map +0 -1
  183. package/lib/DockManagerContext.d.ts.map +0 -1
  184. package/lib/DockModel.d.ts.map +0 -1
  185. package/lib/DockNode.d.ts.map +0 -1
  186. package/lib/DockWheel.d.ts.map +0 -1
  187. package/lib/DockWheelItem.d.ts.map +0 -1
  188. package/lib/DocumentManagerContainer.d.ts.map +0 -1
  189. package/lib/DocumentTabPage.d.ts.map +0 -1
  190. package/lib/DraggableContainer.d.ts.map +0 -1
  191. package/lib/EventHandler.d.ts.map +0 -1
  192. package/lib/FillDockContainer.d.ts.map +0 -1
  193. package/lib/HorizontalDockContainer.d.ts +0 -7
  194. package/lib/HorizontalDockContainer.d.ts.map +0 -1
  195. package/lib/PanelContainer.d.ts.map +0 -1
  196. package/lib/Point.d.ts.map +0 -1
  197. package/lib/ResizableContainer.d.ts.map +0 -1
  198. package/lib/ResizeHandle.d.ts.map +0 -1
  199. package/lib/SplitterBar.d.ts.map +0 -1
  200. package/lib/SplitterDockContainer.d.ts.map +0 -1
  201. package/lib/SplitterPanel.d.ts.map +0 -1
  202. package/lib/TabHandle.d.ts.map +0 -1
  203. package/lib/TabHost.d.ts.map +0 -1
  204. package/lib/TabPage.d.ts.map +0 -1
  205. package/lib/UndockInitiator.d.ts.map +0 -1
  206. package/lib/Utils.d.ts.map +0 -1
  207. package/lib/VerticalDockContainer.d.ts +0 -7
  208. package/lib/VerticalDockContainer.d.ts.map +0 -1
  209. package/lib/enums/PanelType.d.ts.map +0 -1
  210. package/lib/enums/TabHostDirection.d.ts.map +0 -1
  211. package/lib/enums/WheelTypes.d.ts.map +0 -1
  212. package/lib/i18n/Defaults.d.ts.map +0 -1
  213. package/lib/i18n/Localizer.d.ts.map +0 -1
  214. package/lib/index.d.ts.map +0 -1
  215. package/lib/interfaces/IDockContainer.d.ts.map +0 -1
  216. package/lib/interfaces/IDockContainerWithSize.d.ts +0 -6
  217. package/lib/interfaces/IDockContainerWithSize.d.ts.map +0 -1
  218. package/lib/interfaces/ILayoutEventListener.d.ts.map +0 -1
  219. package/lib/interfaces/IMouseOrTouchEvent.d.ts.map +0 -1
  220. package/lib/interfaces/INodeInfo.d.ts +0 -8
  221. package/lib/interfaces/INodeInfo.d.ts.map +0 -1
  222. package/lib/interfaces/IPanelInfo.d.ts +0 -10
  223. package/lib/interfaces/IPanelInfo.d.ts.map +0 -1
  224. package/lib/interfaces/IRectangle.d.ts.map +0 -1
  225. package/lib/interfaces/ISize.d.ts.map +0 -1
  226. package/lib/interfaces/IState.d.ts.map +0 -1
  227. package/lib/interfaces/IThickness.d.ts.map +0 -1
  228. package/lib/webcomponent/DockSpawnTsWebcomponent.d.ts.map +0 -1
  229. package/lib/webcomponent/DockSpawnTsWebcomponent.js +0 -209
  230. package/lib/webcomponent/styles.d.ts.map +0 -1
  231. package/tsconfig.tsbuildinfo +0 -1
  232. /package/{lib → src}/BrowserDialogHelper.d.ts +0 -0
  233. /package/{lib → src}/ContainerType.d.ts +0 -0
  234. /package/{lib → src}/ContainerType.js +0 -0
  235. /package/{lib → src}/DockConfig.d.ts +0 -0
  236. /package/{lib → src}/EventHandler.d.ts +0 -0
  237. /package/{lib → src}/Point.d.ts +0 -0
  238. /package/{lib → src}/Utils.d.ts +0 -0
  239. /package/{lib → src}/enums/PanelType.d.ts +0 -0
  240. /package/{lib → src}/enums/PanelType.js +0 -0
  241. /package/{lib → src}/enums/TabHostDirection.d.ts +0 -0
  242. /package/{lib → src}/enums/TabHostDirection.js +0 -0
  243. /package/{lib → src}/enums/WheelTypes.d.ts +0 -0
  244. /package/{lib → src}/enums/WheelTypes.js +0 -0
  245. /package/{lib → src}/i18n/Defaults.d.ts +0 -0
  246. /package/{lib → src}/i18n/Defaults.js +0 -0
  247. /package/{lib → src}/index.d.ts +0 -0
  248. /package/{lib → src}/index.js +0 -0
  249. /package/{lib → src}/interfaces/IDockContainer.js +0 -0
  250. /package/{lib → src}/interfaces/IDockContainerWithSize.js +0 -0
  251. /package/{lib → src}/interfaces/ILayoutEventListener.js +0 -0
  252. /package/{lib → src}/interfaces/IMouseOrTouchEvent.d.ts +0 -0
  253. /package/{lib → src}/interfaces/IMouseOrTouchEvent.js +0 -0
  254. /package/{lib → src}/interfaces/INodeInfo.js +0 -0
  255. /package/{lib → src}/interfaces/IPanelInfo.js +0 -0
  256. /package/{lib → src}/interfaces/IRectangle.d.ts +0 -0
  257. /package/{lib → src}/interfaces/IRectangle.js +0 -0
  258. /package/{lib → src}/interfaces/ISize.d.ts +0 -0
  259. /package/{lib → src}/interfaces/ISize.js +0 -0
  260. /package/{lib → src}/interfaces/IState.js +0 -0
  261. /package/{lib → src}/interfaces/IThickness.d.ts +0 -0
  262. /package/{lib → src}/interfaces/IThickness.js +0 -0
  263. /package/{lib → src}/webcomponent/styles.d.ts +0 -0
package/src/TabHandle.ts CHANGED
@@ -1,347 +1,350 @@
1
- import {TabPage} from './TabPage.js';
2
- import {PanelContainer} from './PanelContainer.js';
3
- import {UndockInitiator} from './UndockInitiator.js';
4
- import {EventHandler} from './EventHandler.js';
5
- import {Utils} from './Utils.js';
6
- import {PanelType} from './enums/PanelType.js';
7
- import {DockNode} from './DockNode.js';
8
- import {Localizer} from './i18n/Localizer.js';
1
+ import { TabPage } from "./TabPage";
2
+ import { PanelContainer } from "./PanelContainer";
3
+ import { UndockInitiator } from "./UndockInitiator";
4
+ import { EventHandler } from "./EventHandler";
5
+ import { Utils } from "./Utils";
6
+ import { PanelType } from "./enums/PanelType";
7
+ import { DockNode } from "./DockNode";
8
+ import { Localizer } from "./i18n/Localizer";
9
9
 
10
10
  /**
11
11
  * A tab handle represents the tab button on the tab strip
12
12
  */
13
13
  export class TabHandle {
14
- parent: TabPage;
15
- elementBase: HTMLDivElement;
16
- elementText: HTMLDivElement;
17
- elementCloseButton: HTMLDivElement;
18
- undockInitiator: UndockInitiator;
19
- mouseDownHandler: EventHandler;
20
- touchDownHandler: EventHandler;
21
- closeButtonHandler: EventHandler;
22
- closeButtonTouchHandler: EventHandler;
23
- auxClickHandler: EventHandler;
24
- contextMenuHandler: EventHandler;
25
- mouseMoveHandler: EventHandler;
26
- touchMoveHandler: EventHandler;
27
- mouseUpHandler: EventHandler;
28
- touchUpHandler: EventHandler;
29
- stargDragPosition: any;
30
- dragged: boolean;
31
- eventListeners: any[];
32
- undockListener: { onDockEnabled: (e: any) => void; onHideCloseButton: (e: any) => void; };
33
-
34
- prev: number;
35
- current: number;
36
- direction: number;
37
- _ctxMenu: HTMLDivElement;
38
- _windowsContextMenuCloseBound: any;
39
-
40
- constructor(parent: TabPage) {
41
- this.parent = parent;
42
- const undockHandler = this._performUndock.bind(this);
43
- this.elementBase = document.createElement('div');
44
- this.elementText = document.createElement('div');
45
- this.elementCloseButton = document.createElement('div');
46
- this.elementBase.classList.add('dockspan-tab-handle');
47
- this.elementBase.classList.add('disable-selection'); // Disable text selection
48
- this.elementText.classList.add('dockspan-tab-handle-text');
49
- this.elementCloseButton.classList.add('dockspan-tab-handle-close-button');
50
- this.elementBase.appendChild(this.elementText);
51
- if (this.parent.host.displayCloseButton)
52
- this.elementBase.appendChild(this.elementCloseButton);
53
- if ((<PanelContainer> this.parent.container)._hideCloseButton || (<PanelContainer> this.parent.container)._grayOut)
54
- this.elementCloseButton.style.display = 'none';
55
- this.parent.host.tabListElement.appendChild(this.elementBase);
56
-
57
- const panel = parent.container as PanelContainer;
58
- const title = panel.getRawTitle();
59
- this.undockListener = {
60
- onDockEnabled: (e) => {this.undockEnabled(e.state);},
61
- onHideCloseButton: (e) => {this.hideCloseButton(e.state);},
62
- };
63
- this.eventListeners = [];
64
- panel.addListener(this.undockListener);
65
-
66
- this.elementText.innerHTML = title;
67
- this.elementText.setAttribute('dock-spawn-title', this.elementText.innerText);
68
-
69
- //this._bringToFront(this.elementBase);
70
-
71
- this.undockInitiator = new UndockInitiator(this.elementBase, undockHandler);
72
- this.undockInitiator.enabled = true;
73
- this.mouseDownHandler = new EventHandler(this.elementBase, 'mousedown', this.onMouseDown.bind(this));
74
- this.touchDownHandler = new EventHandler(this.elementBase, 'touchstart', this.onMouseDown.bind(this), {passive: false});
75
- this.closeButtonHandler = new EventHandler(this.elementCloseButton, 'click', this.onCloseButtonClicked.bind(this));
76
- this.closeButtonTouchHandler = new EventHandler(this.elementCloseButton, 'touchstart', this.onCloseButtonClicked.bind(this));
77
- this.auxClickHandler = new EventHandler(this.elementBase, 'auxclick', this.onCloseButtonClicked.bind(this));
78
-
79
- if (panel.panelType == PanelType.document)
80
- this.contextMenuHandler = new EventHandler(this.elementBase, 'contextmenu', this.oncontextMenuClicked.bind(this));
81
-
82
-
83
- this.windowsContextMenuClose = this.windowsContextMenuClose.bind(this);
84
- //this.zIndexCounter = parent.host.dockManager.zIndexTabHandle;
85
- }
86
-
87
- addListener(listener) {
88
- this.eventListeners.push(listener);
89
- }
90
-
91
- removeListener(listener) {
92
- this.eventListeners.splice(this.eventListeners.indexOf(listener), 1);
93
- }
94
-
95
- undockEnabled(state: boolean) {
96
- this.undockInitiator.enabled = state;
97
- }
98
-
99
- static createContextMenuContentCallback = (tabHandle: TabHandle, documentMangerNodes: DockNode[]): Node[] => {
100
- const result = [];
101
-
102
- const btnCloseAll = document.createElement('div');
103
- btnCloseAll.innerText = Localizer.getString('CloseAll');
104
- result.push(btnCloseAll);
105
-
106
- btnCloseAll.onclick = () => {
107
- const length = documentMangerNodes.length;
108
- for (let i = length - 1; i >= 0; i--) {
109
- const panel = (<PanelContainer>documentMangerNodes[i].container);
110
- if (panel.panelType == PanelType.document)
111
- panel.close();
112
- }
113
- tabHandle.closeContextMenu();
114
- };
115
-
116
- const btnCloseAllButThis = document.createElement('div');
117
- btnCloseAllButThis.innerText = Localizer.getString('CloseAllButThis');
118
- result.push(btnCloseAllButThis);
119
-
120
- btnCloseAllButThis.onclick = () => {
121
- const length = documentMangerNodes.length;
122
- for (let i = length - 1; i >= 0; i--) {
123
- const panel = (<PanelContainer>documentMangerNodes[i].container);
124
- if (tabHandle.parent.container != panel && panel.panelType == PanelType.document)
125
- panel.close();
126
- }
127
- tabHandle.closeContextMenu();
128
- };
129
-
130
- if (tabHandle.parent.container.dockManager.config.enableBrowserWindows) {
131
- const btnNewBrowserWindow = document.createElement('div');
132
- btnNewBrowserWindow.innerText = Localizer.getString('NewBrowserWindow');
133
- result.push(btnNewBrowserWindow);
134
-
135
- btnNewBrowserWindow.onclick = () => {
136
- (<PanelContainer>tabHandle.parent.container).undockToBrowserDialog();
137
- tabHandle.closeContextMenu();
138
- };
14
+ parent: TabPage;
15
+ elementBase: HTMLDivElement;
16
+ elementText: HTMLDivElement;
17
+ elementCloseButton: HTMLDivElement;
18
+ undockInitiator: UndockInitiator;
19
+ mouseDownHandler: EventHandler;
20
+ touchDownHandler: EventHandler;
21
+ closeButtonHandler: EventHandler;
22
+ closeButtonTouchHandler: EventHandler;
23
+ auxClickHandler: EventHandler;
24
+ contextMenuHandler: EventHandler;
25
+ mouseMoveHandler: EventHandler;
26
+ touchMoveHandler: EventHandler;
27
+ mouseUpHandler: EventHandler;
28
+ touchUpHandler: EventHandler;
29
+ stargDragPosition: any;
30
+ dragged: boolean;
31
+ eventListeners: any[];
32
+ undockListener: { onDockEnabled: (e: any) => void; onHideCloseButton: (e: any) => void; };
33
+
34
+ prev: number;
35
+ current: number;
36
+ direction: number;
37
+ _ctxMenu: HTMLDivElement;
38
+ _windowsContextMenuCloseBound: any;
39
+
40
+ constructor(parent: TabPage) {
41
+ this.parent = parent;
42
+ let undockHandler = this._performUndock.bind(this);
43
+ this.elementBase = document.createElement('div');
44
+ this.elementText = document.createElement('div');
45
+ this.elementCloseButton = document.createElement('div');
46
+ this.elementBase.classList.add('dockspan-tab-handle');
47
+ this.elementBase.classList.add('disable-selection'); // Disable text selection
48
+ this.elementText.classList.add('dockspan-tab-handle-text');
49
+ this.elementCloseButton.classList.add('dockspan-tab-handle-close-button');
50
+ this.elementBase.appendChild(this.elementText);
51
+ if (this.parent.host.displayCloseButton)
52
+ this.elementBase.appendChild(this.elementCloseButton);
53
+ if ((<PanelContainer>this.parent.container)._hideCloseButton || (<PanelContainer>this.parent.container)._grayOut)
54
+ this.elementCloseButton.style.display = 'none';
55
+ this.parent.host.tabListElement.appendChild(this.elementBase);
56
+
57
+ let panel = parent.container as PanelContainer;
58
+ let title = panel.getRawTitle();
59
+ this.undockListener = {
60
+ onDockEnabled: (e) => { this.undockEnabled(e.state); },
61
+ onHideCloseButton: (e) => { this.hideCloseButton(e.state); }
62
+ };
63
+ this.eventListeners = [];
64
+ panel.addListener(this.undockListener);
65
+
66
+ this.elementText.innerHTML = title;
67
+ this.elementText.setAttribute('dock-spawn-title', this.elementText.innerText);
68
+
69
+ //this._bringToFront(this.elementBase);
70
+
71
+ this.undockInitiator = new UndockInitiator(this.elementBase, undockHandler);
72
+ this.undockInitiator.enabled = true;
73
+ this.mouseDownHandler = new EventHandler(this.elementBase, 'mousedown', this.onMouseDown.bind(this));
74
+ this.touchDownHandler = new EventHandler(this.elementBase, 'touchstart', this.onMouseDown.bind(this), { passive: false });
75
+ this.closeButtonHandler = new EventHandler(this.elementCloseButton, 'click', this.onCloseButtonClicked.bind(this));
76
+ this.closeButtonTouchHandler = new EventHandler(this.elementCloseButton, 'touchstart', this.onCloseButtonClicked.bind(this));
77
+ this.auxClickHandler = new EventHandler(this.elementBase, 'auxclick', this.onCloseButtonClicked.bind(this));
78
+
79
+ if (panel.panelType == PanelType.document) {
80
+ this.contextMenuHandler = new EventHandler(this.elementBase, 'contextmenu', this.oncontextMenuClicked.bind(this));
81
+ }
82
+
83
+ this.windowsContextMenuClose = this.windowsContextMenuClose.bind(this);
84
+ //this.zIndexCounter = parent.host.dockManager.zIndexTabHandle;
139
85
  }
140
86
 
141
- return result;
142
- };
143
-
144
- oncontextMenuClicked(e: MouseEvent) {
145
- e.preventDefault();
146
-
147
- if (!this._ctxMenu && TabHandle.createContextMenuContentCallback) {
148
- const menuItems = TabHandle.createContextMenuContentCallback(
149
- this,
150
- this.parent.container.dockManager.context.model.documentManagerNode.children,
151
- );
152
-
153
- if (menuItems.length == 0)
154
- return;
155
-
156
-
157
- this._ctxMenu = document.createElement('div');
158
- this._ctxMenu.className = 'dockspab-tab-handle-context-menu';
159
- this._ctxMenu.append(...menuItems);
160
- this._ctxMenu.style.left = e.pageX + 'px';
161
- this._ctxMenu.style.top = e.pageY + 'px';
162
- document.body.appendChild(this._ctxMenu);
163
- window.addEventListener('mouseup', this.windowsContextMenuClose);
164
- } else
165
- this.closeContextMenu();
166
- }
167
-
168
- closeContextMenu() {
169
- if (this._ctxMenu) {
170
- document.body.removeChild(this._ctxMenu);
171
- delete this._ctxMenu;
172
- window.removeEventListener('mouseup', this.windowsContextMenuClose);
87
+ addListener(listener) {
88
+ this.eventListeners.push(listener);
173
89
  }
174
- }
175
-
176
- windowsContextMenuClose(e: Event) {
177
- const cp = e.composedPath();
178
- for (const i in cp) {
179
- const el = cp[i];
180
- if (el == this._ctxMenu)
181
- return;
90
+
91
+ removeListener(listener) {
92
+ this.eventListeners.splice(this.eventListeners.indexOf(listener), 1);
182
93
  }
183
- this.closeContextMenu();
184
- }
185
94
 
186
- onMouseDown(e) {
187
- e.preventDefault();
95
+ undockEnabled(state: boolean) {
96
+ this.undockInitiator.enabled = state;
97
+ }
188
98
 
189
- this.parent.onSelected();
99
+ static createContextMenuContentCallback = (tabHandle: TabHandle, documentMangerNodes: DockNode[]): Node[] => {
100
+ const result = [];
101
+
102
+ let btnCloseAll = document.createElement('div');
103
+ btnCloseAll.innerText = Localizer.getString('CloseAll');
104
+ result.push(btnCloseAll);
105
+
106
+ btnCloseAll.onclick = () => {
107
+ let length = documentMangerNodes.length;
108
+ for (let i = length - 1; i >= 0; i--) {
109
+ let panel = (<PanelContainer>documentMangerNodes[i].container);
110
+ if (panel.panelType == PanelType.document)
111
+ panel.close();
112
+ }
113
+ tabHandle.closeContextMenu();
114
+ };
115
+
116
+ let btnCloseAllButThis = document.createElement('div');
117
+ btnCloseAllButThis.innerText = Localizer.getString('CloseAllButThis');
118
+ result.push(btnCloseAllButThis);
119
+
120
+ btnCloseAllButThis.onclick = () => {
121
+ let length = documentMangerNodes.length;
122
+ for (let i = length - 1; i >= 0; i--) {
123
+ let panel = (<PanelContainer>documentMangerNodes[i].container);
124
+ if (tabHandle.parent.container != panel && panel.panelType == PanelType.document)
125
+ panel.close();
126
+ }
127
+ tabHandle.closeContextMenu();
128
+ };
129
+
130
+ if (tabHandle.parent.container.dockManager.config.enableBrowserWindows) {
131
+ let btnNewBrowserWindow = document.createElement('div');
132
+ btnNewBrowserWindow.innerText = Localizer.getString('NewBrowserWindow');
133
+ result.push(btnNewBrowserWindow);
134
+
135
+ btnNewBrowserWindow.onclick = () => {
136
+ (<PanelContainer>tabHandle.parent.container).undockToBrowserDialog();
137
+ tabHandle.closeContextMenu();
138
+ };
139
+ }
190
140
 
191
- if (this.mouseMoveHandler) {
192
- this.mouseMoveHandler.cancel();
193
- delete this.mouseMoveHandler;
194
- }
195
- if (this.touchMoveHandler) {
196
- this.touchMoveHandler.cancel();
197
- delete this.touchMoveHandler;
141
+ return result;
198
142
  }
199
- if (this.mouseUpHandler) {
200
- this.mouseUpHandler.cancel();
201
- delete this.mouseUpHandler;
143
+
144
+ oncontextMenuClicked(e: MouseEvent) {
145
+ e.preventDefault();
146
+
147
+ if (!this._ctxMenu && TabHandle.createContextMenuContentCallback) {
148
+ const menuItems = TabHandle.createContextMenuContentCallback(
149
+ this,
150
+ this.parent.container.dockManager.context.model.documentManagerNode.children,
151
+ );
152
+
153
+ if (menuItems.length == 0) {
154
+ return;
155
+ }
156
+
157
+ this._ctxMenu = document.createElement('div');
158
+ this._ctxMenu.className = 'dockspab-tab-handle-context-menu';
159
+ this._ctxMenu.append(...menuItems);
160
+ this._ctxMenu.style.left = e.pageX + "px";
161
+ this._ctxMenu.style.top = e.pageY + "px";
162
+ document.body.appendChild(this._ctxMenu);
163
+ window.addEventListener('mouseup', this.windowsContextMenuClose);
164
+ } else {
165
+ this.closeContextMenu();
166
+ }
202
167
  }
203
- if (this.touchUpHandler) {
204
- this.touchUpHandler.cancel();
205
- delete this.touchUpHandler;
168
+
169
+ closeContextMenu() {
170
+ if (this._ctxMenu) {
171
+ document.body.removeChild(this._ctxMenu);
172
+ delete this._ctxMenu;
173
+ window.removeEventListener('mouseup', this.windowsContextMenuClose);
174
+ }
206
175
  }
207
- this.stargDragPosition = e.clientX;
208
- this.mouseMoveHandler = new EventHandler(window, 'mousemove', this.onMouseMove.bind(this));
209
- this.touchMoveHandler = new EventHandler(window, 'touchmove', this.onMouseMove.bind(this), {passive: false});
210
- this.mouseUpHandler = new EventHandler(window, 'mouseup', this.onMouseUp.bind(this));
211
- this.touchUpHandler = new EventHandler(window, 'touchend', this.onMouseUp.bind(this));
212
- }
213
-
214
- onMouseUp(e) {
215
- if (this.elementBase)
216
- this.elementBase.classList.remove('dockspan-tab-handle-dragged');
217
-
218
- this.dragged = false;
219
- if (this.mouseMoveHandler)
220
- this.mouseMoveHandler.cancel();
221
- if (this.touchMoveHandler)
222
- this.touchMoveHandler.cancel();
223
- if (this.mouseUpHandler)
224
- this.mouseUpHandler.cancel();
225
- if (this.touchUpHandler)
226
- this.touchUpHandler.cancel();
227
- delete this.mouseMoveHandler;
228
- delete this.touchMoveHandler;
229
- delete this.mouseUpHandler;
230
- delete this.touchUpHandler;
231
- }
232
-
233
- moveTabEvent(that, state) {
234
- that.eventListeners.forEach((listener) => {
235
- if (listener.onMoveTab)
236
- listener.onMoveTab({self: that, state: state});
237
- });
238
- }
239
-
240
- onMouseMove(e) {
241
- e.preventDefault();
242
-
243
- if (Math.abs(this.stargDragPosition - e.clientX) < 10)
244
- return;
245
- if (this.elementBase != null) { //Todo: because of this is null, we need to drag 2 times, needs fix
246
- this.elementBase.classList.add('dockspan-tab-handle-dragged');
247
- this.dragged = true;
248
- this.prev = this.current;
249
- this.current = e.clientX;
250
- this.direction = this.current - this.prev;
251
- const tabRect = this.elementBase.getBoundingClientRect();
252
- const event = this.direction < 0 ?
253
- {state: 'left', bound: tabRect.left, rect: tabRect} :
254
- {state: 'right', bound: tabRect.right, rect: tabRect};
255
- if ((e.clientX < tabRect.left && this.direction < 0) || (e.clientX > tabRect.left + tabRect.width && this.direction > 0))
256
- this.moveTabEvent(this, event.state);
176
+
177
+ windowsContextMenuClose(e: Event) {
178
+ let cp = e.composedPath();
179
+ for (let i in cp) {
180
+ let el = cp[i];
181
+ if (el == this._ctxMenu)
182
+ return;
183
+ }
184
+ this.closeContextMenu();
257
185
  }
258
- }
259
186
 
260
- hideCloseButton(state) {
261
- this.elementCloseButton.style.display = state ? 'none' : 'block';
262
- }
187
+ onMouseDown(e) {
188
+ e.preventDefault();
189
+
190
+ this.parent.onSelected();
263
191
 
264
- updateTitle() {
265
- if (this.parent.container instanceof PanelContainer) {
266
- const panel = this.parent.container;
267
- const title = panel.getRawTitle();
268
- this.elementText.innerHTML = title;
192
+ if (this.mouseMoveHandler) {
193
+ this.mouseMoveHandler.cancel();
194
+ delete this.mouseMoveHandler;
195
+ }
196
+ if (this.touchMoveHandler) {
197
+ this.touchMoveHandler.cancel();
198
+ delete this.touchMoveHandler;
199
+ }
200
+ if (this.mouseUpHandler) {
201
+ this.mouseUpHandler.cancel();
202
+ delete this.mouseUpHandler;
203
+ }
204
+ if (this.touchUpHandler) {
205
+ this.touchUpHandler.cancel();
206
+ delete this.touchUpHandler;
207
+ }
208
+ this.stargDragPosition = e.clientX;
209
+ this.mouseMoveHandler = new EventHandler(window, 'mousemove', this.onMouseMove.bind(this));
210
+ this.touchMoveHandler = new EventHandler(window, 'touchmove', this.onMouseMove.bind(this), { passive: false });
211
+ this.mouseUpHandler = new EventHandler(window, 'mouseup', this.onMouseUp.bind(this));
212
+ this.touchUpHandler = new EventHandler(window, 'touchend', this.onMouseUp.bind(this));
269
213
  }
270
- }
271
214
 
272
- destroy() {
273
- const panel = this.parent.container as PanelContainer;
274
- panel.removeListener(this.undockListener);
215
+ onMouseUp(e) {
216
+ if (this.elementBase) {
217
+ this.elementBase.classList.remove('dockspan-tab-handle-dragged');
218
+ }
219
+ this.dragged = false;
220
+ if (this.mouseMoveHandler)
221
+ this.mouseMoveHandler.cancel();
222
+ if (this.touchMoveHandler)
223
+ this.touchMoveHandler.cancel();
224
+ if (this.mouseUpHandler)
225
+ this.mouseUpHandler.cancel();
226
+ if (this.touchUpHandler)
227
+ this.touchUpHandler.cancel();
228
+ delete this.mouseMoveHandler;
229
+ delete this.touchMoveHandler;
230
+ delete this.mouseUpHandler;
231
+ delete this.touchUpHandler;
232
+ }
275
233
 
276
- this.mouseDownHandler.cancel();
277
- this.touchDownHandler.cancel();
278
- this.closeButtonHandler.cancel();
279
- this.closeButtonTouchHandler.cancel();
280
- this.auxClickHandler.cancel();
234
+ moveTabEvent(that, state) {
235
+ that.eventListeners.forEach((listener) => {
236
+ if (listener.onMoveTab) {
237
+ listener.onMoveTab({ self: that, state: state });
238
+ }
239
+ });
240
+ }
281
241
 
282
- if (this.mouseMoveHandler)
283
- this.mouseMoveHandler.cancel();
242
+ onMouseMove(e) {
243
+ e.preventDefault();
244
+
245
+ if (Math.abs(this.stargDragPosition - e.clientX) < 10)
246
+ return;
247
+ if (this.elementBase != null) { //Todo: because of this is null, we need to drag 2 times, needs fix
248
+ this.elementBase.classList.add('dockspan-tab-handle-dragged');
249
+ this.dragged = true;
250
+ this.prev = this.current;
251
+ this.current = e.clientX;
252
+ this.direction = this.current - this.prev;
253
+ let tabRect = this.elementBase.getBoundingClientRect();
254
+ let event = this.direction < 0
255
+ ? { state: 'left', bound: tabRect.left, rect: tabRect }
256
+ : { state: 'right', bound: tabRect.right, rect: tabRect };
257
+ if ((e.clientX < tabRect.left && this.direction < 0) || (e.clientX > tabRect.left + tabRect.width && this.direction > 0))
258
+ this.moveTabEvent(this, event.state);
259
+ }
260
+ }
284
261
 
285
- if (this.touchMoveHandler)
286
- this.touchMoveHandler.cancel();
262
+ hideCloseButton(state) {
263
+ this.elementCloseButton.style.display = state ? 'none' : 'block';
264
+ }
287
265
 
288
- if (this.mouseUpHandler)
289
- this.mouseUpHandler.cancel();
266
+ updateTitle() {
267
+ if (this.parent.container instanceof PanelContainer) {
268
+ let panel = this.parent.container;
269
+ let title = panel.getRawTitle();
270
+ this.elementText.innerHTML = title;
271
+ }
272
+ }
290
273
 
291
- if (this.touchUpHandler)
292
- this.touchUpHandler.cancel();
274
+ destroy() {
275
+ let panel = this.parent.container as PanelContainer;
276
+ panel.removeListener(this.undockListener);
293
277
 
294
- if (this.contextMenuHandler)
295
- this.contextMenuHandler.cancel();
278
+ this.mouseDownHandler.cancel();
279
+ this.touchDownHandler.cancel();
280
+ this.closeButtonHandler.cancel();
281
+ this.closeButtonTouchHandler.cancel();
282
+ this.auxClickHandler.cancel();
296
283
 
284
+ if (this.mouseMoveHandler) {
285
+ this.mouseMoveHandler.cancel();
286
+ }
287
+ if (this.touchMoveHandler) {
288
+ this.touchMoveHandler.cancel();
289
+ }
290
+ if (this.mouseUpHandler) {
291
+ this.mouseUpHandler.cancel();
292
+ }
293
+ if (this.touchUpHandler) {
294
+ this.touchUpHandler.cancel();
295
+ }
296
+ if (this.contextMenuHandler) {
297
+ this.contextMenuHandler.cancel();
298
+ }
297
299
 
298
- if (this.elementBase) {
299
- Utils.removeNode(this.elementBase);
300
- delete this.elementBase;
301
- }
300
+ if (this.elementBase) {
301
+ Utils.removeNode(this.elementBase);
302
+ delete this.elementBase;
303
+ }
302
304
 
303
- if (this.elementCloseButton) {
304
- Utils.removeNode(this.elementCloseButton);
305
- delete this.elementCloseButton;
305
+ if (this.elementCloseButton) {
306
+ Utils.removeNode(this.elementCloseButton);
307
+ delete this.elementCloseButton;
308
+ }
306
309
  }
307
- }
308
-
309
- _performUndock(e, dragOffset) {
310
- if (this.parent.container.containerType === 'panel') {
311
- this.undockInitiator.enabled = false;
312
- const panel = this.parent.container as PanelContainer;
313
- return panel.performUndockToDialog(e, dragOffset);
314
- } else
315
- return null;
316
- }
317
-
318
- onCloseButtonClicked(e) {
319
- if (this.elementCloseButton.style.display !== 'none') {
320
- if (e.button !== 2) {
321
- // If the page contains a panel element, undock it and destroy it
310
+
311
+ _performUndock(e, dragOffset) {
322
312
  if (this.parent.container.containerType === 'panel') {
323
- const panel = this.parent.container as PanelContainer;
324
- panel.close();
313
+ this.undockInitiator.enabled = false;
314
+ let panel = this.parent.container as PanelContainer;
315
+ return panel.performUndockToDialog(e, dragOffset);
316
+ }
317
+ else
318
+ return null;
319
+ }
320
+
321
+ onCloseButtonClicked(e) {
322
+ if (this.elementCloseButton.style.display !== 'none') {
323
+ if (e.button !== 2) {
324
+ // If the page contains a panel element, undock it and destroy it
325
+ if (this.parent.container.containerType === 'panel') {
326
+ let panel = this.parent.container as PanelContainer;
327
+ panel.close();
328
+ }
329
+ }
325
330
  }
326
- }
327
331
  }
328
- }
329
-
330
- setSelected(isSelected: boolean) {
331
- if (isSelected)
332
- this.elementBase.classList.add('dockspan-tab-handle-selected');
333
- else {
334
- this.elementBase.classList.remove('dockspan-tab-handle-selected');
335
- this.elementBase.classList.remove('dockspan-tab-handle-active');
332
+
333
+ setSelected(isSelected: boolean) {
334
+ if (isSelected)
335
+ this.elementBase.classList.add('dockspan-tab-handle-selected');
336
+ else {
337
+ this.elementBase.classList.remove('dockspan-tab-handle-selected');
338
+ this.elementBase.classList.remove('dockspan-tab-handle-active');
339
+ }
336
340
  }
337
- }
338
-
339
- setActive(isActive: boolean) {
340
- if (this.elementBase) {
341
- if (isActive)
342
- this.elementBase.classList.add('dockspan-tab-handle-active');
343
- else
344
- this.elementBase.classList.remove('dockspan-tab-handle-active');
341
+
342
+ setActive(isActive: boolean) {
343
+ if (this.elementBase) {
344
+ if (isActive)
345
+ this.elementBase.classList.add('dockspan-tab-handle-active');
346
+ else
347
+ this.elementBase.classList.remove('dockspan-tab-handle-active');
348
+ }
345
349
  }
346
- }
347
350
  }