@theia/core 1.48.0 → 1.48.1

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