@theia/core 1.45.0 → 1.46.0-next.72

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 (1591) hide show
  1. package/README.md +6 -6
  2. package/i18n/nls.cs.json +524 -520
  3. package/i18n/nls.de.json +524 -520
  4. package/i18n/nls.es.json +524 -520
  5. package/i18n/nls.fr.json +524 -520
  6. package/i18n/nls.hu.json +524 -520
  7. package/i18n/nls.it.json +524 -520
  8. package/i18n/nls.ja.json +524 -520
  9. package/i18n/nls.json +524 -520
  10. package/i18n/nls.pl.json +524 -520
  11. package/i18n/nls.pt-br.json +524 -520
  12. package/i18n/nls.pt-pt.json +524 -520
  13. package/i18n/nls.ru.json +524 -520
  14. package/i18n/nls.zh-cn.json +524 -520
  15. package/lib/browser/about-dialog.d.ts +33 -33
  16. package/lib/browser/about-dialog.js +136 -136
  17. package/lib/browser/authentication-service.d.ts +144 -144
  18. package/lib/browser/authentication-service.js +332 -332
  19. package/lib/browser/breadcrumbs/breadcrumb-popup-container.d.ts +34 -34
  20. package/lib/browser/breadcrumbs/breadcrumb-popup-container.js +114 -114
  21. package/lib/browser/breadcrumbs/breadcrumb-renderer.d.ts +12 -12
  22. package/lib/browser/breadcrumbs/breadcrumb-renderer.js +42 -42
  23. package/lib/browser/breadcrumbs/breadcrumbs-constants.d.ts +49 -49
  24. package/lib/browser/breadcrumbs/breadcrumbs-constants.js +27 -27
  25. package/lib/browser/breadcrumbs/breadcrumbs-renderer.d.ts +43 -43
  26. package/lib/browser/breadcrumbs/breadcrumbs-renderer.js +187 -187
  27. package/lib/browser/breadcrumbs/breadcrumbs-service.d.ts +32 -32
  28. package/lib/browser/breadcrumbs/breadcrumbs-service.js +119 -119
  29. package/lib/browser/breadcrumbs/index.d.ts +5 -5
  30. package/lib/browser/breadcrumbs/index.js +32 -32
  31. package/lib/browser/browser-clipboard-service.d.ts +23 -23
  32. package/lib/browser/browser-clipboard-service.js +115 -115
  33. package/lib/browser/browser.d.ts +37 -34
  34. package/lib/browser/browser.d.ts.map +1 -1
  35. package/lib/browser/browser.js +196 -192
  36. package/lib/browser/browser.js.map +1 -1
  37. package/lib/browser/clipboard-service.d.ts +6 -6
  38. package/lib/browser/clipboard-service.js +19 -19
  39. package/lib/browser/color-application-contribution.d.ts +24 -24
  40. package/lib/browser/color-application-contribution.js +108 -108
  41. package/lib/browser/color-registry.d.ts +14 -14
  42. package/lib/browser/color-registry.js +63 -63
  43. package/lib/browser/command-open-handler.d.ts +9 -9
  44. package/lib/browser/command-open-handler.js +66 -66
  45. package/lib/browser/common-frontend-contribution.d.ts +206 -206
  46. package/lib/browser/common-frontend-contribution.d.ts.map +1 -1
  47. package/lib/browser/common-frontend-contribution.js +2307 -2307
  48. package/lib/browser/common-frontend-contribution.js.map +1 -1
  49. package/lib/browser/common-styling-participants.d.ts +27 -27
  50. package/lib/browser/common-styling-participants.js +370 -370
  51. package/lib/browser/connection-status-service.d.ts +77 -77
  52. package/lib/browser/connection-status-service.js +209 -209
  53. package/lib/browser/connection-status-service.spec.d.ts +1 -1
  54. package/lib/browser/connection-status-service.spec.js +161 -161
  55. package/lib/browser/context-key-service.d.ts +82 -83
  56. package/lib/browser/context-key-service.d.ts.map +1 -1
  57. package/lib/browser/context-key-service.js +88 -88
  58. package/lib/browser/context-key-service.js.map +1 -1
  59. package/lib/browser/context-menu-renderer.d.ts +54 -55
  60. package/lib/browser/context-menu-renderer.d.ts.map +1 -1
  61. package/lib/browser/context-menu-renderer.js +92 -96
  62. package/lib/browser/context-menu-renderer.js.map +1 -1
  63. package/lib/browser/core-preferences.d.ts +37 -36
  64. package/lib/browser/core-preferences.d.ts.map +1 -1
  65. package/lib/browser/core-preferences.js +300 -295
  66. package/lib/browser/core-preferences.js.map +1 -1
  67. package/lib/browser/credentials-service.d.ts +35 -35
  68. package/lib/browser/credentials-service.js +91 -91
  69. package/lib/browser/decoration-style.d.ts +6 -6
  70. package/lib/browser/decoration-style.js +64 -64
  71. package/lib/browser/decorations-service.d.ts +30 -30
  72. package/lib/browser/decorations-service.js +163 -163
  73. package/lib/browser/dialogs/react-dialog.d.ts +17 -17
  74. package/lib/browser/dialogs/react-dialog.js +60 -60
  75. package/lib/browser/dialogs.d.ts +135 -135
  76. package/lib/browser/dialogs.js +457 -457
  77. package/lib/browser/diff-uris.d.ts +17 -17
  78. package/lib/browser/diff-uris.js +126 -126
  79. package/lib/browser/encoding-registry.d.ts +18 -18
  80. package/lib/browser/encoding-registry.js +96 -96
  81. package/lib/browser/endpoint.d.ts +42 -42
  82. package/lib/browser/endpoint.js +120 -120
  83. package/lib/browser/endpoint.spec.d.ts +1 -1
  84. package/lib/browser/endpoint.spec.js +122 -122
  85. package/lib/browser/external-uri-service.d.ts +24 -24
  86. package/lib/browser/external-uri-service.js +77 -77
  87. package/lib/browser/frontend-application-bindings.d.ts +5 -5
  88. package/lib/browser/frontend-application-bindings.js +56 -56
  89. package/lib/browser/frontend-application-config-provider.d.ts +8 -8
  90. package/lib/browser/frontend-application-config-provider.js +46 -46
  91. package/lib/browser/frontend-application-config-provider.spec.d.ts +1 -1
  92. package/lib/browser/frontend-application-config-provider.spec.js +40 -40
  93. package/lib/browser/frontend-application-contribution.d.ts +75 -75
  94. package/lib/browser/frontend-application-contribution.js +50 -50
  95. package/lib/browser/frontend-application-module.d.ts +8 -8
  96. package/lib/browser/frontend-application-module.d.ts.map +1 -1
  97. package/lib/browser/frontend-application-module.js +354 -353
  98. package/lib/browser/frontend-application-module.js.map +1 -1
  99. package/lib/browser/frontend-application-state.d.ts +19 -19
  100. package/lib/browser/frontend-application-state.js +79 -79
  101. package/lib/browser/frontend-application.d.ts +86 -86
  102. package/lib/browser/frontend-application.js +319 -319
  103. package/lib/browser/hover-service.d.ts +50 -50
  104. package/lib/browser/hover-service.js +207 -207
  105. package/lib/browser/http-open-handler.d.ts +14 -14
  106. package/lib/browser/http-open-handler.js +54 -54
  107. package/lib/browser/i18n/i18n-frontend-module.d.ts +3 -3
  108. package/lib/browser/i18n/i18n-frontend-module.js +25 -25
  109. package/lib/browser/i18n/language-quick-pick-service.d.ts +15 -15
  110. package/lib/browser/i18n/language-quick-pick-service.js +144 -144
  111. package/lib/browser/icon-registry.d.ts +56 -62
  112. package/lib/browser/icon-registry.d.ts.map +1 -1
  113. package/lib/browser/icon-registry.js +24 -24
  114. package/lib/browser/icon-registry.js.map +1 -1
  115. package/lib/browser/icon-theme-contribution.d.ts +23 -23
  116. package/lib/browser/icon-theme-contribution.js +72 -72
  117. package/lib/browser/icon-theme-service.d.ts +63 -63
  118. package/lib/browser/icon-theme-service.js +206 -206
  119. package/lib/browser/index.d.ts +31 -31
  120. package/lib/browser/index.js +58 -58
  121. package/lib/browser/json-schema-store.d.ts +37 -37
  122. package/lib/browser/json-schema-store.js +119 -119
  123. package/lib/browser/keybinding.d.ts +288 -288
  124. package/lib/browser/keybinding.js +682 -682
  125. package/lib/browser/keybinding.spec.d.ts +1 -1
  126. package/lib/browser/keybinding.spec.js +456 -456
  127. package/lib/browser/keyboard/browser-keyboard-frontend-contribution.d.ts +13 -13
  128. package/lib/browser/keyboard/browser-keyboard-frontend-contribution.js +118 -118
  129. package/lib/browser/keyboard/browser-keyboard-layout-provider.d.ts +91 -91
  130. package/lib/browser/keyboard/browser-keyboard-layout-provider.js +426 -426
  131. package/lib/browser/keyboard/browser-keyboard-layout-provider.spec.d.ts +1 -1
  132. package/lib/browser/keyboard/browser-keyboard-layout-provider.spec.js +157 -157
  133. package/lib/browser/keyboard/browser-keyboard-module.d.ts +3 -3
  134. package/lib/browser/keyboard/browser-keyboard-module.js +30 -30
  135. package/lib/browser/keyboard/index.d.ts +4 -4
  136. package/lib/browser/keyboard/index.js +31 -31
  137. package/lib/browser/keyboard/keyboard-layout-service.d.ts +49 -49
  138. package/lib/browser/keyboard/keyboard-layout-service.js +435 -435
  139. package/lib/browser/keyboard/keyboard-layout-service.spec.d.ts +1 -1
  140. package/lib/browser/keyboard/keyboard-layout-service.spec.js +115 -115
  141. package/lib/browser/keyboard/keys.d.ts +4 -4
  142. package/lib/browser/keyboard/keys.js +31 -31
  143. package/lib/browser/keyboard/keys.spec.d.ts +1 -1
  144. package/lib/browser/keyboard/keys.spec.js +205 -205
  145. package/lib/browser/keys.d.ts +2 -2
  146. package/lib/browser/keys.js +28 -28
  147. package/lib/browser/label-parser.d.ts +34 -34
  148. package/lib/browser/label-parser.js +112 -112
  149. package/lib/browser/label-parser.spec.d.ts +1 -1
  150. package/lib/browser/label-parser.spec.js +146 -146
  151. package/lib/browser/label-provider.d.ts +140 -140
  152. package/lib/browser/label-provider.js +318 -318
  153. package/lib/browser/label-provider.spec.d.ts +1 -1
  154. package/lib/browser/label-provider.spec.js +53 -53
  155. package/lib/browser/language-icon-provider.d.ts +14 -14
  156. package/lib/browser/language-icon-provider.js +73 -73
  157. package/lib/browser/language-service.d.ts +38 -38
  158. package/lib/browser/language-service.js +71 -71
  159. package/lib/browser/logger-frontend-module.d.ts +2 -2
  160. package/lib/browser/logger-frontend-module.js +63 -63
  161. package/lib/browser/markdown-rendering/markdown-renderer.d.ts +39 -39
  162. package/lib/browser/markdown-rendering/markdown-renderer.d.ts.map +1 -1
  163. package/lib/browser/markdown-rendering/markdown-renderer.js +80 -80
  164. package/lib/browser/menu/browser-context-menu-renderer.d.ts +12 -12
  165. package/lib/browser/menu/browser-context-menu-renderer.js +61 -61
  166. package/lib/browser/menu/browser-menu-module.d.ts +3 -3
  167. package/lib/browser/menu/browser-menu-module.js +28 -28
  168. package/lib/browser/menu/browser-menu-plugin.d.ts +103 -103
  169. package/lib/browser/menu/browser-menu-plugin.js +450 -450
  170. package/lib/browser/menu/context-menu-context.d.ts +7 -7
  171. package/lib/browser/menu/context-menu-context.js +50 -50
  172. package/lib/browser/messaging/connection-source.d.ts +8 -8
  173. package/lib/browser/messaging/connection-source.js +19 -19
  174. package/lib/browser/messaging/frontend-id-provider.d.ts +12 -12
  175. package/lib/browser/messaging/frontend-id-provider.js +39 -39
  176. package/lib/browser/messaging/index.d.ts +1 -1
  177. package/lib/browser/messaging/index.js +28 -28
  178. package/lib/browser/messaging/messaging-frontend-module.d.ts +2 -2
  179. package/lib/browser/messaging/messaging-frontend-module.js +41 -41
  180. package/lib/browser/messaging/service-connection-provider.d.ts +47 -47
  181. package/lib/browser/messaging/service-connection-provider.js +114 -114
  182. package/lib/browser/messaging/ws-connection-provider.d.ts +12 -12
  183. package/lib/browser/messaging/ws-connection-provider.js +57 -57
  184. package/lib/browser/messaging/ws-connection-source.d.ts +42 -40
  185. package/lib/browser/messaging/ws-connection-source.d.ts.map +1 -1
  186. package/lib/browser/messaging/ws-connection-source.js +225 -209
  187. package/lib/browser/messaging/ws-connection-source.js.map +1 -1
  188. package/lib/browser/mime-service.d.ts +7 -7
  189. package/lib/browser/mime-service.js +35 -35
  190. package/lib/browser/navigatable-types.d.ts +33 -33
  191. package/lib/browser/navigatable-types.js +63 -63
  192. package/lib/browser/navigatable.d.ts +8 -8
  193. package/lib/browser/navigatable.js +47 -47
  194. package/lib/browser/opener-service.d.ts +79 -79
  195. package/lib/browser/opener-service.js +90 -90
  196. package/lib/browser/opener-service.spec.d.ts +1 -1
  197. package/lib/browser/opener-service.spec.js +46 -46
  198. package/lib/browser/performance/frontend-stopwatch.d.ts +20 -20
  199. package/lib/browser/performance/frontend-stopwatch.js +74 -74
  200. package/lib/browser/performance/index.d.ts +2 -2
  201. package/lib/browser/performance/index.js +29 -29
  202. package/lib/browser/performance/measurement-frontend-bindings.d.ts +19 -19
  203. package/lib/browser/performance/measurement-frontend-bindings.js +32 -32
  204. package/lib/browser/preferences/index.d.ts +7 -7
  205. package/lib/browser/preferences/index.js +34 -34
  206. package/lib/browser/preferences/injectable-preference-proxy.d.ts +51 -51
  207. package/lib/browser/preferences/injectable-preference-proxy.js +284 -284
  208. package/lib/browser/preferences/preference-configurations.d.ts +22 -22
  209. package/lib/browser/preferences/preference-configurations.js +80 -80
  210. package/lib/browser/preferences/preference-contribution.d.ts +111 -111
  211. package/lib/browser/preferences/preference-contribution.js +394 -394
  212. package/lib/browser/preferences/preference-language-override-service.d.ts +39 -39
  213. package/lib/browser/preferences/preference-language-override-service.js +112 -112
  214. package/lib/browser/preferences/preference-provider.d.ts +132 -132
  215. package/lib/browser/preferences/preference-provider.js +227 -227
  216. package/lib/browser/preferences/preference-provider.spec.d.ts +1 -1
  217. package/lib/browser/preferences/preference-provider.spec.js +33 -33
  218. package/lib/browser/preferences/preference-proxy.d.ts +150 -150
  219. package/lib/browser/preferences/preference-proxy.js +229 -229
  220. package/lib/browser/preferences/preference-proxy.spec.d.ts +1 -1
  221. package/lib/browser/preferences/preference-proxy.spec.js +337 -337
  222. package/lib/browser/preferences/preference-schema-provider.spec.d.ts +1 -1
  223. package/lib/browser/preferences/preference-schema-provider.spec.js +115 -115
  224. package/lib/browser/preferences/preference-scope.d.ts +2 -2
  225. package/lib/browser/preferences/preference-scope.js +20 -20
  226. package/lib/browser/preferences/preference-service.d.ts +278 -278
  227. package/lib/browser/preferences/preference-service.js +358 -358
  228. package/lib/browser/preferences/preference-service.spec.d.ts +1 -1
  229. package/lib/browser/preferences/preference-service.spec.js +505 -505
  230. package/lib/browser/preferences/preference-validation-service.d.ts +57 -57
  231. package/lib/browser/preferences/preference-validation-service.js +354 -354
  232. package/lib/browser/preferences/preference-validation-service.spec.d.ts +1 -1
  233. package/lib/browser/preferences/preference-validation-service.spec.js +330 -330
  234. package/lib/browser/preferences/test/index.d.ts +3 -3
  235. package/lib/browser/preferences/test/index.js +30 -30
  236. package/lib/browser/preferences/test/mock-preference-provider.d.ts +16 -16
  237. package/lib/browser/preferences/test/mock-preference-provider.js +46 -46
  238. package/lib/browser/preferences/test/mock-preference-proxy.d.ts +3 -3
  239. package/lib/browser/preferences/test/mock-preference-proxy.js +49 -49
  240. package/lib/browser/preferences/test/mock-preference-service.d.ts +28 -28
  241. package/lib/browser/preferences/test/mock-preference-service.js +67 -67
  242. package/lib/browser/preload/i18n-preload-contribution.d.ts +6 -6
  243. package/lib/browser/preload/i18n-preload-contribution.js +62 -62
  244. package/lib/browser/preload/os-preload-contribution.d.ts +6 -6
  245. package/lib/browser/preload/os-preload-contribution.js +48 -48
  246. package/lib/browser/preload/preload-module.d.ts +3 -3
  247. package/lib/browser/preload/preload-module.js +38 -38
  248. package/lib/browser/preload/preloader.d.ts +11 -11
  249. package/lib/browser/preload/preloader.js +44 -44
  250. package/lib/browser/preload/theme-preload-contribution.d.ts +4 -4
  251. package/lib/browser/preload/theme-preload-contribution.js +39 -39
  252. package/lib/browser/progress-bar-factory.d.ts +11 -11
  253. package/lib/browser/progress-bar-factory.js +20 -20
  254. package/lib/browser/progress-bar.d.ts +15 -15
  255. package/lib/browser/progress-bar.js +89 -89
  256. package/lib/browser/progress-client.d.ts +12 -12
  257. package/lib/browser/progress-client.js +61 -61
  258. package/lib/browser/progress-location-service.d.ts +21 -21
  259. package/lib/browser/progress-location-service.js +96 -96
  260. package/lib/browser/progress-location-service.spec.d.ts +1 -1
  261. package/lib/browser/progress-location-service.spec.js +44 -44
  262. package/lib/browser/progress-status-bar-item.d.ts +16 -16
  263. package/lib/browser/progress-status-bar-item.js +89 -89
  264. package/lib/browser/quick-input/index.d.ts +8 -8
  265. package/lib/browser/quick-input/index.js +35 -35
  266. package/lib/browser/quick-input/quick-access.d.ts +53 -53
  267. package/lib/browser/quick-input/quick-access.js +20 -20
  268. package/lib/browser/quick-input/quick-command-frontend-contribution.d.ts +11 -11
  269. package/lib/browser/quick-input/quick-command-frontend-contribution.js +104 -104
  270. package/lib/browser/quick-input/quick-command-service.d.ts +59 -59
  271. package/lib/browser/quick-input/quick-command-service.js +233 -233
  272. package/lib/browser/quick-input/quick-help-service.d.ts +11 -11
  273. package/lib/browser/quick-input/quick-help-service.js +91 -91
  274. package/lib/browser/quick-input/quick-input-frontend-contribution.d.ts +7 -7
  275. package/lib/browser/quick-input/quick-input-frontend-contribution.js +46 -46
  276. package/lib/browser/quick-input/quick-input-service.d.ts +1 -1
  277. package/lib/browser/quick-input/quick-input-service.js +28 -28
  278. package/lib/browser/quick-input/quick-input-service.spec.d.ts +1 -1
  279. package/lib/browser/quick-input/quick-input-service.spec.js +159 -159
  280. package/lib/browser/quick-input/quick-pick-service-impl.d.ts +30 -30
  281. package/lib/browser/quick-input/quick-pick-service-impl.js +77 -77
  282. package/lib/browser/quick-input/quick-view-service.d.ts +23 -23
  283. package/lib/browser/quick-input/quick-view-service.js +86 -86
  284. package/lib/browser/request/browser-request-module.d.ts +18 -18
  285. package/lib/browser/request/browser-request-module.js +23 -23
  286. package/lib/browser/request/browser-request-service.d.ts +41 -41
  287. package/lib/browser/request/browser-request-service.js +180 -180
  288. package/lib/browser/resource-context-key.d.ts +19 -19
  289. package/lib/browser/resource-context-key.js +83 -83
  290. package/lib/browser/save-resource-service.d.ts +35 -35
  291. package/lib/browser/save-resource-service.d.ts.map +1 -1
  292. package/lib/browser/save-resource-service.js +72 -71
  293. package/lib/browser/save-resource-service.js.map +1 -1
  294. package/lib/browser/saveable.d.ts +124 -124
  295. package/lib/browser/saveable.js +274 -274
  296. package/lib/browser/secondary-window-handler.d.ts +64 -64
  297. package/lib/browser/secondary-window-handler.js +208 -208
  298. package/lib/browser/shell/additional-views-menu-widget.d.ts +19 -19
  299. package/lib/browser/shell/additional-views-menu-widget.js +81 -81
  300. package/lib/browser/shell/application-shell-mouse-tracker.d.ts +30 -30
  301. package/lib/browser/shell/application-shell-mouse-tracker.js +107 -107
  302. package/lib/browser/shell/application-shell.d.ts +572 -572
  303. package/lib/browser/shell/application-shell.d.ts.map +1 -1
  304. package/lib/browser/shell/application-shell.js +1995 -1990
  305. package/lib/browser/shell/application-shell.js.map +1 -1
  306. package/lib/browser/shell/current-widget-command-adapter.d.ts +23 -23
  307. package/lib/browser/shell/current-widget-command-adapter.js +41 -41
  308. package/lib/browser/shell/index.d.ts +7 -7
  309. package/lib/browser/shell/index.js +34 -34
  310. package/lib/browser/shell/shell-layout-restorer.d.ts +123 -123
  311. package/lib/browser/shell/shell-layout-restorer.js +347 -347
  312. package/lib/browser/shell/side-panel-handler.d.ts +286 -286
  313. package/lib/browser/shell/side-panel-handler.js +667 -667
  314. package/lib/browser/shell/side-panel-toolbar.d.ts +25 -25
  315. package/lib/browser/shell/side-panel-toolbar.js +96 -96
  316. package/lib/browser/shell/sidebar-bottom-menu-widget.d.ts +9 -9
  317. package/lib/browser/shell/sidebar-bottom-menu-widget.js +46 -46
  318. package/lib/browser/shell/sidebar-menu-widget.d.ts +38 -38
  319. package/lib/browser/shell/sidebar-menu-widget.js +121 -121
  320. package/lib/browser/shell/sidebar-top-menu-widget.d.ts +6 -6
  321. package/lib/browser/shell/sidebar-top-menu-widget.js +35 -35
  322. package/lib/browser/shell/split-panels.d.ts +42 -42
  323. package/lib/browser/shell/split-panels.js +177 -177
  324. package/lib/browser/shell/tab-bar-decorator.d.ts +40 -35
  325. package/lib/browser/shell/tab-bar-decorator.d.ts.map +1 -1
  326. package/lib/browser/shell/tab-bar-decorator.js +95 -64
  327. package/lib/browser/shell/tab-bar-decorator.js.map +1 -1
  328. package/lib/browser/shell/tab-bar-toolbar/index.d.ts +3 -3
  329. package/lib/browser/shell/tab-bar-toolbar/index.js +30 -30
  330. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-menu-adapters.d.ts +15 -15
  331. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-menu-adapters.js +35 -35
  332. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-registry.d.ts +95 -95
  333. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-registry.js +253 -253
  334. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-types.d.ts +136 -136
  335. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-types.js +88 -88
  336. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.d.ts +88 -88
  337. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.js +417 -417
  338. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.spec.d.ts +1 -1
  339. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.spec.js +51 -51
  340. package/lib/browser/shell/tab-bars.d.ts +339 -338
  341. package/lib/browser/shell/tab-bars.d.ts.map +1 -1
  342. package/lib/browser/shell/tab-bars.js +1309 -1277
  343. package/lib/browser/shell/tab-bars.js.map +1 -1
  344. package/lib/browser/shell/tab-bars.spec.d.ts +1 -1
  345. package/lib/browser/shell/tab-bars.spec.js +56 -56
  346. package/lib/browser/shell/theia-dock-panel.d.ts +59 -59
  347. package/lib/browser/shell/theia-dock-panel.js +226 -226
  348. package/lib/browser/shell/view-contribution.d.ts +43 -43
  349. package/lib/browser/shell/view-contribution.js +167 -167
  350. package/lib/browser/source-tree/index.d.ts +3 -3
  351. package/lib/browser/source-tree/index.js +30 -30
  352. package/lib/browser/source-tree/source-tree-widget.d.ts +21 -21
  353. package/lib/browser/source-tree/source-tree-widget.js +118 -118
  354. package/lib/browser/source-tree/source-tree.d.ts +36 -36
  355. package/lib/browser/source-tree/source-tree.js +134 -134
  356. package/lib/browser/source-tree/tree-source.d.ts +35 -35
  357. package/lib/browser/source-tree/tree-source.js +64 -64
  358. package/lib/browser/status-bar/index.d.ts +5 -5
  359. package/lib/browser/status-bar/index.js +40 -40
  360. package/lib/browser/status-bar/status-bar-types.d.ts +72 -72
  361. package/lib/browser/status-bar/status-bar-types.js +25 -25
  362. package/lib/browser/status-bar/status-bar-view-model.d.ts +35 -35
  363. package/lib/browser/status-bar/status-bar-view-model.js +212 -212
  364. package/lib/browser/status-bar/status-bar.d.ts +34 -34
  365. package/lib/browser/status-bar/status-bar.js +192 -192
  366. package/lib/browser/storage-service.d.ts +35 -35
  367. package/lib/browser/storage-service.js +130 -130
  368. package/lib/browser/storage-service.spec.d.ts +1 -1
  369. package/lib/browser/storage-service.spec.js +68 -68
  370. package/lib/browser/styling-service.d.ts +28 -28
  371. package/lib/browser/styling-service.js +85 -85
  372. package/lib/browser/supported-encodings.d.ts +9 -9
  373. package/lib/browser/supported-encodings.js +263 -263
  374. package/lib/browser/test/jsdom.d.ts +8 -8
  375. package/lib/browser/test/jsdom.js +69 -69
  376. package/lib/browser/test/mock-connection-status-service.d.ts +5 -5
  377. package/lib/browser/test/mock-connection-status-service.js +32 -32
  378. package/lib/browser/test/mock-env-variables-server.d.ts +12 -12
  379. package/lib/browser/test/mock-env-variables-server.js +42 -42
  380. package/lib/browser/test/mock-opener-service.d.ts +8 -8
  381. package/lib/browser/test/mock-opener-service.js +40 -40
  382. package/lib/browser/test/mock-storage-service.d.ts +11 -11
  383. package/lib/browser/test/mock-storage-service.js +54 -54
  384. package/lib/browser/theming.d.ts +50 -50
  385. package/lib/browser/theming.js +211 -211
  386. package/lib/browser/tooltip-service.d.ts +34 -34
  387. package/lib/browser/tooltip-service.js +87 -87
  388. package/lib/browser/tooltip-service.js.map +1 -1
  389. package/lib/browser/tree/fuzzy-search.d.ts +60 -60
  390. package/lib/browser/tree/fuzzy-search.js +80 -80
  391. package/lib/browser/tree/fuzzy-search.spec.d.ts +1 -1
  392. package/lib/browser/tree/fuzzy-search.spec.js +89 -89
  393. package/lib/browser/tree/index.d.ts +13 -12
  394. package/lib/browser/tree/index.d.ts.map +1 -1
  395. package/lib/browser/tree/index.js +40 -39
  396. package/lib/browser/tree/index.js.map +1 -1
  397. package/lib/browser/tree/search-box-debounce.d.ts +33 -33
  398. package/lib/browser/tree/search-box-debounce.js +75 -75
  399. package/lib/browser/tree/search-box.d.ts +105 -105
  400. package/lib/browser/tree/search-box.js +265 -265
  401. package/lib/browser/tree/test/mock-selectable-tree-model.d.ts +15 -0
  402. package/lib/browser/tree/test/mock-selectable-tree-model.d.ts.map +1 -0
  403. package/lib/browser/tree/test/mock-selectable-tree-model.js +103 -0
  404. package/lib/browser/tree/test/mock-selectable-tree-model.js.map +1 -0
  405. package/lib/browser/tree/test/mock-tree-model.d.ts +12 -12
  406. package/lib/browser/tree/test/mock-tree-model.js +129 -129
  407. package/lib/browser/tree/test/tree-test-container.d.ts +2 -2
  408. package/lib/browser/tree/test/tree-test-container.js +52 -52
  409. package/lib/browser/tree/tree-compression/compressed-tree-expansion-service.d.ts +8 -8
  410. package/lib/browser/tree/tree-compression/compressed-tree-expansion-service.js +67 -67
  411. package/lib/browser/tree/tree-compression/compressed-tree-model.d.ts +23 -23
  412. package/lib/browser/tree/tree-compression/compressed-tree-model.js +97 -97
  413. package/lib/browser/tree/tree-compression/compressed-tree-widget.d.ts +38 -38
  414. package/lib/browser/tree/tree-compression/compressed-tree-widget.js +198 -198
  415. package/lib/browser/tree/tree-compression/index.d.ts +4 -4
  416. package/lib/browser/tree/tree-compression/index.js +31 -31
  417. package/lib/browser/tree/tree-compression/tree-compression-service.d.ts +58 -58
  418. package/lib/browser/tree/tree-compression/tree-compression-service.js +103 -103
  419. package/lib/browser/tree/tree-consistency.spec.d.ts +1 -1
  420. package/lib/browser/tree/tree-consistency.spec.js +104 -104
  421. package/lib/browser/tree/tree-container.d.ts +51 -51
  422. package/lib/browser/tree/tree-container.js +115 -115
  423. package/lib/browser/tree/tree-container.spec.d.ts +1 -1
  424. package/lib/browser/tree/tree-container.spec.js +45 -45
  425. package/lib/browser/tree/tree-decorator.d.ts +143 -143
  426. package/lib/browser/tree/tree-decorator.js +123 -123
  427. package/lib/browser/tree/tree-decorator.spec.d.ts +1 -1
  428. package/lib/browser/tree/tree-decorator.spec.js +145 -145
  429. package/lib/browser/tree/tree-expansion.d.ts +65 -65
  430. package/lib/browser/tree/tree-expansion.js +132 -132
  431. package/lib/browser/tree/tree-expansion.spec.d.ts +1 -1
  432. package/lib/browser/tree/tree-expansion.spec.js +155 -155
  433. package/lib/browser/tree/tree-focus-service.d.ts +19 -19
  434. package/lib/browser/tree/tree-focus-service.js +61 -61
  435. package/lib/browser/tree/tree-iterator.d.ts +94 -94
  436. package/lib/browser/tree/tree-iterator.js +223 -223
  437. package/lib/browser/tree/tree-iterator.spec.d.ts +1 -1
  438. package/lib/browser/tree/tree-iterator.spec.js +150 -150
  439. package/lib/browser/tree/tree-label-provider.d.ts +8 -8
  440. package/lib/browser/tree/tree-label-provider.js +44 -44
  441. package/lib/browser/tree/tree-model.d.ts +202 -178
  442. package/lib/browser/tree/tree-model.d.ts.map +1 -1
  443. package/lib/browser/tree/tree-model.js +403 -357
  444. package/lib/browser/tree/tree-model.js.map +1 -1
  445. package/lib/browser/tree/tree-navigation.d.ts +10 -10
  446. package/lib/browser/tree/tree-navigation.js +62 -62
  447. package/lib/browser/tree/tree-preference.d.ts +11 -0
  448. package/lib/browser/tree/tree-preference.d.ts.map +1 -0
  449. package/lib/browser/tree/tree-preference.js +47 -0
  450. package/lib/browser/tree/tree-preference.js.map +1 -0
  451. package/lib/browser/tree/tree-search.d.ts +36 -36
  452. package/lib/browser/tree/tree-search.js +138 -138
  453. package/lib/browser/tree/tree-selectable.spec.d.ts +2 -0
  454. package/lib/browser/tree/tree-selectable.spec.d.ts.map +1 -0
  455. package/lib/browser/tree/tree-selectable.spec.js +147 -0
  456. package/lib/browser/tree/tree-selectable.spec.js.map +1 -0
  457. package/lib/browser/tree/tree-selection-impl.d.ts +44 -44
  458. package/lib/browser/tree/tree-selection-impl.js +166 -166
  459. package/lib/browser/tree/tree-selection-state.d.ts +48 -48
  460. package/lib/browser/tree/tree-selection-state.js +227 -227
  461. package/lib/browser/tree/tree-selection-state.spec.d.ts +1 -1
  462. package/lib/browser/tree/tree-selection-state.spec.js +420 -420
  463. package/lib/browser/tree/tree-selection.d.ts +86 -86
  464. package/lib/browser/tree/tree-selection.js +86 -86
  465. package/lib/browser/tree/tree-view-welcome-widget.d.ts +45 -45
  466. package/lib/browser/tree/tree-view-welcome-widget.js +200 -200
  467. package/lib/browser/tree/tree-widget-selection.d.ts +11 -11
  468. package/lib/browser/tree/tree-widget-selection.js +46 -46
  469. package/lib/browser/tree/tree-widget.d.ts +559 -556
  470. package/lib/browser/tree/tree-widget.d.ts.map +1 -1
  471. package/lib/browser/tree/tree-widget.js +1363 -1342
  472. package/lib/browser/tree/tree-widget.js.map +1 -1
  473. package/lib/browser/tree/tree.d.ts +180 -180
  474. package/lib/browser/tree/tree.d.ts.map +1 -1
  475. package/lib/browser/tree/tree.js +296 -293
  476. package/lib/browser/tree/tree.js.map +1 -1
  477. package/lib/browser/tree/tree.spec.d.ts +1 -1
  478. package/lib/browser/tree/tree.spec.js +226 -226
  479. package/lib/browser/user-working-directory-provider.d.ts +23 -23
  480. package/lib/browser/user-working-directory-provider.js +84 -84
  481. package/lib/browser/view-container.d.ts +312 -312
  482. package/lib/browser/view-container.js +1466 -1466
  483. package/lib/browser/widget-decoration.d.ts +299 -299
  484. package/lib/browser/widget-decoration.js +140 -140
  485. package/lib/browser/widget-manager.d.ts +172 -163
  486. package/lib/browser/widget-manager.d.ts.map +1 -1
  487. package/lib/browser/widget-manager.js +230 -207
  488. package/lib/browser/widget-manager.js.map +1 -1
  489. package/lib/browser/widget-manager.spec.d.ts +1 -1
  490. package/lib/browser/widget-manager.spec.js +91 -91
  491. package/lib/browser/widget-open-handler.d.ts +88 -88
  492. package/lib/browser/widget-open-handler.js +145 -145
  493. package/lib/browser/widgets/alert-message.d.ts +23 -23
  494. package/lib/browser/widgets/alert-message.js +38 -38
  495. package/lib/browser/widgets/enhanced-preview-widget.d.ts +6 -6
  496. package/lib/browser/widgets/enhanced-preview-widget.js +26 -26
  497. package/lib/browser/widgets/extractable-widget.d.ts +13 -13
  498. package/lib/browser/widgets/extractable-widget.js +26 -26
  499. package/lib/browser/widgets/index.d.ts +4 -4
  500. package/lib/browser/widgets/index.js +31 -31
  501. package/lib/browser/widgets/previewable-widget.d.ts +8 -8
  502. package/lib/browser/widgets/previewable-widget.js +30 -30
  503. package/lib/browser/widgets/react-renderer.d.ts +14 -14
  504. package/lib/browser/widgets/react-renderer.js +59 -59
  505. package/lib/browser/widgets/react-widget.d.ts +16 -16
  506. package/lib/browser/widgets/react-widget.js +57 -57
  507. package/lib/browser/widgets/select-component.d.ts +53 -53
  508. package/lib/browser/widgets/select-component.d.ts.map +1 -1
  509. package/lib/browser/widgets/select-component.js +307 -306
  510. package/lib/browser/widgets/select-component.js.map +1 -1
  511. package/lib/browser/widgets/widget.d.ts +108 -106
  512. package/lib/browser/widgets/widget.d.ts.map +1 -1
  513. package/lib/browser/widgets/widget.js +385 -377
  514. package/lib/browser/widgets/widget.js.map +1 -1
  515. package/lib/browser/window/browser-window-module.d.ts +3 -3
  516. package/lib/browser/window/browser-window-module.js +32 -32
  517. package/lib/browser/window/default-secondary-window-service.d.ts +25 -25
  518. package/lib/browser/window/default-secondary-window-service.js +198 -198
  519. package/lib/browser/window/default-window-service.d.ts +49 -49
  520. package/lib/browser/window/default-window-service.js +172 -172
  521. package/lib/browser/window/default-window-service.spec.d.ts +1 -1
  522. package/lib/browser/window/default-window-service.spec.js +80 -80
  523. package/lib/browser/window/secondary-window-service.d.ts +20 -20
  524. package/lib/browser/window/secondary-window-service.js +19 -19
  525. package/lib/browser/window/test/mock-window-service.d.ts +10 -10
  526. package/lib/browser/window/test/mock-window-service.js +38 -38
  527. package/lib/browser/window/window-service.d.ts +45 -45
  528. package/lib/browser/window/window-service.js +22 -22
  529. package/lib/browser/window/window-title-service.d.ts +31 -31
  530. package/lib/browser/window/window-title-service.js +120 -120
  531. package/lib/browser/window/window-title-updater.d.ts +19 -19
  532. package/lib/browser/window/window-title-updater.js +107 -107
  533. package/lib/browser/window-contribution.d.ts +14 -14
  534. package/lib/browser/window-contribution.js +70 -70
  535. package/lib/browser-only/frontend-only-application-module.d.ts +5 -0
  536. package/lib/browser-only/frontend-only-application-module.d.ts.map +1 -0
  537. package/lib/browser-only/frontend-only-application-module.js +115 -0
  538. package/lib/browser-only/frontend-only-application-module.js.map +1 -0
  539. package/lib/browser-only/i18n/i18n-frontend-only-module.d.ts +4 -0
  540. package/lib/browser-only/i18n/i18n-frontend-only-module.d.ts.map +1 -0
  541. package/lib/browser-only/i18n/i18n-frontend-only-module.js +35 -0
  542. package/lib/browser-only/i18n/i18n-frontend-only-module.js.map +1 -0
  543. package/lib/browser-only/logger-frontend-only-module.d.ts +3 -0
  544. package/lib/browser-only/logger-frontend-only-module.d.ts.map +1 -0
  545. package/lib/browser-only/logger-frontend-only-module.js +61 -0
  546. package/lib/browser-only/logger-frontend-only-module.js.map +1 -0
  547. package/lib/browser-only/messaging/frontend-only-service-connection-provider.d.ts +14 -0
  548. package/lib/browser-only/messaging/frontend-only-service-connection-provider.d.ts.map +1 -0
  549. package/lib/browser-only/messaging/frontend-only-service-connection-provider.js +57 -0
  550. package/lib/browser-only/messaging/frontend-only-service-connection-provider.js.map +1 -0
  551. package/lib/browser-only/messaging/messaging-frontend-only-module.d.ts +3 -0
  552. package/lib/browser-only/messaging/messaging-frontend-only-module.d.ts.map +1 -0
  553. package/lib/browser-only/messaging/messaging-frontend-only-module.js +48 -0
  554. package/lib/browser-only/messaging/messaging-frontend-only-module.js.map +1 -0
  555. package/lib/browser-only/preload/frontend-only-preload-module.d.ts +4 -0
  556. package/lib/browser-only/preload/frontend-only-preload-module.d.ts.map +1 -0
  557. package/lib/browser-only/preload/frontend-only-preload-module.js +52 -0
  558. package/lib/browser-only/preload/frontend-only-preload-module.js.map +1 -0
  559. package/lib/common/accessibility.d.ts +16 -16
  560. package/lib/common/accessibility.js +17 -17
  561. package/lib/common/application-error.d.ts +20 -20
  562. package/lib/common/application-error.js +62 -62
  563. package/lib/common/application-error.spec.d.ts +1 -1
  564. package/lib/common/application-error.spec.js +26 -26
  565. package/lib/common/application-protocol.d.ts +20 -19
  566. package/lib/common/application-protocol.d.ts.map +1 -1
  567. package/lib/common/application-protocol.js +20 -20
  568. package/lib/common/array-utils.d.ts +55 -55
  569. package/lib/common/array-utils.js +118 -118
  570. package/lib/common/buffer.d.ts +43 -43
  571. package/lib/common/buffer.js +205 -205
  572. package/lib/common/cancellation.d.ts +24 -24
  573. package/lib/common/cancellation.js +142 -142
  574. package/lib/common/char-code.d.ts +401 -401
  575. package/lib/common/char-code.js +22 -22
  576. package/lib/common/collections.d.ts +29 -29
  577. package/lib/common/collections.js +121 -121
  578. package/lib/common/color.d.ts +71 -71
  579. package/lib/common/color.js +43 -43
  580. package/lib/common/command.d.ts +232 -232
  581. package/lib/common/command.js +364 -364
  582. package/lib/common/command.spec.d.ts +1 -1
  583. package/lib/common/command.spec.js +173 -173
  584. package/lib/common/contribution-filter/contribution-filter-registry.d.ts +17 -17
  585. package/lib/common/contribution-filter/contribution-filter-registry.js +88 -88
  586. package/lib/common/contribution-filter/contribution-filter.d.ts +41 -41
  587. package/lib/common/contribution-filter/contribution-filter.js +20 -20
  588. package/lib/common/contribution-filter/filter.d.ts +6 -6
  589. package/lib/common/contribution-filter/filter.js +19 -19
  590. package/lib/common/contribution-filter/index.d.ts +3 -3
  591. package/lib/common/contribution-filter/index.js +30 -30
  592. package/lib/common/contribution-provider.d.ts +20 -20
  593. package/lib/common/contribution-provider.js +82 -82
  594. package/lib/common/disposable.d.ts +80 -43
  595. package/lib/common/disposable.d.ts.map +1 -1
  596. package/lib/common/disposable.js +173 -120
  597. package/lib/common/disposable.js.map +1 -1
  598. package/lib/common/disposable.spec.d.ts +1 -1
  599. package/lib/common/disposable.spec.js +80 -29
  600. package/lib/common/disposable.spec.js.map +1 -1
  601. package/lib/common/encoding-service.d.ts +38 -38
  602. package/lib/common/encoding-service.js +307 -307
  603. package/lib/common/encodings.d.ts +7 -7
  604. package/lib/common/encodings.js +25 -25
  605. package/lib/common/env-variables/env-variables-protocol.d.ts +20 -20
  606. package/lib/common/env-variables/env-variables-protocol.js +20 -20
  607. package/lib/common/env-variables/index.d.ts +1 -1
  608. package/lib/common/env-variables/index.js +28 -28
  609. package/lib/common/event.d.ts +115 -115
  610. package/lib/common/event.js +385 -385
  611. package/lib/common/event.spec.d.ts +1 -1
  612. package/lib/common/event.spec.js +29 -29
  613. package/lib/{node → common}/file-uri.d.ts +14 -14
  614. package/lib/common/file-uri.d.ts.map +1 -0
  615. package/lib/{node → common}/file-uri.js +62 -62
  616. package/lib/common/file-uri.js.map +1 -0
  617. package/lib/common/frontend-application-state.d.ts +15 -15
  618. package/lib/common/frontend-application-state.js +33 -33
  619. package/lib/common/glob.d.ts +50 -50
  620. package/lib/common/glob.js +591 -591
  621. package/lib/common/hash.d.ts +7 -7
  622. package/lib/common/hash.js +84 -84
  623. package/lib/common/i18n/localization-server.d.ts +6 -6
  624. package/lib/common/i18n/localization-server.js +20 -20
  625. package/lib/common/i18n/localization.d.ts +34 -34
  626. package/lib/common/i18n/localization.js +59 -59
  627. package/lib/common/index.d.ts +35 -34
  628. package/lib/common/index.d.ts.map +1 -1
  629. package/lib/common/index.js +65 -64
  630. package/lib/common/index.js.map +1 -1
  631. package/lib/common/json-schema.d.ts +72 -72
  632. package/lib/common/json-schema.js +17 -17
  633. package/lib/common/key-store.d.ts +12 -12
  634. package/lib/common/key-store.js +20 -20
  635. package/lib/common/keybinding.d.ts +75 -75
  636. package/lib/common/keybinding.js +113 -113
  637. package/lib/common/keyboard/keyboard-layout-provider.d.ts +26 -26
  638. package/lib/common/keyboard/keyboard-layout-provider.js +22 -22
  639. package/lib/common/keys.d.ts +253 -253
  640. package/lib/common/keys.js +634 -634
  641. package/lib/common/label-protocol.d.ts +13 -13
  642. package/lib/common/label-protocol.js +17 -17
  643. package/lib/common/logger-protocol.d.ts +41 -41
  644. package/lib/common/logger-protocol.js +105 -105
  645. package/lib/common/logger-watcher.d.ts +9 -9
  646. package/lib/common/logger-watcher.js +54 -54
  647. package/lib/common/logger.d.ts +207 -207
  648. package/lib/common/logger.js +212 -212
  649. package/lib/common/logger.spec.d.ts +1 -1
  650. package/lib/common/logger.spec.js +41 -41
  651. package/lib/common/lsp-types.d.ts +9 -9
  652. package/lib/common/lsp-types.js +30 -30
  653. package/lib/common/markdown-rendering/icon-utilities.d.ts +7 -7
  654. package/lib/common/markdown-rendering/icon-utilities.js +32 -32
  655. package/lib/common/markdown-rendering/index.d.ts +2 -2
  656. package/lib/common/markdown-rendering/index.js +29 -29
  657. package/lib/common/markdown-rendering/markdown-string.d.ts +46 -43
  658. package/lib/common/markdown-rendering/markdown-string.d.ts.map +1 -1
  659. package/lib/common/markdown-rendering/markdown-string.js +126 -126
  660. package/lib/common/markdown-rendering/markdown-string.js.map +1 -1
  661. package/lib/common/menu/action-menu-node.d.ts +19 -19
  662. package/lib/common/menu/action-menu-node.js +56 -56
  663. package/lib/common/menu/composite-menu-node.d.ts +46 -46
  664. package/lib/common/menu/composite-menu-node.js +93 -93
  665. package/lib/common/menu/index.d.ts +5 -5
  666. package/lib/common/menu/index.js +32 -32
  667. package/lib/common/menu/menu-adapter.d.ts +35 -35
  668. package/lib/common/menu/menu-adapter.js +100 -100
  669. package/lib/common/menu/menu-model-registry.d.ts +145 -145
  670. package/lib/common/menu/menu-model-registry.d.ts.map +1 -1
  671. package/lib/common/menu/menu-model-registry.js +286 -272
  672. package/lib/common/menu/menu-model-registry.js.map +1 -1
  673. package/lib/common/menu/menu-types.d.ts +148 -148
  674. package/lib/common/menu/menu-types.js +93 -93
  675. package/lib/common/menu/menu.spec.d.ts +1 -1
  676. package/lib/common/menu/menu.spec.js +96 -69
  677. package/lib/common/menu/menu.spec.js.map +1 -1
  678. package/lib/common/message-rpc/channel.d.ts +123 -123
  679. package/lib/common/message-rpc/channel.js +230 -230
  680. package/lib/common/message-rpc/channel.spec.d.ts +8 -8
  681. package/lib/common/message-rpc/channel.spec.js +79 -79
  682. package/lib/common/message-rpc/index.d.ts +3 -3
  683. package/lib/common/message-rpc/index.js +24 -24
  684. package/lib/common/message-rpc/message-buffer.d.ts +51 -51
  685. package/lib/common/message-rpc/message-buffer.js +59 -59
  686. package/lib/common/message-rpc/msg-pack-extension-manager.d.ts +22 -22
  687. package/lib/common/message-rpc/msg-pack-extension-manager.js +57 -57
  688. package/lib/common/message-rpc/rpc-message-encoder.d.ts +103 -103
  689. package/lib/common/message-rpc/rpc-message-encoder.js +113 -113
  690. package/lib/common/message-rpc/rpc-message-encoder.spec.d.ts +1 -1
  691. package/lib/common/message-rpc/rpc-message-encoder.spec.js +58 -58
  692. package/lib/common/message-rpc/rpc-protocol.d.ts +67 -65
  693. package/lib/common/message-rpc/rpc-protocol.d.ts.map +1 -1
  694. package/lib/common/message-rpc/rpc-protocol.js +209 -191
  695. package/lib/common/message-rpc/rpc-protocol.js.map +1 -1
  696. package/lib/common/message-rpc/uint8-array-message-buffer.d.ts +52 -52
  697. package/lib/common/message-rpc/uint8-array-message-buffer.js +174 -174
  698. package/lib/common/message-rpc/uint8-array-message-buffer.spec.d.ts +1 -1
  699. package/lib/common/message-rpc/uint8-array-message-buffer.spec.js +38 -38
  700. package/lib/common/message-service-protocol.d.ts +110 -110
  701. package/lib/common/message-service-protocol.js +78 -78
  702. package/lib/common/message-service.d.ts +134 -134
  703. package/lib/common/message-service.js +162 -162
  704. package/lib/common/messaging/connection-error-handler.d.ts +28 -28
  705. package/lib/common/messaging/connection-error-handler.js +47 -47
  706. package/lib/common/messaging/connection-management.d.ts +24 -24
  707. package/lib/common/messaging/connection-management.js +37 -37
  708. package/lib/common/messaging/handler.d.ts +7 -7
  709. package/lib/common/messaging/handler.js +20 -20
  710. package/lib/common/messaging/index.d.ts +3 -3
  711. package/lib/common/messaging/index.js +30 -30
  712. package/lib/common/messaging/proxy-factory.d.ts +180 -180
  713. package/lib/common/messaging/proxy-factory.d.ts.map +1 -1
  714. package/lib/common/messaging/proxy-factory.js +280 -287
  715. package/lib/common/messaging/proxy-factory.js.map +1 -1
  716. package/lib/common/messaging/proxy-factory.spec.d.ts +1 -1
  717. package/lib/common/messaging/proxy-factory.spec.js +99 -99
  718. package/lib/common/messaging/socket-write-buffer.d.ts +10 -10
  719. package/lib/common/messaging/socket-write-buffer.js +49 -49
  720. package/lib/common/messaging/web-socket-channel.d.ts +19 -19
  721. package/lib/common/messaging/web-socket-channel.js +64 -64
  722. package/lib/common/nls.d.ts +15 -15
  723. package/lib/common/nls.js +133 -133
  724. package/lib/common/numbers.d.ts +5 -5
  725. package/lib/common/numbers.js +23 -23
  726. package/lib/common/objects.d.ts +8 -8
  727. package/lib/common/objects.js +118 -118
  728. package/lib/common/objects.spec.d.ts +1 -1
  729. package/lib/common/objects.spec.js +101 -101
  730. package/lib/common/os.d.ts +31 -31
  731. package/lib/common/os.js +73 -73
  732. package/lib/common/path.d.ts +93 -93
  733. package/lib/common/path.js +307 -307
  734. package/lib/common/path.spec.d.ts +1 -1
  735. package/lib/common/path.spec.js +350 -350
  736. package/lib/common/paths.d.ts +24 -24
  737. package/lib/common/paths.js +226 -226
  738. package/lib/common/performance/index.d.ts +3 -3
  739. package/lib/common/performance/index.js +30 -30
  740. package/lib/common/performance/measurement-protocol.d.ts +64 -64
  741. package/lib/common/performance/measurement-protocol.js +78 -78
  742. package/lib/common/performance/measurement.d.ts +111 -111
  743. package/lib/common/performance/measurement.js +17 -17
  744. package/lib/common/performance/stopwatch.d.ts +75 -75
  745. package/lib/common/performance/stopwatch.js +156 -156
  746. package/lib/common/preferences/preference-schema.d.ts +52 -52
  747. package/lib/common/preferences/preference-schema.js +58 -58
  748. package/lib/common/preferences/preference-scope.d.ts +19 -19
  749. package/lib/common/preferences/preference-scope.js +71 -71
  750. package/lib/common/preferences/preference-scope.spec.d.ts +1 -1
  751. package/lib/common/preferences/preference-scope.spec.js +44 -44
  752. package/lib/common/prioritizeable.d.ts +16 -16
  753. package/lib/common/prioritizeable.js +55 -55
  754. package/lib/common/progress-service-protocol.d.ts +13 -13
  755. package/lib/common/progress-service-protocol.js +19 -19
  756. package/lib/common/progress-service.d.ts +13 -13
  757. package/lib/common/progress-service.js +96 -96
  758. package/lib/common/promise-util.d.ts +51 -51
  759. package/lib/common/promise-util.js +132 -132
  760. package/lib/common/promise-util.spec.d.ts +1 -1
  761. package/lib/common/promise-util.spec.js +55 -55
  762. package/lib/common/quick-pick-service.d.ts +269 -280
  763. package/lib/common/quick-pick-service.d.ts.map +1 -1
  764. package/lib/common/quick-pick-service.js +133 -158
  765. package/lib/common/quick-pick-service.js.map +1 -1
  766. package/lib/common/reference.d.ts +95 -40
  767. package/lib/common/reference.d.ts.map +1 -1
  768. package/lib/common/reference.js +207 -152
  769. package/lib/common/reference.js.map +1 -1
  770. package/lib/common/reference.spec.d.ts +1 -1
  771. package/lib/common/reference.spec.js +125 -125
  772. package/lib/common/resource.d.ts +207 -205
  773. package/lib/common/resource.d.ts.map +1 -1
  774. package/lib/common/resource.js +333 -333
  775. package/lib/common/resource.js.map +1 -1
  776. package/lib/common/selection-command-handler.d.ts +24 -24
  777. package/lib/common/selection-command-handler.js +83 -83
  778. package/lib/common/selection-service.d.ts +18 -18
  779. package/lib/common/selection-service.js +48 -48
  780. package/lib/common/selection-service.spec.d.ts +1 -1
  781. package/lib/common/selection-service.spec.js +38 -38
  782. package/lib/common/selection.d.ts +9 -9
  783. package/lib/common/selection.js +47 -47
  784. package/lib/common/severity.d.ts +15 -15
  785. package/lib/common/severity.js +113 -113
  786. package/lib/common/stream.d.ts +176 -176
  787. package/lib/common/stream.js +474 -474
  788. package/lib/common/strings.d.ts +24 -24
  789. package/lib/common/strings.js +215 -215
  790. package/lib/common/telemetry.d.ts +19 -19
  791. package/lib/common/telemetry.js +24 -24
  792. package/lib/common/ternary-search-tree.d.ts +50 -50
  793. package/lib/common/ternary-search-tree.js +381 -381
  794. package/lib/common/test/expect.d.ts +2 -2
  795. package/lib/common/test/expect.js +34 -34
  796. package/lib/common/test/mock-logger.d.ts +27 -27
  797. package/lib/common/test/mock-logger.js +104 -104
  798. package/lib/common/test/mock-menu.d.ts +7 -7
  799. package/lib/common/test/mock-menu.js +34 -34
  800. package/lib/common/test/mock-resource-provider.d.ts +6 -6
  801. package/lib/common/test/mock-resource-provider.js +44 -44
  802. package/lib/common/theme.d.ts +40 -15
  803. package/lib/common/theme.d.ts.map +1 -1
  804. package/lib/common/theme.js +22 -22
  805. package/lib/common/theme.js.map +1 -1
  806. package/lib/common/types.d.ts +58 -58
  807. package/lib/common/types.js +126 -126
  808. package/lib/common/types.spec.d.ts +1 -1
  809. package/lib/common/types.spec.js +73 -73
  810. package/lib/common/uri-command-handler.d.ts +53 -53
  811. package/lib/common/uri-command-handler.js +99 -99
  812. package/lib/common/uri-command-handler.spec.d.ts +1 -1
  813. package/lib/common/uri-command-handler.spec.js +80 -80
  814. package/lib/common/uri.d.ts +87 -86
  815. package/lib/common/uri.d.ts.map +1 -1
  816. package/lib/common/uri.js +236 -236
  817. package/lib/common/uri.js.map +1 -1
  818. package/lib/common/uri.spec.d.ts +1 -1
  819. package/lib/common/uri.spec.js +230 -230
  820. package/lib/common/uuid.d.ts +8 -2
  821. package/lib/common/uuid.d.ts.map +1 -1
  822. package/lib/common/uuid.js +44 -85
  823. package/lib/common/uuid.js.map +1 -1
  824. package/lib/common/version.d.ts +1 -1
  825. package/lib/common/version.js +19 -19
  826. package/lib/common/view-column.d.ts +17 -17
  827. package/lib/common/view-column.js +36 -36
  828. package/lib/common/window.d.ts +16 -16
  829. package/lib/common/window.js +22 -22
  830. package/lib/electron-browser/electron-clipboard-service.d.ts +5 -5
  831. package/lib/electron-browser/electron-clipboard-service.js +38 -38
  832. package/lib/electron-browser/keyboard/electron-keyboard-layout-change-notifier.d.ts +11 -11
  833. package/lib/electron-browser/keyboard/electron-keyboard-layout-change-notifier.js +54 -54
  834. package/lib/electron-browser/keyboard/electron-keyboard-module.d.ts +3 -3
  835. package/lib/electron-browser/keyboard/electron-keyboard-module.js +26 -26
  836. package/lib/electron-browser/menu/electron-context-menu-renderer.d.ts +30 -30
  837. package/lib/electron-browser/menu/electron-context-menu-renderer.js +137 -137
  838. package/lib/electron-browser/menu/electron-main-menu-factory.d.ts +59 -59
  839. package/lib/electron-browser/menu/electron-main-menu-factory.js +282 -282
  840. package/lib/electron-browser/menu/electron-menu-contribution.d.ts +78 -77
  841. package/lib/electron-browser/menu/electron-menu-contribution.d.ts.map +1 -1
  842. package/lib/electron-browser/menu/electron-menu-contribution.js +482 -473
  843. package/lib/electron-browser/menu/electron-menu-contribution.js.map +1 -1
  844. package/lib/electron-browser/menu/electron-menu-module.d.ts +3 -3
  845. package/lib/electron-browser/menu/electron-menu-module.js +39 -39
  846. package/lib/electron-browser/messaging/electron-frontend-id-provider.d.ts +4 -4
  847. package/lib/electron-browser/messaging/electron-frontend-id-provider.js +34 -34
  848. package/lib/electron-browser/messaging/electron-ipc-connection-source.d.ts +23 -23
  849. package/lib/electron-browser/messaging/electron-ipc-connection-source.js +64 -64
  850. package/lib/electron-browser/messaging/electron-local-ws-connection-source.d.ts +6 -6
  851. package/lib/electron-browser/messaging/electron-local-ws-connection-source.js +54 -54
  852. package/lib/electron-browser/messaging/electron-messaging-frontend-module.d.ts +2 -2
  853. package/lib/electron-browser/messaging/electron-messaging-frontend-module.js +75 -75
  854. package/lib/electron-browser/messaging/electron-messaging-frontend-module.js.map +1 -1
  855. package/lib/electron-browser/messaging/electron-ws-connection-source.d.ts +11 -11
  856. package/lib/electron-browser/messaging/electron-ws-connection-source.js +50 -50
  857. package/lib/electron-browser/preload.d.ts +1 -1
  858. package/lib/electron-browser/preload.js +201 -201
  859. package/lib/electron-browser/request/electron-browser-request-module.d.ts +18 -18
  860. package/lib/electron-browser/request/electron-browser-request-module.js +26 -26
  861. package/lib/electron-browser/token/electron-token-frontend-module.d.ts +3 -3
  862. package/lib/electron-browser/token/electron-token-frontend-module.js +22 -22
  863. package/lib/electron-browser/window/electron-frontend-application-state.d.ts +4 -4
  864. package/lib/electron-browser/window/electron-frontend-application-state.js +36 -36
  865. package/lib/electron-browser/window/electron-secondary-window-service.d.ts +7 -7
  866. package/lib/electron-browser/window/electron-secondary-window-service.js +47 -47
  867. package/lib/electron-browser/window/electron-window-module.d.ts +3 -3
  868. package/lib/electron-browser/window/electron-window-module.js +39 -39
  869. package/lib/electron-browser/window/electron-window-preferences.d.ts +18 -18
  870. package/lib/electron-browser/window/electron-window-preferences.js +72 -72
  871. package/lib/electron-browser/window/electron-window-service.d.ts +29 -29
  872. package/lib/electron-browser/window/electron-window-service.js +114 -114
  873. package/lib/electron-common/electron-api.d.ts +104 -104
  874. package/lib/electron-common/electron-api.js +56 -56
  875. package/lib/electron-common/electron-main-window-service.d.ts +7 -7
  876. package/lib/electron-common/electron-main-window-service.js +20 -20
  877. package/lib/electron-common/electron-token.d.ts +10 -10
  878. package/lib/electron-common/electron-token.js +27 -27
  879. package/lib/electron-main/electron-api-main.d.ts +22 -22
  880. package/lib/electron-main/electron-api-main.js +294 -294
  881. package/lib/electron-main/electron-main-application-module.d.ts +3 -3
  882. package/lib/electron-main/electron-main-application-module.js +56 -56
  883. package/lib/electron-main/electron-main-application-module.js.map +1 -1
  884. package/lib/electron-main/electron-main-application.d.ts +159 -159
  885. package/lib/electron-main/electron-main-application.js +611 -611
  886. package/lib/electron-main/electron-main-application.js.map +1 -1
  887. package/lib/electron-main/electron-main-constants.d.ts +6 -6
  888. package/lib/electron-main/electron-main-constants.js +19 -19
  889. package/lib/electron-main/electron-main-window-service-impl.d.ts +8 -8
  890. package/lib/electron-main/electron-main-window-service-impl.js +54 -54
  891. package/lib/electron-main/electron-security-token-service.d.ts +5 -5
  892. package/lib/electron-main/electron-security-token-service.js +49 -49
  893. package/lib/electron-main/event-utils.d.ts +8 -8
  894. package/lib/electron-main/event-utils.js +33 -33
  895. package/lib/electron-main/messaging/electron-connection-handler.d.ts +5 -5
  896. package/lib/electron-main/messaging/electron-connection-handler.js +23 -23
  897. package/lib/electron-main/messaging/electron-messaging-contribution.d.ts +41 -41
  898. package/lib/electron-main/messaging/electron-messaging-contribution.js +150 -150
  899. package/lib/electron-main/messaging/electron-messaging-service.d.ts +17 -17
  900. package/lib/electron-main/messaging/electron-messaging-service.js +22 -22
  901. package/lib/electron-main/theia-electron-window.d.ts +53 -53
  902. package/lib/electron-main/theia-electron-window.js +194 -194
  903. package/lib/electron-main/theia-electron-window.js.map +1 -1
  904. package/lib/electron-node/hosting/electron-backend-hosting-module.d.ts +3 -3
  905. package/lib/electron-node/hosting/electron-backend-hosting-module.js +24 -24
  906. package/lib/electron-node/hosting/electron-ws-origin-validator.d.ts +8 -8
  907. package/lib/electron-node/hosting/electron-ws-origin-validator.js +48 -48
  908. package/lib/electron-node/keyboard/electron-backend-keyboard-module.d.ts +3 -3
  909. package/lib/electron-node/keyboard/electron-backend-keyboard-module.js +26 -26
  910. package/lib/electron-node/keyboard/electron-keyboard-layout-provider.d.ts +5 -5
  911. package/lib/electron-node/keyboard/electron-keyboard-layout-provider.js +41 -41
  912. package/lib/electron-node/request/electron-backend-request-module.d.ts +18 -18
  913. package/lib/electron-node/request/electron-backend-request-module.js +23 -23
  914. package/lib/electron-node/request/electron-backend-request-service.d.ts +22 -22
  915. package/lib/electron-node/request/electron-backend-request-service.js +86 -86
  916. package/lib/electron-node/token/electron-token-backend-contribution.d.ts +15 -15
  917. package/lib/electron-node/token/electron-token-backend-contribution.js +58 -58
  918. package/lib/electron-node/token/electron-token-backend-module.d.ts +3 -3
  919. package/lib/electron-node/token/electron-token-backend-module.js +28 -28
  920. package/lib/electron-node/token/electron-token-validator.d.ts +29 -29
  921. package/lib/electron-node/token/electron-token-validator.js +103 -103
  922. package/lib/node/application-server.d.ts +10 -9
  923. package/lib/node/application-server.d.ts.map +1 -1
  924. package/lib/node/application-server.js +63 -57
  925. package/lib/node/application-server.js.map +1 -1
  926. package/lib/node/backend-application-config-provider.d.ts +7 -7
  927. package/lib/node/backend-application-config-provider.js +45 -45
  928. package/lib/node/backend-application-config-provider.spec.d.ts +1 -1
  929. package/lib/node/backend-application-config-provider.spec.js +28 -28
  930. package/lib/node/backend-application-module.d.ts +2 -2
  931. package/lib/node/backend-application-module.js +108 -108
  932. package/lib/node/backend-application.d.ts +108 -108
  933. package/lib/node/backend-application.js +301 -301
  934. package/lib/node/backend-remote-service.d.ts +3 -3
  935. package/lib/node/backend-remote-service.js +34 -34
  936. package/lib/node/cli.d.ts +17 -17
  937. package/lib/node/cli.js +70 -70
  938. package/lib/node/cli.spec.d.ts +1 -1
  939. package/lib/node/cli.spec.js +89 -89
  940. package/lib/node/console-logger-server.d.ts +15 -15
  941. package/lib/node/console-logger-server.js +90 -90
  942. package/lib/node/console-logger-server.spec.d.ts +1 -1
  943. package/lib/node/console-logger-server.spec.js +69 -69
  944. package/lib/node/debug.d.ts +1 -1
  945. package/lib/node/debug.js +28 -28
  946. package/lib/node/dynamic-require.d.ts +7 -7
  947. package/lib/node/dynamic-require.js +56 -56
  948. package/lib/node/env-variables/env-variables-server.d.ts +23 -23
  949. package/lib/node/env-variables/env-variables-server.js +125 -125
  950. package/lib/node/env-variables/env-variables-server.js.map +1 -1
  951. package/lib/node/env-variables/index.d.ts +1 -1
  952. package/lib/node/env-variables/index.js +28 -28
  953. package/lib/node/environment-utils.d.ts +21 -21
  954. package/lib/node/environment-utils.js +77 -77
  955. package/lib/node/environment-utils.spec.d.ts +1 -1
  956. package/lib/node/environment-utils.spec.js +77 -77
  957. package/lib/node/file-uri.spec.d.ts +1 -1
  958. package/lib/node/file-uri.spec.js +66 -66
  959. package/lib/node/file-uri.spec.js.map +1 -1
  960. package/lib/node/filesystem-locking.d.ts +23 -23
  961. package/lib/node/filesystem-locking.js +70 -70
  962. package/lib/node/hosting/backend-application-hosts.d.ts +23 -23
  963. package/lib/node/hosting/backend-application-hosts.js +77 -77
  964. package/lib/node/hosting/backend-hosting-module.d.ts +3 -3
  965. package/lib/node/hosting/backend-hosting-module.js +26 -26
  966. package/lib/node/hosting/ws-origin-validator.d.ts +8 -8
  967. package/lib/node/hosting/ws-origin-validator.js +47 -47
  968. package/lib/node/i18n/i18n-backend-module.d.ts +3 -3
  969. package/lib/node/i18n/i18n-backend-module.js +38 -38
  970. package/lib/node/i18n/localization-contribution.d.ts +18 -18
  971. package/lib/node/i18n/localization-contribution.js +116 -116
  972. package/lib/node/i18n/localization-provider.d.ts +23 -23
  973. package/lib/node/i18n/localization-provider.js +114 -114
  974. package/lib/node/i18n/localization-server.d.ts +14 -14
  975. package/lib/node/i18n/localization-server.js +62 -62
  976. package/lib/node/i18n/theia-localization-contribution.d.ts +4 -4
  977. package/lib/node/i18n/theia-localization-contribution.js +45 -45
  978. package/lib/node/index.d.ts +6 -6
  979. package/lib/node/index.d.ts.map +1 -1
  980. package/lib/node/index.js +35 -35
  981. package/lib/node/index.js.map +1 -1
  982. package/lib/node/key-store-server.d.ts +27 -27
  983. package/lib/node/key-store-server.js +150 -150
  984. package/lib/node/logger-backend-module.d.ts +9 -9
  985. package/lib/node/logger-backend-module.js +78 -78
  986. package/lib/node/logger-cli-contribution.d.ts +33 -33
  987. package/lib/node/logger-cli-contribution.js +152 -152
  988. package/lib/node/logger-cli-contribution.spec.d.ts +1 -1
  989. package/lib/node/logger-cli-contribution.spec.js +207 -207
  990. package/lib/node/main.d.ts +7 -7
  991. package/lib/node/main.js +29 -29
  992. package/lib/node/messaging/binary-message-pipe.d.ts +44 -44
  993. package/lib/node/messaging/binary-message-pipe.js +151 -151
  994. package/lib/node/messaging/connection-container-module.d.ts +53 -53
  995. package/lib/node/messaging/connection-container-module.js +81 -81
  996. package/lib/node/messaging/default-messaging-service.d.ts +28 -28
  997. package/lib/node/messaging/default-messaging-service.js +139 -139
  998. package/lib/node/messaging/frontend-connection-service.d.ts +6 -6
  999. package/lib/node/messaging/frontend-connection-service.js +18 -18
  1000. package/lib/node/messaging/index.d.ts +3 -3
  1001. package/lib/node/messaging/index.js +30 -30
  1002. package/lib/node/messaging/ipc-bootstrap.d.ts +1 -1
  1003. package/lib/node/messaging/ipc-bootstrap.js +24 -24
  1004. package/lib/node/messaging/ipc-channel.d.ts +17 -17
  1005. package/lib/node/messaging/ipc-channel.js +69 -69
  1006. package/lib/node/messaging/ipc-connection-provider.d.ts +21 -21
  1007. package/lib/node/messaging/ipc-connection-provider.js +100 -100
  1008. package/lib/node/messaging/ipc-protocol.d.ts +19 -19
  1009. package/lib/node/messaging/ipc-protocol.js +68 -68
  1010. package/lib/node/messaging/messaging-backend-module.d.ts +2 -2
  1011. package/lib/node/messaging/messaging-backend-module.js +52 -52
  1012. package/lib/node/messaging/messaging-listeners.d.ts +27 -27
  1013. package/lib/node/messaging/messaging-listeners.js +53 -53
  1014. package/lib/node/messaging/messaging-service.d.ts +28 -28
  1015. package/lib/node/messaging/messaging-service.js +24 -24
  1016. package/lib/node/messaging/test/test-web-socket-channel.d.ts +12 -12
  1017. package/lib/node/messaging/test/test-web-socket-channel.js +62 -62
  1018. package/lib/node/messaging/websocket-endpoint.d.ts +20 -20
  1019. package/lib/node/messaging/websocket-endpoint.js +88 -88
  1020. package/lib/node/messaging/websocket-frontend-connection-service.d.ts +30 -29
  1021. package/lib/node/messaging/websocket-frontend-connection-service.d.ts.map +1 -1
  1022. package/lib/node/messaging/websocket-frontend-connection-service.js +177 -172
  1023. package/lib/node/messaging/websocket-frontend-connection-service.js.map +1 -1
  1024. package/lib/node/os-backend-provider.d.ts +4 -4
  1025. package/lib/node/os-backend-provider.js +35 -35
  1026. package/lib/node/performance/index.d.ts +2 -2
  1027. package/lib/node/performance/index.js +29 -29
  1028. package/lib/node/performance/measurement-backend-bindings.d.ts +19 -19
  1029. package/lib/node/performance/measurement-backend-bindings.js +30 -30
  1030. package/lib/node/performance/node-stopwatch.d.ts +20 -20
  1031. package/lib/node/performance/node-stopwatch.js +51 -51
  1032. package/lib/node/process-utils.d.ts +13 -13
  1033. package/lib/node/process-utils.js +110 -110
  1034. package/lib/node/process-utils.spec.d.ts +1 -1
  1035. package/lib/node/process-utils.spec.js +44 -44
  1036. package/lib/node/request/backend-request-facade.d.ts +22 -22
  1037. package/lib/node/request/backend-request-facade.js +49 -49
  1038. package/lib/node/request/backend-request-module.d.ts +18 -18
  1039. package/lib/node/request/backend-request-module.js +24 -24
  1040. package/lib/node/request/proxy-cli-contribution.d.ts +27 -27
  1041. package/lib/node/request/proxy-cli-contribution.js +72 -72
  1042. package/lib/node/ws-request-validators.d.ts +25 -25
  1043. package/lib/node/ws-request-validators.js +60 -60
  1044. package/package.json +13 -8
  1045. package/shared/ajv/index.d.ts +2 -2
  1046. package/shared/markdown-it.d.ts +2 -2
  1047. package/shared/markdown-it.js +1 -1
  1048. package/shared/reflect-metadata/index.d.ts +1 -1
  1049. package/shared/reflect-metadata/index.js +1 -1
  1050. package/shared/vscode-languageserver-types/index.d.ts +1 -1
  1051. package/src/browser/about-dialog.tsx +137 -137
  1052. package/src/browser/authentication-service.ts +456 -456
  1053. package/src/browser/breadcrumbs/breadcrumb-popup-container.ts +101 -101
  1054. package/src/browser/breadcrumbs/breadcrumb-renderer.tsx +41 -41
  1055. package/src/browser/breadcrumbs/breadcrumbs-constants.ts +79 -79
  1056. package/src/browser/breadcrumbs/breadcrumbs-renderer.tsx +185 -185
  1057. package/src/browser/breadcrumbs/breadcrumbs-service.ts +108 -108
  1058. package/src/browser/breadcrumbs/index.ts +21 -21
  1059. package/src/browser/browser-clipboard-service.ts +122 -122
  1060. package/src/browser/browser.ts +225 -220
  1061. package/src/browser/clipboard-service.ts +23 -23
  1062. package/src/browser/color-application-contribution.ts +101 -101
  1063. package/src/browser/color-registry.ts +60 -60
  1064. package/src/browser/command-open-handler.ts +54 -54
  1065. package/src/browser/common-frontend-contribution.ts +2526 -2526
  1066. package/src/browser/common-styling-participants.ts +361 -361
  1067. package/src/browser/connection-status-service.spec.ts +200 -200
  1068. package/src/browser/connection-status-service.ts +216 -216
  1069. package/src/browser/context-key-service.ts +142 -143
  1070. package/src/browser/context-menu-renderer.ts +124 -128
  1071. package/src/browser/core-preferences.ts +334 -328
  1072. package/src/browser/credentials-service.ts +106 -106
  1073. package/src/browser/decoration-style.ts +65 -65
  1074. package/src/browser/decorations-service.ts +209 -209
  1075. package/src/browser/dialogs/react-dialog.tsx +56 -56
  1076. package/src/browser/dialogs.ts +534 -534
  1077. package/src/browser/diff-uris.ts +117 -117
  1078. package/src/browser/encoding-registry.ts +97 -97
  1079. package/src/browser/endpoint.spec.ts +148 -148
  1080. package/src/browser/endpoint.ts +136 -136
  1081. package/src/browser/external-uri-service.ts +79 -79
  1082. package/src/browser/file-icons-js.d.ts +20 -20
  1083. package/src/browser/frontend-application-bindings.ts +62 -62
  1084. package/src/browser/frontend-application-config-provider.spec.ts +45 -45
  1085. package/src/browser/frontend-application-config-provider.ts +50 -50
  1086. package/src/browser/frontend-application-contribution.ts +110 -110
  1087. package/src/browser/frontend-application-module.ts +458 -457
  1088. package/src/browser/frontend-application-state.ts +74 -74
  1089. package/src/browser/frontend-application.ts +326 -326
  1090. package/src/browser/hover-service.ts +218 -218
  1091. package/src/browser/http-open-handler.ts +47 -47
  1092. package/src/browser/i18n/i18n-frontend-module.ts +27 -27
  1093. package/src/browser/i18n/language-quick-pick-service.ts +130 -130
  1094. package/src/browser/icon-registry.ts +87 -96
  1095. package/src/browser/icon-theme-contribution.ts +64 -64
  1096. package/src/browser/icon-theme-service.ts +217 -217
  1097. package/src/browser/icons/CollapseAll.svg +7 -7
  1098. package/src/browser/icons/CollapseAll_inverse.svg +7 -7
  1099. package/src/browser/icons/Refresh.svg +7 -7
  1100. package/src/browser/icons/Refresh_inverse.svg +7 -7
  1101. package/src/browser/icons/add-inverse.svg +4 -4
  1102. package/src/browser/icons/add.svg +4 -4
  1103. package/src/browser/icons/arrow-down-bright.svg +6 -6
  1104. package/src/browser/icons/arrow-down-dark.svg +6 -6
  1105. package/src/browser/icons/arrow-up-bright.svg +6 -6
  1106. package/src/browser/icons/arrow-up-dark.svg +6 -6
  1107. package/src/browser/icons/case-sensitive-dark.svg +16 -16
  1108. package/src/browser/icons/case-sensitive.svg +16 -16
  1109. package/src/browser/icons/chevron-right-dark.svg +5 -5
  1110. package/src/browser/icons/chevron-right-light.svg +6 -6
  1111. package/src/browser/icons/circle-bright.svg +7 -7
  1112. package/src/browser/icons/circle-dark.svg +7 -7
  1113. package/src/browser/icons/clear-search-results-dark.svg +7 -7
  1114. package/src/browser/icons/clear-search-results.svg +7 -7
  1115. package/src/browser/icons/close-all-bright.svg +7 -7
  1116. package/src/browser/icons/close-all-dark.svg +7 -7
  1117. package/src/browser/icons/close-bright.svg +7 -7
  1118. package/src/browser/icons/close-dark.svg +7 -7
  1119. package/src/browser/icons/collapse.svg +4 -4
  1120. package/src/browser/icons/edit-json-dark.svg +6 -6
  1121. package/src/browser/icons/edit-json.svg +6 -6
  1122. package/src/browser/icons/expand.svg +4 -4
  1123. package/src/browser/icons/loading-dark.svg +6 -6
  1124. package/src/browser/icons/loading-light.svg +6 -6
  1125. package/src/browser/icons/open-change-bright.svg +3 -3
  1126. package/src/browser/icons/open-change-dark.svg +4 -4
  1127. package/src/browser/icons/open-file-bright.svg +4 -4
  1128. package/src/browser/icons/open-file-dark.svg +4 -4
  1129. package/src/browser/icons/preview-bright.svg +3 -3
  1130. package/src/browser/icons/preview-dark.svg +3 -3
  1131. package/src/browser/icons/regex-dark.svg +10 -10
  1132. package/src/browser/icons/regex.svg +10 -10
  1133. package/src/browser/icons/remove-all-inverse.svg +4 -4
  1134. package/src/browser/icons/remove-all.svg +4 -4
  1135. package/src/browser/icons/replace-all-inverse.svg +13 -13
  1136. package/src/browser/icons/replace-all.svg +13 -13
  1137. package/src/browser/icons/replace-inverse.svg +15 -15
  1138. package/src/browser/icons/replace.svg +15 -15
  1139. package/src/browser/icons/whole-word-dark.svg +19 -19
  1140. package/src/browser/icons/whole-word.svg +19 -19
  1141. package/src/browser/index.ts +47 -47
  1142. package/src/browser/json-schema-store.ts +127 -127
  1143. package/src/browser/keybinding.spec.ts +553 -553
  1144. package/src/browser/keybinding.ts +756 -756
  1145. package/src/browser/keyboard/browser-keyboard-frontend-contribution.ts +108 -108
  1146. package/src/browser/keyboard/browser-keyboard-layout-provider.spec.ts +171 -171
  1147. package/src/browser/keyboard/browser-keyboard-layout-provider.ts +469 -469
  1148. package/src/browser/keyboard/browser-keyboard-module.ts +30 -30
  1149. package/src/browser/keyboard/index.ts +20 -20
  1150. package/src/browser/keyboard/keyboard-layout-service.spec.ts +121 -121
  1151. package/src/browser/keyboard/keyboard-layout-service.ts +455 -455
  1152. package/src/browser/keyboard/keys.spec.ts +258 -258
  1153. package/src/browser/keyboard/keys.ts +20 -20
  1154. package/src/browser/keys.ts +21 -21
  1155. package/src/browser/label-parser.spec.ts +165 -165
  1156. package/src/browser/label-parser.ts +108 -108
  1157. package/src/browser/label-provider.spec.ts +62 -62
  1158. package/src/browser/label-provider.ts +385 -385
  1159. package/src/browser/language-icon-provider.ts +55 -55
  1160. package/src/browser/language-service.ts +77 -77
  1161. package/src/browser/logger-frontend-module.ts +65 -65
  1162. package/src/browser/markdown-rendering/markdown-renderer.ts +98 -98
  1163. package/src/browser/menu/browser-context-menu-renderer.ts +47 -47
  1164. package/src/browser/menu/browser-menu-module.ts +28 -28
  1165. package/src/browser/menu/browser-menu-plugin.ts +484 -484
  1166. package/src/browser/menu/context-menu-context.ts +41 -41
  1167. package/src/browser/messaging/connection-source.ts +26 -26
  1168. package/src/browser/messaging/frontend-id-provider.ts +37 -37
  1169. package/src/browser/messaging/index.ts +17 -17
  1170. package/src/browser/messaging/messaging-frontend-module.ts +41 -41
  1171. package/src/browser/messaging/service-connection-provider.ts +126 -126
  1172. package/src/browser/messaging/ws-connection-provider.ts +48 -48
  1173. package/src/browser/messaging/ws-connection-source.ts +230 -210
  1174. package/src/browser/mime-service.ts +30 -30
  1175. package/src/browser/navigatable-types.ts +81 -81
  1176. package/src/browser/navigatable.ts +39 -39
  1177. package/src/browser/opener-service.spec.ts +49 -49
  1178. package/src/browser/opener-service.ts +146 -146
  1179. package/src/browser/performance/frontend-stopwatch.ts +65 -65
  1180. package/src/browser/performance/index.ts +18 -18
  1181. package/src/browser/performance/measurement-frontend-bindings.ts +31 -31
  1182. package/src/browser/preferences/index.ts +23 -23
  1183. package/src/browser/preferences/injectable-preference-proxy.ts +283 -283
  1184. package/src/browser/preferences/preference-configurations.ts +82 -82
  1185. package/src/browser/preferences/preference-contribution.ts +436 -436
  1186. package/src/browser/preferences/preference-language-override-service.ts +111 -111
  1187. package/src/browser/preferences/preference-provider.spec.ts +36 -36
  1188. package/src/browser/preferences/preference-provider.ts +277 -277
  1189. package/src/browser/preferences/preference-proxy.spec.ts +367 -367
  1190. package/src/browser/preferences/preference-proxy.ts +367 -367
  1191. package/src/browser/preferences/preference-schema-provider.spec.ts +130 -130
  1192. package/src/browser/preferences/preference-scope.ts +18 -18
  1193. package/src/browser/preferences/preference-service.spec.ts +613 -613
  1194. package/src/browser/preferences/preference-service.ts +594 -594
  1195. package/src/browser/preferences/preference-validation-service.spec.ts +334 -334
  1196. package/src/browser/preferences/preference-validation-service.ts +358 -358
  1197. package/src/browser/preferences/test/index.ts +19 -19
  1198. package/src/browser/preferences/test/mock-preference-provider.ts +50 -50
  1199. package/src/browser/preferences/test/mock-preference-proxy.ts +48 -48
  1200. package/src/browser/preferences/test/mock-preference-service.ts +63 -63
  1201. package/src/browser/preload/i18n-preload-contribution.ts +50 -50
  1202. package/src/browser/preload/os-preload-contribution.ts +37 -37
  1203. package/src/browser/preload/preload-module.ts +45 -45
  1204. package/src/browser/preload/preloader.ts +37 -37
  1205. package/src/browser/preload/theme-preload-contribution.ts +31 -31
  1206. package/src/browser/progress-bar-factory.ts +29 -29
  1207. package/src/browser/progress-bar.ts +76 -76
  1208. package/src/browser/progress-client.ts +53 -53
  1209. package/src/browser/progress-location-service.spec.ts +50 -50
  1210. package/src/browser/progress-location-service.ts +96 -96
  1211. package/src/browser/progress-status-bar-item.ts +83 -83
  1212. package/src/browser/quick-input/index.ts +23 -23
  1213. package/src/browser/quick-input/quick-access.ts +75 -75
  1214. package/src/browser/quick-input/quick-command-frontend-contribution.ts +89 -89
  1215. package/src/browser/quick-input/quick-command-service.ts +246 -246
  1216. package/src/browser/quick-input/quick-help-service.ts +87 -87
  1217. package/src/browser/quick-input/quick-input-frontend-contribution.ts +33 -33
  1218. package/src/browser/quick-input/quick-input-service.spec.ts +176 -176
  1219. package/src/browser/quick-input/quick-input-service.ts +17 -17
  1220. package/src/browser/quick-input/quick-pick-service-impl.ts +69 -69
  1221. package/src/browser/quick-input/quick-view-service.ts +83 -83
  1222. package/src/browser/request/browser-request-module.ts +23 -23
  1223. package/src/browser/request/browser-request-service.ts +172 -172
  1224. package/src/browser/resource-context-key.ts +77 -77
  1225. package/src/browser/save-resource-service.ts +60 -59
  1226. package/src/browser/saveable.ts +365 -365
  1227. package/src/browser/secondary-window-handler.ts +212 -212
  1228. package/src/browser/shell/additional-views-menu-widget.tsx +71 -71
  1229. package/src/browser/shell/application-shell-mouse-tracker.ts +103 -103
  1230. package/src/browser/shell/application-shell.ts +2254 -2249
  1231. package/src/browser/shell/current-widget-command-adapter.ts +57 -57
  1232. package/src/browser/shell/index.ts +23 -23
  1233. package/src/browser/shell/shell-layout-restorer.ts +399 -399
  1234. package/src/browser/shell/side-panel-handler.ts +793 -793
  1235. package/src/browser/shell/side-panel-toolbar.ts +111 -111
  1236. package/src/browser/shell/sidebar-bottom-menu-widget.tsx +39 -39
  1237. package/src/browser/shell/sidebar-menu-widget.tsx +140 -140
  1238. package/src/browser/shell/sidebar-top-menu-widget.tsx +26 -26
  1239. package/src/browser/shell/split-panels.ts +190 -190
  1240. package/src/browser/shell/tab-bar-decorator.ts +106 -76
  1241. package/src/browser/shell/tab-bar-toolbar/index.ts +19 -19
  1242. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar-menu-adapters.ts +31 -31
  1243. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar-registry.ts +256 -256
  1244. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar-types.ts +207 -207
  1245. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar.spec.ts +62 -62
  1246. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar.tsx +423 -423
  1247. package/src/browser/shell/tab-bars.spec.ts +63 -63
  1248. package/src/browser/shell/tab-bars.ts +1481 -1449
  1249. package/src/browser/shell/theia-dock-panel.ts +255 -255
  1250. package/src/browser/shell/view-contribution.ts +177 -177
  1251. package/src/browser/source-tree/index.ts +19 -19
  1252. package/src/browser/source-tree/source-tree-widget.tsx +107 -107
  1253. package/src/browser/source-tree/source-tree.ts +146 -146
  1254. package/src/browser/source-tree/tree-source.ts +73 -73
  1255. package/src/browser/status-bar/index.ts +29 -29
  1256. package/src/browser/status-bar/status-bar-types.ts +97 -97
  1257. package/src/browser/status-bar/status-bar-view-model.ts +209 -209
  1258. package/src/browser/status-bar/status-bar.tsx +189 -189
  1259. package/src/browser/storage-service.spec.ts +76 -76
  1260. package/src/browser/storage-service.ts +129 -129
  1261. package/src/browser/style/about.css +36 -36
  1262. package/src/browser/style/alert-messages.css +62 -62
  1263. package/src/browser/style/ansi.css +88 -88
  1264. package/src/browser/style/breadcrumbs.css +130 -130
  1265. package/src/browser/style/dialog.css +126 -126
  1266. package/src/browser/style/dockpanel.css +76 -76
  1267. package/src/browser/style/hover-service.css +101 -101
  1268. package/src/browser/style/icons.css +61 -61
  1269. package/src/browser/style/index.css +351 -346
  1270. package/src/browser/style/materialcolors.css +278 -278
  1271. package/src/browser/style/menus.css +230 -230
  1272. package/src/browser/style/notification.css +39 -39
  1273. package/src/browser/style/os.css +87 -87
  1274. package/src/browser/style/progress-bar.css +43 -43
  1275. package/src/browser/style/quick-title-bar.css +45 -45
  1276. package/src/browser/style/scrollbars.css +172 -172
  1277. package/src/browser/style/search-box.css +123 -123
  1278. package/src/browser/style/select-component.css +107 -108
  1279. package/src/browser/style/sidepanel.css +364 -364
  1280. package/src/browser/style/status-bar.css +127 -127
  1281. package/src/browser/style/tabs.css +647 -641
  1282. package/src/browser/style/tooltip.css +28 -28
  1283. package/src/browser/style/tree-decorators.css +81 -81
  1284. package/src/browser/style/tree.css +232 -232
  1285. package/src/browser/style/view-container.css +194 -194
  1286. package/src/browser/style/widget.css +19 -19
  1287. package/src/browser/styling-service.ts +87 -87
  1288. package/src/browser/supported-encodings.ts +262 -262
  1289. package/src/browser/test/jsdom.ts +69 -69
  1290. package/src/browser/test/mock-connection-status-service.ts +33 -33
  1291. package/src/browser/test/mock-env-variables-server.ts +47 -47
  1292. package/src/browser/test/mock-opener-service.ts +34 -34
  1293. package/src/browser/test/mock-storage-service.ts +49 -49
  1294. package/src/browser/theming.ts +206 -206
  1295. package/src/browser/tooltip-service.tsx +96 -96
  1296. package/src/browser/tree/fuzzy-search.spec.ts +99 -99
  1297. package/src/browser/tree/fuzzy-search.ts +136 -136
  1298. package/src/browser/tree/index.ts +29 -28
  1299. package/src/browser/tree/search-box-debounce.ts +96 -96
  1300. package/src/browser/tree/search-box.ts +355 -355
  1301. package/src/browser/tree/test/mock-selectable-tree-model.ts +109 -0
  1302. package/src/browser/tree/test/mock-tree-model.ts +136 -136
  1303. package/src/browser/tree/test/tree-test-container.ts +50 -50
  1304. package/src/browser/tree/tree-compression/compressed-tree-expansion-service.ts +46 -46
  1305. package/src/browser/tree/tree-compression/compressed-tree-model.ts +88 -88
  1306. package/src/browser/tree/tree-compression/compressed-tree-widget.tsx +203 -203
  1307. package/src/browser/tree/tree-compression/index.ts +20 -20
  1308. package/src/browser/tree/tree-compression/tree-compression-service.ts +125 -125
  1309. package/src/browser/tree/tree-compression/tree-compression.css +28 -28
  1310. package/src/browser/tree/tree-consistency.spec.ts +105 -105
  1311. package/src/browser/tree/tree-container.spec.ts +45 -45
  1312. package/src/browser/tree/tree-container.ts +155 -155
  1313. package/src/browser/tree/tree-decorator.spec.ts +162 -162
  1314. package/src/browser/tree/tree-decorator.ts +238 -238
  1315. package/src/browser/tree/tree-expansion.spec.ts +173 -173
  1316. package/src/browser/tree/tree-expansion.ts +165 -165
  1317. package/src/browser/tree/tree-focus-service.ts +55 -55
  1318. package/src/browser/tree/tree-iterator.spec.ts +170 -170
  1319. package/src/browser/tree/tree-iterator.ts +256 -256
  1320. package/src/browser/tree/tree-label-provider.ts +40 -40
  1321. package/src/browser/tree/tree-model.ts +562 -488
  1322. package/src/browser/tree/tree-navigation.ts +58 -58
  1323. package/src/browser/tree/tree-preference.ts +50 -0
  1324. package/src/browser/tree/tree-search.ts +128 -128
  1325. package/src/browser/tree/tree-selectable.spec.ts +152 -0
  1326. package/src/browser/tree/tree-selection-impl.ts +176 -176
  1327. package/src/browser/tree/tree-selection-state.spec.ts +462 -462
  1328. package/src/browser/tree/tree-selection-state.ts +245 -245
  1329. package/src/browser/tree/tree-selection.ts +159 -159
  1330. package/src/browser/tree/tree-view-welcome-widget.tsx +263 -263
  1331. package/src/browser/tree/tree-widget-selection.ts +45 -45
  1332. package/src/browser/tree/tree-widget.tsx +1585 -1566
  1333. package/src/browser/tree/tree.spec.ts +241 -241
  1334. package/src/browser/tree/tree.ts +425 -424
  1335. package/src/browser/user-working-directory-provider.ts +77 -77
  1336. package/src/browser/view-container.ts +1640 -1640
  1337. package/src/browser/widget-decoration.ts +358 -358
  1338. package/src/browser/widget-manager.spec.ts +102 -102
  1339. package/src/browser/widget-manager.ts +310 -285
  1340. package/src/browser/widget-open-handler.ts +165 -165
  1341. package/src/browser/widgets/alert-message.tsx +56 -56
  1342. package/src/browser/widgets/enhanced-preview-widget.ts +27 -27
  1343. package/src/browser/widgets/extractable-widget.ts +33 -33
  1344. package/src/browser/widgets/index.ts +20 -20
  1345. package/src/browser/widgets/previewable-widget.ts +31 -31
  1346. package/src/browser/widgets/react-renderer.tsx +50 -50
  1347. package/src/browser/widgets/react-widget.tsx +51 -51
  1348. package/src/browser/widgets/select-component.tsx +367 -366
  1349. package/src/browser/widgets/widget.ts +406 -398
  1350. package/src/browser/window/browser-window-module.ts +32 -32
  1351. package/src/browser/window/default-secondary-window-service.ts +187 -187
  1352. package/src/browser/window/default-window-service.spec.ts +78 -78
  1353. package/src/browser/window/default-window-service.ts +167 -167
  1354. package/src/browser/window/secondary-window-service.ts +39 -39
  1355. package/src/browser/window/test/mock-window-service.ts +28 -28
  1356. package/src/browser/window/window-service.ts +68 -68
  1357. package/src/browser/window/window-title-service.ts +107 -107
  1358. package/src/browser/window/window-title-updater.ts +95 -95
  1359. package/src/browser/window-contribution.ts +64 -64
  1360. package/src/browser-only/frontend-only-application-module.ts +115 -0
  1361. package/src/browser-only/i18n/i18n-frontend-only-module.ts +37 -0
  1362. package/src/browser-only/logger-frontend-only-module.ts +63 -0
  1363. package/src/browser-only/messaging/frontend-only-service-connection-provider.ts +39 -0
  1364. package/src/browser-only/messaging/messaging-frontend-only-module.ts +42 -0
  1365. package/src/browser-only/preload/frontend-only-preload-module.ts +49 -0
  1366. package/src/common/accessibility.ts +33 -33
  1367. package/src/common/application-error.spec.ts +27 -27
  1368. package/src/common/application-error.ts +76 -76
  1369. package/src/common/application-protocol.ts +41 -40
  1370. package/src/common/array-utils.ts +129 -129
  1371. package/src/common/buffer.ts +228 -228
  1372. package/src/common/cancellation.ts +163 -163
  1373. package/src/common/char-code.ts +438 -438
  1374. package/src/common/collections.ts +125 -125
  1375. package/src/common/color.ts +103 -103
  1376. package/src/common/command.spec.ts +208 -208
  1377. package/src/common/command.ts +485 -485
  1378. package/src/common/contribution-filter/contribution-filter-registry.ts +79 -79
  1379. package/src/common/contribution-filter/contribution-filter.ts +64 -64
  1380. package/src/common/contribution-filter/filter.ts +23 -23
  1381. package/src/common/contribution-filter/index.ts +19 -19
  1382. package/src/common/contribution-provider.ts +96 -96
  1383. package/src/common/disposable.spec.ts +94 -29
  1384. package/src/common/disposable.ts +188 -135
  1385. package/src/common/encoding-service.ts +380 -380
  1386. package/src/common/encodings.ts +24 -24
  1387. package/src/common/env-variables/env-variables-protocol.ts +38 -38
  1388. package/src/common/env-variables/index.ts +17 -17
  1389. package/src/common/event.spec.ts +32 -32
  1390. package/src/common/event.ts +469 -469
  1391. package/src/{node → common}/file-uri.ts +61 -61
  1392. package/src/common/frontend-application-state.ts +38 -38
  1393. package/src/common/glob.ts +741 -741
  1394. package/src/common/hash.ts +85 -85
  1395. package/src/common/i18n/localization-server.ts +25 -25
  1396. package/src/common/i18n/localization.ts +80 -80
  1397. package/src/common/i18n/nls.metadata.json +31314 -31314
  1398. package/src/common/index.ts +51 -50
  1399. package/src/common/json-schema.ts +106 -106
  1400. package/src/common/key-store.ts +26 -26
  1401. package/src/common/keybinding.ts +152 -152
  1402. package/src/common/keyboard/keyboard-layout-provider.ts +51 -51
  1403. package/src/common/keys.ts +694 -694
  1404. package/src/common/label-protocol.ts +35 -35
  1405. package/src/common/logger-protocol.ts +119 -119
  1406. package/src/common/logger-watcher.ts +48 -48
  1407. package/src/common/logger.spec.ts +46 -46
  1408. package/src/common/logger.ts +389 -389
  1409. package/src/common/lsp-types.ts +34 -34
  1410. package/src/common/markdown-rendering/icon-utilities.ts +30 -30
  1411. package/src/common/markdown-rendering/index.ts +18 -18
  1412. package/src/common/markdown-rendering/markdown-string.ts +152 -149
  1413. package/src/common/menu/action-menu-node.ts +65 -65
  1414. package/src/common/menu/composite-menu-node.ts +114 -114
  1415. package/src/common/menu/index.ts +21 -21
  1416. package/src/common/menu/menu-adapter.ts +103 -103
  1417. package/src/common/menu/menu-model-registry.ts +343 -326
  1418. package/src/common/menu/menu-types.ts +219 -219
  1419. package/src/common/menu/menu.spec.ts +101 -73
  1420. package/src/common/message-rpc/channel.spec.ts +88 -88
  1421. package/src/common/message-rpc/channel.ts +300 -300
  1422. package/src/common/message-rpc/index.ts +22 -22
  1423. package/src/common/message-rpc/message-buffer.ts +105 -105
  1424. package/src/common/message-rpc/msg-pack-extension-manager.ts +70 -70
  1425. package/src/common/message-rpc/rpc-message-encoder.spec.ts +65 -65
  1426. package/src/common/message-rpc/rpc-message-encoder.ts +190 -190
  1427. package/src/common/message-rpc/rpc-protocol.ts +255 -235
  1428. package/src/common/message-rpc/uint8-array-message-buffer.spec.ts +41 -41
  1429. package/src/common/message-rpc/uint8-array-message-buffer.ts +213 -213
  1430. package/src/common/message-service-protocol.ts +148 -148
  1431. package/src/common/message-service.ts +226 -226
  1432. package/src/common/messaging/connection-error-handler.ts +73 -73
  1433. package/src/common/messaging/connection-management.ts +43 -43
  1434. package/src/common/messaging/handler.ts +26 -26
  1435. package/src/common/messaging/index.ts +19 -19
  1436. package/src/common/messaging/proxy-factory.spec.ts +108 -108
  1437. package/src/common/messaging/proxy-factory.ts +336 -343
  1438. package/src/common/messaging/socket-write-buffer.ts +52 -52
  1439. package/src/common/messaging/web-socket-channel.ts +76 -76
  1440. package/src/common/nls.ts +149 -149
  1441. package/src/common/numbers.ts +21 -21
  1442. package/src/common/objects.spec.ts +112 -112
  1443. package/src/common/objects.ts +123 -123
  1444. package/src/common/os.ts +82 -82
  1445. package/src/common/path.spec.ts +415 -415
  1446. package/src/common/path.ts +334 -334
  1447. package/src/common/paths.ts +250 -250
  1448. package/src/common/performance/index.ts +19 -19
  1449. package/src/common/performance/measurement-protocol.ts +104 -104
  1450. package/src/common/performance/measurement.ts +130 -130
  1451. package/src/common/performance/stopwatch.ts +183 -183
  1452. package/src/common/preferences/preference-schema.ts +95 -95
  1453. package/src/common/preferences/preference-scope.spec.ts +48 -48
  1454. package/src/common/preferences/preference-scope.ts +68 -68
  1455. package/src/common/prioritizeable.ts +58 -58
  1456. package/src/common/progress-service-protocol.ts +35 -35
  1457. package/src/common/progress-service.ts +82 -82
  1458. package/src/common/promise-util.spec.ts +72 -72
  1459. package/src/common/promise-util.ts +143 -143
  1460. package/src/common/quick-pick-service.ts +355 -377
  1461. package/src/common/reference.spec.ts +145 -145
  1462. package/src/common/reference.ts +230 -175
  1463. package/src/common/resource.ts +430 -426
  1464. package/src/common/selection-command-handler.ts +101 -101
  1465. package/src/common/selection-service.spec.ts +43 -43
  1466. package/src/common/selection-service.ts +49 -49
  1467. package/src/common/selection.ts +50 -50
  1468. package/src/common/severity.ts +111 -111
  1469. package/src/common/stream.ts +718 -718
  1470. package/src/common/strings.ts +231 -231
  1471. package/src/common/telemetry.ts +45 -45
  1472. package/src/common/ternary-search-tree.ts +417 -417
  1473. package/src/common/test/expect.ts +34 -34
  1474. package/src/common/test/mock-logger.ts +118 -118
  1475. package/src/common/test/mock-menu.ts +35 -35
  1476. package/src/common/test/mock-resource-provider.ts +33 -33
  1477. package/src/common/theme.ts +68 -36
  1478. package/src/common/types.spec.ts +86 -86
  1479. package/src/common/types.ts +140 -140
  1480. package/src/common/uri-command-handler.spec.ts +90 -90
  1481. package/src/common/uri-command-handler.ts +148 -148
  1482. package/src/common/uri.spec.ts +278 -278
  1483. package/src/common/uri.ts +279 -277
  1484. package/src/common/uuid.ts +45 -99
  1485. package/src/common/version.ts +17 -17
  1486. package/src/common/view-column.ts +33 -33
  1487. package/src/common/window.ts +34 -34
  1488. package/src/electron-browser/electron-clipboard-service.ts +32 -32
  1489. package/src/electron-browser/keyboard/electron-keyboard-layout-change-notifier.ts +39 -39
  1490. package/src/electron-browser/keyboard/electron-keyboard-module.ts +28 -28
  1491. package/src/electron-browser/menu/electron-context-menu-renderer.ts +120 -120
  1492. package/src/electron-browser/menu/electron-main-menu-factory.ts +335 -335
  1493. package/src/electron-browser/menu/electron-menu-contribution.ts +506 -498
  1494. package/src/electron-browser/menu/electron-menu-module.ts +40 -40
  1495. package/src/electron-browser/menu/electron-menu-style.css +110 -110
  1496. package/src/electron-browser/messaging/electron-frontend-id-provider.ts +25 -25
  1497. package/src/electron-browser/messaging/electron-ipc-connection-source.ts +65 -65
  1498. package/src/electron-browser/messaging/electron-local-ws-connection-source.ts +45 -45
  1499. package/src/electron-browser/messaging/electron-messaging-frontend-module.ts +78 -78
  1500. package/src/electron-browser/messaging/electron-ws-connection-source.ts +38 -38
  1501. package/src/electron-browser/preload.ts +246 -246
  1502. package/src/electron-browser/request/electron-browser-request-module.ts +26 -26
  1503. package/src/electron-browser/token/electron-token-frontend-module.ts +22 -22
  1504. package/src/electron-browser/window/electron-frontend-application-state.ts +26 -26
  1505. package/src/electron-browser/window/electron-secondary-window-service.ts +39 -39
  1506. package/src/electron-browser/window/electron-window-module.ts +41 -41
  1507. package/src/electron-browser/window/electron-window-preferences.ts +76 -76
  1508. package/src/electron-browser/window/electron-window-service.ts +97 -97
  1509. package/src/electron-common/electron-api.ts +148 -148
  1510. package/src/electron-common/electron-main-window-service.ts +24 -24
  1511. package/src/electron-common/electron-token.ts +27 -27
  1512. package/src/electron-main/electron-api-main.ts +333 -333
  1513. package/src/electron-main/electron-main-application-module.ts +65 -65
  1514. package/src/electron-main/electron-main-application.ts +685 -685
  1515. package/src/electron-main/electron-main-constants.ts +22 -22
  1516. package/src/electron-main/electron-main-window-service-impl.ts +44 -44
  1517. package/src/electron-main/electron-security-token-service.ts +36 -36
  1518. package/src/electron-main/event-utils.ts +36 -36
  1519. package/src/electron-main/messaging/electron-connection-handler.ts +21 -21
  1520. package/src/electron-main/messaging/electron-messaging-contribution.ts +143 -143
  1521. package/src/electron-main/messaging/electron-messaging-service.ts +35 -35
  1522. package/src/electron-main/theia-electron-window.ts +202 -202
  1523. package/src/electron-node/hosting/electron-backend-hosting-module.ts +24 -24
  1524. package/src/electron-node/hosting/electron-ws-origin-validator.ts +37 -37
  1525. package/src/electron-node/keyboard/electron-backend-keyboard-module.ts +30 -30
  1526. package/src/electron-node/keyboard/electron-keyboard-layout-provider.ts +35 -35
  1527. package/src/electron-node/request/electron-backend-request-module.ts +23 -23
  1528. package/src/electron-node/request/electron-backend-request-service.ts +78 -78
  1529. package/src/electron-node/token/electron-token-backend-contribution.ts +48 -48
  1530. package/src/electron-node/token/electron-token-backend-module.ts +28 -28
  1531. package/src/electron-node/token/electron-token-validator.ts +93 -93
  1532. package/src/node/application-server.ts +55 -48
  1533. package/src/node/backend-application-config-provider.spec.ts +29 -29
  1534. package/src/node/backend-application-config-provider.ts +48 -48
  1535. package/src/node/backend-application-module.ts +140 -140
  1536. package/src/node/backend-application.ts +382 -382
  1537. package/src/node/backend-remote-service.ts +25 -25
  1538. package/src/node/cli.spec.ts +94 -94
  1539. package/src/node/cli.ts +63 -63
  1540. package/src/node/console-logger-server.spec.ts +59 -59
  1541. package/src/node/console-logger-server.ts +76 -76
  1542. package/src/node/debug.ts +30 -30
  1543. package/src/node/dynamic-require.ts +56 -56
  1544. package/src/node/env-variables/env-variables-server.ts +120 -120
  1545. package/src/node/env-variables/index.ts +17 -17
  1546. package/src/node/environment-utils.spec.ts +92 -92
  1547. package/src/node/environment-utils.ts +66 -66
  1548. package/src/node/file-uri.spec.ts +76 -76
  1549. package/src/node/filesystem-locking.ts +77 -77
  1550. package/src/node/hosting/backend-application-hosts.ts +60 -60
  1551. package/src/node/hosting/backend-hosting-module.ts +26 -26
  1552. package/src/node/hosting/ws-origin-validator.ts +36 -36
  1553. package/src/node/i18n/i18n-backend-module.ts +42 -42
  1554. package/src/node/i18n/localization-contribution.ts +112 -112
  1555. package/src/node/i18n/localization-provider.ts +125 -125
  1556. package/src/node/i18n/localization-server.ts +52 -52
  1557. package/src/node/i18n/theia-localization-contribution.ts +36 -36
  1558. package/src/node/index.ts +22 -22
  1559. package/src/node/key-store-server.ts +162 -162
  1560. package/src/node/logger-backend-module.ts +88 -88
  1561. package/src/node/logger-cli-contribution.spec.ts +245 -245
  1562. package/src/node/logger-cli-contribution.ts +168 -168
  1563. package/src/node/main.ts +33 -33
  1564. package/src/node/messaging/binary-message-pipe.ts +168 -168
  1565. package/src/node/messaging/connection-container-module.ts +96 -96
  1566. package/src/node/messaging/default-messaging-service.ts +129 -129
  1567. package/src/node/messaging/frontend-connection-service.ts +24 -24
  1568. package/src/node/messaging/index.ts +19 -19
  1569. package/src/node/messaging/ipc-bootstrap.ts +27 -27
  1570. package/src/node/messaging/ipc-channel.ts +77 -77
  1571. package/src/node/messaging/ipc-connection-provider.ts +107 -107
  1572. package/src/node/messaging/ipc-protocol.ts +76 -76
  1573. package/src/node/messaging/messaging-backend-module.ts +52 -52
  1574. package/src/node/messaging/messaging-listeners.ts +52 -52
  1575. package/src/node/messaging/messaging-service.ts +46 -46
  1576. package/src/node/messaging/test/test-web-socket-channel.ts +61 -61
  1577. package/src/node/messaging/websocket-endpoint.ts +79 -79
  1578. package/src/node/messaging/websocket-frontend-connection-service.ts +176 -171
  1579. package/src/node/os-backend-provider.ts +25 -25
  1580. package/src/node/performance/index.ts +18 -18
  1581. package/src/node/performance/measurement-backend-bindings.ts +35 -35
  1582. package/src/node/performance/node-stopwatch.ts +40 -40
  1583. package/src/node/process-utils.spec.ts +48 -48
  1584. package/src/node/process-utils.ts +102 -102
  1585. package/src/node/request/backend-request-facade.ts +39 -39
  1586. package/src/node/request/backend-request-module.ts +25 -25
  1587. package/src/node/request/proxy-cli-contribution.ts +65 -65
  1588. package/src/node/ws-request-validators.ts +56 -56
  1589. package/src/typings/native-keymap.d.ts +108 -108
  1590. package/lib/node/file-uri.d.ts.map +0 -1
  1591. package/lib/node/file-uri.js.map +0 -1
