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