@@ -1,1278 +1,1310 @@
1
- "use strict";
2
- // *****************************************************************************
3
- // Copyright (C) 2018 TypeFox and others.
4
- //
5
- // This program and the accompanying materials are made available under the
6
- // terms of the Eclipse Public License v. 2.0 which is available at
7
- // http://www.eclipse.org/legal/epl-2.0.
8
- //
9
- // This Source Code may also be made available under the following Secondary
10
- // Licenses when the conditions for such availability set forth in the Eclipse
11
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
- // with the GNU Classpath Exception which is available at
13
- // https://www.gnu.org/software/classpath/license.html.
14
- //
15
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
- // *****************************************************************************
17
- Object.defineProperty(exports, "__esModule", { value: true });
18
- exports.SideTabBar = exports.ToolbarAwareTabBar = exports.ScrollableTabBar = exports.TabBarRenderer = exports.TabBarRendererFactory = exports.SHELL_TABBAR_CONTEXT_SPLIT = exports.SHELL_TABBAR_CONTEXT_PIN = exports.SHELL_TABBAR_CONTEXT_COPY = exports.SHELL_TABBAR_CONTEXT_CLOSE = exports.SHELL_TABBAR_CONTEXT_MENU = void 0;
19
- const perfect_scrollbar_1 = require("perfect-scrollbar");
20
- const widgets_1 = require("@phosphor/widgets");
21
- const virtualdom_1 = require("@phosphor/virtualdom");
22
- const common_1 = require("../../common");
23
- const signaling_1 = require("@phosphor/signaling");
24
- const messaging_1 = require("@phosphor/messaging");
25
- const algorithm_1 = require("@phosphor/algorithm");
26
- const domutils_1 = require("@phosphor/domutils");
27
- const theia_dock_panel_1 = require("./theia-dock-panel");
28
- const widget_decoration_1 = require("../widget-decoration");
29
- const navigatable_types_1 = require("../navigatable-types");
30
- const widget_1 = require("../widgets/widget");
31
- const client_1 = require("react-dom/client");
32
- const select_component_1 = require("../widgets/select-component");
33
- const react_1 = require("react");
34
- const previewable_widget_1 = require("../widgets/previewable-widget");
35
- const enhanced_preview_widget_1 = require("../widgets/enhanced-preview-widget");
36
- /** The class name added to hidden content nodes, which are required to render vertical side bars. */
37
- const HIDDEN_CONTENT_CLASS = 'theia-TabBar-hidden-content';
38
- /** Menu path for tab bars used throughout the application shell. */
39
- exports.SHELL_TABBAR_CONTEXT_MENU = ['shell-tabbar-context-menu'];
40
- exports.SHELL_TABBAR_CONTEXT_CLOSE = [...exports.SHELL_TABBAR_CONTEXT_MENU, '0_close'];
41
- exports.SHELL_TABBAR_CONTEXT_COPY = [...exports.SHELL_TABBAR_CONTEXT_MENU, '1_copy'];
42
- // Kept here in anticipation of tab pinning behavior implemented in tab-bars.ts
43
- exports.SHELL_TABBAR_CONTEXT_PIN = [...exports.SHELL_TABBAR_CONTEXT_MENU, '4_pin'];
44
- exports.SHELL_TABBAR_CONTEXT_SPLIT = [...exports.SHELL_TABBAR_CONTEXT_MENU, '5_split'];
45
- exports.TabBarRendererFactory = Symbol('TabBarRendererFactory');
46
- /**
47
- * A tab bar renderer that offers a context menu. In addition, this renderer is able to
48
- * set an explicit position and size on the icon and label of each tab in a side bar.
49
- * This is necessary because the elements of side bar tabs are rotated using the CSS
50
- * `transform` property, disrupting the browser's ability to arrange those elements
51
- * automatically.
52
- */
53
- class TabBarRenderer extends widgets_1.TabBar.Renderer {
54
- // TODO refactor shell, rendered should only receive props with event handlers
55
- // events should be handled by clients, like ApplicationShell
56
- // right now it is mess: (1) client logic belong to renderer, (2) cyclic dependencies between renderers and clients
57
- constructor(contextMenuRenderer, decoratorService, iconThemeService, selectionService, commandService, corePreferences, hoverService) {
58
- super();
59
- this.contextMenuRenderer = contextMenuRenderer;
60
- this.decoratorService = decoratorService;
61
- this.iconThemeService = iconThemeService;
62
- this.selectionService = selectionService;
63
- this.commandService = commandService;
64
- this.corePreferences = corePreferences;
65
- this.hoverService = hoverService;
66
- this.toDispose = new common_1.DisposableCollection();
67
- this.toDisposeOnTabBar = new common_1.DisposableCollection();
68
- this.decorations = new Map();
69
- this.renderEnhancedPreview = (title) => {
70
- const hoverBox = document.createElement('div');
71
- hoverBox.classList.add('theia-horizontal-tabBar-hover-div');
72
- const labelElement = document.createElement('p');
73
- labelElement.classList.add('theia-horizontal-tabBar-hover-title');
74
- labelElement.textContent = title.label;
75
- hoverBox.append(labelElement);
76
- const widget = title.owner;
77
- if (enhanced_preview_widget_1.EnhancedPreviewWidget.is(widget)) {
78
- const enhancedPreviewNode = widget.getEnhancedPreviewNode();
79
- if (enhancedPreviewNode) {
80
- hoverBox.appendChild(enhancedPreviewNode);
81
- }
82
- }
83
- else if (title.caption) {
84
- const captionElement = document.createElement('p');
85
- captionElement.classList.add('theia-horizontal-tabBar-hover-caption');
86
- captionElement.textContent = title.caption;
87
- hoverBox.appendChild(captionElement);
88
- }
89
- return hoverBox;
90
- };
91
- this.handleMouseEnterEvent = (event) => {
92
- var _a;
93
- if (this.tabBar && this.hoverService && event.currentTarget instanceof HTMLElement) {
94
- const id = event.currentTarget.id;
95
- const title = this.tabBar.titles.find(t => this.createTabId(t) === id);
96
- if (title) {
97
- if (this.tabBar.orientation === 'horizontal') {
98
- this.hoverService.requestHover({
99
- content: this.renderEnhancedPreview(title),
100
- target: event.currentTarget,
101
- position: 'bottom',
102
- cssClasses: ['extended-tab-preview'],
103
- visualPreview: ((_a = this.corePreferences) === null || _a === void 0 ? void 0 : _a['window.tabbar.enhancedPreview']) === 'visual' ? width => this.renderVisualPreview(width, title) : undefined
104
- });
105
- }
106
- else {
107
- this.hoverService.requestHover({
108
- content: title.caption,
109
- target: event.currentTarget,
110
- position: 'right'
111
- });
112
- }
113
- }
114
- }
115
- };
116
- this.handleContextMenuEvent = (event) => {
117
- var _a;
118
- if (this.contextMenuRenderer && this.contextMenuPath && event.currentTarget instanceof HTMLElement) {
119
- event.stopPropagation();
120
- event.preventDefault();
121
- let widget = undefined;
122
- if (this.tabBar) {
123
- const titleIndex = Array.from(this.tabBar.contentNode.getElementsByClassName('p-TabBar-tab'))
124
- .findIndex(node => node.contains(event.currentTarget));
125
- if (titleIndex !== -1) {
126
- widget = this.tabBar.titles[titleIndex].owner;
127
- }
128
- }
129
- const oldSelection = (_a = this.selectionService) === null || _a === void 0 ? void 0 : _a.selection;
130
- if (widget && this.selectionService) {
131
- this.selectionService.selection = navigatable_types_1.NavigatableWidget.is(widget) ? { uri: widget.getResourceUri() } : widget;
132
- }
133
- this.contextMenuRenderer.render({
134
- menuPath: this.contextMenuPath,
135
- anchor: event,
136
- args: [event],
137
- // We'd like to wait until the command triggered by the context menu has been run, but this should let it get through the preamble, at least.
138
- onHide: () => setTimeout(() => { if (this.selectionService) {
139
- this.selectionService.selection = oldSelection;
140
- } })
141
- });
142
- }
143
- };
144
- this.handleCloseClickEvent = (event) => {
145
- if (this.tabBar && event.currentTarget instanceof HTMLElement) {
146
- const id = event.currentTarget.parentElement.id;
147
- const title = this.tabBar.titles.find(t => this.createTabId(t) === id);
148
- if ((title === null || title === void 0 ? void 0 : title.closable) === false && (title === null || title === void 0 ? void 0 : title.className.includes(widget_1.PINNED_CLASS)) && this.commandService) {
149
- this.commandService.executeCommand('workbench.action.unpinEditor', event);
150
- }
151
- }
152
- };
153
- this.handleDblClickEvent = (event) => {
154
- var _a;
155
- if (!((_a = this.corePreferences) === null || _a === void 0 ? void 0 : _a.get('workbench.tab.maximize'))) {
156
- return;
157
- }
158
- if (this.tabBar && event.currentTarget instanceof HTMLElement) {
159
- const id = event.currentTarget.id;
160
- const title = this.tabBar.titles.find(t => this.createTabId(t) === id);
161
- const area = title === null || title === void 0 ? void 0 : title.owner.parent;
162
- if (area instanceof theia_dock_panel_1.TheiaDockPanel && (area.id === theia_dock_panel_1.BOTTOM_AREA_ID || area.id === theia_dock_panel_1.MAIN_AREA_ID)) {
163
- area.toggleMaximized();
164
- }
165
- }
166
- };
167
- if (this.decoratorService) {
168
- this.toDispose.push(common_1.Disposable.create(() => this.resetDecorations()));
169
- this.toDispose.push(this.decoratorService.onDidChangeDecorations(() => this.resetDecorations()));
170
- }
171
- if (this.iconThemeService) {
172
- this.toDispose.push(this.iconThemeService.onDidChangeCurrent(() => {
173
- if (this._tabBar) {
174
- this._tabBar.update();
175
- }
176
- }));
177
- }
178
- }
179
- dispose() {
180
- this.toDispose.dispose();
181
- }
182
- /**
183
- * A reference to the tab bar is required in order to activate it when a context menu
184
- * is requested.
185
- */
186
- set tabBar(tabBar) {
187
- if (this.toDispose.disposed) {
188
- throw new Error('disposed');
189
- }
190
- if (this._tabBar === tabBar) {
191
- return;
192
- }
193
- this.toDisposeOnTabBar.dispose();
194
- this.toDispose.push(this.toDisposeOnTabBar);
195
- this._tabBar = tabBar;
196
- if (tabBar) {
197
- const listener = (_, { title }) => this.resetDecorations(title);
198
- tabBar.tabCloseRequested.connect(listener);
199
- this.toDisposeOnTabBar.push(common_1.Disposable.create(() => tabBar.tabCloseRequested.disconnect(listener)));
200
- }
201
- this.resetDecorations();
202
- }
203
- get tabBar() {
204
- return this._tabBar;
205
- }
206
- /**
207
- * Render tabs with the default DOM structure, but additionally register a context menu listener.
208
- * @param {SideBarRenderData} data Data used to render the tab.
209
- * @param {boolean} isInSidePanel An optional check which determines if the tab is in the side-panel.
210
- * @param {boolean} isPartOfHiddenTabBar An optional check which determines if the tab is in the hidden horizontal tab bar.
211
- * @returns {VirtualElement} The virtual element of the rendered tab.
212
- */
213
- renderTab(data, isInSidePanel, isPartOfHiddenTabBar) {
214
- var _a;
215
- const title = data.title;
216
- const id = this.createTabId(title, isPartOfHiddenTabBar);
217
- const key = this.createTabKey(data);
218
- const style = this.createTabStyle(data);
219
- const className = this.createTabClass(data);
220
- const dataset = this.createTabDataset(data);
221
- const closeIconTitle = data.title.className.includes(widget_1.PINNED_CLASS)
222
- ? common_1.nls.localizeByDefault('Unpin')
223
- : common_1.nls.localizeByDefault('Close');
224
- const hover = this.tabBar && (this.tabBar.orientation === 'horizontal' && ((_a = this.corePreferences) === null || _a === void 0 ? void 0 : _a['window.tabbar.enhancedPreview']) === 'classic')
225
- ? { title: title.caption }
226
- : {
227
- onmouseenter: this.handleMouseEnterEvent
228
- };
229
- return virtualdom_1.h.li({
230
- ...hover,
231
- key, className, id, style, dataset,
232
- oncontextmenu: this.handleContextMenuEvent,
233
- ondblclick: this.handleDblClickEvent,
234
- onauxclick: (e) => {
235
- // If user closes the tab using mouse wheel, nothing should be pasted to an active editor
236
- e.preventDefault();
237
- }
238
- }, virtualdom_1.h.div({ className: 'theia-tab-icon-label' }, this.renderIcon(data, isInSidePanel), this.renderLabel(data, isInSidePanel), this.renderBadge(data, isInSidePanel), this.renderLock(data, isInSidePanel)), virtualdom_1.h.div({
239
- className: 'p-TabBar-tabCloseIcon action-label',
240
- title: closeIconTitle,
241
- onclick: this.handleCloseClickEvent
242
- }));
243
- }
244
- createTabClass(data) {
245
- var _a;
246
- let tabClass = super.createTabClass(data);
247
- if (!((_a = data.visible) !== null && _a !== void 0 ? _a : true)) {
248
- tabClass += ' p-mod-invisible';
249
- }
250
- return tabClass;
251
- }
252
- /**
253
- * Generate ID for an entry in the tab bar
254
- * @param {Title<Widget>} title Title of the widget controlled by this tab bar
255
- * @param {boolean} isPartOfHiddenTabBar Tells us if this entry is part of the hidden horizontal tab bar.
256
- * If yes, add a suffix to differentiate it's ID from the entry in the visible tab bar
257
- * @returns {string} DOM element ID
258
- */
259
- createTabId(title, isPartOfHiddenTabBar = false) {
260
- return 'shell-tab-' + title.owner.id + (isPartOfHiddenTabBar ? '-hidden' : '');
261
- }
262
- /**
263
- * If size information is available for the label and icon, set an explicit height on the tab.
264
- * The height value also considers padding, which should be derived from CSS settings.
265
- */
266
- createTabStyle(data) {
267
- const zIndex = `${data.zIndex}`;
268
- const labelSize = data.labelSize;
269
- const iconSize = data.iconSize;
270
- let height;
271
- let width;
272
- if (labelSize || iconSize) {
273
- const labelHeight = labelSize ? (this.tabBar && this.tabBar.orientation === 'horizontal' ? labelSize.height : labelSize.width) : 0;
274
- const iconHeight = iconSize ? iconSize.height : 0;
275
- let paddingTop = data.paddingTop || 0;
276
- if (labelHeight > 0 && iconHeight > 0) {
277
- // Leave some extra space between icon and label
278
- paddingTop = paddingTop * 1.5;
279
- }
280
- const paddingBottom = data.paddingBottom || 0;
281
- height = `${labelHeight + iconHeight + paddingTop + paddingBottom}px`;
282
- }
283
- if (data.tabWidth) {
284
- width = `${data.tabWidth}px`;
285
- }
286
- else {
287
- width = '';
288
- }
289
- return { zIndex, height, minWidth: width, maxWidth: width };
290
- }
291
- /**
292
- * If size information is available for the label, set it as inline style.
293
- * Tab padding and icon size are also considered in the `top` position.
294
- * @param {SideBarRenderData} data Data used to render the tab.
295
- * @param {boolean} isInSidePanel An optional check which determines if the tab is in the side-panel.
296
- * @returns {VirtualElement} The virtual element of the rendered label.
297
- */
298
- renderLabel(data, isInSidePanel) {
299
- const labelSize = data.labelSize;
300
- const iconSize = data.iconSize;
301
- let width;
302
- let height;
303
- let top;
304
- if (labelSize) {
305
- width = `${labelSize.width}px`;
306
- height = `${labelSize.height}px`;
307
- }
308
- if (data.paddingTop || iconSize) {
309
- const iconHeight = iconSize ? iconSize.height : 0;
310
- let paddingTop = data.paddingTop || 0;
311
- if (iconHeight > 0) {
312
- // Leave some extra space between icon and label
313
- paddingTop = paddingTop * 1.5;
314
- }
315
- top = `${paddingTop + iconHeight}px`;
316
- }
317
- const style = { width, height, top };
318
- // No need to check for duplicate labels if the tab is rendered in the side panel (title is not displayed),
319
- // or if there are less than two files in the tab bar.
320
- if (isInSidePanel || (this.tabBar && this.tabBar.titles.length < 2)) {
321
- return virtualdom_1.h.div({ className: 'p-TabBar-tabLabel', style }, data.title.label);
322
- }
323
- const originalToDisplayedMap = this.findDuplicateLabels([...this.tabBar.titles]);
324
- const labelDetails = originalToDisplayedMap.get(data.title.caption);
325
- if (labelDetails) {
326
- return virtualdom_1.h.div({ className: 'p-TabBar-tabLabelWrapper' }, virtualdom_1.h.div({ className: 'p-TabBar-tabLabel', style }, data.title.label), virtualdom_1.h.div({ className: 'p-TabBar-tabLabelDetails', style }, labelDetails));
327
- }
328
- return virtualdom_1.h.div({ className: 'p-TabBar-tabLabel', style }, data.title.label);
329
- }
330
- renderBadge(data, isInSidePanel) {
331
- const totalBadge = this.getDecorationData(data.title, 'badge').reduce((sum, badge) => sum + badge, 0);
332
- if (!totalBadge) {
333
- return virtualdom_1.h.div({});
334
- }
335
- const limitedBadge = totalBadge >= 100 ? '99+' : totalBadge;
336
- return isInSidePanel
337
- ? virtualdom_1.h.div({ className: 'theia-badge-decorator-sidebar' }, `${limitedBadge}`)
338
- : virtualdom_1.h.div({ className: 'theia-badge-decorator-horizontal' }, `${limitedBadge}`);
339
- }
340
- renderLock(data, isInSidePanel) {
341
- return !isInSidePanel && data.title.className.includes(widget_1.LOCKED_CLASS)
342
- ? virtualdom_1.h.div({ className: 'p-TabBar-tabLock' })
343
- : virtualdom_1.h.div({});
344
- }
345
- resetDecorations(title) {
346
- if (title) {
347
- this.decorations.delete(title);
348
- }
349
- else {
350
- this.decorations.clear();
351
- }
352
- if (this.tabBar) {
353
- this.tabBar.update();
354
- }
355
- }
356
- /**
357
- * Get all available decorations of a given tab.
358
- * @param {string} title The widget title.
359
- */
360
- getDecorations(title) {
361
- if (this.tabBar && this.decoratorService) {
362
- const owner = title.owner;
363
- if (!owner.resetTabBarDecorations) {
364
- owner.resetTabBarDecorations = () => this.decorations.delete(title);
365
- title.owner.disposed.connect(owner.resetTabBarDecorations);
366
- }
367
- const decorations = this.decorations.get(title) || this.decoratorService.getDecorations(title);
368
- this.decorations.set(title, decorations);
369
- return decorations;
370
- }
371
- return [];
372
- }
373
- /**
374
- * Get the decoration data given the tab URI and the decoration data type.
375
- * @param {string} title The title.
376
- * @param {K} key The type of the decoration data.
377
- */
378
- getDecorationData(title, key) {
379
- return this.getDecorations(title).filter(data => data[key] !== undefined).map(data => data[key]);
380
- }
381
- /**
382
- * Get the class of an icon.
383
- * @param {string | string[]} iconName The name of the icon.
384
- * @param {string[]} additionalClasses Additional classes of the icon.
385
- */
386
- getIconClass(iconName, additionalClasses = []) {
387
- const iconClass = (typeof iconName === 'string') ? ['a', 'fa', `fa-${iconName}`] : ['a'].concat(iconName);
388
- return iconClass.concat(additionalClasses).join(' ');
389
- }
390
- /**
391
- * Find duplicate labels from the currently opened tabs in the tab bar.
392
- * Return the appropriate partial paths that can distinguish the identical labels.
393
- *
394
- * E.g., a/p/index.ts => a/..., b/p/index.ts => b/...
395
- *
396
- * To prevent excessively long path displayed, show at maximum three levels from the end by default.
397
- * @param {Title<Widget>[]} titles Array of titles in the current tab bar.
398
- * @returns {Map<string, string>} A map from each tab's original path to its displayed partial path.
399
- */
400
- findDuplicateLabels(titles) {
401
- // Filter from all tabs to group them by the distinct label (file name).
402
- // E.g., 'foo.js' => {0 (index) => 'a/b/foo.js', '2 => a/c/foo.js' },
403
- // 'bar.js' => {1 => 'a/d/bar.js', ...}
404
- const labelGroups = new Map();
405
- titles.forEach((title, index) => {
406
- if (!labelGroups.has(title.label)) {
407
- labelGroups.set(title.label, new Map());
408
- }
409
- labelGroups.get(title.label).set(index, title.caption);
410
- });
411
- const originalToDisplayedMap = new Map();
412
- // Parse each group of editors with the same label.
413
- labelGroups.forEach(labelGroup => {
414
- // Filter to get groups that have duplicates.
415
- if (labelGroup.size > 1) {
416
- const paths = [];
417
- let maxPathLength = 0;
418
- labelGroup.forEach((pathStr, index) => {
419
- const steps = pathStr.split('/');
420
- maxPathLength = Math.max(maxPathLength, steps.length);
421
- paths[index] = (steps.slice(0, steps.length - 1));
422
- // By default, show at maximum three levels from the end.
423
- let defaultDisplayedPath = steps.slice(-4, -1).join('/');
424
- if (steps.length > 4) {
425
- defaultDisplayedPath = '.../' + defaultDisplayedPath;
426
- }
427
- originalToDisplayedMap.set(pathStr, defaultDisplayedPath);
428
- });
429
- // Iterate through the steps of the path from the left to find the step that can distinguish it.
430
- // E.g., ['root', 'foo', 'c'], ['root', 'bar', 'd'] => 'foo', 'bar'
431
- let i = 0;
432
- while (i < maxPathLength - 1) {
433
- // Store indexes of all paths that have the identical element in each step.
434
- const stepOccurrences = new Map();
435
- // Compare the current step of all paths
436
- paths.forEach((path, index) => {
437
- const step = path[i];
438
- if (path.length > 0) {
439
- if (i > path.length - 1) {
440
- paths[index] = [];
441
- }
442
- else if (!stepOccurrences.has(step)) {
443
- stepOccurrences.set(step, [index]);
444
- }
445
- else {
446
- stepOccurrences.get(step).push(index);
447
- }
448
- }
449
- });
450
- // Set the displayed path for each tab.
451
- stepOccurrences.forEach((indexArr, displayedPath) => {
452
- if (indexArr.length === 1) {
453
- const originalPath = labelGroup.get(indexArr[0]);
454
- if (originalPath) {
455
- const originalElements = originalPath.split('/');
456
- const displayedElements = displayedPath.split('/');
457
- if (originalElements.slice(-2)[0] !== displayedElements.slice(-1)[0]) {
458
- displayedPath += '/...';
459
- }
460
- if (originalElements[0] !== displayedElements[0]) {
461
- displayedPath = '.../' + displayedPath;
462
- }
463
- originalToDisplayedMap.set(originalPath, displayedPath);
464
- paths[indexArr[0]] = [];
465
- }
466
- }
467
- });
468
- i++;
469
- }
470
- }
471
- });
472
- return originalToDisplayedMap;
473
- }
474
- /**
475
- * If size information is available for the icon, set it as inline style. Tab padding
476
- * is also considered in the `top` position.
477
- * @param {SideBarRenderData} data Data used to render the tab icon.
478
- * @param {boolean} isInSidePanel An optional check which determines if the tab is in the side-panel.
479
- */
480
- renderIcon(data, isInSidePanel) {
481
- if (!isInSidePanel && this.iconThemeService && this.iconThemeService.current === 'none') {
482
- return virtualdom_1.h.div();
483
- }
484
- let top;
485
- if (data.paddingTop) {
486
- top = `${data.paddingTop || 0}px`;
487
- }
488
- const style = { top };
489
- const baseClassName = this.createIconClass(data);
490
- const overlayIcons = [];
491
- const decorationData = this.getDecorationData(data.title, 'iconOverlay');
492
- // Check if the tab has decoration markers to be rendered on top.
493
- if (decorationData.length > 0) {
494
- const baseIcon = virtualdom_1.h.div({ className: baseClassName, style }, data.title.iconLabel);
495
- const wrapperClassName = widget_decoration_1.WidgetDecoration.Styles.ICON_WRAPPER_CLASS;
496
- const decoratorSizeClassName = isInSidePanel ? widget_decoration_1.WidgetDecoration.Styles.DECORATOR_SIDEBAR_SIZE_CLASS : widget_decoration_1.WidgetDecoration.Styles.DECORATOR_SIZE_CLASS;
497
- decorationData
498
- .filter(common_1.notEmpty)
499
- .map(overlay => [overlay.position, overlay])
500
- .forEach(([position, overlay]) => {
501
- const iconAdditionalClasses = [decoratorSizeClassName, widget_decoration_1.WidgetDecoration.IconOverlayPosition.getStyle(position, isInSidePanel)];
502
- const overlayIconStyle = (color) => {
503
- if (color === undefined) {
504
- return {};
505
- }
506
- return { color };
507
- };
508
- // Parse the optional background (if it exists) of the overlay icon.
509
- if (overlay.background) {
510
- const backgroundIconClassName = this.getIconClass(overlay.background.shape, iconAdditionalClasses);
511
- overlayIcons.push(virtualdom_1.h.div({ key: data.title.label + '-background', className: backgroundIconClassName, style: overlayIconStyle(overlay.background.color) }));
512
- }
513
- // Parse the overlay icon.
514
- const overlayIcon = overlay.icon || overlay.iconClass;
515
- const overlayIconClassName = this.getIconClass(overlayIcon, iconAdditionalClasses);
516
- overlayIcons.push(virtualdom_1.h.span({ key: data.title.label, className: overlayIconClassName, style: overlayIconStyle(overlay.color) }));
517
- });
518
- return virtualdom_1.h.div({ className: wrapperClassName, style }, [baseIcon, ...overlayIcons]);
519
- }
520
- return virtualdom_1.h.div({ className: baseClassName, style }, data.title.iconLabel);
521
- }
522
- renderVisualPreview(desiredWidth, title) {
523
- var _a;
524
- const widget = title.owner;
525
- // Check that the widget is not currently shown, is a PreviewableWidget and it was already loaded before
526
- if (this.tabBar && this.tabBar.currentTitle !== title && previewable_widget_1.PreviewableWidget.isPreviewable(widget)) {
527
- const html = document.getElementById(widget.id);
528
- if (html) {
529
- const previewNode = widget.getPreviewNode();
530
- if (previewNode) {
531
- const clonedNode = previewNode.cloneNode(true);
532
- const visualPreviewDiv = document.createElement('div');
533
- visualPreviewDiv.classList.add('enhanced-preview-container');
534
- // Add the clonedNode and get it from the children to have a HTMLElement instead of a Node
535
- visualPreviewDiv.append(clonedNode);
536
- const visualPreview = visualPreviewDiv.children.item(visualPreviewDiv.children.length - 1);
537
- if (visualPreview instanceof HTMLElement) {
538
- visualPreview.classList.remove('p-mod-hidden');
539
- visualPreview.classList.add('enhanced-preview');
540
- visualPreview.id = `preview:${widget.id}`;
541
- // Use the current visible editor as a fallback if not available
542
- const height = visualPreview.style.height === '' ? this.tabBar.currentTitle.owner.node.offsetHeight : parseFloat(visualPreview.style.height);
543
- const width = visualPreview.style.width === '' ? this.tabBar.currentTitle.owner.node.offsetWidth : parseFloat(visualPreview.style.width);
544
- const desiredRatio = 9 / 16;
545
- const desiredHeight = desiredWidth * desiredRatio;
546
- const ratio = height / width;
547
- visualPreviewDiv.style.width = `${desiredWidth}px`;
548
- visualPreviewDiv.style.height = `${desiredHeight}px`;
549
- // If the view is wider than the desiredRatio scale the width and crop the height. If the view is longer its the other way around.
550
- const scale = ratio < desiredRatio ? (desiredHeight / height) : (desiredWidth / width);
551
- visualPreview.style.transform = `scale(${scale},${scale})`;
552
- visualPreview.style.removeProperty('top');
553
- visualPreview.style.removeProperty('left');
554
- // Copy canvases (They are cloned empty)
555
- const originalCanvases = html.getElementsByTagName('canvas');
556
- const previewCanvases = visualPreview.getElementsByTagName('canvas');
557
- // If this is not given, something went wrong during the cloning
558
- if (originalCanvases.length === previewCanvases.length) {
559
- for (let i = 0; i < originalCanvases.length; i++) {
560
- (_a = previewCanvases[i].getContext('2d')) === null || _a === void 0 ? void 0 : _a.drawImage(originalCanvases[i], 0, 0);
561
- }
562
- }
563
- return visualPreviewDiv;
564
- }
565
- }
566
- }
567
- }
568
- return undefined;
569
- }
570
- }
571
- exports.TabBarRenderer = TabBarRenderer;
572
- /**
573
- * A specialized tab bar for the main and bottom areas.
574
- */
575
- class ScrollableTabBar extends widgets_1.TabBar {
576
- constructor(options, dynamicTabOptions) {
577
- super(options);
578
- this.isMouseOver = false;
579
- this.needsRecompute = false;
580
- this.tabSize = 0;
581
- this.toDispose = new common_1.DisposableCollection();
582
- this.scrollBarFactory = () => new perfect_scrollbar_1.default(this.scrollbarHost, options);
583
- this._dynamicTabOptions = dynamicTabOptions;
584
- this.rewireDOM();
585
- }
586
- set dynamicTabOptions(options) {
587
- this._dynamicTabOptions = options;
588
- this.updateTabs();
589
- }
590
- get dynamicTabOptions() {
591
- return this._dynamicTabOptions;
592
- }
593
- dispose() {
594
- if (this.isDisposed) {
595
- return;
596
- }
597
- super.dispose();
598
- this.toDispose.dispose();
599
- }
600
- /**
601
- * Restructures the DOM defined in PhosphorJS.
602
- *
603
- * By default the tabs (`li`) are contained in the `this.contentNode` (`ul`) which is wrapped in a `div` (`this.node`).
604
- * Instead of this structure, we add a container for the `this.contentNode` and for the toolbar.
605
- * The scrollbar will only work for the `ul` part but it does not affect the toolbar, so it can be on the right hand-side.
606
- */
607
- rewireDOM() {
608
- const contentNode = this.node.getElementsByClassName(ScrollableTabBar.Styles.TAB_BAR_CONTENT)[0];
609
- if (!contentNode) {
610
- throw new Error("'this.node' does not have the content as a direct child with class name 'p-TabBar-content'.");
611
- }
612
- this.node.removeChild(contentNode);
613
- this.contentContainer = document.createElement('div');
614
- this.contentContainer.classList.add(ScrollableTabBar.Styles.TAB_BAR_CONTENT_CONTAINER);
615
- this.contentContainer.appendChild(contentNode);
616
- this.topRow = document.createElement('div');
617
- this.topRow.classList.add('theia-tabBar-tab-row');
618
- this.topRow.appendChild(this.contentContainer);
619
- this.openTabsContainer = document.createElement('div');
620
- this.openTabsContainer.classList.add('theia-tabBar-open-tabs');
621
- this.openTabsRoot = (0, client_1.createRoot)(this.openTabsContainer);
622
- this.topRow.appendChild(this.openTabsContainer);
623
- this.node.appendChild(this.topRow);
624
- }
625
- onAfterAttach(msg) {
626
- if (!this.scrollBar) {
627
- this.scrollBar = this.scrollBarFactory();
628
- }
629
- this.node.addEventListener('mouseenter', () => { this.isMouseOver = true; });
630
- this.node.addEventListener('mouseleave', () => {
631
- this.isMouseOver = false;
632
- if (this.needsRecompute) {
633
- this.updateTabs();
634
- }
635
- });
636
- super.onAfterAttach(msg);
637
- }
638
- onBeforeDetach(msg) {
639
- super.onBeforeDetach(msg);
640
- if (this.scrollBar) {
641
- this.scrollBar.destroy();
642
- this.scrollBar = undefined;
643
- }
644
- }
645
- onUpdateRequest(msg) {
646
- this.updateTabs();
647
- }
648
- updateTabs() {
649
- const content = [];
650
- if (this.dynamicTabOptions) {
651
- this.openTabsRoot.render((0, react_1.createElement)(select_component_1.SelectComponent, {
652
- options: this.titles,
653
- onChange: (option, index) => {
654
- this.currentIndex = index;
655
- },
656
- alignment: 'right'
657
- }));
658
- if (this.isMouseOver) {
659
- this.needsRecompute = true;
660
- }
661
- else {
662
- this.needsRecompute = false;
663
- if (this.orientation === 'horizontal') {
664
- let availableWidth = this.scrollbarHost.clientWidth;
665
- let effectiveWidth = availableWidth;
666
- if (!this.openTabsContainer.classList.contains('p-mod-hidden')) {
667
- availableWidth += this.openTabsContainer.getBoundingClientRect().width;
668
- }
669
- if (this.dynamicTabOptions.minimumTabSize * this.titles.length <= availableWidth) {
670
- effectiveWidth += this.openTabsContainer.getBoundingClientRect().width;
671
- this.openTabsContainer.classList.add('p-mod-hidden');
672
- }
673
- else {
674
- this.openTabsContainer.classList.remove('p-mod-hidden');
675
- }
676
- this.tabSize = Math.max(Math.min(effectiveWidth / this.titles.length, this.dynamicTabOptions.defaultTabSize), this.dynamicTabOptions.minimumTabSize);
677
- }
678
- }
679
- this.node.classList.add('dynamic-tabs');
680
- }
681
- else {
682
- this.openTabsContainer.classList.add('p-mod-hidden');
683
- this.node.classList.remove('dynamic-tabs');
684
- }
685
- for (let i = 0, n = this.titles.length; i < n; ++i) {
686
- const title = this.titles[i];
687
- const current = title === this.currentTitle;
688
- const zIndex = current ? n : n - i - 1;
689
- const renderData = { title: title, current: current, zIndex: zIndex };
690
- if (this.dynamicTabOptions && this.orientation === 'horizontal') {
691
- renderData.tabWidth = this.tabSize;
692
- }
693
- content[i] = this.renderer.renderTab(renderData);
694
- }
695
- virtualdom_1.VirtualDOM.render(content, this.contentNode);
696
- if (this.scrollBar) {
697
- if (!(this.dynamicTabOptions && this.isMouseOver)) {
698
- this.scrollBar.update();
699
- }
700
- }
701
- }
702
- onResize(msg) {
703
- super.onResize(msg);
704
- if (this.dynamicTabOptions) {
705
- this.updateTabs();
706
- }
707
- if (this.scrollBar) {
708
- if (this.currentIndex >= 0) {
709
- this.revealTab(this.currentIndex);
710
- }
711
- this.scrollBar.update();
712
- }
713
- }
714
- /**
715
- * Reveal the tab with the given index by moving the scroll bar if necessary.
716
- */
717
- revealTab(index) {
718
- if (this.pendingReveal) {
719
- // A reveal has already been scheduled
720
- return this.pendingReveal;
721
- }
722
- const result = new Promise((resolve, reject) => {
723
- // The tab might not have been created yet, so wait until the next frame
724
- window.requestAnimationFrame(() => {
725
- const tab = this.contentNode.children[index];
726
- if (tab && this.isVisible) {
727
- const parent = this.scrollbarHost;
728
- if (this.orientation === 'horizontal') {
729
- const scroll = parent.scrollLeft;
730
- const left = tab.offsetLeft;
731
- if (scroll > left) {
732
- parent.scrollLeft = left;
733
- }
734
- else {
735
- const right = left + tab.clientWidth - parent.clientWidth;
736
- if (scroll < right && tab.clientWidth < parent.clientWidth) {
737
- parent.scrollLeft = right;
738
- }
739
- }
740
- }
741
- else {
742
- const scroll = parent.scrollTop;
743
- const top = tab.offsetTop;
744
- if (scroll > top) {
745
- parent.scrollTop = top;
746
- }
747
- else {
748
- const bottom = top + tab.clientHeight - parent.clientHeight;
749
- if (scroll < bottom && tab.clientHeight < parent.clientHeight) {
750
- parent.scrollTop = bottom;
751
- }
752
- }
753
- }
754
- }
755
- if (this.pendingReveal === result) {
756
- this.pendingReveal = undefined;
757
- }
758
- resolve();
759
- });
760
- });
761
- this.pendingReveal = result;
762
- return result;
763
- }
764
- /**
765
- * Overrides the `contentNode` property getter in PhosphorJS' TabBar.
766
- */
767
- // @ts-expect-error TS2611 `TabBar<T>.contentNode` is declared as `readonly contentNode` but is implemented as a getter.
768
- get contentNode() {
769
- return this.tabBarContainer.getElementsByClassName(ToolbarAwareTabBar.Styles.TAB_BAR_CONTENT)[0];
770
- }
771
- /**
772
- * Overrides the scrollable host from the parent class.
773
- */
774
- get scrollbarHost() {
775
- return this.tabBarContainer;
776
- }
777
- get tabBarContainer() {
778
- return this.node.getElementsByClassName(ToolbarAwareTabBar.Styles.TAB_BAR_CONTENT_CONTAINER)[0];
779
- }
780
- }
781
- exports.ScrollableTabBar = ScrollableTabBar;
782
- (function (ScrollableTabBar) {
783
- let Styles;
784
- (function (Styles) {
785
- Styles.TAB_BAR_CONTENT = 'p-TabBar-content';
786
- Styles.TAB_BAR_CONTENT_CONTAINER = 'p-TabBar-content-container';
787
- })(Styles = ScrollableTabBar.Styles || (ScrollableTabBar.Styles = {}));
788
- })(ScrollableTabBar = exports.ScrollableTabBar || (exports.ScrollableTabBar = {}));
789
- /**
790
- * Specialized scrollable tab-bar which comes with toolbar support.
791
- * Instead of the following DOM structure.
792
- *
793
- * +-------------------------+
794
- * |[TAB_0][TAB_1][TAB_2][TAB|
795
- * +-------------Scrollable--+
796
- *
797
- * There is a dedicated HTML element for toolbar which does **not** contained in the scrollable element.
798
- *
799
- * +-------------------------+-----------------+
800
- * |[TAB_0][TAB_1][TAB_2][TAB| Toolbar |
801
- * +-------------Scrollable--+-Non-Scrollable-+
802
- *
803
- */
804
- class ToolbarAwareTabBar extends ScrollableTabBar {
805
- constructor(tabBarToolbarRegistry, tabBarToolbarFactory, breadcrumbsRendererFactory, options, dynamicTabOptions) {
806
- super(options, dynamicTabOptions);
807
- this.tabBarToolbarRegistry = tabBarToolbarRegistry;
808
- this.tabBarToolbarFactory = tabBarToolbarFactory;
809
- this.breadcrumbsRendererFactory = breadcrumbsRendererFactory;
810
- this.breadcrumbsRenderer = this.breadcrumbsRendererFactory();
811
- this.addBreadcrumbs();
812
- this.toolbar = this.tabBarToolbarFactory();
813
- this.toDispose.push(this.tabBarToolbarRegistry.onDidChange(() => this.update()));
814
- this.toDispose.push(this.breadcrumbsRenderer);
815
- this.toDispose.push(this.breadcrumbsRenderer.onDidChangeActiveState(active => {
816
- this.node.classList.toggle('theia-tabBar-multirow', active);
817
- if (this.parent) {
818
- messaging_1.MessageLoop.sendMessage(this.parent, new messaging_1.Message('fit-request'));
819
- }
820
- }));
821
- this.node.classList.toggle('theia-tabBar-multirow', this.breadcrumbsRenderer.active);
822
- const handler = () => this.updateBreadcrumbs();
823
- this.currentChanged.connect(handler);
824
- this.toDispose.push(common_1.Disposable.create(() => this.currentChanged.disconnect(handler)));
825
- }
826
- async updateBreadcrumbs() {
827
- var _a;
828
- const current = (_a = this.currentTitle) === null || _a === void 0 ? void 0 : _a.owner;
829
- const uri = navigatable_types_1.NavigatableWidget.is(current) ? current.getResourceUri() : undefined;
830
- await this.breadcrumbsRenderer.refresh(uri);
831
- }
832
- onAfterAttach(msg) {
833
- if (this.toolbar) {
834
- if (this.toolbar.isAttached) {
835
- widgets_1.Widget.detach(this.toolbar);
836
- }
837
- widgets_1.Widget.attach(this.toolbar, this.topRow);
838
- if (this.breadcrumbsContainer) {
839
- this.node.appendChild(this.breadcrumbsContainer);
840
- }
841
- this.updateBreadcrumbs();
842
- }
843
- super.onAfterAttach(msg);
844
- }
845
- onBeforeDetach(msg) {
846
- if (this.toolbar && this.toolbar.isAttached) {
847
- widgets_1.Widget.detach(this.toolbar);
848
- }
849
- super.onBeforeDetach(msg);
850
- }
851
- onUpdateRequest(msg) {
852
- super.onUpdateRequest(msg);
853
- this.updateToolbar();
854
- }
855
- updateToolbar() {
856
- var _a, _b;
857
- if (!this.toolbar) {
858
- return;
859
- }
860
- const widget = (_b = (_a = this.currentTitle) === null || _a === void 0 ? void 0 : _a.owner) !== null && _b !== void 0 ? _b : undefined;
861
- this.toolbar.updateTarget(widget);
862
- this.updateTabs();
863
- }
864
- handleEvent(event) {
865
- if (event instanceof MouseEvent) {
866
- if (this.toolbar && this.toolbar.shouldHandleMouseEvent(event) || this.isOver(event, this.openTabsContainer)) {
867
- // if the mouse event is over the toolbar part don't handle it.
868
- return;
869
- }
870
- }
871
- super.handleEvent(event);
872
- }
873
- isOver(event, element) {
874
- return element && event.target instanceof Element && element.contains(event.target);
875
- }
876
- /**
877
- * Restructures the DOM defined in PhosphorJS.
878
- *
879
- * By default the tabs (`li`) are contained in the `this.contentNode` (`ul`) which is wrapped in a `div` (`this.node`).
880
- * Instead of this structure, we add a container for the `this.contentNode` and for the toolbar.
881
- * The scrollbar will only work for the `ul` part but it does not affect the toolbar, so it can be on the right hand-side.
882
- */
883
- addBreadcrumbs() {
884
- this.breadcrumbsContainer = document.createElement('div');
885
- this.breadcrumbsContainer.classList.add('theia-tabBar-breadcrumb-row');
886
- this.breadcrumbsContainer.appendChild(this.breadcrumbsRenderer.host);
887
- this.node.appendChild(this.breadcrumbsContainer);
888
- }
889
- }
890
- exports.ToolbarAwareTabBar = ToolbarAwareTabBar;
891
- /**
892
- * A specialized tab bar for side areas.
893
- */
894
- class SideTabBar extends ScrollableTabBar {
895
- constructor(options) {
896
- super(options);
897
- /**
898
- * Emitted when a tab is added to the tab bar.
899
- */
900
- this.tabAdded = new signaling_1.Signal(this);
901
- /**
902
- * Side panels can be collapsed by clicking on the currently selected tab. This signal is
903
- * emitted when the mouse is released on the selected tab without initiating a drag.
904
- */
905
- this.collapseRequested = new signaling_1.Signal(this);
906
- /**
907
- * Emitted when the set of overflowing/hidden tabs changes.
908
- */
909
- this.tabsOverflowChanged = new signaling_1.Signal(this);
910
- this.toCancelViewContainerDND = new common_1.DisposableCollection();
911
- this.cancelViewContainerDND = () => {
912
- this.toCancelViewContainerDND.dispose();
913
- };
914
- /**
915
- * Handles `viewContainerPart` drag enter.
916
- */
917
- this.onDragEnter = (event) => {
918
- this.cancelViewContainerDND();
919
- if (event.mimeData.getData('application/vnd.phosphor.view-container-factory')) {
920
- event.preventDefault();
921
- event.stopPropagation();
922
- }
923
- };
924
- /**
925
- * Handle `viewContainerPart` drag over,
926
- * Defines the appropriate `dropAction` and opens the tab on which the mouse stands on for more than 800 ms.
927
- */
928
- this.onDragOver = (event) => {
929
- const factory = event.mimeData.getData('application/vnd.phosphor.view-container-factory');
930
- const widget = factory && factory();
931
- if (!widget) {
932
- event.dropAction = 'none';
933
- return;
934
- }
935
- event.preventDefault();
936
- event.stopPropagation();
937
- if (!this.toCancelViewContainerDND.disposed) {
938
- event.dropAction = event.proposedAction;
939
- return;
940
- }
941
- const { target, clientX, clientY } = event;
942
- if (target instanceof HTMLElement) {
943
- if (widget.options.disableDraggingToOtherContainers || widget.viewContainer.disableDNDBetweenContainers) {
944
- event.dropAction = 'none';
945
- target.classList.add('theia-cursor-no-drop');
946
- this.toCancelViewContainerDND.push(common_1.Disposable.create(() => {
947
- target.classList.remove('theia-cursor-no-drop');
948
- }));
949
- }
950
- else {
951
- event.dropAction = event.proposedAction;
952
- }
953
- const { top, bottom, left, right, height } = target.getBoundingClientRect();
954
- const mouseOnTop = (clientY - top) < (height / 2);
955
- const dropTargetClass = `drop-target-${mouseOnTop ? 'top' : 'bottom'}`;
956
- const tabs = this.contentNode.children;
957
- const targetTab = algorithm_1.ArrayExt.findFirstValue(tabs, t => domutils_1.ElementExt.hitTest(t, clientX, clientY));
958
- if (!targetTab) {
959
- return;
960
- }
961
- targetTab.classList.add(dropTargetClass);
962
- this.toCancelViewContainerDND.push(common_1.Disposable.create(() => {
963
- if (targetTab) {
964
- targetTab.classList.remove(dropTargetClass);
965
- }
966
- }));
967
- const openTabTimer = setTimeout(() => {
968
- const title = this.titles.find(t => this.renderer.createTabId(t) === targetTab.id);
969
- if (title) {
970
- const mouseStillOnTab = clientX >= left && clientX <= right && clientY >= top && clientY <= bottom;
971
- if (mouseStillOnTab) {
972
- this.currentTitle = title;
973
- }
974
- }
975
- }, 800);
976
- this.toCancelViewContainerDND.push(common_1.Disposable.create(() => {
977
- clearTimeout(openTabTimer);
978
- }));
979
- }
980
- };
981
- // Create the hidden content node (see `hiddenContentNode` for explanation)
982
- const hiddenContent = document.createElement('ul');
983
- hiddenContent.className = HIDDEN_CONTENT_CLASS;
984
- this.node.appendChild(hiddenContent);
985
- }
986
- /**
987
- * Tab bars of the left and right side panel are arranged vertically by rotating their labels.
988
- * Rotation is realized with the CSS `transform` property, which disrupts the browser's ability
989
- * to arrange the involved elements automatically. Therefore the elements are arranged explicitly
990
- * by the TabBarRenderer using inline `height` and `top` styles. However, the size of labels
991
- * must still be computed by the browser, so the rendering is performed in two steps: first the
992
- * tab bar is rendered horizontally inside a _hidden content node_, then it is rendered again
993
- * vertically inside the proper content node. After the first step, size information is gathered
994
- * from all labels so it can be applied during the second step.
995
- */
996
- get hiddenContentNode() {
997
- return this.node.getElementsByClassName(HIDDEN_CONTENT_CLASS)[0];
998
- }
999
- insertTab(index, value) {
1000
- const result = super.insertTab(index, value);
1001
- this.tabAdded.emit({ title: result });
1002
- return result;
1003
- }
1004
- onAfterAttach(msg) {
1005
- this.updateTabs();
1006
- this.node.addEventListener('p-dragenter', this);
1007
- this.node.addEventListener('p-dragover', this);
1008
- this.node.addEventListener('p-dragleave', this);
1009
- document.addEventListener('p-drop', this);
1010
- }
1011
- onAfterDetach(msg) {
1012
- super.onAfterDetach(msg);
1013
- this.node.removeEventListener('p-dragenter', this);
1014
- this.node.removeEventListener('p-dragover', this);
1015
- this.node.removeEventListener('p-dragleave', this);
1016
- document.removeEventListener('p-drop', this);
1017
- }
1018
- onUpdateRequest(msg) {
1019
- this.updateTabs();
1020
- }
1021
- onResize(msg) {
1022
- // Tabs need to be updated if there are already overflowing tabs or the current tabs don't fit
1023
- if (this.tabsOverflowData || this.node.clientHeight < this.contentNode.clientHeight) {
1024
- this.updateTabs();
1025
- }
1026
- }
1027
- // Queries the tabRowGap value of the content node. Needed to properly compute overflowing
1028
- // tabs that should be hidden
1029
- get tabRowGap() {
1030
- // We assume that the tab row gap is static i.e. we compute it once an then cache it
1031
- if (!this._rowGap) {
1032
- this._rowGap = this.computeTabRowGap();
1033
- }
1034
- return this._rowGap;
1035
- }
1036
- computeTabRowGap() {
1037
- var _a;
1038
- const style = window.getComputedStyle(this.contentNode);
1039
- const rowGapStyle = style.getPropertyValue('row-gap');
1040
- const numericValue = parseFloat(rowGapStyle);
1041
- const unit = (_a = rowGapStyle.match(/[a-zA-Z]+/)) === null || _a === void 0 ? void 0 : _a[0];
1042
- const tempDiv = document.createElement('div');
1043
- tempDiv.style.height = '1' + unit;
1044
- document.body.appendChild(tempDiv);
1045
- const rowGapValue = numericValue * tempDiv.offsetHeight;
1046
- document.body.removeChild(tempDiv);
1047
- return rowGapValue;
1048
- }
1049
- /**
1050
- * Reveal the tab with the given index by moving it into the non-overflowing tabBar section
1051
- * if necessary.
1052
- */
1053
- revealTab(index) {
1054
- if (this.pendingReveal) {
1055
- // A reveal has already been scheduled
1056
- return this.pendingReveal;
1057
- }
1058
- const result = new Promise(resolve => {
1059
- // The tab might not have been created yet, so wait until the next frame
1060
- window.requestAnimationFrame(() => {
1061
- if (this.tabsOverflowData && index >= this.tabsOverflowData.startIndex) {
1062
- const title = this.titles[index];
1063
- this.insertTab(this.tabsOverflowData.startIndex - 1, title);
1064
- }
1065
- if (this.pendingReveal === result) {
1066
- this.pendingReveal = undefined;
1067
- }
1068
- resolve();
1069
- });
1070
- });
1071
- this.pendingReveal = result;
1072
- return result;
1073
- }
1074
- /**
1075
- * Render the tab bar in the _hidden content node_ (see `hiddenContentNode` for explanation),
1076
- * then gather size information for labels and render it again in the proper content node.
1077
- */
1078
- updateTabs() {
1079
- if (this.isAttached) {
1080
- // Render into the invisible node
1081
- this.renderTabs(this.hiddenContentNode);
1082
- // Await a rendering frame
1083
- window.requestAnimationFrame(() => {
1084
- const hiddenContent = this.hiddenContentNode;
1085
- const n = hiddenContent.children.length;
1086
- const renderData = new Array(n);
1087
- const availableWidth = this.node.clientHeight - this.tabRowGap;
1088
- let actualWidth = 0;
1089
- let overflowStartIndex = -1;
1090
- for (let i = 0; i < n; i++) {
1091
- const hiddenTab = hiddenContent.children[i];
1092
- // Extract tab padding from the computed style
1093
- const tabStyle = window.getComputedStyle(hiddenTab);
1094
- const paddingTop = parseFloat(tabStyle.paddingTop);
1095
- const paddingBottom = parseFloat(tabStyle.paddingBottom);
1096
- const rd = {
1097
- paddingTop,
1098
- paddingBottom
1099
- };
1100
- // Extract label size from the DOM
1101
- const labelElements = hiddenTab.getElementsByClassName('p-TabBar-tabLabel');
1102
- if (labelElements.length === 1) {
1103
- const label = labelElements[0];
1104
- rd.labelSize = { width: label.clientWidth, height: label.clientHeight };
1105
- }
1106
- // Extract icon size from the DOM
1107
- const iconElements = hiddenTab.getElementsByClassName('p-TabBar-tabIcon');
1108
- if (iconElements.length === 1) {
1109
- const icon = iconElements[0];
1110
- rd.iconSize = { width: icon.clientWidth, height: icon.clientHeight };
1111
- actualWidth += icon.clientHeight + paddingTop + paddingBottom + this.tabRowGap;
1112
- if (actualWidth > availableWidth && i !== 0) {
1113
- rd.visible = false;
1114
- if (overflowStartIndex === -1) {
1115
- overflowStartIndex = i;
1116
- }
1117
- }
1118
- renderData[i] = rd;
1119
- }
1120
- }
1121
- // Special handling if only one element is overflowing.
1122
- if (overflowStartIndex === n - 1 && renderData[overflowStartIndex]) {
1123
- if (!this.tabsOverflowData) {
1124
- overflowStartIndex--;
1125
- renderData[overflowStartIndex].visible = false;
1126
- }
1127
- else {
1128
- renderData[overflowStartIndex].visible = true;
1129
- overflowStartIndex = -1;
1130
- }
1131
- }
1132
- // Render into the visible node
1133
- this.renderTabs(this.contentNode, renderData);
1134
- this.computeOverflowingTabsData(overflowStartIndex);
1135
- });
1136
- }
1137
- }
1138
- computeOverflowingTabsData(startIndex) {
1139
- // ensure that render tabs has completed
1140
- window.requestAnimationFrame(() => {
1141
- var _a, _b;
1142
- if (startIndex === -1) {
1143
- if (this.tabsOverflowData) {
1144
- this.tabsOverflowData = undefined;
1145
- this.tabsOverflowChanged.emit({ titles: [], startIndex });
1146
- }
1147
- return;
1148
- }
1149
- const newOverflowingTabs = this.titles.slice(startIndex);
1150
- if (!this.tabsOverflowData) {
1151
- this.tabsOverflowData = { titles: newOverflowingTabs, startIndex };
1152
- this.tabsOverflowChanged.emit(this.tabsOverflowData);
1153
- return;
1154
- }
1155
- if (((_b = newOverflowingTabs.length !== ((_a = this.tabsOverflowData) === null || _a === void 0 ? void 0 : _a.titles.length)) !== null && _b !== void 0 ? _b : 0) ||
1156
- newOverflowingTabs.find((newTitle, i) => { var _a; return newTitle !== ((_a = this.tabsOverflowData) === null || _a === void 0 ? void 0 : _a.titles[i]); }) !== undefined) {
1157
- this.tabsOverflowData = { titles: newOverflowingTabs, startIndex };
1158
- this.tabsOverflowChanged.emit(this.tabsOverflowData);
1159
- }
1160
- });
1161
- }
1162
- /**
1163
- * Render the tab bar using the given DOM element as host. The optional `renderData` is forwarded
1164
- * to the TabBarRenderer.
1165
- */
1166
- renderTabs(host, renderData) {
1167
- const titles = this.titles;
1168
- const n = titles.length;
1169
- const renderer = this.renderer;
1170
- const currentTitle = this.currentTitle;
1171
- const content = new Array(n);
1172
- for (let i = 0; i < n; i++) {
1173
- const title = titles[i];
1174
- const current = title === currentTitle;
1175
- const zIndex = current ? n : n - i - 1;
1176
- let rd;
1177
- if (renderData && i < renderData.length) {
1178
- rd = { title, current, zIndex, ...renderData[i] };
1179
- }
1180
- else {
1181
- rd = { title, current, zIndex };
1182
- }
1183
- // Based on how renderTabs() is called, assume renderData will be undefined when invoked for this.hiddenContentNode
1184
- content[i] = renderer.renderTab(rd, true, renderData === undefined);
1185
- }
1186
- virtualdom_1.VirtualDOM.render(content, host);
1187
- }
1188
- /**
1189
- * The following event processing is used to generate `collapseRequested` signals
1190
- * when the mouse goes up on the currently selected tab without too much movement
1191
- * between `mousedown` and `mouseup`. The movement threshold is the same that
1192
- * is used by the superclass to detect a drag event. The `allowDeselect` option
1193
- * of the TabBar constructor cannot be used here because it is triggered when the
1194
- * mouse goes down, and thus collides with dragging.
1195
- */
1196
- handleEvent(event) {
1197
- switch (event.type) {
1198
- case 'mousedown':
1199
- this.onMouseDown(event);
1200
- super.handleEvent(event);
1201
- break;
1202
- case 'mouseup':
1203
- super.handleEvent(event);
1204
- this.onMouseUp(event);
1205
- break;
1206
- case 'mousemove':
1207
- this.onMouseMove(event);
1208
- super.handleEvent(event);
1209
- break;
1210
- case 'p-dragenter':
1211
- this.onDragEnter(event);
1212
- break;
1213
- case 'p-dragover':
1214
- this.onDragOver(event);
1215
- break;
1216
- case 'p-dragleave':
1217
- case 'p-drop':
1218
- this.cancelViewContainerDND();
1219
- break;
1220
- default:
1221
- super.handleEvent(event);
1222
- }
1223
- }
1224
- onMouseDown(event) {
1225
- // Check for left mouse button and current mouse status
1226
- if (event.button !== 0 || this.mouseData) {
1227
- return;
1228
- }
1229
- // Check whether the mouse went down on the current tab
1230
- const tabs = this.contentNode.children;
1231
- const index = algorithm_1.ArrayExt.findFirstIndex(tabs, tab => domutils_1.ElementExt.hitTest(tab, event.clientX, event.clientY));
1232
- if (index < 0 || index !== this.currentIndex) {
1233
- return;
1234
- }
1235
- // Check whether the close button was clicked
1236
- const icon = tabs[index].querySelector(this.renderer.closeIconSelector);
1237
- if (icon && icon.contains(event.target)) {
1238
- return;
1239
- }
1240
- this.mouseData = {
1241
- pressX: event.clientX,
1242
- pressY: event.clientY,
1243
- mouseDownTabIndex: index
1244
- };
1245
- }
1246
- onMouseUp(event) {
1247
- // Check for left mouse button and current mouse status
1248
- if (event.button !== 0 || !this.mouseData) {
1249
- return;
1250
- }
1251
- // Check whether the mouse went up on the current tab
1252
- const mouseDownTabIndex = this.mouseData.mouseDownTabIndex;
1253
- this.mouseData = undefined;
1254
- const tabs = this.contentNode.children;
1255
- const index = algorithm_1.ArrayExt.findFirstIndex(tabs, tab => domutils_1.ElementExt.hitTest(tab, event.clientX, event.clientY));
1256
- if (index < 0 || index !== mouseDownTabIndex) {
1257
- return;
1258
- }
1259
- // Collapse the side bar
1260
- this.collapseRequested.emit(this.titles[index]);
1261
- }
1262
- onMouseMove(event) {
1263
- // Check for left mouse button and current mouse status
1264
- if (event.button !== 0 || !this.mouseData) {
1265
- return;
1266
- }
1267
- const data = this.mouseData;
1268
- const dx = Math.abs(event.clientX - data.pressX);
1269
- const dy = Math.abs(event.clientY - data.pressY);
1270
- const threshold = SideTabBar.DRAG_THRESHOLD;
1271
- if (dx >= threshold || dy >= threshold) {
1272
- this.mouseData = undefined;
1273
- }
1274
- }
1275
- }
1276
- exports.SideTabBar = SideTabBar;
1277
- SideTabBar.DRAG_THRESHOLD = 5;
1
+ "use strict";
2
+ // *****************************************************************************
3
+ // Copyright (C) 2018 TypeFox and others.
4
+ //
5
+ // This program and the accompanying materials are made available under the
6
+ // terms of the Eclipse Public License v. 2.0 which is available at
7
+ // http://www.eclipse.org/legal/epl-2.0.
8
+ //
9
+ // This Source Code may also be made available under the following Secondary
10
+ // Licenses when the conditions for such availability set forth in the Eclipse
11
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
+ // with the GNU Classpath Exception which is available at
13
+ // https://www.gnu.org/software/classpath/license.html.
14
+ //
15
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
+ // *****************************************************************************
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.SideTabBar = exports.ToolbarAwareTabBar = exports.ScrollableTabBar = exports.TabBarRenderer = exports.TabBarRendererFactory = exports.SHELL_TABBAR_CONTEXT_SPLIT = exports.SHELL_TABBAR_CONTEXT_PIN = exports.SHELL_TABBAR_CONTEXT_COPY = exports.SHELL_TABBAR_CONTEXT_CLOSE = exports.SHELL_TABBAR_CONTEXT_MENU = void 0;
19
+ const perfect_scrollbar_1 = require("perfect-scrollbar");
20
+ const widgets_1 = require("@phosphor/widgets");
21
+ const virtualdom_1 = require("@phosphor/virtualdom");
22
+ const common_1 = require("../../common");
23
+ const signaling_1 = require("@phosphor/signaling");
24
+ const messaging_1 = require("@phosphor/messaging");
25
+ const algorithm_1 = require("@phosphor/algorithm");
26
+ const domutils_1 = require("@phosphor/domutils");
27
+ const theia_dock_panel_1 = require("./theia-dock-panel");
28
+ const widget_decoration_1 = require("../widget-decoration");
29
+ const navigatable_types_1 = require("../navigatable-types");
30
+ const widget_1 = require("../widgets/widget");
31
+ const client_1 = require("react-dom/client");
32
+ const select_component_1 = require("../widgets/select-component");
33
+ const react_1 = require("react");
34
+ const previewable_widget_1 = require("../widgets/previewable-widget");
35
+ const enhanced_preview_widget_1 = require("../widgets/enhanced-preview-widget");
36
+ /** The class name added to hidden content nodes, which are required to render vertical side bars. */
37
+ const HIDDEN_CONTENT_CLASS = 'theia-TabBar-hidden-content';
38
+ /** Menu path for tab bars used throughout the application shell. */
39
+ exports.SHELL_TABBAR_CONTEXT_MENU = ['shell-tabbar-context-menu'];
40
+ exports.SHELL_TABBAR_CONTEXT_CLOSE = [...exports.SHELL_TABBAR_CONTEXT_MENU, '0_close'];
41
+ exports.SHELL_TABBAR_CONTEXT_COPY = [...exports.SHELL_TABBAR_CONTEXT_MENU, '1_copy'];
42
+ // Kept here in anticipation of tab pinning behavior implemented in tab-bars.ts
43
+ exports.SHELL_TABBAR_CONTEXT_PIN = [...exports.SHELL_TABBAR_CONTEXT_MENU, '4_pin'];
44
+ exports.SHELL_TABBAR_CONTEXT_SPLIT = [...exports.SHELL_TABBAR_CONTEXT_MENU, '5_split'];
45
+ exports.TabBarRendererFactory = Symbol('TabBarRendererFactory');
46
+ /**
47
+ * A tab bar renderer that offers a context menu. In addition, this renderer is able to
48
+ * set an explicit position and size on the icon and label of each tab in a side bar.
49
+ * This is necessary because the elements of side bar tabs are rotated using the CSS
50
+ * `transform` property, disrupting the browser's ability to arrange those elements
51
+ * automatically.
52
+ */
53
+ class TabBarRenderer extends widgets_1.TabBar.Renderer {
54
+ // TODO refactor shell, rendered should only receive props with event handlers
55
+ // events should be handled by clients, like ApplicationShell
56
+ // right now it is mess: (1) client logic belong to renderer, (2) cyclic dependencies between renderers and clients
57
+ constructor(contextMenuRenderer, decoratorService, iconThemeService, selectionService, commandService, corePreferences, hoverService) {
58
+ super();
59
+ this.contextMenuRenderer = contextMenuRenderer;
60
+ this.decoratorService = decoratorService;
61
+ this.iconThemeService = iconThemeService;
62
+ this.selectionService = selectionService;
63
+ this.commandService = commandService;
64
+ this.corePreferences = corePreferences;
65
+ this.hoverService = hoverService;
66
+ this.toDispose = new common_1.DisposableCollection();
67
+ this.toDisposeOnTabBar = new common_1.DisposableCollection();
68
+ this.decorations = new Map();
69
+ this.renderEnhancedPreview = (title) => {
70
+ const hoverBox = document.createElement('div');
71
+ hoverBox.classList.add('theia-horizontal-tabBar-hover-div');
72
+ const labelElement = document.createElement('p');
73
+ labelElement.classList.add('theia-horizontal-tabBar-hover-title');
74
+ labelElement.textContent = title.label;
75
+ hoverBox.append(labelElement);
76
+ const widget = title.owner;
77
+ if (enhanced_preview_widget_1.EnhancedPreviewWidget.is(widget)) {
78
+ const enhancedPreviewNode = widget.getEnhancedPreviewNode();
79
+ if (enhancedPreviewNode) {
80
+ hoverBox.appendChild(enhancedPreviewNode);
81
+ }
82
+ }
83
+ else if (title.caption) {
84
+ const captionElement = document.createElement('p');
85
+ captionElement.classList.add('theia-horizontal-tabBar-hover-caption');
86
+ captionElement.textContent = title.caption;
87
+ hoverBox.appendChild(captionElement);
88
+ }
89
+ return hoverBox;
90
+ };
91
+ this.handleMouseEnterEvent = (event) => {
92
+ var _a;
93
+ if (this.tabBar && this.hoverService && event.currentTarget instanceof HTMLElement) {
94
+ const id = event.currentTarget.id;
95
+ const title = this.tabBar.titles.find(t => this.createTabId(t) === id);
96
+ if (title) {
97
+ if (this.tabBar.orientation === 'horizontal') {
98
+ this.hoverService.requestHover({
99
+ content: this.renderEnhancedPreview(title),
100
+ target: event.currentTarget,
101
+ position: 'bottom',
102
+ cssClasses: ['extended-tab-preview'],
103
+ visualPreview: ((_a = this.corePreferences) === null || _a === void 0 ? void 0 : _a['window.tabbar.enhancedPreview']) === 'visual' ? width => this.renderVisualPreview(width, title) : undefined
104
+ });
105
+ }
106
+ else {
107
+ this.hoverService.requestHover({
108
+ content: title.caption,
109
+ target: event.currentTarget,
110
+ position: 'right'
111
+ });
112
+ }
113
+ }
114
+ }
115
+ };
116
+ this.handleContextMenuEvent = (event) => {
117
+ var _a;
118
+ if (this.contextMenuRenderer && this.contextMenuPath && event.currentTarget instanceof HTMLElement) {
119
+ event.stopPropagation();
120
+ event.preventDefault();
121
+ let widget = undefined;
122
+ if (this.tabBar) {
123
+ const titleIndex = Array.from(this.tabBar.contentNode.getElementsByClassName('p-TabBar-tab'))
124
+ .findIndex(node => node.contains(event.currentTarget));
125
+ if (titleIndex !== -1) {
126
+ widget = this.tabBar.titles[titleIndex].owner;
127
+ }
128
+ }
129
+ const oldSelection = (_a = this.selectionService) === null || _a === void 0 ? void 0 : _a.selection;
130
+ if (widget && this.selectionService) {
131
+ this.selectionService.selection = navigatable_types_1.NavigatableWidget.is(widget) ? { uri: widget.getResourceUri() } : widget;
132
+ }
133
+ this.contextMenuRenderer.render({
134
+ menuPath: this.contextMenuPath,
135
+ anchor: event,
136
+ args: [event],
137
+ // We'd like to wait until the command triggered by the context menu has been run, but this should let it get through the preamble, at least.
138
+ onHide: () => setTimeout(() => { if (this.selectionService) {
139
+ this.selectionService.selection = oldSelection;
140
+ } })
141
+ });
142
+ }
143
+ };
144
+ this.handleCloseClickEvent = (event) => {
145
+ if (this.tabBar && event.currentTarget instanceof HTMLElement) {
146
+ const id = event.currentTarget.parentElement.id;
147
+ const title = this.tabBar.titles.find(t => this.createTabId(t) === id);
148
+ if ((title === null || title === void 0 ? void 0 : title.closable) === false && (title === null || title === void 0 ? void 0 : title.className.includes(widget_1.PINNED_CLASS)) && this.commandService) {
149
+ this.commandService.executeCommand('workbench.action.unpinEditor', event);
150
+ }
151
+ }
152
+ };
153
+ this.handleDblClickEvent = (event) => {
154
+ var _a;
155
+ if (!((_a = this.corePreferences) === null || _a === void 0 ? void 0 : _a.get('workbench.tab.maximize'))) {
156
+ return;
157
+ }
158
+ if (this.tabBar && event.currentTarget instanceof HTMLElement) {
159
+ const id = event.currentTarget.id;
160
+ const title = this.tabBar.titles.find(t => this.createTabId(t) === id);
161
+ const area = title === null || title === void 0 ? void 0 : title.owner.parent;
162
+ if (area instanceof theia_dock_panel_1.TheiaDockPanel && (area.id === theia_dock_panel_1.BOTTOM_AREA_ID || area.id === theia_dock_panel_1.MAIN_AREA_ID)) {
163
+ area.toggleMaximized();
164
+ }
165
+ }
166
+ };
167
+ if (this.decoratorService) {
168
+ this.toDispose.push(common_1.Disposable.create(() => this.resetDecorations()));
169
+ this.toDispose.push(this.decoratorService.onDidChangeDecorations(() => this.resetDecorations()));
170
+ }
171
+ if (this.iconThemeService) {
172
+ this.toDispose.push(this.iconThemeService.onDidChangeCurrent(() => {
173
+ if (this._tabBar) {
174
+ this._tabBar.update();
175
+ }
176
+ }));
177
+ }
178
+ }
179
+ dispose() {
180
+ this.toDispose.dispose();
181
+ }
182
+ /**
183
+ * A reference to the tab bar is required in order to activate it when a context menu
184
+ * is requested.
185
+ */
186
+ set tabBar(tabBar) {
187
+ if (this.toDispose.disposed) {
188
+ throw new Error('disposed');
189
+ }
190
+ if (this._tabBar === tabBar) {
191
+ return;
192
+ }
193
+ this.toDisposeOnTabBar.dispose();
194
+ this.toDispose.push(this.toDisposeOnTabBar);
195
+ this._tabBar = tabBar;
196
+ if (tabBar) {
197
+ const listener = (_, { title }) => this.resetDecorations(title);
198
+ tabBar.tabCloseRequested.connect(listener);
199
+ this.toDisposeOnTabBar.push(common_1.Disposable.create(() => tabBar.tabCloseRequested.disconnect(listener)));
200
+ }
201
+ this.resetDecorations();
202
+ }
203
+ get tabBar() {
204
+ return this._tabBar;
205
+ }
206
+ /**
207
+ * Render tabs with the default DOM structure, but additionally register a context menu listener.
208
+ * @param {SideBarRenderData} data Data used to render the tab.
209
+ * @param {boolean} isInSidePanel An optional check which determines if the tab is in the side-panel.
210
+ * @param {boolean} isPartOfHiddenTabBar An optional check which determines if the tab is in the hidden horizontal tab bar.
211
+ * @returns {VirtualElement} The virtual element of the rendered tab.
212
+ */
213
+ renderTab(data, isInSidePanel, isPartOfHiddenTabBar) {
214
+ var _a;
215
+ const title = data.title;
216
+ const id = this.createTabId(title, isPartOfHiddenTabBar);
217
+ const key = this.createTabKey(data);
218
+ const style = this.createTabStyle(data);
219
+ const className = this.createTabClass(data);
220
+ const dataset = this.createTabDataset(data);
221
+ const closeIconTitle = data.title.className.includes(widget_1.PINNED_CLASS)
222
+ ? common_1.nls.localizeByDefault('Unpin')
223
+ : common_1.nls.localizeByDefault('Close');
224
+ const hover = this.tabBar && (this.tabBar.orientation === 'horizontal' && ((_a = this.corePreferences) === null || _a === void 0 ? void 0 : _a['window.tabbar.enhancedPreview']) === 'classic')
225
+ ? { title: title.caption }
226
+ : {
227
+ onmouseenter: this.handleMouseEnterEvent
228
+ };
229
+ return virtualdom_1.h.li({
230
+ ...hover,
231
+ key, className, id, style, dataset,
232
+ oncontextmenu: this.handleContextMenuEvent,
233
+ ondblclick: this.handleDblClickEvent,
234
+ onauxclick: (e) => {
235
+ // If user closes the tab using mouse wheel, nothing should be pasted to an active editor
236
+ e.preventDefault();
237
+ }
238
+ }, virtualdom_1.h.div({ className: 'theia-tab-icon-label' }, this.renderIcon(data, isInSidePanel), this.renderLabel(data, isInSidePanel), this.renderTailDecorations(data, isInSidePanel), this.renderBadge(data, isInSidePanel), this.renderLock(data, isInSidePanel)), virtualdom_1.h.div({
239
+ className: 'p-TabBar-tabCloseIcon action-label',
240
+ title: closeIconTitle,
241
+ onclick: this.handleCloseClickEvent
242
+ }));
243
+ }
244
+ createTabClass(data) {
245
+ var _a;
246
+ let tabClass = super.createTabClass(data);
247
+ if (!((_a = data.visible) !== null && _a !== void 0 ? _a : true)) {
248
+ tabClass += ' p-mod-invisible';
249
+ }
250
+ return tabClass;
251
+ }
252
+ /**
253
+ * Generate ID for an entry in the tab bar
254
+ * @param {Title<Widget>} title Title of the widget controlled by this tab bar
255
+ * @param {boolean} isPartOfHiddenTabBar Tells us if this entry is part of the hidden horizontal tab bar.
256
+ * If yes, add a suffix to differentiate it's ID from the entry in the visible tab bar
257
+ * @returns {string} DOM element ID
258
+ */
259
+ createTabId(title, isPartOfHiddenTabBar = false) {
260
+ return 'shell-tab-' + title.owner.id + (isPartOfHiddenTabBar ? '-hidden' : '');
261
+ }
262
+ /**
263
+ * If size information is available for the label and icon, set an explicit height on the tab.
264
+ * The height value also considers padding, which should be derived from CSS settings.
265
+ */
266
+ createTabStyle(data) {
267
+ const zIndex = `${data.zIndex}`;
268
+ const labelSize = data.labelSize;
269
+ const iconSize = data.iconSize;
270
+ let height;
271
+ let width;
272
+ if (labelSize || iconSize) {
273
+ const labelHeight = labelSize ? (this.tabBar && this.tabBar.orientation === 'horizontal' ? labelSize.height : labelSize.width) : 0;
274
+ const iconHeight = iconSize ? iconSize.height : 0;
275
+ let paddingTop = data.paddingTop || 0;
276
+ if (labelHeight > 0 && iconHeight > 0) {
277
+ // Leave some extra space between icon and label
278
+ paddingTop = paddingTop * 1.5;
279
+ }
280
+ const paddingBottom = data.paddingBottom || 0;
281
+ height = `${labelHeight + iconHeight + paddingTop + paddingBottom}px`;
282
+ }
283
+ if (data.tabWidth) {
284
+ width = `${data.tabWidth}px`;
285
+ }
286
+ else {
287
+ width = '';
288
+ }
289
+ return { zIndex, height, minWidth: width, maxWidth: width };
290
+ }
291
+ /**
292
+ * If size information is available for the label, set it as inline style.
293
+ * Tab padding and icon size are also considered in the `top` position.
294
+ * @param {SideBarRenderData} data Data used to render the tab.
295
+ * @param {boolean} isInSidePanel An optional check which determines if the tab is in the side-panel.
296
+ * @returns {VirtualElement} The virtual element of the rendered label.
297
+ */
298
+ renderLabel(data, isInSidePanel) {
299
+ const labelSize = data.labelSize;
300
+ const iconSize = data.iconSize;
301
+ let width;
302
+ let height;
303
+ let top;
304
+ if (labelSize) {
305
+ width = `${labelSize.width}px`;
306
+ height = `${labelSize.height}px`;
307
+ }
308
+ if (data.paddingTop || iconSize) {
309
+ const iconHeight = iconSize ? iconSize.height : 0;
310
+ let paddingTop = data.paddingTop || 0;
311
+ if (iconHeight > 0) {
312
+ // Leave some extra space between icon and label
313
+ paddingTop = paddingTop * 1.5;
314
+ }
315
+ top = `${paddingTop + iconHeight}px`;
316
+ }
317
+ const style = { width, height, top };
318
+ // No need to check for duplicate labels if the tab is rendered in the side panel (title is not displayed),
319
+ // or if there are less than two files in the tab bar.
320
+ if (isInSidePanel || (this.tabBar && this.tabBar.titles.length < 2)) {
321
+ return virtualdom_1.h.div({ className: 'p-TabBar-tabLabel', style }, data.title.label);
322
+ }
323
+ const originalToDisplayedMap = this.findDuplicateLabels([...this.tabBar.titles]);
324
+ const labelDetails = originalToDisplayedMap.get(data.title.caption);
325
+ if (labelDetails) {
326
+ return virtualdom_1.h.div({ className: 'p-TabBar-tabLabelWrapper' }, virtualdom_1.h.div({ className: 'p-TabBar-tabLabel', style }, data.title.label), virtualdom_1.h.div({ className: 'p-TabBar-tabLabelDetails', style }, labelDetails));
327
+ }
328
+ return virtualdom_1.h.div({ className: 'p-TabBar-tabLabel', style }, data.title.label);
329
+ }
330
+ renderTailDecorations(renderData, isInSidePanel) {
331
+ var _a;
332
+ if (!((_a = this.corePreferences) === null || _a === void 0 ? void 0 : _a.get('workbench.editor.decorations.badges'))) {
333
+ return [];
334
+ }
335
+ const tailDecorations = common_1.ArrayUtils.coalesce(this.getDecorationData(renderData.title, 'tailDecorations')).flat();
336
+ if (tailDecorations === undefined || tailDecorations.length === 0) {
337
+ return [];
338
+ }
339
+ let dotDecoration;
340
+ const otherDecorations = [];
341
+ tailDecorations.reverse().forEach(decoration => {
342
+ const partial = decoration;
343
+ if (widget_decoration_1.WidgetDecoration.TailDecoration.isDotDecoration(partial)) {
344
+ dotDecoration || (dotDecoration = partial);
345
+ }
346
+ else if (partial.data || partial.icon || partial.iconClass) {
347
+ otherDecorations.push(partial);
348
+ }
349
+ });
350
+ const decorationsToRender = dotDecoration ? [dotDecoration, ...otherDecorations] : otherDecorations;
351
+ return decorationsToRender.map((decoration, index) => {
352
+ const { tooltip, data, fontData, color, icon, iconClass } = decoration;
353
+ const iconToRender = icon !== null && icon !== void 0 ? icon : iconClass;
354
+ const className = ['p-TabBar-tail', 'flex'].join(' ');
355
+ const style = fontData ? fontData : color ? { color } : undefined;
356
+ const content = (data ? data : iconToRender
357
+ ? virtualdom_1.h.span({ className: this.getIconClass(iconToRender, iconToRender === 'circle' ? [widget_decoration_1.WidgetDecoration.Styles.DECORATOR_SIZE_CLASS] : []) })
358
+ : '') + (index !== decorationsToRender.length - 1 ? ',' : '');
359
+ return virtualdom_1.h.span({ key: ('tailDecoration_' + index), className, style, title: tooltip !== null && tooltip !== void 0 ? tooltip : content }, content);
360
+ });
361
+ }
362
+ renderBadge(data, isInSidePanel) {
363
+ const totalBadge = this.getDecorationData(data.title, 'badge').reduce((sum, badge) => sum + badge, 0);
364
+ if (!totalBadge) {
365
+ return virtualdom_1.h.div({});
366
+ }
367
+ const limitedBadge = totalBadge >= 100 ? '99+' : totalBadge;
368
+ return isInSidePanel
369
+ ? virtualdom_1.h.div({ className: 'theia-badge-decorator-sidebar' }, `${limitedBadge}`)
370
+ : virtualdom_1.h.div({ className: 'theia-badge-decorator-horizontal' }, `${limitedBadge}`);
371
+ }
372
+ renderLock(data, isInSidePanel) {
373
+ return !isInSidePanel && data.title.className.includes(widget_1.LOCKED_CLASS)
374
+ ? virtualdom_1.h.div({ className: 'p-TabBar-tabLock' })
375
+ : virtualdom_1.h.div({});
376
+ }
377
+ resetDecorations(title) {
378
+ if (title) {
379
+ this.decorations.delete(title);
380
+ }
381
+ else {
382
+ this.decorations.clear();
383
+ }
384
+ if (this.tabBar) {
385
+ this.tabBar.update();
386
+ }
387
+ }
388
+ /**
389
+ * Get all available decorations of a given tab.
390
+ * @param {string} title The widget title.
391
+ */
392
+ getDecorations(title) {
393
+ if (this.tabBar && this.decoratorService) {
394
+ const owner = title.owner;
395
+ if (!owner.resetTabBarDecorations) {
396
+ owner.resetTabBarDecorations = () => this.decorations.delete(title);
397
+ title.owner.disposed.connect(owner.resetTabBarDecorations);
398
+ }
399
+ const decorations = this.decorations.get(title) || this.decoratorService.getDecorations(title);
400
+ this.decorations.set(title, decorations);
401
+ return decorations;
402
+ }
403
+ return [];
404
+ }
405
+ /**
406
+ * Get the decoration data given the tab URI and the decoration data type.
407
+ * @param {string} title The title.
408
+ * @param {K} key The type of the decoration data.
409
+ */
410
+ getDecorationData(title, key) {
411
+ return this.getDecorations(title).filter(data => data[key] !== undefined).map(data => data[key]);
412
+ }
413
+ /**
414
+ * Get the class of an icon.
415
+ * @param {string | string[]} iconName The name of the icon.
416
+ * @param {string[]} additionalClasses Additional classes of the icon.
417
+ */
418
+ getIconClass(iconName, additionalClasses = []) {
419
+ const iconClass = (typeof iconName === 'string') ? ['a', 'fa', `fa-${iconName}`] : ['a'].concat(iconName);
420
+ return iconClass.concat(additionalClasses).join(' ');
421
+ }
422
+ /**
423
+ * Find duplicate labels from the currently opened tabs in the tab bar.
424
+ * Return the appropriate partial paths that can distinguish the identical labels.
425
+ *
426
+ * E.g., a/p/index.ts => a/..., b/p/index.ts => b/...
427
+ *
428
+ * To prevent excessively long path displayed, show at maximum three levels from the end by default.
429
+ * @param {Title<Widget>[]} titles Array of titles in the current tab bar.
430
+ * @returns {Map<string, string>} A map from each tab's original path to its displayed partial path.
431
+ */
432
+ findDuplicateLabels(titles) {
433
+ // Filter from all tabs to group them by the distinct label (file name).
434
+ // E.g., 'foo.js' => {0 (index) => 'a/b/foo.js', '2 => a/c/foo.js' },
435
+ // 'bar.js' => {1 => 'a/d/bar.js', ...}
436
+ const labelGroups = new Map();
437
+ titles.forEach((title, index) => {
438
+ if (!labelGroups.has(title.label)) {
439
+ labelGroups.set(title.label, new Map());
440
+ }
441
+ labelGroups.get(title.label).set(index, title.caption);
442
+ });
443
+ const originalToDisplayedMap = new Map();
444
+ // Parse each group of editors with the same label.
445
+ labelGroups.forEach(labelGroup => {
446
+ // Filter to get groups that have duplicates.
447
+ if (labelGroup.size > 1) {
448
+ const paths = [];
449
+ let maxPathLength = 0;
450
+ labelGroup.forEach((pathStr, index) => {
451
+ const steps = pathStr.split('/');
452
+ maxPathLength = Math.max(maxPathLength, steps.length);
453
+ paths[index] = (steps.slice(0, steps.length - 1));
454
+ // By default, show at maximum three levels from the end.
455
+ let defaultDisplayedPath = steps.slice(-4, -1).join('/');
456
+ if (steps.length > 4) {
457
+ defaultDisplayedPath = '.../' + defaultDisplayedPath;
458
+ }
459
+ originalToDisplayedMap.set(pathStr, defaultDisplayedPath);
460
+ });
461
+ // Iterate through the steps of the path from the left to find the step that can distinguish it.
462
+ // E.g., ['root', 'foo', 'c'], ['root', 'bar', 'd'] => 'foo', 'bar'
463
+ let i = 0;
464
+ while (i < maxPathLength - 1) {
465
+ // Store indexes of all paths that have the identical element in each step.
466
+ const stepOccurrences = new Map();
467
+ // Compare the current step of all paths
468
+ paths.forEach((path, index) => {
469
+ const step = path[i];
470
+ if (path.length > 0) {
471
+ if (i > path.length - 1) {
472
+ paths[index] = [];
473
+ }
474
+ else if (!stepOccurrences.has(step)) {
475
+ stepOccurrences.set(step, [index]);
476
+ }
477
+ else {
478
+ stepOccurrences.get(step).push(index);
479
+ }
480
+ }
481
+ });
482
+ // Set the displayed path for each tab.
483
+ stepOccurrences.forEach((indexArr, displayedPath) => {
484
+ if (indexArr.length === 1) {
485
+ const originalPath = labelGroup.get(indexArr[0]);
486
+ if (originalPath) {
487
+ const originalElements = originalPath.split('/');
488
+ const displayedElements = displayedPath.split('/');
489
+ if (originalElements.slice(-2)[0] !== displayedElements.slice(-1)[0]) {
490
+ displayedPath += '/...';
491
+ }
492
+ if (originalElements[0] !== displayedElements[0]) {
493
+ displayedPath = '.../' + displayedPath;
494
+ }
495
+ originalToDisplayedMap.set(originalPath, displayedPath);
496
+ paths[indexArr[0]] = [];
497
+ }
498
+ }
499
+ });
500
+ i++;
501
+ }
502
+ }
503
+ });
504
+ return originalToDisplayedMap;
505
+ }
506
+ /**
507
+ * If size information is available for the icon, set it as inline style. Tab padding
508
+ * is also considered in the `top` position.
509
+ * @param {SideBarRenderData} data Data used to render the tab icon.
510
+ * @param {boolean} isInSidePanel An optional check which determines if the tab is in the side-panel.
511
+ */
512
+ renderIcon(data, isInSidePanel) {
513
+ if (!isInSidePanel && this.iconThemeService && this.iconThemeService.current === 'none') {
514
+ return virtualdom_1.h.div();
515
+ }
516
+ let top;
517
+ if (data.paddingTop) {
518
+ top = `${data.paddingTop || 0}px`;
519
+ }
520
+ const style = { top };
521
+ const baseClassName = this.createIconClass(data);
522
+ const overlayIcons = [];
523
+ const decorationData = this.getDecorationData(data.title, 'iconOverlay');
524
+ // Check if the tab has decoration markers to be rendered on top.
525
+ if (decorationData.length > 0) {
526
+ const baseIcon = virtualdom_1.h.div({ className: baseClassName, style }, data.title.iconLabel);
527
+ const wrapperClassName = widget_decoration_1.WidgetDecoration.Styles.ICON_WRAPPER_CLASS;
528
+ const decoratorSizeClassName = isInSidePanel ? widget_decoration_1.WidgetDecoration.Styles.DECORATOR_SIDEBAR_SIZE_CLASS : widget_decoration_1.WidgetDecoration.Styles.DECORATOR_SIZE_CLASS;
529
+ decorationData
530
+ .filter(common_1.notEmpty)
531
+ .map(overlay => [overlay.position, overlay])
532
+ .forEach(([position, overlay]) => {
533
+ const iconAdditionalClasses = [decoratorSizeClassName, widget_decoration_1.WidgetDecoration.IconOverlayPosition.getStyle(position, isInSidePanel)];
534
+ const overlayIconStyle = (color) => {
535
+ if (color === undefined) {
536
+ return {};
537
+ }
538
+ return { color };
539
+ };
540
+ // Parse the optional background (if it exists) of the overlay icon.
541
+ if (overlay.background) {
542
+ const backgroundIconClassName = this.getIconClass(overlay.background.shape, iconAdditionalClasses);
543
+ overlayIcons.push(virtualdom_1.h.div({ key: data.title.label + '-background', className: backgroundIconClassName, style: overlayIconStyle(overlay.background.color) }));
544
+ }
545
+ // Parse the overlay icon.
546
+ const overlayIcon = overlay.icon || overlay.iconClass;
547
+ const overlayIconClassName = this.getIconClass(overlayIcon, iconAdditionalClasses);
548
+ overlayIcons.push(virtualdom_1.h.span({ key: data.title.label, className: overlayIconClassName, style: overlayIconStyle(overlay.color) }));
549
+ });
550
+ return virtualdom_1.h.div({ className: wrapperClassName, style }, [baseIcon, ...overlayIcons]);
551
+ }
552
+ return virtualdom_1.h.div({ className: baseClassName, style }, data.title.iconLabel);
553
+ }
554
+ renderVisualPreview(desiredWidth, title) {
555
+ var _a;
556
+ const widget = title.owner;
557
+ // Check that the widget is not currently shown, is a PreviewableWidget and it was already loaded before
558
+ if (this.tabBar && this.tabBar.currentTitle !== title && previewable_widget_1.PreviewableWidget.isPreviewable(widget)) {
559
+ const html = document.getElementById(widget.id);
560
+ if (html) {
561
+ const previewNode = widget.getPreviewNode();
562
+ if (previewNode) {
563
+ const clonedNode = previewNode.cloneNode(true);
564
+ const visualPreviewDiv = document.createElement('div');
565
+ visualPreviewDiv.classList.add('enhanced-preview-container');
566
+ // Add the clonedNode and get it from the children to have a HTMLElement instead of a Node
567
+ visualPreviewDiv.append(clonedNode);
568
+ const visualPreview = visualPreviewDiv.children.item(visualPreviewDiv.children.length - 1);
569
+ if (visualPreview instanceof HTMLElement) {
570
+ visualPreview.classList.remove('p-mod-hidden');
571
+ visualPreview.classList.add('enhanced-preview');
572
+ visualPreview.id = `preview:${widget.id}`;
573
+ // Use the current visible editor as a fallback if not available
574
+ const height = visualPreview.style.height === '' ? this.tabBar.currentTitle.owner.node.offsetHeight : parseFloat(visualPreview.style.height);
575
+ const width = visualPreview.style.width === '' ? this.tabBar.currentTitle.owner.node.offsetWidth : parseFloat(visualPreview.style.width);
576
+ const desiredRatio = 9 / 16;
577
+ const desiredHeight = desiredWidth * desiredRatio;
578
+ const ratio = height / width;
579
+ visualPreviewDiv.style.width = `${desiredWidth}px`;
580
+ visualPreviewDiv.style.height = `${desiredHeight}px`;
581
+ // If the view is wider than the desiredRatio scale the width and crop the height. If the view is longer its the other way around.
582
+ const scale = ratio < desiredRatio ? (desiredHeight / height) : (desiredWidth / width);
583
+ visualPreview.style.transform = `scale(${scale},${scale})`;
584
+ visualPreview.style.removeProperty('top');
585
+ visualPreview.style.removeProperty('left');
586
+ // Copy canvases (They are cloned empty)
587
+ const originalCanvases = html.getElementsByTagName('canvas');
588
+ const previewCanvases = visualPreview.getElementsByTagName('canvas');
589
+ // If this is not given, something went wrong during the cloning
590
+ if (originalCanvases.length === previewCanvases.length) {
591
+ for (let i = 0; i < originalCanvases.length; i++) {
592
+ (_a = previewCanvases[i].getContext('2d')) === null || _a === void 0 ? void 0 : _a.drawImage(originalCanvases[i], 0, 0);
593
+ }
594
+ }
595
+ return visualPreviewDiv;
596
+ }
597
+ }
598
+ }
599
+ }
600
+ return undefined;
601
+ }
602
+ }
603
+ exports.TabBarRenderer = TabBarRenderer;
604
+ /**
605
+ * A specialized tab bar for the main and bottom areas.
606
+ */
607
+ class ScrollableTabBar extends widgets_1.TabBar {
608
+ constructor(options, dynamicTabOptions) {
609
+ super(options);
610
+ this.isMouseOver = false;
611
+ this.needsRecompute = false;
612
+ this.tabSize = 0;
613
+ this.toDispose = new common_1.DisposableCollection();
614
+ this.scrollBarFactory = () => new perfect_scrollbar_1.default(this.scrollbarHost, options);
615
+ this._dynamicTabOptions = dynamicTabOptions;
616
+ this.rewireDOM();
617
+ }
618
+ set dynamicTabOptions(options) {
619
+ this._dynamicTabOptions = options;
620
+ this.updateTabs();
621
+ }
622
+ get dynamicTabOptions() {
623
+ return this._dynamicTabOptions;
624
+ }
625
+ dispose() {
626
+ if (this.isDisposed) {
627
+ return;
628
+ }
629
+ super.dispose();
630
+ this.toDispose.dispose();
631
+ }
632
+ /**
633
+ * Restructures the DOM defined in PhosphorJS.
634
+ *
635
+ * By default the tabs (`li`) are contained in the `this.contentNode` (`ul`) which is wrapped in a `div` (`this.node`).
636
+ * Instead of this structure, we add a container for the `this.contentNode` and for the toolbar.
637
+ * The scrollbar will only work for the `ul` part but it does not affect the toolbar, so it can be on the right hand-side.
638
+ */
639
+ rewireDOM() {
640
+ const contentNode = this.node.getElementsByClassName(ScrollableTabBar.Styles.TAB_BAR_CONTENT)[0];
641
+ if (!contentNode) {
642
+ throw new Error("'this.node' does not have the content as a direct child with class name 'p-TabBar-content'.");
643
+ }
644
+ this.node.removeChild(contentNode);
645
+ this.contentContainer = document.createElement('div');
646
+ this.contentContainer.classList.add(ScrollableTabBar.Styles.TAB_BAR_CONTENT_CONTAINER);
647
+ this.contentContainer.appendChild(contentNode);
648
+ this.topRow = document.createElement('div');
649
+ this.topRow.classList.add('theia-tabBar-tab-row');
650
+ this.topRow.appendChild(this.contentContainer);
651
+ this.openTabsContainer = document.createElement('div');
652
+ this.openTabsContainer.classList.add('theia-tabBar-open-tabs');
653
+ this.openTabsRoot = (0, client_1.createRoot)(this.openTabsContainer);
654
+ this.topRow.appendChild(this.openTabsContainer);
655
+ this.node.appendChild(this.topRow);
656
+ }
657
+ onAfterAttach(msg) {
658
+ if (!this.scrollBar) {
659
+ this.scrollBar = this.scrollBarFactory();
660
+ }
661
+ this.node.addEventListener('mouseenter', () => { this.isMouseOver = true; });
662
+ this.node.addEventListener('mouseleave', () => {
663
+ this.isMouseOver = false;
664
+ if (this.needsRecompute) {
665
+ this.updateTabs();
666
+ }
667
+ });
668
+ super.onAfterAttach(msg);
669
+ }
670
+ onBeforeDetach(msg) {
671
+ super.onBeforeDetach(msg);
672
+ if (this.scrollBar) {
673
+ this.scrollBar.destroy();
674
+ this.scrollBar = undefined;
675
+ }
676
+ }
677
+ onUpdateRequest(msg) {
678
+ this.updateTabs();
679
+ }
680
+ updateTabs() {
681
+ const content = [];
682
+ if (this.dynamicTabOptions) {
683
+ this.openTabsRoot.render((0, react_1.createElement)(select_component_1.SelectComponent, {
684
+ options: this.titles,
685
+ onChange: (option, index) => {
686
+ this.currentIndex = index;
687
+ },
688
+ alignment: 'right'
689
+ }));
690
+ if (this.isMouseOver) {
691
+ this.needsRecompute = true;
692
+ }
693
+ else {
694
+ this.needsRecompute = false;
695
+ if (this.orientation === 'horizontal') {
696
+ let availableWidth = this.scrollbarHost.clientWidth;
697
+ let effectiveWidth = availableWidth;
698
+ if (!this.openTabsContainer.classList.contains('p-mod-hidden')) {
699
+ availableWidth += this.openTabsContainer.getBoundingClientRect().width;
700
+ }
701
+ if (this.dynamicTabOptions.minimumTabSize * this.titles.length <= availableWidth) {
702
+ effectiveWidth += this.openTabsContainer.getBoundingClientRect().width;
703
+ this.openTabsContainer.classList.add('p-mod-hidden');
704
+ }
705
+ else {
706
+ this.openTabsContainer.classList.remove('p-mod-hidden');
707
+ }
708
+ this.tabSize = Math.max(Math.min(effectiveWidth / this.titles.length, this.dynamicTabOptions.defaultTabSize), this.dynamicTabOptions.minimumTabSize);
709
+ }
710
+ }
711
+ this.node.classList.add('dynamic-tabs');
712
+ }
713
+ else {
714
+ this.openTabsContainer.classList.add('p-mod-hidden');
715
+ this.node.classList.remove('dynamic-tabs');
716
+ }
717
+ for (let i = 0, n = this.titles.length; i < n; ++i) {
718
+ const title = this.titles[i];
719
+ const current = title === this.currentTitle;
720
+ const zIndex = current ? n : n - i - 1;
721
+ const renderData = { title: title, current: current, zIndex: zIndex };
722
+ if (this.dynamicTabOptions && this.orientation === 'horizontal') {
723
+ renderData.tabWidth = this.tabSize;
724
+ }
725
+ content[i] = this.renderer.renderTab(renderData);
726
+ }
727
+ virtualdom_1.VirtualDOM.render(content, this.contentNode);
728
+ if (this.scrollBar) {
729
+ if (!(this.dynamicTabOptions && this.isMouseOver)) {
730
+ this.scrollBar.update();
731
+ }
732
+ }
733
+ }
734
+ onResize(msg) {
735
+ super.onResize(msg);
736
+ if (this.dynamicTabOptions) {
737
+ this.updateTabs();
738
+ }
739
+ if (this.scrollBar) {
740
+ if (this.currentIndex >= 0) {
741
+ this.revealTab(this.currentIndex);
742
+ }
743
+ this.scrollBar.update();
744
+ }
745
+ }
746
+ /**
747
+ * Reveal the tab with the given index by moving the scroll bar if necessary.
748
+ */
749
+ revealTab(index) {
750
+ if (this.pendingReveal) {
751
+ // A reveal has already been scheduled
752
+ return this.pendingReveal;
753
+ }
754
+ const result = new Promise((resolve, reject) => {
755
+ // The tab might not have been created yet, so wait until the next frame
756
+ window.requestAnimationFrame(() => {
757
+ const tab = this.contentNode.children[index];
758
+ if (tab && this.isVisible) {
759
+ const parent = this.scrollbarHost;
760
+ if (this.orientation === 'horizontal') {
761
+ const scroll = parent.scrollLeft;
762
+ const left = tab.offsetLeft;
763
+ if (scroll > left) {
764
+ parent.scrollLeft = left;
765
+ }
766
+ else {
767
+ const right = left + tab.clientWidth - parent.clientWidth;
768
+ if (scroll < right && tab.clientWidth < parent.clientWidth) {
769
+ parent.scrollLeft = right;
770
+ }
771
+ }
772
+ }
773
+ else {
774
+ const scroll = parent.scrollTop;
775
+ const top = tab.offsetTop;
776
+ if (scroll > top) {
777
+ parent.scrollTop = top;
778
+ }
779
+ else {
780
+ const bottom = top + tab.clientHeight - parent.clientHeight;
781
+ if (scroll < bottom && tab.clientHeight < parent.clientHeight) {
782
+ parent.scrollTop = bottom;
783
+ }
784
+ }
785
+ }
786
+ }
787
+ if (this.pendingReveal === result) {
788
+ this.pendingReveal = undefined;
789
+ }
790
+ resolve();
791
+ });
792
+ });
793
+ this.pendingReveal = result;
794
+ return result;
795
+ }
796
+ /**
797
+ * Overrides the `contentNode` property getter in PhosphorJS' TabBar.
798
+ */
799
+ // @ts-expect-error TS2611 `TabBar<T>.contentNode` is declared as `readonly contentNode` but is implemented as a getter.
800
+ get contentNode() {
801
+ return this.tabBarContainer.getElementsByClassName(ToolbarAwareTabBar.Styles.TAB_BAR_CONTENT)[0];
802
+ }
803
+ /**
804
+ * Overrides the scrollable host from the parent class.
805
+ */
806
+ get scrollbarHost() {
807
+ return this.tabBarContainer;
808
+ }
809
+ get tabBarContainer() {
810
+ return this.node.getElementsByClassName(ToolbarAwareTabBar.Styles.TAB_BAR_CONTENT_CONTAINER)[0];
811
+ }
812
+ }
813
+ exports.ScrollableTabBar = ScrollableTabBar;
814
+ (function (ScrollableTabBar) {
815
+ let Styles;
816
+ (function (Styles) {
817
+ Styles.TAB_BAR_CONTENT = 'p-TabBar-content';
818
+ Styles.TAB_BAR_CONTENT_CONTAINER = 'p-TabBar-content-container';
819
+ })(Styles = ScrollableTabBar.Styles || (ScrollableTabBar.Styles = {}));
820
+ })(ScrollableTabBar = exports.ScrollableTabBar || (exports.ScrollableTabBar = {}));
821
+ /**
822
+ * Specialized scrollable tab-bar which comes with toolbar support.
823
+ * Instead of the following DOM structure.
824
+ *
825
+ * +-------------------------+
826
+ * |[TAB_0][TAB_1][TAB_2][TAB|
827
+ * +-------------Scrollable--+
828
+ *
829
+ * There is a dedicated HTML element for toolbar which does **not** contained in the scrollable element.
830
+ *
831
+ * +-------------------------+-----------------+
832
+ * |[TAB_0][TAB_1][TAB_2][TAB| Toolbar |
833
+ * +-------------Scrollable--+-Non-Scrollable-+
834
+ *
835
+ */
836
+ class ToolbarAwareTabBar extends ScrollableTabBar {
837
+ constructor(tabBarToolbarRegistry, tabBarToolbarFactory, breadcrumbsRendererFactory, options, dynamicTabOptions) {
838
+ super(options, dynamicTabOptions);
839
+ this.tabBarToolbarRegistry = tabBarToolbarRegistry;
840
+ this.tabBarToolbarFactory = tabBarToolbarFactory;
841
+ this.breadcrumbsRendererFactory = breadcrumbsRendererFactory;
842
+ this.breadcrumbsRenderer = this.breadcrumbsRendererFactory();
843
+ this.addBreadcrumbs();
844
+ this.toolbar = this.tabBarToolbarFactory();
845
+ this.toDispose.push(this.tabBarToolbarRegistry.onDidChange(() => this.update()));
846
+ this.toDispose.push(this.breadcrumbsRenderer);
847
+ this.toDispose.push(this.breadcrumbsRenderer.onDidChangeActiveState(active => {
848
+ this.node.classList.toggle('theia-tabBar-multirow', active);
849
+ if (this.parent) {
850
+ messaging_1.MessageLoop.sendMessage(this.parent, new messaging_1.Message('fit-request'));
851
+ }
852
+ }));
853
+ this.node.classList.toggle('theia-tabBar-multirow', this.breadcrumbsRenderer.active);
854
+ const handler = () => this.updateBreadcrumbs();
855
+ this.currentChanged.connect(handler);
856
+ this.toDispose.push(common_1.Disposable.create(() => this.currentChanged.disconnect(handler)));
857
+ }
858
+ async updateBreadcrumbs() {
859
+ var _a;
860
+ const current = (_a = this.currentTitle) === null || _a === void 0 ? void 0 : _a.owner;
861
+ const uri = navigatable_types_1.NavigatableWidget.is(current) ? current.getResourceUri() : undefined;
862
+ await this.breadcrumbsRenderer.refresh(uri);
863
+ }
864
+ onAfterAttach(msg) {
865
+ if (this.toolbar) {
866
+ if (this.toolbar.isAttached) {
867
+ widgets_1.Widget.detach(this.toolbar);
868
+ }
869
+ widgets_1.Widget.attach(this.toolbar, this.topRow);
870
+ if (this.breadcrumbsContainer) {
871
+ this.node.appendChild(this.breadcrumbsContainer);
872
+ }
873
+ this.updateBreadcrumbs();
874
+ }
875
+ super.onAfterAttach(msg);
876
+ }
877
+ onBeforeDetach(msg) {
878
+ if (this.toolbar && this.toolbar.isAttached) {
879
+ this.toolbar.dispose();
880
+ }
881
+ super.onBeforeDetach(msg);
882
+ }
883
+ onUpdateRequest(msg) {
884
+ super.onUpdateRequest(msg);
885
+ this.updateToolbar();
886
+ }
887
+ updateToolbar() {
888
+ var _a, _b;
889
+ if (!this.toolbar) {
890
+ return;
891
+ }
892
+ const widget = (_b = (_a = this.currentTitle) === null || _a === void 0 ? void 0 : _a.owner) !== null && _b !== void 0 ? _b : undefined;
893
+ this.toolbar.updateTarget(widget);
894
+ this.updateTabs();
895
+ }
896
+ handleEvent(event) {
897
+ if (event instanceof MouseEvent) {
898
+ if (this.toolbar && this.toolbar.shouldHandleMouseEvent(event) || this.isOver(event, this.openTabsContainer)) {
899
+ // if the mouse event is over the toolbar part don't handle it.
900
+ return;
901
+ }
902
+ }
903
+ super.handleEvent(event);
904
+ }
905
+ isOver(event, element) {
906
+ return element && event.target instanceof Element && element.contains(event.target);
907
+ }
908
+ /**
909
+ * Restructures the DOM defined in PhosphorJS.
910
+ *
911
+ * By default the tabs (`li`) are contained in the `this.contentNode` (`ul`) which is wrapped in a `div` (`this.node`).
912
+ * Instead of this structure, we add a container for the `this.contentNode` and for the toolbar.
913
+ * The scrollbar will only work for the `ul` part but it does not affect the toolbar, so it can be on the right hand-side.
914
+ */
915
+ addBreadcrumbs() {
916
+ this.breadcrumbsContainer = document.createElement('div');
917
+ this.breadcrumbsContainer.classList.add('theia-tabBar-breadcrumb-row');
918
+ this.breadcrumbsContainer.appendChild(this.breadcrumbsRenderer.host);
919
+ this.node.appendChild(this.breadcrumbsContainer);
920
+ }
921
+ }
922
+ exports.ToolbarAwareTabBar = ToolbarAwareTabBar;
923
+ /**
924
+ * A specialized tab bar for side areas.
925
+ */
926
+ class SideTabBar extends ScrollableTabBar {
927
+ constructor(options) {
928
+ super(options);
929
+ /**
930
+ * Emitted when a tab is added to the tab bar.
931
+ */
932
+ this.tabAdded = new signaling_1.Signal(this);
933
+ /**
934
+ * Side panels can be collapsed by clicking on the currently selected tab. This signal is
935
+ * emitted when the mouse is released on the selected tab without initiating a drag.
936
+ */
937
+ this.collapseRequested = new signaling_1.Signal(this);
938
+ /**
939
+ * Emitted when the set of overflowing/hidden tabs changes.
940
+ */
941
+ this.tabsOverflowChanged = new signaling_1.Signal(this);
942
+ this.toCancelViewContainerDND = new common_1.DisposableCollection();
943
+ this.cancelViewContainerDND = () => {
944
+ this.toCancelViewContainerDND.dispose();
945
+ };
946
+ /**
947
+ * Handles `viewContainerPart` drag enter.
948
+ */
949
+ this.onDragEnter = (event) => {
950
+ this.cancelViewContainerDND();
951
+ if (event.mimeData.getData('application/vnd.phosphor.view-container-factory')) {
952
+ event.preventDefault();
953
+ event.stopPropagation();
954
+ }
955
+ };
956
+ /**
957
+ * Handle `viewContainerPart` drag over,
958
+ * Defines the appropriate `dropAction` and opens the tab on which the mouse stands on for more than 800 ms.
959
+ */
960
+ this.onDragOver = (event) => {
961
+ const factory = event.mimeData.getData('application/vnd.phosphor.view-container-factory');
962
+ const widget = factory && factory();
963
+ if (!widget) {
964
+ event.dropAction = 'none';
965
+ return;
966
+ }
967
+ event.preventDefault();
968
+ event.stopPropagation();
969
+ if (!this.toCancelViewContainerDND.disposed) {
970
+ event.dropAction = event.proposedAction;
971
+ return;
972
+ }
973
+ const { target, clientX, clientY } = event;
974
+ if (target instanceof HTMLElement) {
975
+ if (widget.options.disableDraggingToOtherContainers || widget.viewContainer.disableDNDBetweenContainers) {
976
+ event.dropAction = 'none';
977
+ target.classList.add('theia-cursor-no-drop');
978
+ this.toCancelViewContainerDND.push(common_1.Disposable.create(() => {
979
+ target.classList.remove('theia-cursor-no-drop');
980
+ }));
981
+ }
982
+ else {
983
+ event.dropAction = event.proposedAction;
984
+ }
985
+ const { top, bottom, left, right, height } = target.getBoundingClientRect();
986
+ const mouseOnTop = (clientY - top) < (height / 2);
987
+ const dropTargetClass = `drop-target-${mouseOnTop ? 'top' : 'bottom'}`;
988
+ const tabs = this.contentNode.children;
989
+ const targetTab = algorithm_1.ArrayExt.findFirstValue(tabs, t => domutils_1.ElementExt.hitTest(t, clientX, clientY));
990
+ if (!targetTab) {
991
+ return;
992
+ }
993
+ targetTab.classList.add(dropTargetClass);
994
+ this.toCancelViewContainerDND.push(common_1.Disposable.create(() => {
995
+ if (targetTab) {
996
+ targetTab.classList.remove(dropTargetClass);
997
+ }
998
+ }));
999
+ const openTabTimer = setTimeout(() => {
1000
+ const title = this.titles.find(t => this.renderer.createTabId(t) === targetTab.id);
1001
+ if (title) {
1002
+ const mouseStillOnTab = clientX >= left && clientX <= right && clientY >= top && clientY <= bottom;
1003
+ if (mouseStillOnTab) {
1004
+ this.currentTitle = title;
1005
+ }
1006
+ }
1007
+ }, 800);
1008
+ this.toCancelViewContainerDND.push(common_1.Disposable.create(() => {
1009
+ clearTimeout(openTabTimer);
1010
+ }));
1011
+ }
1012
+ };
1013
+ // Create the hidden content node (see `hiddenContentNode` for explanation)
1014
+ const hiddenContent = document.createElement('ul');
1015
+ hiddenContent.className = HIDDEN_CONTENT_CLASS;
1016
+ this.node.appendChild(hiddenContent);
1017
+ }
1018
+ /**
1019
+ * Tab bars of the left and right side panel are arranged vertically by rotating their labels.
1020
+ * Rotation is realized with the CSS `transform` property, which disrupts the browser's ability
1021
+ * to arrange the involved elements automatically. Therefore the elements are arranged explicitly
1022
+ * by the TabBarRenderer using inline `height` and `top` styles. However, the size of labels
1023
+ * must still be computed by the browser, so the rendering is performed in two steps: first the
1024
+ * tab bar is rendered horizontally inside a _hidden content node_, then it is rendered again
1025
+ * vertically inside the proper content node. After the first step, size information is gathered
1026
+ * from all labels so it can be applied during the second step.
1027
+ */
1028
+ get hiddenContentNode() {
1029
+ return this.node.getElementsByClassName(HIDDEN_CONTENT_CLASS)[0];
1030
+ }
1031
+ insertTab(index, value) {
1032
+ const result = super.insertTab(index, value);
1033
+ this.tabAdded.emit({ title: result });
1034
+ return result;
1035
+ }
1036
+ onAfterAttach(msg) {
1037
+ this.updateTabs();
1038
+ this.node.addEventListener('p-dragenter', this);
1039
+ this.node.addEventListener('p-dragover', this);
1040
+ this.node.addEventListener('p-dragleave', this);
1041
+ document.addEventListener('p-drop', this);
1042
+ }
1043
+ onAfterDetach(msg) {
1044
+ super.onAfterDetach(msg);
1045
+ this.node.removeEventListener('p-dragenter', this);
1046
+ this.node.removeEventListener('p-dragover', this);
1047
+ this.node.removeEventListener('p-dragleave', this);
1048
+ document.removeEventListener('p-drop', this);
1049
+ }
1050
+ onUpdateRequest(msg) {
1051
+ this.updateTabs();
1052
+ }
1053
+ onResize(msg) {
1054
+ // Tabs need to be updated if there are already overflowing tabs or the current tabs don't fit
1055
+ if (this.tabsOverflowData || this.node.clientHeight < this.contentNode.clientHeight) {
1056
+ this.updateTabs();
1057
+ }
1058
+ }
1059
+ // Queries the tabRowGap value of the content node. Needed to properly compute overflowing
1060
+ // tabs that should be hidden
1061
+ get tabRowGap() {
1062
+ // We assume that the tab row gap is static i.e. we compute it once an then cache it
1063
+ if (!this._rowGap) {
1064
+ this._rowGap = this.computeTabRowGap();
1065
+ }
1066
+ return this._rowGap;
1067
+ }
1068
+ computeTabRowGap() {
1069
+ var _a;
1070
+ const style = window.getComputedStyle(this.contentNode);
1071
+ const rowGapStyle = style.getPropertyValue('row-gap');
1072
+ const numericValue = parseFloat(rowGapStyle);
1073
+ const unit = (_a = rowGapStyle.match(/[a-zA-Z]+/)) === null || _a === void 0 ? void 0 : _a[0];
1074
+ const tempDiv = document.createElement('div');
1075
+ tempDiv.style.height = '1' + unit;
1076
+ document.body.appendChild(tempDiv);
1077
+ const rowGapValue = numericValue * tempDiv.offsetHeight;
1078
+ document.body.removeChild(tempDiv);
1079
+ return rowGapValue;
1080
+ }
1081
+ /**
1082
+ * Reveal the tab with the given index by moving it into the non-overflowing tabBar section
1083
+ * if necessary.
1084
+ */
1085
+ revealTab(index) {
1086
+ if (this.pendingReveal) {
1087
+ // A reveal has already been scheduled
1088
+ return this.pendingReveal;
1089
+ }
1090
+ const result = new Promise(resolve => {
1091
+ // The tab might not have been created yet, so wait until the next frame
1092
+ window.requestAnimationFrame(() => {
1093
+ if (this.tabsOverflowData && index >= this.tabsOverflowData.startIndex) {
1094
+ const title = this.titles[index];
1095
+ this.insertTab(this.tabsOverflowData.startIndex - 1, title);
1096
+ }
1097
+ if (this.pendingReveal === result) {
1098
+ this.pendingReveal = undefined;
1099
+ }
1100
+ resolve();
1101
+ });
1102
+ });
1103
+ this.pendingReveal = result;
1104
+ return result;
1105
+ }
1106
+ /**
1107
+ * Render the tab bar in the _hidden content node_ (see `hiddenContentNode` for explanation),
1108
+ * then gather size information for labels and render it again in the proper content node.
1109
+ */
1110
+ updateTabs() {
1111
+ if (this.isAttached) {
1112
+ // Render into the invisible node
1113
+ this.renderTabs(this.hiddenContentNode);
1114
+ // Await a rendering frame
1115
+ window.requestAnimationFrame(() => {
1116
+ const hiddenContent = this.hiddenContentNode;
1117
+ const n = hiddenContent.children.length;
1118
+ const renderData = new Array(n);
1119
+ const availableWidth = this.node.clientHeight - this.tabRowGap;
1120
+ let actualWidth = 0;
1121
+ let overflowStartIndex = -1;
1122
+ for (let i = 0; i < n; i++) {
1123
+ const hiddenTab = hiddenContent.children[i];
1124
+ // Extract tab padding from the computed style
1125
+ const tabStyle = window.getComputedStyle(hiddenTab);
1126
+ const paddingTop = parseFloat(tabStyle.paddingTop);
1127
+ const paddingBottom = parseFloat(tabStyle.paddingBottom);
1128
+ const rd = {
1129
+ paddingTop,
1130
+ paddingBottom
1131
+ };
1132
+ // Extract label size from the DOM
1133
+ const labelElements = hiddenTab.getElementsByClassName('p-TabBar-tabLabel');
1134
+ if (labelElements.length === 1) {
1135
+ const label = labelElements[0];
1136
+ rd.labelSize = { width: label.clientWidth, height: label.clientHeight };
1137
+ }
1138
+ // Extract icon size from the DOM
1139
+ const iconElements = hiddenTab.getElementsByClassName('p-TabBar-tabIcon');
1140
+ if (iconElements.length === 1) {
1141
+ const icon = iconElements[0];
1142
+ rd.iconSize = { width: icon.clientWidth, height: icon.clientHeight };
1143
+ actualWidth += icon.clientHeight + paddingTop + paddingBottom + this.tabRowGap;
1144
+ if (actualWidth > availableWidth && i !== 0) {
1145
+ rd.visible = false;
1146
+ if (overflowStartIndex === -1) {
1147
+ overflowStartIndex = i;
1148
+ }
1149
+ }
1150
+ renderData[i] = rd;
1151
+ }
1152
+ }
1153
+ // Special handling if only one element is overflowing.
1154
+ if (overflowStartIndex === n - 1 && renderData[overflowStartIndex]) {
1155
+ if (!this.tabsOverflowData) {
1156
+ overflowStartIndex--;
1157
+ renderData[overflowStartIndex].visible = false;
1158
+ }
1159
+ else {
1160
+ renderData[overflowStartIndex].visible = true;
1161
+ overflowStartIndex = -1;
1162
+ }
1163
+ }
1164
+ // Render into the visible node
1165
+ this.renderTabs(this.contentNode, renderData);
1166
+ this.computeOverflowingTabsData(overflowStartIndex);
1167
+ });
1168
+ }
1169
+ }
1170
+ computeOverflowingTabsData(startIndex) {
1171
+ // ensure that render tabs has completed
1172
+ window.requestAnimationFrame(() => {
1173
+ var _a, _b;
1174
+ if (startIndex === -1) {
1175
+ if (this.tabsOverflowData) {
1176
+ this.tabsOverflowData = undefined;
1177
+ this.tabsOverflowChanged.emit({ titles: [], startIndex });
1178
+ }
1179
+ return;
1180
+ }
1181
+ const newOverflowingTabs = this.titles.slice(startIndex);
1182
+ if (!this.tabsOverflowData) {
1183
+ this.tabsOverflowData = { titles: newOverflowingTabs, startIndex };
1184
+ this.tabsOverflowChanged.emit(this.tabsOverflowData);
1185
+ return;
1186
+ }
1187
+ if (((_b = newOverflowingTabs.length !== ((_a = this.tabsOverflowData) === null || _a === void 0 ? void 0 : _a.titles.length)) !== null && _b !== void 0 ? _b : 0) ||
1188
+ newOverflowingTabs.find((newTitle, i) => { var _a; return newTitle !== ((_a = this.tabsOverflowData) === null || _a === void 0 ? void 0 : _a.titles[i]); }) !== undefined) {
1189
+ this.tabsOverflowData = { titles: newOverflowingTabs, startIndex };
1190
+ this.tabsOverflowChanged.emit(this.tabsOverflowData);
1191
+ }
1192
+ });
1193
+ }
1194
+ /**
1195
+ * Render the tab bar using the given DOM element as host. The optional `renderData` is forwarded
1196
+ * to the TabBarRenderer.
1197
+ */
1198
+ renderTabs(host, renderData) {
1199
+ const titles = this.titles;
1200
+ const n = titles.length;
1201
+ const renderer = this.renderer;
1202
+ const currentTitle = this.currentTitle;
1203
+ const content = new Array(n);
1204
+ for (let i = 0; i < n; i++) {
1205
+ const title = titles[i];
1206
+ const current = title === currentTitle;
1207
+ const zIndex = current ? n : n - i - 1;
1208
+ let rd;
1209
+ if (renderData && i < renderData.length) {
1210
+ rd = { title, current, zIndex, ...renderData[i] };
1211
+ }
1212
+ else {
1213
+ rd = { title, current, zIndex };
1214
+ }
1215
+ // Based on how renderTabs() is called, assume renderData will be undefined when invoked for this.hiddenContentNode
1216
+ content[i] = renderer.renderTab(rd, true, renderData === undefined);
1217
+ }
1218
+ virtualdom_1.VirtualDOM.render(content, host);
1219
+ }
1220
+ /**
1221
+ * The following event processing is used to generate `collapseRequested` signals
1222
+ * when the mouse goes up on the currently selected tab without too much movement
1223
+ * between `mousedown` and `mouseup`. The movement threshold is the same that
1224
+ * is used by the superclass to detect a drag event. The `allowDeselect` option
1225
+ * of the TabBar constructor cannot be used here because it is triggered when the
1226
+ * mouse goes down, and thus collides with dragging.
1227
+ */
1228
+ handleEvent(event) {
1229
+ switch (event.type) {
1230
+ case 'mousedown':
1231
+ this.onMouseDown(event);
1232
+ super.handleEvent(event);
1233
+ break;
1234
+ case 'mouseup':
1235
+ super.handleEvent(event);
1236
+ this.onMouseUp(event);
1237
+ break;
1238
+ case 'mousemove':
1239
+ this.onMouseMove(event);
1240
+ super.handleEvent(event);
1241
+ break;
1242
+ case 'p-dragenter':
1243
+ this.onDragEnter(event);
1244
+ break;
1245
+ case 'p-dragover':
1246
+ this.onDragOver(event);
1247
+ break;
1248
+ case 'p-dragleave':
1249
+ case 'p-drop':
1250
+ this.cancelViewContainerDND();
1251
+ break;
1252
+ default:
1253
+ super.handleEvent(event);
1254
+ }
1255
+ }
1256
+ onMouseDown(event) {
1257
+ // Check for left mouse button and current mouse status
1258
+ if (event.button !== 0 || this.mouseData) {
1259
+ return;
1260
+ }
1261
+ // Check whether the mouse went down on the current tab
1262
+ const tabs = this.contentNode.children;
1263
+ const index = algorithm_1.ArrayExt.findFirstIndex(tabs, tab => domutils_1.ElementExt.hitTest(tab, event.clientX, event.clientY));
1264
+ if (index < 0 || index !== this.currentIndex) {
1265
+ return;
1266
+ }
1267
+ // Check whether the close button was clicked
1268
+ const icon = tabs[index].querySelector(this.renderer.closeIconSelector);
1269
+ if (icon && icon.contains(event.target)) {
1270
+ return;
1271
+ }
1272
+ this.mouseData = {
1273
+ pressX: event.clientX,
1274
+ pressY: event.clientY,
1275
+ mouseDownTabIndex: index
1276
+ };
1277
+ }
1278
+ onMouseUp(event) {
1279
+ // Check for left mouse button and current mouse status
1280
+ if (event.button !== 0 || !this.mouseData) {
1281
+ return;
1282
+ }
1283
+ // Check whether the mouse went up on the current tab
1284
+ const mouseDownTabIndex = this.mouseData.mouseDownTabIndex;
1285
+ this.mouseData = undefined;
1286
+ const tabs = this.contentNode.children;
1287
+ const index = algorithm_1.ArrayExt.findFirstIndex(tabs, tab => domutils_1.ElementExt.hitTest(tab, event.clientX, event.clientY));
1288
+ if (index < 0 || index !== mouseDownTabIndex) {
1289
+ return;
1290
+ }
1291
+ // Collapse the side bar
1292
+ this.collapseRequested.emit(this.titles[index]);
1293
+ }
1294
+ onMouseMove(event) {
1295
+ // Check for left mouse button and current mouse status
1296
+ if (event.button !== 0 || !this.mouseData) {
1297
+ return;
1298
+ }
1299
+ const data = this.mouseData;
1300
+ const dx = Math.abs(event.clientX - data.pressX);
1301
+ const dy = Math.abs(event.clientY - data.pressY);
1302
+ const threshold = SideTabBar.DRAG_THRESHOLD;
1303
+ if (dx >= threshold || dy >= threshold) {
1304
+ this.mouseData = undefined;
1305
+ }
1306
+ }
1307
+ }
1308
+ exports.SideTabBar = SideTabBar;
1309
+ SideTabBar.DRAG_THRESHOLD = 5;
1278
1310
  //# sourceMappingURL=tab-bars.js.map