@theia/core 1.47.1 → 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 (1531) hide show
  1. package/README.md +6 -6
  2. package/i18n/nls.cs.json +541 -537
  3. package/i18n/nls.de.json +541 -537
  4. package/i18n/nls.es.json +541 -537
  5. package/i18n/nls.fr.json +541 -537
  6. package/i18n/nls.hu.json +541 -537
  7. package/i18n/nls.it.json +541 -537
  8. package/i18n/nls.ja.json +541 -537
  9. package/i18n/nls.json +541 -537
  10. package/i18n/nls.pl.json +541 -537
  11. package/i18n/nls.pt-br.json +541 -537
  12. package/i18n/nls.pt-pt.json +541 -537
  13. package/i18n/nls.ru.json +541 -537
  14. package/i18n/nls.zh-cn.json +541 -537
  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 -24
  38. package/lib/browser/color-application-contribution.d.ts.map +1 -1
  39. package/lib/browser/color-application-contribution.js +110 -100
  40. package/lib/browser/color-application-contribution.js.map +1 -1
  41. package/lib/browser/color-registry.d.ts +14 -14
  42. package/lib/browser/color-registry.js +58 -58
  43. package/lib/browser/command-open-handler.d.ts +9 -9
  44. package/lib/browser/command-open-handler.js +58 -58
  45. package/lib/browser/common-frontend-contribution.d.ts +212 -206
  46. package/lib/browser/common-frontend-contribution.d.ts.map +1 -1
  47. package/lib/browser/common-frontend-contribution.js +2338 -2296
  48. package/lib/browser/common-frontend-contribution.js.map +1 -1
  49. package/lib/browser/common-styling-participants.d.ts +27 -27
  50. package/lib/browser/common-styling-participants.js +365 -365
  51. package/lib/browser/connection-status-service.d.ts +77 -77
  52. package/lib/browser/connection-status-service.js +198 -198
  53. package/lib/browser/connection-status-service.spec.d.ts +1 -1
  54. package/lib/browser/connection-status-service.spec.js +161 -161
  55. package/lib/browser/context-key-service.d.ts +82 -82
  56. package/lib/browser/context-key-service.js +83 -83
  57. package/lib/browser/context-menu-renderer.d.ts +54 -54
  58. package/lib/browser/context-menu-renderer.js +87 -87
  59. package/lib/browser/core-preferences.d.ts +37 -37
  60. package/lib/browser/core-preferences.js +300 -300
  61. package/lib/browser/credentials-service.d.ts +35 -35
  62. package/lib/browser/credentials-service.js +80 -80
  63. package/lib/browser/decoration-style.d.ts +6 -6
  64. package/lib/browser/decoration-style.js +64 -64
  65. package/lib/browser/decorations-service.d.ts +30 -30
  66. package/lib/browser/decorations-service.js +157 -158
  67. package/lib/browser/decorations-service.js.map +1 -1
  68. package/lib/browser/dialogs/react-dialog.d.ts +17 -17
  69. package/lib/browser/dialogs/react-dialog.js +49 -49
  70. package/lib/browser/dialogs.d.ts +135 -135
  71. package/lib/browser/dialogs.js +446 -446
  72. package/lib/browser/diff-uris.d.ts +17 -17
  73. package/lib/browser/diff-uris.js +115 -115
  74. package/lib/browser/encoding-registry.d.ts +18 -18
  75. package/lib/browser/encoding-registry.js +88 -88
  76. package/lib/browser/endpoint.d.ts +42 -42
  77. package/lib/browser/endpoint.js +120 -120
  78. package/lib/browser/endpoint.spec.d.ts +1 -1
  79. package/lib/browser/endpoint.spec.js +122 -122
  80. package/lib/browser/external-uri-service.d.ts +24 -24
  81. package/lib/browser/external-uri-service.js +72 -72
  82. package/lib/browser/frontend-application-bindings.d.ts +5 -5
  83. package/lib/browser/frontend-application-bindings.js +56 -56
  84. package/lib/browser/frontend-application-config-provider.d.ts +8 -8
  85. package/lib/browser/frontend-application-config-provider.js +46 -46
  86. package/lib/browser/frontend-application-config-provider.spec.d.ts +1 -1
  87. package/lib/browser/frontend-application-config-provider.spec.js +40 -40
  88. package/lib/browser/frontend-application-contribution.d.ts +75 -75
  89. package/lib/browser/frontend-application-contribution.js +45 -45
  90. package/lib/browser/frontend-application-module.d.ts +8 -8
  91. package/lib/browser/frontend-application-module.js +355 -355
  92. package/lib/browser/frontend-application-state.d.ts +19 -19
  93. package/lib/browser/frontend-application-state.js +71 -71
  94. package/lib/browser/frontend-application.d.ts +86 -86
  95. package/lib/browser/frontend-application.js +308 -308
  96. package/lib/browser/hover-service.d.ts +50 -50
  97. package/lib/browser/hover-service.js +199 -199
  98. package/lib/browser/http-open-handler.d.ts +14 -14
  99. package/lib/browser/http-open-handler.js +46 -46
  100. package/lib/browser/i18n/i18n-frontend-module.d.ts +3 -3
  101. package/lib/browser/i18n/i18n-frontend-module.js +25 -25
  102. package/lib/browser/i18n/language-quick-pick-service.d.ts +15 -15
  103. package/lib/browser/i18n/language-quick-pick-service.js +136 -136
  104. package/lib/browser/icon-registry.d.ts +56 -56
  105. package/lib/browser/icon-registry.js +24 -24
  106. package/lib/browser/icon-theme-contribution.d.ts +23 -23
  107. package/lib/browser/icon-theme-contribution.js +64 -64
  108. package/lib/browser/icon-theme-service.d.ts +63 -63
  109. package/lib/browser/icon-theme-service.js +198 -198
  110. package/lib/browser/index.d.ts +31 -31
  111. package/lib/browser/index.js +49 -49
  112. package/lib/browser/json-schema-store.d.ts +37 -37
  113. package/lib/browser/json-schema-store.js +111 -111
  114. package/lib/browser/keybinding.d.ts +288 -288
  115. package/lib/browser/keybinding.d.ts.map +1 -1
  116. package/lib/browser/keybinding.js +677 -674
  117. package/lib/browser/keybinding.js.map +1 -1
  118. package/lib/browser/keybinding.spec.d.ts +1 -1
  119. package/lib/browser/keybinding.spec.js +451 -451
  120. package/lib/browser/keyboard/browser-keyboard-frontend-contribution.d.ts +13 -13
  121. package/lib/browser/keyboard/browser-keyboard-frontend-contribution.js +110 -110
  122. package/lib/browser/keyboard/browser-keyboard-layout-provider.d.ts +91 -91
  123. package/lib/browser/keyboard/browser-keyboard-layout-provider.js +418 -418
  124. package/lib/browser/keyboard/browser-keyboard-layout-provider.spec.d.ts +1 -1
  125. package/lib/browser/keyboard/browser-keyboard-layout-provider.spec.js +152 -152
  126. package/lib/browser/keyboard/browser-keyboard-module.d.ts +3 -3
  127. package/lib/browser/keyboard/browser-keyboard-module.js +30 -30
  128. package/lib/browser/keyboard/index.d.ts +4 -4
  129. package/lib/browser/keyboard/index.js +22 -22
  130. package/lib/browser/keyboard/keyboard-layout-service.d.ts +49 -49
  131. package/lib/browser/keyboard/keyboard-layout-service.js +427 -427
  132. package/lib/browser/keyboard/keyboard-layout-service.spec.d.ts +1 -1
  133. package/lib/browser/keyboard/keyboard-layout-service.spec.js +110 -110
  134. package/lib/browser/keyboard/keys.d.ts +4 -4
  135. package/lib/browser/keyboard/keys.js +22 -22
  136. package/lib/browser/keyboard/keys.spec.d.ts +1 -1
  137. package/lib/browser/keyboard/keys.spec.js +205 -205
  138. package/lib/browser/keys.d.ts +2 -2
  139. package/lib/browser/keys.js +28 -28
  140. package/lib/browser/label-parser.d.ts +34 -34
  141. package/lib/browser/label-parser.js +107 -107
  142. package/lib/browser/label-parser.spec.d.ts +1 -1
  143. package/lib/browser/label-parser.spec.js +146 -146
  144. package/lib/browser/label-provider.d.ts +140 -140
  145. package/lib/browser/label-provider.js +310 -310
  146. package/lib/browser/label-provider.spec.d.ts +1 -1
  147. package/lib/browser/label-provider.spec.js +53 -53
  148. package/lib/browser/language-icon-provider.d.ts +14 -14
  149. package/lib/browser/language-icon-provider.js +65 -65
  150. package/lib/browser/language-service.d.ts +38 -38
  151. package/lib/browser/language-service.js +66 -66
  152. package/lib/browser/logger-frontend-module.d.ts +2 -2
  153. package/lib/browser/logger-frontend-module.js +63 -63
  154. package/lib/browser/markdown-rendering/markdown-renderer.d.ts +39 -39
  155. package/lib/browser/markdown-rendering/markdown-renderer.js +72 -72
  156. package/lib/browser/menu/browser-context-menu-renderer.d.ts +12 -12
  157. package/lib/browser/menu/browser-context-menu-renderer.d.ts.map +1 -1
  158. package/lib/browser/menu/browser-context-menu-renderer.js +51 -50
  159. package/lib/browser/menu/browser-context-menu-renderer.js.map +1 -1
  160. package/lib/browser/menu/browser-menu-module.d.ts +3 -3
  161. package/lib/browser/menu/browser-menu-module.js +28 -28
  162. package/lib/browser/menu/browser-menu-plugin.d.ts +103 -103
  163. package/lib/browser/menu/browser-menu-plugin.d.ts.map +1 -1
  164. package/lib/browser/menu/browser-menu-plugin.js +439 -439
  165. package/lib/browser/menu/browser-menu-plugin.js.map +1 -1
  166. package/lib/browser/menu/context-menu-context.d.ts +7 -7
  167. package/lib/browser/menu/context-menu-context.js +42 -42
  168. package/lib/browser/messaging/connection-source.d.ts +8 -8
  169. package/lib/browser/messaging/connection-source.js +19 -19
  170. package/lib/browser/messaging/frontend-id-provider.d.ts +12 -12
  171. package/lib/browser/messaging/frontend-id-provider.js +34 -34
  172. package/lib/browser/messaging/index.d.ts +1 -1
  173. package/lib/browser/messaging/index.js +19 -19
  174. package/lib/browser/messaging/messaging-frontend-module.d.ts +2 -2
  175. package/lib/browser/messaging/messaging-frontend-module.js +41 -41
  176. package/lib/browser/messaging/service-connection-provider.d.ts +47 -47
  177. package/lib/browser/messaging/service-connection-provider.js +106 -106
  178. package/lib/browser/messaging/ws-connection-provider.d.ts +12 -12
  179. package/lib/browser/messaging/ws-connection-provider.js +49 -49
  180. package/lib/browser/messaging/ws-connection-source.d.ts +42 -42
  181. package/lib/browser/messaging/ws-connection-source.js +217 -217
  182. package/lib/browser/mime-service.d.ts +7 -7
  183. package/lib/browser/mime-service.js +30 -30
  184. package/lib/browser/navigatable-types.d.ts +33 -33
  185. package/lib/browser/navigatable-types.js +63 -63
  186. package/lib/browser/navigatable.d.ts +8 -8
  187. package/lib/browser/navigatable.js +38 -38
  188. package/lib/browser/opener-service.d.ts +79 -79
  189. package/lib/browser/opener-service.js +79 -79
  190. package/lib/browser/opener-service.spec.d.ts +1 -1
  191. package/lib/browser/opener-service.spec.js +46 -46
  192. package/lib/browser/performance/frontend-stopwatch.d.ts +20 -20
  193. package/lib/browser/performance/frontend-stopwatch.js +66 -66
  194. package/lib/browser/performance/index.d.ts +2 -2
  195. package/lib/browser/performance/index.js +20 -20
  196. package/lib/browser/performance/measurement-frontend-bindings.d.ts +19 -19
  197. package/lib/browser/performance/measurement-frontend-bindings.js +32 -32
  198. package/lib/browser/preferences/index.d.ts +7 -7
  199. package/lib/browser/preferences/index.js +25 -25
  200. package/lib/browser/preferences/injectable-preference-proxy.d.ts +51 -51
  201. package/lib/browser/preferences/injectable-preference-proxy.js +276 -276
  202. package/lib/browser/preferences/preference-configurations.d.ts +22 -22
  203. package/lib/browser/preferences/preference-configurations.js +72 -72
  204. package/lib/browser/preferences/preference-contribution.d.ts +111 -111
  205. package/lib/browser/preferences/preference-contribution.js +386 -386
  206. package/lib/browser/preferences/preference-language-override-service.d.ts +39 -39
  207. package/lib/browser/preferences/preference-language-override-service.js +107 -107
  208. package/lib/browser/preferences/preference-provider.d.ts +132 -132
  209. package/lib/browser/preferences/preference-provider.js +219 -219
  210. package/lib/browser/preferences/preference-provider.spec.d.ts +1 -1
  211. package/lib/browser/preferences/preference-provider.spec.js +33 -33
  212. package/lib/browser/preferences/preference-proxy.d.ts +150 -150
  213. package/lib/browser/preferences/preference-proxy.js +229 -229
  214. package/lib/browser/preferences/preference-proxy.spec.d.ts +1 -1
  215. package/lib/browser/preferences/preference-proxy.spec.js +337 -337
  216. package/lib/browser/preferences/preference-schema-provider.spec.d.ts +1 -1
  217. package/lib/browser/preferences/preference-schema-provider.spec.js +115 -115
  218. package/lib/browser/preferences/preference-scope.d.ts +2 -2
  219. package/lib/browser/preferences/preference-scope.js +20 -20
  220. package/lib/browser/preferences/preference-service.d.ts +278 -278
  221. package/lib/browser/preferences/preference-service.js +350 -350
  222. package/lib/browser/preferences/preference-service.spec.d.ts +1 -1
  223. package/lib/browser/preferences/preference-service.spec.js +505 -505
  224. package/lib/browser/preferences/preference-validation-service.d.ts +57 -57
  225. package/lib/browser/preferences/preference-validation-service.js +346 -346
  226. package/lib/browser/preferences/preference-validation-service.spec.d.ts +1 -1
  227. package/lib/browser/preferences/preference-validation-service.spec.js +330 -330
  228. package/lib/browser/preferences/test/index.d.ts +3 -3
  229. package/lib/browser/preferences/test/index.js +21 -21
  230. package/lib/browser/preferences/test/mock-preference-provider.d.ts +16 -16
  231. package/lib/browser/preferences/test/mock-preference-provider.js +46 -46
  232. package/lib/browser/preferences/test/mock-preference-proxy.d.ts +3 -3
  233. package/lib/browser/preferences/test/mock-preference-proxy.js +49 -49
  234. package/lib/browser/preferences/test/mock-preference-service.d.ts +28 -28
  235. package/lib/browser/preferences/test/mock-preference-service.js +59 -59
  236. package/lib/browser/preload/i18n-preload-contribution.d.ts +6 -6
  237. package/lib/browser/preload/i18n-preload-contribution.js +54 -54
  238. package/lib/browser/preload/os-preload-contribution.d.ts +6 -6
  239. package/lib/browser/preload/os-preload-contribution.js +40 -40
  240. package/lib/browser/preload/preload-module.d.ts +3 -3
  241. package/lib/browser/preload/preload-module.js +38 -38
  242. package/lib/browser/preload/preloader.d.ts +11 -11
  243. package/lib/browser/preload/preloader.js +36 -36
  244. package/lib/browser/preload/theme-preload-contribution.d.ts +4 -4
  245. package/lib/browser/preload/theme-preload-contribution.js +34 -34
  246. package/lib/browser/progress-bar-factory.d.ts +11 -11
  247. package/lib/browser/progress-bar-factory.js +20 -20
  248. package/lib/browser/progress-bar.d.ts +15 -15
  249. package/lib/browser/progress-bar.js +81 -81
  250. package/lib/browser/progress-client.d.ts +12 -12
  251. package/lib/browser/progress-client.js +53 -53
  252. package/lib/browser/progress-location-service.d.ts +21 -21
  253. package/lib/browser/progress-location-service.js +91 -91
  254. package/lib/browser/progress-location-service.spec.d.ts +1 -1
  255. package/lib/browser/progress-location-service.spec.js +44 -44
  256. package/lib/browser/progress-status-bar-item.d.ts +16 -16
  257. package/lib/browser/progress-status-bar-item.js +81 -81
  258. package/lib/browser/quick-input/index.d.ts +8 -8
  259. package/lib/browser/quick-input/index.js +26 -26
  260. package/lib/browser/quick-input/quick-access.d.ts +53 -53
  261. package/lib/browser/quick-input/quick-access.js +20 -20
  262. package/lib/browser/quick-input/quick-command-frontend-contribution.d.ts +11 -11
  263. package/lib/browser/quick-input/quick-command-frontend-contribution.js +96 -96
  264. package/lib/browser/quick-input/quick-command-service.d.ts +59 -59
  265. package/lib/browser/quick-input/quick-command-service.js +225 -225
  266. package/lib/browser/quick-input/quick-help-service.d.ts +11 -11
  267. package/lib/browser/quick-input/quick-help-service.js +83 -83
  268. package/lib/browser/quick-input/quick-input-frontend-contribution.d.ts +7 -7
  269. package/lib/browser/quick-input/quick-input-frontend-contribution.js +38 -38
  270. package/lib/browser/quick-input/quick-input-service.d.ts +1 -1
  271. package/lib/browser/quick-input/quick-input-service.js +19 -19
  272. package/lib/browser/quick-input/quick-input-service.spec.d.ts +1 -1
  273. package/lib/browser/quick-input/quick-input-service.spec.js +159 -159
  274. package/lib/browser/quick-input/quick-pick-service-impl.d.ts +30 -30
  275. package/lib/browser/quick-input/quick-pick-service-impl.js +69 -69
  276. package/lib/browser/quick-input/quick-view-service.d.ts +23 -23
  277. package/lib/browser/quick-input/quick-view-service.js +78 -78
  278. package/lib/browser/request/browser-request-module.d.ts +18 -18
  279. package/lib/browser/request/browser-request-module.js +23 -23
  280. package/lib/browser/request/browser-request-service.d.ts +41 -41
  281. package/lib/browser/request/browser-request-service.js +172 -172
  282. package/lib/browser/resource-context-key.d.ts +19 -19
  283. package/lib/browser/resource-context-key.js +75 -75
  284. package/lib/browser/save-resource-service.d.ts +35 -35
  285. package/lib/browser/save-resource-service.js +64 -64
  286. package/lib/browser/saveable.d.ts +124 -124
  287. package/lib/browser/saveable.js +274 -274
  288. package/lib/browser/secondary-window-handler.d.ts +65 -64
  289. package/lib/browser/secondary-window-handler.d.ts.map +1 -1
  290. package/lib/browser/secondary-window-handler.js +193 -200
  291. package/lib/browser/secondary-window-handler.js.map +1 -1
  292. package/lib/browser/shell/additional-views-menu-widget.d.ts +19 -19
  293. package/lib/browser/shell/additional-views-menu-widget.js +73 -73
  294. package/lib/browser/shell/application-shell-mouse-tracker.d.ts +30 -30
  295. package/lib/browser/shell/application-shell-mouse-tracker.js +99 -99
  296. package/lib/browser/shell/application-shell.d.ts +574 -572
  297. package/lib/browser/shell/application-shell.d.ts.map +1 -1
  298. package/lib/browser/shell/application-shell.js +1992 -1984
  299. package/lib/browser/shell/application-shell.js.map +1 -1
  300. package/lib/browser/shell/current-widget-command-adapter.d.ts +23 -23
  301. package/lib/browser/shell/current-widget-command-adapter.js +41 -41
  302. package/lib/browser/shell/index.d.ts +7 -7
  303. package/lib/browser/shell/index.js +25 -25
  304. package/lib/browser/shell/shell-layout-restorer.d.ts +123 -123
  305. package/lib/browser/shell/shell-layout-restorer.js +336 -336
  306. package/lib/browser/shell/side-panel-handler.d.ts +286 -286
  307. package/lib/browser/shell/side-panel-handler.js +659 -659
  308. package/lib/browser/shell/side-panel-toolbar.d.ts +25 -25
  309. package/lib/browser/shell/side-panel-toolbar.js +96 -96
  310. package/lib/browser/shell/sidebar-bottom-menu-widget.d.ts +9 -9
  311. package/lib/browser/shell/sidebar-bottom-menu-widget.js +41 -41
  312. package/lib/browser/shell/sidebar-menu-widget.d.ts +38 -38
  313. package/lib/browser/shell/sidebar-menu-widget.js +113 -113
  314. package/lib/browser/shell/sidebar-top-menu-widget.d.ts +6 -6
  315. package/lib/browser/shell/sidebar-top-menu-widget.js +30 -30
  316. package/lib/browser/shell/split-panels.d.ts +42 -42
  317. package/lib/browser/shell/split-panels.js +172 -172
  318. package/lib/browser/shell/tab-bar-decorator.d.ts +40 -40
  319. package/lib/browser/shell/tab-bar-decorator.js +87 -87
  320. package/lib/browser/shell/tab-bar-toolbar/index.d.ts +3 -3
  321. package/lib/browser/shell/tab-bar-toolbar/index.js +21 -21
  322. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-menu-adapters.d.ts +15 -15
  323. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-menu-adapters.js +35 -35
  324. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-registry.d.ts +95 -95
  325. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-registry.js +245 -245
  326. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-types.d.ts +136 -136
  327. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-types.js +88 -88
  328. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.d.ts +89 -88
  329. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.d.ts.map +1 -1
  330. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.js +414 -409
  331. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.js.map +1 -1
  332. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.spec.d.ts +1 -1
  333. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.spec.js +51 -51
  334. package/lib/browser/shell/tab-bars.d.ts +341 -341
  335. package/lib/browser/shell/tab-bars.js +1312 -1312
  336. package/lib/browser/shell/tab-bars.spec.d.ts +1 -1
  337. package/lib/browser/shell/tab-bars.spec.js +56 -56
  338. package/lib/browser/shell/theia-dock-panel.d.ts +59 -59
  339. package/lib/browser/shell/theia-dock-panel.js +226 -226
  340. package/lib/browser/shell/view-contribution.d.ts +43 -43
  341. package/lib/browser/shell/view-contribution.js +159 -159
  342. package/lib/browser/source-tree/index.d.ts +3 -3
  343. package/lib/browser/source-tree/index.js +21 -21
  344. package/lib/browser/source-tree/source-tree-widget.d.ts +21 -21
  345. package/lib/browser/source-tree/source-tree-widget.js +110 -110
  346. package/lib/browser/source-tree/source-tree.d.ts +36 -36
  347. package/lib/browser/source-tree/source-tree.js +129 -129
  348. package/lib/browser/source-tree/tree-source.d.ts +35 -35
  349. package/lib/browser/source-tree/tree-source.js +53 -53
  350. package/lib/browser/status-bar/index.d.ts +5 -5
  351. package/lib/browser/status-bar/index.js +31 -31
  352. package/lib/browser/status-bar/status-bar-types.d.ts +72 -72
  353. package/lib/browser/status-bar/status-bar-types.js +25 -25
  354. package/lib/browser/status-bar/status-bar-view-model.d.ts +35 -35
  355. package/lib/browser/status-bar/status-bar-view-model.js +207 -207
  356. package/lib/browser/status-bar/status-bar.d.ts +34 -34
  357. package/lib/browser/status-bar/status-bar.js +181 -181
  358. package/lib/browser/storage-service.d.ts +35 -35
  359. package/lib/browser/storage-service.js +122 -122
  360. package/lib/browser/storage-service.spec.d.ts +1 -1
  361. package/lib/browser/storage-service.spec.js +68 -68
  362. package/lib/browser/styling-service.d.ts +29 -28
  363. package/lib/browser/styling-service.d.ts.map +1 -1
  364. package/lib/browser/styling-service.js +86 -77
  365. package/lib/browser/styling-service.js.map +1 -1
  366. package/lib/browser/supported-encodings.d.ts +9 -9
  367. package/lib/browser/supported-encodings.js +263 -263
  368. package/lib/browser/test/jsdom.d.ts +8 -8
  369. package/lib/browser/test/jsdom.js +69 -69
  370. package/lib/browser/test/mock-connection-status-service.d.ts +5 -5
  371. package/lib/browser/test/mock-connection-status-service.js +32 -32
  372. package/lib/browser/test/mock-env-variables-server.d.ts +12 -12
  373. package/lib/browser/test/mock-env-variables-server.js +42 -42
  374. package/lib/browser/test/mock-opener-service.d.ts +8 -8
  375. package/lib/browser/test/mock-opener-service.js +35 -35
  376. package/lib/browser/test/mock-storage-service.d.ts +11 -11
  377. package/lib/browser/test/mock-storage-service.js +49 -49
  378. package/lib/browser/theming.d.ts +50 -50
  379. package/lib/browser/theming.js +203 -203
  380. package/lib/browser/tooltip-service.d.ts +34 -34
  381. package/lib/browser/tooltip-service.js +76 -76
  382. package/lib/browser/tree/fuzzy-search.d.ts +60 -60
  383. package/lib/browser/tree/fuzzy-search.js +75 -75
  384. package/lib/browser/tree/fuzzy-search.spec.d.ts +1 -1
  385. package/lib/browser/tree/fuzzy-search.spec.js +89 -89
  386. package/lib/browser/tree/index.d.ts +13 -13
  387. package/lib/browser/tree/index.js +31 -31
  388. package/lib/browser/tree/search-box-debounce.d.ts +33 -33
  389. package/lib/browser/tree/search-box-debounce.js +75 -75
  390. package/lib/browser/tree/search-box.d.ts +105 -105
  391. package/lib/browser/tree/search-box.js +265 -265
  392. package/lib/browser/tree/test/mock-selectable-tree-model.d.ts +14 -14
  393. package/lib/browser/tree/test/mock-selectable-tree-model.js +102 -102
  394. package/lib/browser/tree/test/mock-tree-model.d.ts +12 -12
  395. package/lib/browser/tree/test/mock-tree-model.js +129 -129
  396. package/lib/browser/tree/test/tree-test-container.d.ts +2 -2
  397. package/lib/browser/tree/test/tree-test-container.js +52 -52
  398. package/lib/browser/tree/tree-compression/compressed-tree-expansion-service.d.ts +8 -8
  399. package/lib/browser/tree/tree-compression/compressed-tree-expansion-service.js +59 -59
  400. package/lib/browser/tree/tree-compression/compressed-tree-model.d.ts +23 -23
  401. package/lib/browser/tree/tree-compression/compressed-tree-model.js +89 -89
  402. package/lib/browser/tree/tree-compression/compressed-tree-widget.d.ts +38 -38
  403. package/lib/browser/tree/tree-compression/compressed-tree-widget.js +187 -187
  404. package/lib/browser/tree/tree-compression/index.d.ts +4 -4
  405. package/lib/browser/tree/tree-compression/index.js +22 -22
  406. package/lib/browser/tree/tree-compression/tree-compression-service.d.ts +58 -58
  407. package/lib/browser/tree/tree-compression/tree-compression-service.js +98 -98
  408. package/lib/browser/tree/tree-consistency.spec.d.ts +1 -1
  409. package/lib/browser/tree/tree-consistency.spec.js +99 -99
  410. package/lib/browser/tree/tree-container.d.ts +51 -51
  411. package/lib/browser/tree/tree-container.js +115 -115
  412. package/lib/browser/tree/tree-container.spec.d.ts +1 -1
  413. package/lib/browser/tree/tree-container.spec.js +45 -45
  414. package/lib/browser/tree/tree-decorator.d.ts +143 -143
  415. package/lib/browser/tree/tree-decorator.js +115 -115
  416. package/lib/browser/tree/tree-decorator.spec.d.ts +1 -1
  417. package/lib/browser/tree/tree-decorator.spec.js +145 -145
  418. package/lib/browser/tree/tree-expansion.d.ts +65 -65
  419. package/lib/browser/tree/tree-expansion.js +124 -124
  420. package/lib/browser/tree/tree-expansion.spec.d.ts +1 -1
  421. package/lib/browser/tree/tree-expansion.spec.js +155 -155
  422. package/lib/browser/tree/tree-focus-service.d.ts +19 -19
  423. package/lib/browser/tree/tree-focus-service.js +53 -53
  424. package/lib/browser/tree/tree-iterator.d.ts +94 -94
  425. package/lib/browser/tree/tree-iterator.js +223 -223
  426. package/lib/browser/tree/tree-iterator.spec.d.ts +1 -1
  427. package/lib/browser/tree/tree-iterator.spec.js +150 -150
  428. package/lib/browser/tree/tree-label-provider.d.ts +8 -8
  429. package/lib/browser/tree/tree-label-provider.js +39 -39
  430. package/lib/browser/tree/tree-model.d.ts +202 -202
  431. package/lib/browser/tree/tree-model.js +395 -395
  432. package/lib/browser/tree/tree-navigation.d.ts +10 -10
  433. package/lib/browser/tree/tree-navigation.js +57 -57
  434. package/lib/browser/tree/tree-preference.d.ts +10 -10
  435. package/lib/browser/tree/tree-preference.js +46 -46
  436. package/lib/browser/tree/tree-search.d.ts +36 -36
  437. package/lib/browser/tree/tree-search.js +130 -130
  438. package/lib/browser/tree/tree-selectable.spec.d.ts +1 -1
  439. package/lib/browser/tree/tree-selectable.spec.js +146 -146
  440. package/lib/browser/tree/tree-selection-impl.d.ts +44 -44
  441. package/lib/browser/tree/tree-selection-impl.js +158 -158
  442. package/lib/browser/tree/tree-selection-state.d.ts +48 -48
  443. package/lib/browser/tree/tree-selection-state.js +227 -227
  444. package/lib/browser/tree/tree-selection-state.spec.d.ts +1 -1
  445. package/lib/browser/tree/tree-selection-state.spec.js +420 -420
  446. package/lib/browser/tree/tree-selection.d.ts +86 -86
  447. package/lib/browser/tree/tree-selection.js +86 -86
  448. package/lib/browser/tree/tree-view-welcome-widget.d.ts +45 -45
  449. package/lib/browser/tree/tree-view-welcome-widget.js +192 -192
  450. package/lib/browser/tree/tree-widget-selection.d.ts +11 -11
  451. package/lib/browser/tree/tree-widget-selection.js +46 -46
  452. package/lib/browser/tree/tree-widget.d.ts +559 -559
  453. package/lib/browser/tree/tree-widget.js +1352 -1352
  454. package/lib/browser/tree/tree.d.ts +180 -180
  455. package/lib/browser/tree/tree.js +288 -288
  456. package/lib/browser/tree/tree.spec.d.ts +1 -1
  457. package/lib/browser/tree/tree.spec.js +226 -226
  458. package/lib/browser/user-working-directory-provider.d.ts +23 -23
  459. package/lib/browser/user-working-directory-provider.js +76 -76
  460. package/lib/browser/view-container.d.ts +312 -312
  461. package/lib/browser/view-container.js +1458 -1458
  462. package/lib/browser/widget-decoration.d.ts +299 -299
  463. package/lib/browser/widget-decoration.js +140 -140
  464. package/lib/browser/widget-manager.d.ts +172 -172
  465. package/lib/browser/widget-manager.js +222 -222
  466. package/lib/browser/widget-manager.spec.d.ts +1 -1
  467. package/lib/browser/widget-manager.spec.js +91 -91
  468. package/lib/browser/widget-open-handler.d.ts +88 -88
  469. package/lib/browser/widget-open-handler.js +137 -137
  470. package/lib/browser/widgets/alert-message.d.ts +23 -23
  471. package/lib/browser/widgets/alert-message.js +38 -38
  472. package/lib/browser/widgets/enhanced-preview-widget.d.ts +6 -6
  473. package/lib/browser/widgets/enhanced-preview-widget.js +26 -26
  474. package/lib/browser/widgets/extractable-widget.d.ts +13 -13
  475. package/lib/browser/widgets/extractable-widget.js +26 -26
  476. package/lib/browser/widgets/index.d.ts +4 -4
  477. package/lib/browser/widgets/index.js +22 -22
  478. package/lib/browser/widgets/previewable-widget.d.ts +8 -8
  479. package/lib/browser/widgets/previewable-widget.js +30 -30
  480. package/lib/browser/widgets/react-renderer.d.ts +14 -14
  481. package/lib/browser/widgets/react-renderer.js +48 -48
  482. package/lib/browser/widgets/react-widget.d.ts +16 -16
  483. package/lib/browser/widgets/react-widget.js +46 -46
  484. package/lib/browser/widgets/select-component.d.ts +53 -53
  485. package/lib/browser/widgets/select-component.js +307 -307
  486. package/lib/browser/widgets/widget.d.ts +108 -108
  487. package/lib/browser/widgets/widget.js +367 -367
  488. package/lib/browser/window/browser-window-module.d.ts +3 -3
  489. package/lib/browser/window/browser-window-module.js +32 -32
  490. package/lib/browser/window/default-secondary-window-service.d.ts +25 -25
  491. package/lib/browser/window/default-secondary-window-service.d.ts.map +1 -1
  492. package/lib/browser/window/default-secondary-window-service.js +187 -190
  493. package/lib/browser/window/default-secondary-window-service.js.map +1 -1
  494. package/lib/browser/window/default-window-service.d.ts +50 -49
  495. package/lib/browser/window/default-window-service.d.ts.map +1 -1
  496. package/lib/browser/window/default-window-service.js +167 -164
  497. package/lib/browser/window/default-window-service.js.map +1 -1
  498. package/lib/browser/window/default-window-service.spec.d.ts +1 -1
  499. package/lib/browser/window/default-window-service.spec.js +80 -80
  500. package/lib/browser/window/secondary-window-service.d.ts +20 -20
  501. package/lib/browser/window/secondary-window-service.js +19 -19
  502. package/lib/browser/window/test/mock-window-service.d.ts +11 -10
  503. package/lib/browser/window/test/mock-window-service.d.ts.map +1 -1
  504. package/lib/browser/window/test/mock-window-service.js +34 -33
  505. package/lib/browser/window/test/mock-window-service.js.map +1 -1
  506. package/lib/browser/window/window-service.d.ts +53 -45
  507. package/lib/browser/window/window-service.d.ts.map +1 -1
  508. package/lib/browser/window/window-service.js +22 -22
  509. package/lib/browser/window/window-service.js.map +1 -1
  510. package/lib/browser/window/window-title-service.d.ts +31 -31
  511. package/lib/browser/window/window-title-service.js +112 -112
  512. package/lib/browser/window/window-title-updater.d.ts +19 -19
  513. package/lib/browser/window/window-title-updater.js +99 -99
  514. package/lib/browser/window-contribution.d.ts +14 -14
  515. package/lib/browser/window-contribution.js +62 -62
  516. package/lib/browser-only/frontend-only-application-module.d.ts +4 -4
  517. package/lib/browser-only/frontend-only-application-module.js +114 -114
  518. package/lib/browser-only/i18n/i18n-frontend-only-module.d.ts +3 -3
  519. package/lib/browser-only/i18n/i18n-frontend-only-module.js +34 -34
  520. package/lib/browser-only/logger-frontend-only-module.d.ts +2 -2
  521. package/lib/browser-only/logger-frontend-only-module.js +60 -60
  522. package/lib/browser-only/messaging/frontend-only-service-connection-provider.d.ts +13 -13
  523. package/lib/browser-only/messaging/frontend-only-service-connection-provider.js +51 -51
  524. package/lib/browser-only/messaging/messaging-frontend-only-module.d.ts +2 -2
  525. package/lib/browser-only/messaging/messaging-frontend-only-module.js +47 -47
  526. package/lib/browser-only/preload/frontend-only-preload-module.d.ts +3 -3
  527. package/lib/browser-only/preload/frontend-only-preload-module.js +51 -51
  528. package/lib/common/accessibility.d.ts +16 -16
  529. package/lib/common/accessibility.js +17 -17
  530. package/lib/common/application-error.d.ts +20 -20
  531. package/lib/common/application-error.js +62 -62
  532. package/lib/common/application-error.spec.d.ts +1 -1
  533. package/lib/common/application-error.spec.js +26 -26
  534. package/lib/common/application-protocol.d.ts +20 -20
  535. package/lib/common/application-protocol.js +20 -20
  536. package/lib/common/array-utils.d.ts +55 -55
  537. package/lib/common/array-utils.js +118 -118
  538. package/lib/common/buffer.d.ts +43 -43
  539. package/lib/common/buffer.js +205 -205
  540. package/lib/common/cancellation.d.ts +24 -24
  541. package/lib/common/cancellation.js +142 -142
  542. package/lib/common/char-code.d.ts +401 -401
  543. package/lib/common/char-code.js +22 -22
  544. package/lib/common/collections.d.ts +29 -29
  545. package/lib/common/collections.js +121 -121
  546. package/lib/common/color.d.ts +71 -71
  547. package/lib/common/color.js +43 -43
  548. package/lib/common/command.d.ts +232 -232
  549. package/lib/common/command.js +353 -353
  550. package/lib/common/command.spec.d.ts +1 -1
  551. package/lib/common/command.spec.js +173 -173
  552. package/lib/common/contribution-filter/contribution-filter-registry.d.ts +17 -17
  553. package/lib/common/contribution-filter/contribution-filter-registry.js +77 -77
  554. package/lib/common/contribution-filter/contribution-filter.d.ts +41 -41
  555. package/lib/common/contribution-filter/contribution-filter.js +20 -20
  556. package/lib/common/contribution-filter/filter.d.ts +6 -6
  557. package/lib/common/contribution-filter/filter.js +19 -19
  558. package/lib/common/contribution-filter/index.d.ts +3 -3
  559. package/lib/common/contribution-filter/index.js +21 -21
  560. package/lib/common/contribution-provider.d.ts +20 -20
  561. package/lib/common/contribution-provider.js +82 -82
  562. package/lib/common/disposable.d.ts +80 -80
  563. package/lib/common/disposable.js +173 -173
  564. package/lib/common/disposable.spec.d.ts +1 -1
  565. package/lib/common/disposable.spec.js +80 -80
  566. package/lib/common/encoding-service.d.ts +38 -38
  567. package/lib/common/encoding-service.js +302 -302
  568. package/lib/common/encodings.d.ts +7 -7
  569. package/lib/common/encodings.js +25 -25
  570. package/lib/common/env-variables/env-variables-protocol.d.ts +20 -20
  571. package/lib/common/env-variables/env-variables-protocol.js +20 -20
  572. package/lib/common/env-variables/index.d.ts +1 -1
  573. package/lib/common/env-variables/index.js +19 -19
  574. package/lib/common/event.d.ts +115 -115
  575. package/lib/common/event.js +385 -385
  576. package/lib/common/event.spec.d.ts +1 -1
  577. package/lib/common/event.spec.js +29 -29
  578. package/lib/common/file-uri.d.ts +14 -14
  579. package/lib/common/file-uri.js +62 -62
  580. package/lib/common/frontend-application-state.d.ts +15 -15
  581. package/lib/common/frontend-application-state.js +33 -33
  582. package/lib/common/glob.d.ts +50 -50
  583. package/lib/common/glob.js +591 -591
  584. package/lib/common/hash.d.ts +7 -7
  585. package/lib/common/hash.js +84 -84
  586. package/lib/common/i18n/localization-server.d.ts +6 -6
  587. package/lib/common/i18n/localization-server.js +20 -20
  588. package/lib/common/i18n/localization.d.ts +34 -34
  589. package/lib/common/i18n/localization.js +59 -59
  590. package/lib/common/index.d.ts +35 -35
  591. package/lib/common/index.js +56 -56
  592. package/lib/common/json-schema.d.ts +72 -72
  593. package/lib/common/json-schema.js +17 -17
  594. package/lib/common/key-store.d.ts +12 -12
  595. package/lib/common/key-store.js +20 -20
  596. package/lib/common/keybinding.d.ts +75 -75
  597. package/lib/common/keybinding.js +113 -113
  598. package/lib/common/keyboard/keyboard-layout-provider.d.ts +26 -26
  599. package/lib/common/keyboard/keyboard-layout-provider.js +22 -22
  600. package/lib/common/keys.d.ts +253 -253
  601. package/lib/common/keys.js +634 -634
  602. package/lib/common/label-protocol.d.ts +13 -13
  603. package/lib/common/label-protocol.js +17 -17
  604. package/lib/common/logger-protocol.d.ts +41 -41
  605. package/lib/common/logger-protocol.js +100 -100
  606. package/lib/common/logger-watcher.d.ts +9 -9
  607. package/lib/common/logger-watcher.js +49 -49
  608. package/lib/common/logger.d.ts +207 -207
  609. package/lib/common/logger.js +204 -204
  610. package/lib/common/logger.spec.d.ts +1 -1
  611. package/lib/common/logger.spec.js +41 -41
  612. package/lib/common/lsp-types.d.ts +9 -9
  613. package/lib/common/lsp-types.js +30 -30
  614. package/lib/common/markdown-rendering/icon-utilities.d.ts +7 -7
  615. package/lib/common/markdown-rendering/icon-utilities.js +32 -32
  616. package/lib/common/markdown-rendering/index.d.ts +2 -2
  617. package/lib/common/markdown-rendering/index.js +20 -20
  618. package/lib/common/markdown-rendering/markdown-string.d.ts +46 -46
  619. package/lib/common/markdown-rendering/markdown-string.js +126 -126
  620. package/lib/common/menu/action-menu-node.d.ts +19 -19
  621. package/lib/common/menu/action-menu-node.js +56 -56
  622. package/lib/common/menu/composite-menu-node.d.ts +46 -46
  623. package/lib/common/menu/composite-menu-node.js +93 -93
  624. package/lib/common/menu/composite-menu-node.spec.d.ts +1 -1
  625. package/lib/common/menu/composite-menu-node.spec.js +67 -67
  626. package/lib/common/menu/index.d.ts +5 -5
  627. package/lib/common/menu/index.js +23 -23
  628. package/lib/common/menu/menu-adapter.d.ts +35 -35
  629. package/lib/common/menu/menu-adapter.js +92 -92
  630. package/lib/common/menu/menu-model-registry.d.ts +145 -145
  631. package/lib/common/menu/menu-model-registry.js +275 -275
  632. package/lib/common/menu/menu-types.d.ts +148 -148
  633. package/lib/common/menu/menu-types.js +93 -93
  634. package/lib/common/menu/menu.spec.d.ts +1 -1
  635. package/lib/common/menu/menu.spec.js +96 -96
  636. package/lib/common/message-rpc/channel.d.ts +123 -123
  637. package/lib/common/message-rpc/channel.js +230 -230
  638. package/lib/common/message-rpc/channel.spec.d.ts +8 -8
  639. package/lib/common/message-rpc/channel.spec.js +79 -79
  640. package/lib/common/message-rpc/index.d.ts +3 -3
  641. package/lib/common/message-rpc/index.js +24 -24
  642. package/lib/common/message-rpc/message-buffer.d.ts +51 -51
  643. package/lib/common/message-rpc/message-buffer.js +59 -59
  644. package/lib/common/message-rpc/msg-pack-extension-manager.d.ts +22 -22
  645. package/lib/common/message-rpc/msg-pack-extension-manager.js +57 -57
  646. package/lib/common/message-rpc/rpc-message-encoder.d.ts +103 -103
  647. package/lib/common/message-rpc/rpc-message-encoder.js +113 -113
  648. package/lib/common/message-rpc/rpc-message-encoder.spec.d.ts +1 -1
  649. package/lib/common/message-rpc/rpc-message-encoder.spec.js +58 -58
  650. package/lib/common/message-rpc/rpc-protocol.d.ts +67 -67
  651. package/lib/common/message-rpc/rpc-protocol.js +209 -209
  652. package/lib/common/message-rpc/uint8-array-message-buffer.d.ts +52 -52
  653. package/lib/common/message-rpc/uint8-array-message-buffer.js +174 -174
  654. package/lib/common/message-rpc/uint8-array-message-buffer.spec.d.ts +1 -1
  655. package/lib/common/message-rpc/uint8-array-message-buffer.spec.js +38 -38
  656. package/lib/common/message-service-protocol.d.ts +110 -110
  657. package/lib/common/message-service-protocol.js +73 -73
  658. package/lib/common/message-service.d.ts +134 -134
  659. package/lib/common/message-service.js +151 -151
  660. package/lib/common/messaging/connection-error-handler.d.ts +28 -28
  661. package/lib/common/messaging/connection-error-handler.js +47 -47
  662. package/lib/common/messaging/connection-management.d.ts +24 -24
  663. package/lib/common/messaging/connection-management.js +37 -37
  664. package/lib/common/messaging/handler.d.ts +7 -7
  665. package/lib/common/messaging/handler.js +20 -20
  666. package/lib/common/messaging/index.d.ts +3 -3
  667. package/lib/common/messaging/index.js +21 -21
  668. package/lib/common/messaging/proxy-factory.d.ts +180 -180
  669. package/lib/common/messaging/proxy-factory.js +280 -280
  670. package/lib/common/messaging/proxy-factory.spec.d.ts +1 -1
  671. package/lib/common/messaging/proxy-factory.spec.js +99 -99
  672. package/lib/common/messaging/socket-write-buffer.d.ts +10 -10
  673. package/lib/common/messaging/socket-write-buffer.js +49 -49
  674. package/lib/common/messaging/web-socket-channel.d.ts +19 -19
  675. package/lib/common/messaging/web-socket-channel.js +64 -64
  676. package/lib/common/nls.d.ts +15 -15
  677. package/lib/common/nls.js +135 -133
  678. package/lib/common/nls.js.map +1 -1
  679. package/lib/common/numbers.d.ts +5 -5
  680. package/lib/common/numbers.js +23 -23
  681. package/lib/common/objects.d.ts +8 -8
  682. package/lib/common/objects.js +118 -118
  683. package/lib/common/objects.spec.d.ts +1 -1
  684. package/lib/common/objects.spec.js +101 -101
  685. package/lib/common/os.d.ts +31 -31
  686. package/lib/common/os.js +73 -73
  687. package/lib/common/path.d.ts +93 -93
  688. package/lib/common/path.js +307 -307
  689. package/lib/common/path.spec.d.ts +1 -1
  690. package/lib/common/path.spec.js +350 -350
  691. package/lib/common/paths.d.ts +24 -24
  692. package/lib/common/paths.js +226 -226
  693. package/lib/common/performance/index.d.ts +3 -3
  694. package/lib/common/performance/index.js +21 -21
  695. package/lib/common/performance/measurement-protocol.d.ts +64 -64
  696. package/lib/common/performance/measurement-protocol.js +70 -70
  697. package/lib/common/performance/measurement.d.ts +111 -111
  698. package/lib/common/performance/measurement.js +17 -17
  699. package/lib/common/performance/stopwatch.d.ts +75 -75
  700. package/lib/common/performance/stopwatch.js +148 -148
  701. package/lib/common/preferences/preference-schema.d.ts +52 -52
  702. package/lib/common/preferences/preference-schema.js +58 -58
  703. package/lib/common/preferences/preference-scope.d.ts +19 -19
  704. package/lib/common/preferences/preference-scope.js +71 -71
  705. package/lib/common/preferences/preference-scope.spec.d.ts +1 -1
  706. package/lib/common/preferences/preference-scope.spec.js +44 -44
  707. package/lib/common/prioritizeable.d.ts +16 -16
  708. package/lib/common/prioritizeable.js +55 -55
  709. package/lib/common/progress-service-protocol.d.ts +13 -13
  710. package/lib/common/progress-service-protocol.js +19 -19
  711. package/lib/common/progress-service.d.ts +13 -13
  712. package/lib/common/progress-service.js +88 -88
  713. package/lib/common/promise-util.d.ts +51 -51
  714. package/lib/common/promise-util.js +132 -132
  715. package/lib/common/promise-util.spec.d.ts +1 -1
  716. package/lib/common/promise-util.spec.js +80 -80
  717. package/lib/common/quick-pick-service.d.ts +270 -269
  718. package/lib/common/quick-pick-service.d.ts.map +1 -1
  719. package/lib/common/quick-pick-service.js +133 -133
  720. package/lib/common/quick-pick-service.js.map +1 -1
  721. package/lib/common/reference.d.ts +95 -95
  722. package/lib/common/reference.js +207 -207
  723. package/lib/common/reference.spec.d.ts +1 -1
  724. package/lib/common/reference.spec.js +125 -125
  725. package/lib/common/resource.d.ts +207 -207
  726. package/lib/common/resource.js +322 -322
  727. package/lib/common/selection-command-handler.d.ts +24 -24
  728. package/lib/common/selection-command-handler.js +83 -83
  729. package/lib/common/selection-service.d.ts +18 -18
  730. package/lib/common/selection-service.js +43 -43
  731. package/lib/common/selection-service.spec.d.ts +1 -1
  732. package/lib/common/selection-service.spec.js +38 -38
  733. package/lib/common/selection.d.ts +9 -9
  734. package/lib/common/selection.js +47 -47
  735. package/lib/common/severity.d.ts +15 -15
  736. package/lib/common/severity.js +113 -113
  737. package/lib/common/stream.d.ts +176 -176
  738. package/lib/common/stream.js +474 -474
  739. package/lib/common/strings.d.ts +24 -24
  740. package/lib/common/strings.js +215 -215
  741. package/lib/common/telemetry.d.ts +19 -19
  742. package/lib/common/telemetry.js +24 -24
  743. package/lib/common/ternary-search-tree.d.ts +50 -50
  744. package/lib/common/ternary-search-tree.js +381 -381
  745. package/lib/common/test/expect.d.ts +2 -2
  746. package/lib/common/test/expect.js +34 -34
  747. package/lib/common/test/mock-logger.d.ts +27 -27
  748. package/lib/common/test/mock-logger.js +99 -99
  749. package/lib/common/test/mock-menu.d.ts +7 -7
  750. package/lib/common/test/mock-menu.js +34 -34
  751. package/lib/common/test/mock-resource-provider.d.ts +6 -6
  752. package/lib/common/test/mock-resource-provider.js +36 -36
  753. package/lib/common/theme.d.ts +40 -40
  754. package/lib/common/theme.js +22 -22
  755. package/lib/common/types.d.ts +58 -58
  756. package/lib/common/types.js +126 -126
  757. package/lib/common/types.spec.d.ts +1 -1
  758. package/lib/common/types.spec.js +73 -73
  759. package/lib/common/uri-command-handler.d.ts +53 -53
  760. package/lib/common/uri-command-handler.js +99 -99
  761. package/lib/common/uri-command-handler.spec.d.ts +1 -1
  762. package/lib/common/uri-command-handler.spec.js +80 -80
  763. package/lib/common/uri.d.ts +87 -87
  764. package/lib/common/uri.js +236 -236
  765. package/lib/common/uri.spec.d.ts +1 -1
  766. package/lib/common/uri.spec.js +230 -230
  767. package/lib/common/uuid.d.ts +8 -8
  768. package/lib/common/uuid.js +44 -44
  769. package/lib/common/version.d.ts +1 -1
  770. package/lib/common/version.js +19 -19
  771. package/lib/common/view-column.d.ts +17 -17
  772. package/lib/common/view-column.js +36 -36
  773. package/lib/common/window.d.ts +16 -16
  774. package/lib/common/window.js +22 -22
  775. package/lib/electron-browser/electron-clipboard-service.d.ts +5 -5
  776. package/lib/electron-browser/electron-clipboard-service.js +33 -33
  777. package/lib/electron-browser/keyboard/electron-keyboard-layout-change-notifier.d.ts +11 -11
  778. package/lib/electron-browser/keyboard/electron-keyboard-layout-change-notifier.js +46 -46
  779. package/lib/electron-browser/keyboard/electron-keyboard-module.d.ts +3 -3
  780. package/lib/electron-browser/keyboard/electron-keyboard-module.js +26 -26
  781. package/lib/electron-browser/menu/electron-context-menu-renderer.d.ts +30 -30
  782. package/lib/electron-browser/menu/electron-context-menu-renderer.d.ts.map +1 -1
  783. package/lib/electron-browser/menu/electron-context-menu-renderer.js +128 -126
  784. package/lib/electron-browser/menu/electron-context-menu-renderer.js.map +1 -1
  785. package/lib/electron-browser/menu/electron-main-menu-factory.d.ts +59 -59
  786. package/lib/electron-browser/menu/electron-main-menu-factory.js +274 -274
  787. package/lib/electron-browser/menu/electron-menu-contribution.d.ts +78 -78
  788. package/lib/electron-browser/menu/electron-menu-contribution.js +471 -471
  789. package/lib/electron-browser/menu/electron-menu-module.d.ts +3 -3
  790. package/lib/electron-browser/menu/electron-menu-module.js +39 -39
  791. package/lib/electron-browser/messaging/electron-frontend-id-provider.d.ts +4 -4
  792. package/lib/electron-browser/messaging/electron-frontend-id-provider.js +29 -29
  793. package/lib/electron-browser/messaging/electron-ipc-connection-source.d.ts +23 -23
  794. package/lib/electron-browser/messaging/electron-ipc-connection-source.js +59 -59
  795. package/lib/electron-browser/messaging/electron-local-ws-connection-source.d.ts +6 -6
  796. package/lib/electron-browser/messaging/electron-local-ws-connection-source.js +49 -49
  797. package/lib/electron-browser/messaging/electron-messaging-frontend-module.d.ts +2 -2
  798. package/lib/electron-browser/messaging/electron-messaging-frontend-module.js +75 -75
  799. package/lib/electron-browser/messaging/electron-ws-connection-source.d.ts +11 -11
  800. package/lib/electron-browser/messaging/electron-ws-connection-source.js +42 -42
  801. package/lib/electron-browser/preload.d.ts +1 -1
  802. package/lib/electron-browser/preload.js +201 -201
  803. package/lib/electron-browser/preload.js.map +1 -1
  804. package/lib/electron-browser/request/electron-browser-request-module.d.ts +18 -18
  805. package/lib/electron-browser/request/electron-browser-request-module.js +26 -26
  806. package/lib/electron-browser/token/electron-token-frontend-module.d.ts +3 -3
  807. package/lib/electron-browser/token/electron-token-frontend-module.js +22 -22
  808. package/lib/electron-browser/window/electron-frontend-application-state.d.ts +4 -4
  809. package/lib/electron-browser/window/electron-frontend-application-state.js +31 -31
  810. package/lib/electron-browser/window/electron-secondary-window-service.d.ts +7 -7
  811. package/lib/electron-browser/window/electron-secondary-window-service.d.ts.map +1 -1
  812. package/lib/electron-browser/window/electron-secondary-window-service.js +38 -42
  813. package/lib/electron-browser/window/electron-secondary-window-service.js.map +1 -1
  814. package/lib/electron-browser/window/electron-window-module.d.ts +3 -3
  815. package/lib/electron-browser/window/electron-window-module.js +39 -39
  816. package/lib/electron-browser/window/electron-window-preferences.d.ts +18 -18
  817. package/lib/electron-browser/window/electron-window-preferences.js +72 -72
  818. package/lib/electron-browser/window/electron-window-service.d.ts +31 -29
  819. package/lib/electron-browser/window/electron-window-service.d.ts.map +1 -1
  820. package/lib/electron-browser/window/electron-window-service.js +116 -106
  821. package/lib/electron-browser/window/electron-window-service.js.map +1 -1
  822. package/lib/electron-common/electron-api.d.ts +104 -104
  823. package/lib/electron-common/electron-api.d.ts.map +1 -1
  824. package/lib/electron-common/electron-api.js +56 -56
  825. package/lib/electron-common/electron-main-window-service.d.ts +7 -7
  826. package/lib/electron-common/electron-main-window-service.js +20 -20
  827. package/lib/electron-common/electron-token.d.ts +10 -10
  828. package/lib/electron-common/electron-token.js +27 -27
  829. package/lib/electron-main/electron-api-main.d.ts +22 -22
  830. package/lib/electron-main/electron-api-main.d.ts.map +1 -1
  831. package/lib/electron-main/electron-api-main.js +294 -286
  832. package/lib/electron-main/electron-api-main.js.map +1 -1
  833. package/lib/electron-main/electron-main-application-module.d.ts +3 -3
  834. package/lib/electron-main/electron-main-application-module.js +56 -56
  835. package/lib/electron-main/electron-main-application.d.ts +159 -159
  836. package/lib/electron-main/electron-main-application.js +603 -603
  837. package/lib/electron-main/electron-main-constants.d.ts +6 -6
  838. package/lib/electron-main/electron-main-constants.js +19 -19
  839. package/lib/electron-main/electron-main-window-service-impl.d.ts +8 -8
  840. package/lib/electron-main/electron-main-window-service-impl.js +46 -46
  841. package/lib/electron-main/electron-security-token-service.d.ts +5 -5
  842. package/lib/electron-main/electron-security-token-service.js +41 -41
  843. package/lib/electron-main/event-utils.d.ts +8 -8
  844. package/lib/electron-main/event-utils.js +33 -33
  845. package/lib/electron-main/messaging/electron-connection-handler.d.ts +5 -5
  846. package/lib/electron-main/messaging/electron-connection-handler.js +23 -23
  847. package/lib/electron-main/messaging/electron-messaging-contribution.d.ts +41 -41
  848. package/lib/electron-main/messaging/electron-messaging-contribution.js +142 -142
  849. package/lib/electron-main/messaging/electron-messaging-service.d.ts +17 -17
  850. package/lib/electron-main/messaging/electron-messaging-service.js +22 -22
  851. package/lib/electron-main/theia-electron-window.d.ts +53 -53
  852. package/lib/electron-main/theia-electron-window.js +186 -186
  853. package/lib/electron-node/hosting/electron-backend-hosting-module.d.ts +3 -3
  854. package/lib/electron-node/hosting/electron-backend-hosting-module.js +24 -24
  855. package/lib/electron-node/hosting/electron-ws-origin-validator.d.ts +8 -8
  856. package/lib/electron-node/hosting/electron-ws-origin-validator.js +40 -40
  857. package/lib/electron-node/keyboard/electron-backend-keyboard-module.d.ts +3 -3
  858. package/lib/electron-node/keyboard/electron-backend-keyboard-module.js +26 -26
  859. package/lib/electron-node/keyboard/electron-keyboard-layout-provider.d.ts +5 -5
  860. package/lib/electron-node/keyboard/electron-keyboard-layout-provider.js +36 -36
  861. package/lib/electron-node/request/electron-backend-request-module.d.ts +18 -18
  862. package/lib/electron-node/request/electron-backend-request-module.js +23 -23
  863. package/lib/electron-node/request/electron-backend-request-service.d.ts +22 -22
  864. package/lib/electron-node/request/electron-backend-request-service.js +81 -81
  865. package/lib/electron-node/token/electron-token-backend-contribution.d.ts +15 -15
  866. package/lib/electron-node/token/electron-token-backend-contribution.js +50 -50
  867. package/lib/electron-node/token/electron-token-backend-module.d.ts +3 -3
  868. package/lib/electron-node/token/electron-token-backend-module.js +28 -28
  869. package/lib/electron-node/token/electron-token-validator.d.ts +29 -29
  870. package/lib/electron-node/token/electron-token-validator.js +95 -95
  871. package/lib/node/application-server.d.ts +10 -10
  872. package/lib/node/application-server.js +55 -55
  873. package/lib/node/backend-application-config-provider.d.ts +7 -7
  874. package/lib/node/backend-application-config-provider.js +45 -45
  875. package/lib/node/backend-application-config-provider.spec.d.ts +1 -1
  876. package/lib/node/backend-application-config-provider.spec.js +28 -28
  877. package/lib/node/backend-application-module.d.ts +2 -2
  878. package/lib/node/backend-application-module.js +108 -108
  879. package/lib/node/backend-application.d.ts +108 -108
  880. package/lib/node/backend-application.js +290 -290
  881. package/lib/node/backend-remote-service.d.ts +3 -3
  882. package/lib/node/backend-remote-service.js +29 -29
  883. package/lib/node/cli.d.ts +17 -17
  884. package/lib/node/cli.js +59 -59
  885. package/lib/node/cli.spec.d.ts +1 -1
  886. package/lib/node/cli.spec.js +89 -89
  887. package/lib/node/console-logger-server.d.ts +15 -15
  888. package/lib/node/console-logger-server.js +82 -82
  889. package/lib/node/console-logger-server.spec.d.ts +1 -1
  890. package/lib/node/console-logger-server.spec.js +61 -61
  891. package/lib/node/debug.d.ts +1 -1
  892. package/lib/node/debug.js +28 -28
  893. package/lib/node/dynamic-require.d.ts +7 -7
  894. package/lib/node/dynamic-require.js +56 -56
  895. package/lib/node/env-variables/env-variables-server.d.ts +23 -23
  896. package/lib/node/env-variables/env-variables-server.js +117 -117
  897. package/lib/node/env-variables/index.d.ts +1 -1
  898. package/lib/node/env-variables/index.js +19 -19
  899. package/lib/node/environment-utils.d.ts +21 -21
  900. package/lib/node/environment-utils.js +72 -72
  901. package/lib/node/environment-utils.spec.d.ts +1 -1
  902. package/lib/node/environment-utils.spec.js +77 -77
  903. package/lib/node/file-uri.spec.d.ts +1 -1
  904. package/lib/node/file-uri.spec.js +66 -66
  905. package/lib/node/filesystem-locking.d.ts +23 -23
  906. package/lib/node/filesystem-locking.js +65 -65
  907. package/lib/node/hosting/backend-application-hosts.d.ts +23 -23
  908. package/lib/node/hosting/backend-application-hosts.js +69 -69
  909. package/lib/node/hosting/backend-hosting-module.d.ts +3 -3
  910. package/lib/node/hosting/backend-hosting-module.js +26 -26
  911. package/lib/node/hosting/ws-origin-validator.d.ts +8 -8
  912. package/lib/node/hosting/ws-origin-validator.js +39 -39
  913. package/lib/node/i18n/i18n-backend-module.d.ts +3 -3
  914. package/lib/node/i18n/i18n-backend-module.js +38 -38
  915. package/lib/node/i18n/localization-contribution.d.ts +18 -18
  916. package/lib/node/i18n/localization-contribution.js +108 -108
  917. package/lib/node/i18n/localization-provider.d.ts +23 -23
  918. package/lib/node/i18n/localization-provider.js +109 -109
  919. package/lib/node/i18n/localization-server.d.ts +14 -14
  920. package/lib/node/i18n/localization-server.js +54 -54
  921. package/lib/node/i18n/theia-localization-contribution.d.ts +4 -4
  922. package/lib/node/i18n/theia-localization-contribution.js +40 -40
  923. package/lib/node/index.d.ts +6 -6
  924. package/lib/node/index.js +26 -26
  925. package/lib/node/key-store-server.d.ts +27 -27
  926. package/lib/node/key-store-server.js +145 -145
  927. package/lib/node/logger-backend-module.d.ts +9 -9
  928. package/lib/node/logger-backend-module.js +78 -78
  929. package/lib/node/logger-cli-contribution.d.ts +33 -33
  930. package/lib/node/logger-cli-contribution.js +147 -147
  931. package/lib/node/logger-cli-contribution.spec.d.ts +1 -1
  932. package/lib/node/logger-cli-contribution.spec.js +207 -207
  933. package/lib/node/main.d.ts +7 -7
  934. package/lib/node/main.js +29 -29
  935. package/lib/node/messaging/binary-message-pipe.d.ts +44 -44
  936. package/lib/node/messaging/binary-message-pipe.js +151 -151
  937. package/lib/node/messaging/connection-container-module.d.ts +53 -53
  938. package/lib/node/messaging/connection-container-module.js +81 -81
  939. package/lib/node/messaging/default-messaging-service.d.ts +28 -28
  940. package/lib/node/messaging/default-messaging-service.js +131 -131
  941. package/lib/node/messaging/frontend-connection-service.d.ts +6 -6
  942. package/lib/node/messaging/frontend-connection-service.js +18 -18
  943. package/lib/node/messaging/index.d.ts +3 -3
  944. package/lib/node/messaging/index.js +21 -21
  945. package/lib/node/messaging/ipc-bootstrap.d.ts +1 -1
  946. package/lib/node/messaging/ipc-bootstrap.js +24 -24
  947. package/lib/node/messaging/ipc-channel.d.ts +17 -17
  948. package/lib/node/messaging/ipc-channel.js +69 -69
  949. package/lib/node/messaging/ipc-connection-provider.d.ts +21 -21
  950. package/lib/node/messaging/ipc-connection-provider.js +92 -92
  951. package/lib/node/messaging/ipc-protocol.d.ts +19 -19
  952. package/lib/node/messaging/ipc-protocol.js +68 -68
  953. package/lib/node/messaging/messaging-backend-module.d.ts +2 -2
  954. package/lib/node/messaging/messaging-backend-module.js +52 -52
  955. package/lib/node/messaging/messaging-listeners.d.ts +27 -27
  956. package/lib/node/messaging/messaging-listeners.js +45 -45
  957. package/lib/node/messaging/messaging-service.d.ts +28 -28
  958. package/lib/node/messaging/messaging-service.js +24 -24
  959. package/lib/node/messaging/test/test-web-socket-channel.d.ts +12 -12
  960. package/lib/node/messaging/test/test-web-socket-channel.js +54 -54
  961. package/lib/node/messaging/websocket-endpoint.d.ts +20 -20
  962. package/lib/node/messaging/websocket-endpoint.js +80 -80
  963. package/lib/node/messaging/websocket-frontend-connection-service.d.ts +30 -30
  964. package/lib/node/messaging/websocket-frontend-connection-service.js +169 -169
  965. package/lib/node/os-backend-provider.d.ts +4 -4
  966. package/lib/node/os-backend-provider.js +30 -30
  967. package/lib/node/performance/index.d.ts +2 -2
  968. package/lib/node/performance/index.js +20 -20
  969. package/lib/node/performance/measurement-backend-bindings.d.ts +19 -19
  970. package/lib/node/performance/measurement-backend-bindings.js +30 -30
  971. package/lib/node/performance/node-stopwatch.d.ts +20 -20
  972. package/lib/node/performance/node-stopwatch.js +43 -43
  973. package/lib/node/process-utils.d.ts +13 -13
  974. package/lib/node/process-utils.js +105 -105
  975. package/lib/node/process-utils.spec.d.ts +1 -1
  976. package/lib/node/process-utils.spec.js +44 -44
  977. package/lib/node/request/backend-request-facade.d.ts +22 -22
  978. package/lib/node/request/backend-request-facade.js +41 -41
  979. package/lib/node/request/backend-request-module.d.ts +18 -18
  980. package/lib/node/request/backend-request-module.js +24 -24
  981. package/lib/node/request/proxy-cli-contribution.d.ts +27 -27
  982. package/lib/node/request/proxy-cli-contribution.js +64 -64
  983. package/lib/node/ws-request-validators.d.ts +25 -25
  984. package/lib/node/ws-request-validators.js +52 -52
  985. package/package.json +6 -6
  986. package/shared/ajv/index.d.ts +2 -2
  987. package/shared/markdown-it.d.ts +2 -2
  988. package/shared/markdown-it.js +1 -1
  989. package/shared/reflect-metadata/index.d.ts +1 -1
  990. package/shared/reflect-metadata/index.js +1 -1
  991. package/shared/vscode-languageserver-types/index.d.ts +1 -1
  992. package/src/browser/about-dialog.tsx +137 -137
  993. package/src/browser/authentication-service.ts +456 -456
  994. package/src/browser/breadcrumbs/breadcrumb-popup-container.ts +101 -101
  995. package/src/browser/breadcrumbs/breadcrumb-renderer.tsx +41 -41
  996. package/src/browser/breadcrumbs/breadcrumbs-constants.ts +79 -79
  997. package/src/browser/breadcrumbs/breadcrumbs-renderer.tsx +185 -185
  998. package/src/browser/breadcrumbs/breadcrumbs-service.ts +108 -108
  999. package/src/browser/breadcrumbs/index.ts +21 -21
  1000. package/src/browser/browser-clipboard-service.ts +122 -122
  1001. package/src/browser/browser.ts +225 -225
  1002. package/src/browser/clipboard-service.ts +23 -23
  1003. package/src/browser/color-application-contribution.ts +110 -101
  1004. package/src/browser/color-registry.ts +60 -60
  1005. package/src/browser/command-open-handler.ts +54 -54
  1006. package/src/browser/common-frontend-contribution.ts +2569 -2526
  1007. package/src/browser/common-styling-participants.ts +361 -361
  1008. package/src/browser/connection-status-service.spec.ts +200 -200
  1009. package/src/browser/connection-status-service.ts +216 -216
  1010. package/src/browser/context-key-service.ts +142 -142
  1011. package/src/browser/context-menu-renderer.ts +124 -124
  1012. package/src/browser/core-preferences.ts +334 -334
  1013. package/src/browser/credentials-service.ts +106 -106
  1014. package/src/browser/decoration-style.ts +65 -65
  1015. package/src/browser/decorations-service.ts +209 -209
  1016. package/src/browser/dialogs/react-dialog.tsx +56 -56
  1017. package/src/browser/dialogs.ts +534 -534
  1018. package/src/browser/diff-uris.ts +117 -117
  1019. package/src/browser/encoding-registry.ts +97 -97
  1020. package/src/browser/endpoint.spec.ts +148 -148
  1021. package/src/browser/endpoint.ts +136 -136
  1022. package/src/browser/external-uri-service.ts +79 -79
  1023. package/src/browser/file-icons-js.d.ts +20 -20
  1024. package/src/browser/frontend-application-bindings.ts +62 -62
  1025. package/src/browser/frontend-application-config-provider.spec.ts +45 -45
  1026. package/src/browser/frontend-application-config-provider.ts +50 -50
  1027. package/src/browser/frontend-application-contribution.ts +110 -110
  1028. package/src/browser/frontend-application-module.ts +460 -460
  1029. package/src/browser/frontend-application-state.ts +74 -74
  1030. package/src/browser/frontend-application.ts +326 -326
  1031. package/src/browser/hover-service.ts +218 -218
  1032. package/src/browser/http-open-handler.ts +47 -47
  1033. package/src/browser/i18n/i18n-frontend-module.ts +27 -27
  1034. package/src/browser/i18n/language-quick-pick-service.ts +130 -130
  1035. package/src/browser/icon-registry.ts +87 -87
  1036. package/src/browser/icon-theme-contribution.ts +64 -64
  1037. package/src/browser/icon-theme-service.ts +217 -217
  1038. package/src/browser/icons/CollapseAll.svg +7 -7
  1039. package/src/browser/icons/CollapseAll_inverse.svg +7 -7
  1040. package/src/browser/icons/Refresh.svg +7 -7
  1041. package/src/browser/icons/Refresh_inverse.svg +7 -7
  1042. package/src/browser/icons/add-inverse.svg +4 -4
  1043. package/src/browser/icons/add.svg +4 -4
  1044. package/src/browser/icons/arrow-down-bright.svg +6 -6
  1045. package/src/browser/icons/arrow-down-dark.svg +6 -6
  1046. package/src/browser/icons/arrow-up-bright.svg +6 -6
  1047. package/src/browser/icons/arrow-up-dark.svg +6 -6
  1048. package/src/browser/icons/case-sensitive-dark.svg +16 -16
  1049. package/src/browser/icons/case-sensitive.svg +16 -16
  1050. package/src/browser/icons/chevron-right-dark.svg +5 -5
  1051. package/src/browser/icons/chevron-right-light.svg +6 -6
  1052. package/src/browser/icons/circle-bright.svg +7 -7
  1053. package/src/browser/icons/circle-dark.svg +7 -7
  1054. package/src/browser/icons/clear-search-results-dark.svg +7 -7
  1055. package/src/browser/icons/clear-search-results.svg +7 -7
  1056. package/src/browser/icons/close-all-bright.svg +7 -7
  1057. package/src/browser/icons/close-all-dark.svg +7 -7
  1058. package/src/browser/icons/close-bright.svg +7 -7
  1059. package/src/browser/icons/close-dark.svg +7 -7
  1060. package/src/browser/icons/collapse.svg +4 -4
  1061. package/src/browser/icons/edit-json-dark.svg +6 -6
  1062. package/src/browser/icons/edit-json.svg +6 -6
  1063. package/src/browser/icons/expand.svg +4 -4
  1064. package/src/browser/icons/loading-dark.svg +6 -6
  1065. package/src/browser/icons/loading-light.svg +6 -6
  1066. package/src/browser/icons/open-change-bright.svg +3 -3
  1067. package/src/browser/icons/open-change-dark.svg +4 -4
  1068. package/src/browser/icons/open-file-bright.svg +4 -4
  1069. package/src/browser/icons/open-file-dark.svg +4 -4
  1070. package/src/browser/icons/preview-bright.svg +3 -3
  1071. package/src/browser/icons/preview-dark.svg +3 -3
  1072. package/src/browser/icons/regex-dark.svg +10 -10
  1073. package/src/browser/icons/regex.svg +10 -10
  1074. package/src/browser/icons/remove-all-inverse.svg +4 -4
  1075. package/src/browser/icons/remove-all.svg +4 -4
  1076. package/src/browser/icons/replace-all-inverse.svg +13 -13
  1077. package/src/browser/icons/replace-all.svg +13 -13
  1078. package/src/browser/icons/replace-inverse.svg +15 -15
  1079. package/src/browser/icons/replace.svg +15 -15
  1080. package/src/browser/icons/whole-word-dark.svg +19 -19
  1081. package/src/browser/icons/whole-word.svg +19 -19
  1082. package/src/browser/index.ts +47 -47
  1083. package/src/browser/json-schema-store.ts +127 -127
  1084. package/src/browser/keybinding.spec.ts +553 -553
  1085. package/src/browser/keybinding.ts +759 -756
  1086. package/src/browser/keyboard/browser-keyboard-frontend-contribution.ts +108 -108
  1087. package/src/browser/keyboard/browser-keyboard-layout-provider.spec.ts +171 -171
  1088. package/src/browser/keyboard/browser-keyboard-layout-provider.ts +469 -469
  1089. package/src/browser/keyboard/browser-keyboard-module.ts +30 -30
  1090. package/src/browser/keyboard/index.ts +20 -20
  1091. package/src/browser/keyboard/keyboard-layout-service.spec.ts +121 -121
  1092. package/src/browser/keyboard/keyboard-layout-service.ts +455 -455
  1093. package/src/browser/keyboard/keys.spec.ts +258 -258
  1094. package/src/browser/keyboard/keys.ts +20 -20
  1095. package/src/browser/keys.ts +21 -21
  1096. package/src/browser/label-parser.spec.ts +165 -165
  1097. package/src/browser/label-parser.ts +108 -108
  1098. package/src/browser/label-provider.spec.ts +62 -62
  1099. package/src/browser/label-provider.ts +385 -385
  1100. package/src/browser/language-icon-provider.ts +55 -55
  1101. package/src/browser/language-service.ts +77 -77
  1102. package/src/browser/logger-frontend-module.ts +65 -65
  1103. package/src/browser/markdown-rendering/markdown-renderer.ts +98 -98
  1104. package/src/browser/menu/browser-context-menu-renderer.ts +48 -47
  1105. package/src/browser/menu/browser-menu-module.ts +28 -28
  1106. package/src/browser/menu/browser-menu-plugin.ts +484 -484
  1107. package/src/browser/menu/context-menu-context.ts +41 -41
  1108. package/src/browser/messaging/connection-source.ts +26 -26
  1109. package/src/browser/messaging/frontend-id-provider.ts +37 -37
  1110. package/src/browser/messaging/index.ts +17 -17
  1111. package/src/browser/messaging/messaging-frontend-module.ts +41 -41
  1112. package/src/browser/messaging/service-connection-provider.ts +126 -126
  1113. package/src/browser/messaging/ws-connection-provider.ts +48 -48
  1114. package/src/browser/messaging/ws-connection-source.ts +230 -230
  1115. package/src/browser/mime-service.ts +30 -30
  1116. package/src/browser/navigatable-types.ts +81 -81
  1117. package/src/browser/navigatable.ts +39 -39
  1118. package/src/browser/opener-service.spec.ts +49 -49
  1119. package/src/browser/opener-service.ts +146 -146
  1120. package/src/browser/performance/frontend-stopwatch.ts +65 -65
  1121. package/src/browser/performance/index.ts +18 -18
  1122. package/src/browser/performance/measurement-frontend-bindings.ts +31 -31
  1123. package/src/browser/preferences/index.ts +23 -23
  1124. package/src/browser/preferences/injectable-preference-proxy.ts +283 -283
  1125. package/src/browser/preferences/preference-configurations.ts +82 -82
  1126. package/src/browser/preferences/preference-contribution.ts +436 -436
  1127. package/src/browser/preferences/preference-language-override-service.ts +111 -111
  1128. package/src/browser/preferences/preference-provider.spec.ts +36 -36
  1129. package/src/browser/preferences/preference-provider.ts +277 -277
  1130. package/src/browser/preferences/preference-proxy.spec.ts +367 -367
  1131. package/src/browser/preferences/preference-proxy.ts +367 -367
  1132. package/src/browser/preferences/preference-schema-provider.spec.ts +130 -130
  1133. package/src/browser/preferences/preference-scope.ts +18 -18
  1134. package/src/browser/preferences/preference-service.spec.ts +613 -613
  1135. package/src/browser/preferences/preference-service.ts +594 -594
  1136. package/src/browser/preferences/preference-validation-service.spec.ts +334 -334
  1137. package/src/browser/preferences/preference-validation-service.ts +358 -358
  1138. package/src/browser/preferences/test/index.ts +19 -19
  1139. package/src/browser/preferences/test/mock-preference-provider.ts +50 -50
  1140. package/src/browser/preferences/test/mock-preference-proxy.ts +48 -48
  1141. package/src/browser/preferences/test/mock-preference-service.ts +63 -63
  1142. package/src/browser/preload/i18n-preload-contribution.ts +50 -50
  1143. package/src/browser/preload/os-preload-contribution.ts +37 -37
  1144. package/src/browser/preload/preload-module.ts +45 -45
  1145. package/src/browser/preload/preloader.ts +37 -37
  1146. package/src/browser/preload/theme-preload-contribution.ts +31 -31
  1147. package/src/browser/progress-bar-factory.ts +29 -29
  1148. package/src/browser/progress-bar.ts +76 -76
  1149. package/src/browser/progress-client.ts +53 -53
  1150. package/src/browser/progress-location-service.spec.ts +50 -50
  1151. package/src/browser/progress-location-service.ts +96 -96
  1152. package/src/browser/progress-status-bar-item.ts +83 -83
  1153. package/src/browser/quick-input/index.ts +23 -23
  1154. package/src/browser/quick-input/quick-access.ts +75 -75
  1155. package/src/browser/quick-input/quick-command-frontend-contribution.ts +89 -89
  1156. package/src/browser/quick-input/quick-command-service.ts +246 -246
  1157. package/src/browser/quick-input/quick-help-service.ts +87 -87
  1158. package/src/browser/quick-input/quick-input-frontend-contribution.ts +33 -33
  1159. package/src/browser/quick-input/quick-input-service.spec.ts +176 -176
  1160. package/src/browser/quick-input/quick-input-service.ts +17 -17
  1161. package/src/browser/quick-input/quick-pick-service-impl.ts +69 -69
  1162. package/src/browser/quick-input/quick-view-service.ts +83 -83
  1163. package/src/browser/request/browser-request-module.ts +23 -23
  1164. package/src/browser/request/browser-request-service.ts +172 -172
  1165. package/src/browser/resource-context-key.ts +77 -77
  1166. package/src/browser/save-resource-service.ts +60 -60
  1167. package/src/browser/saveable.ts +365 -365
  1168. package/src/browser/secondary-window-handler.ts +211 -212
  1169. package/src/browser/shell/additional-views-menu-widget.tsx +71 -71
  1170. package/src/browser/shell/application-shell-mouse-tracker.ts +103 -103
  1171. package/src/browser/shell/application-shell.ts +2261 -2254
  1172. package/src/browser/shell/current-widget-command-adapter.ts +57 -57
  1173. package/src/browser/shell/index.ts +23 -23
  1174. package/src/browser/shell/shell-layout-restorer.ts +399 -399
  1175. package/src/browser/shell/side-panel-handler.ts +793 -793
  1176. package/src/browser/shell/side-panel-toolbar.ts +111 -111
  1177. package/src/browser/shell/sidebar-bottom-menu-widget.tsx +39 -39
  1178. package/src/browser/shell/sidebar-menu-widget.tsx +140 -140
  1179. package/src/browser/shell/sidebar-top-menu-widget.tsx +26 -26
  1180. package/src/browser/shell/split-panels.ts +190 -190
  1181. package/src/browser/shell/tab-bar-decorator.ts +106 -106
  1182. package/src/browser/shell/tab-bar-toolbar/index.ts +19 -19
  1183. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar-menu-adapters.ts +31 -31
  1184. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar-registry.ts +256 -256
  1185. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar-types.ts +207 -207
  1186. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar.spec.ts +62 -62
  1187. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar.tsx +428 -423
  1188. package/src/browser/shell/tab-bars.spec.ts +63 -63
  1189. package/src/browser/shell/tab-bars.ts +1485 -1485
  1190. package/src/browser/shell/theia-dock-panel.ts +255 -255
  1191. package/src/browser/shell/view-contribution.ts +177 -177
  1192. package/src/browser/source-tree/index.ts +19 -19
  1193. package/src/browser/source-tree/source-tree-widget.tsx +107 -107
  1194. package/src/browser/source-tree/source-tree.ts +146 -146
  1195. package/src/browser/source-tree/tree-source.ts +73 -73
  1196. package/src/browser/status-bar/index.ts +29 -29
  1197. package/src/browser/status-bar/status-bar-types.ts +97 -97
  1198. package/src/browser/status-bar/status-bar-view-model.ts +209 -209
  1199. package/src/browser/status-bar/status-bar.tsx +189 -189
  1200. package/src/browser/storage-service.spec.ts +76 -76
  1201. package/src/browser/storage-service.ts +129 -129
  1202. package/src/browser/style/about.css +36 -36
  1203. package/src/browser/style/alert-messages.css +62 -62
  1204. package/src/browser/style/ansi.css +88 -88
  1205. package/src/browser/style/breadcrumbs.css +130 -130
  1206. package/src/browser/style/dialog.css +126 -126
  1207. package/src/browser/style/dockpanel.css +76 -76
  1208. package/src/browser/style/hover-service.css +101 -101
  1209. package/src/browser/style/icons.css +61 -61
  1210. package/src/browser/style/index.css +351 -351
  1211. package/src/browser/style/materialcolors.css +278 -278
  1212. package/src/browser/style/menus.css +230 -230
  1213. package/src/browser/style/notification.css +39 -39
  1214. package/src/browser/style/os.css +87 -87
  1215. package/src/browser/style/progress-bar.css +43 -43
  1216. package/src/browser/style/quick-title-bar.css +45 -45
  1217. package/src/browser/style/scrollbars.css +172 -172
  1218. package/src/browser/style/search-box.css +123 -123
  1219. package/src/browser/style/select-component.css +107 -107
  1220. package/src/browser/style/sidepanel.css +364 -364
  1221. package/src/browser/style/status-bar.css +127 -127
  1222. package/src/browser/style/tabs.css +647 -647
  1223. package/src/browser/style/tooltip.css +28 -28
  1224. package/src/browser/style/tree-decorators.css +81 -81
  1225. package/src/browser/style/tree.css +232 -232
  1226. package/src/browser/style/view-container.css +194 -194
  1227. package/src/browser/style/widget.css +19 -19
  1228. package/src/browser/styling-service.ts +96 -87
  1229. package/src/browser/supported-encodings.ts +262 -262
  1230. package/src/browser/test/jsdom.ts +69 -69
  1231. package/src/browser/test/mock-connection-status-service.ts +33 -33
  1232. package/src/browser/test/mock-env-variables-server.ts +47 -47
  1233. package/src/browser/test/mock-opener-service.ts +34 -34
  1234. package/src/browser/test/mock-storage-service.ts +49 -49
  1235. package/src/browser/theming.ts +206 -206
  1236. package/src/browser/tooltip-service.tsx +96 -96
  1237. package/src/browser/tree/fuzzy-search.spec.ts +99 -99
  1238. package/src/browser/tree/fuzzy-search.ts +136 -136
  1239. package/src/browser/tree/index.ts +29 -29
  1240. package/src/browser/tree/search-box-debounce.ts +96 -96
  1241. package/src/browser/tree/search-box.ts +355 -355
  1242. package/src/browser/tree/test/mock-selectable-tree-model.ts +109 -109
  1243. package/src/browser/tree/test/mock-tree-model.ts +136 -136
  1244. package/src/browser/tree/test/tree-test-container.ts +50 -50
  1245. package/src/browser/tree/tree-compression/compressed-tree-expansion-service.ts +46 -46
  1246. package/src/browser/tree/tree-compression/compressed-tree-model.ts +88 -88
  1247. package/src/browser/tree/tree-compression/compressed-tree-widget.tsx +203 -203
  1248. package/src/browser/tree/tree-compression/index.ts +20 -20
  1249. package/src/browser/tree/tree-compression/tree-compression-service.ts +125 -125
  1250. package/src/browser/tree/tree-compression/tree-compression.css +28 -28
  1251. package/src/browser/tree/tree-consistency.spec.ts +105 -105
  1252. package/src/browser/tree/tree-container.spec.ts +45 -45
  1253. package/src/browser/tree/tree-container.ts +155 -155
  1254. package/src/browser/tree/tree-decorator.spec.ts +162 -162
  1255. package/src/browser/tree/tree-decorator.ts +238 -238
  1256. package/src/browser/tree/tree-expansion.spec.ts +173 -173
  1257. package/src/browser/tree/tree-expansion.ts +165 -165
  1258. package/src/browser/tree/tree-focus-service.ts +55 -55
  1259. package/src/browser/tree/tree-iterator.spec.ts +170 -170
  1260. package/src/browser/tree/tree-iterator.ts +256 -256
  1261. package/src/browser/tree/tree-label-provider.ts +40 -40
  1262. package/src/browser/tree/tree-model.ts +562 -562
  1263. package/src/browser/tree/tree-navigation.ts +58 -58
  1264. package/src/browser/tree/tree-preference.ts +50 -50
  1265. package/src/browser/tree/tree-search.ts +128 -128
  1266. package/src/browser/tree/tree-selectable.spec.ts +152 -152
  1267. package/src/browser/tree/tree-selection-impl.ts +176 -176
  1268. package/src/browser/tree/tree-selection-state.spec.ts +462 -462
  1269. package/src/browser/tree/tree-selection-state.ts +245 -245
  1270. package/src/browser/tree/tree-selection.ts +159 -159
  1271. package/src/browser/tree/tree-view-welcome-widget.tsx +263 -263
  1272. package/src/browser/tree/tree-widget-selection.ts +45 -45
  1273. package/src/browser/tree/tree-widget.tsx +1585 -1585
  1274. package/src/browser/tree/tree.spec.ts +241 -241
  1275. package/src/browser/tree/tree.ts +425 -425
  1276. package/src/browser/user-working-directory-provider.ts +77 -77
  1277. package/src/browser/view-container.ts +1640 -1640
  1278. package/src/browser/widget-decoration.ts +358 -358
  1279. package/src/browser/widget-manager.spec.ts +102 -102
  1280. package/src/browser/widget-manager.ts +310 -310
  1281. package/src/browser/widget-open-handler.ts +165 -165
  1282. package/src/browser/widgets/alert-message.tsx +56 -56
  1283. package/src/browser/widgets/enhanced-preview-widget.ts +27 -27
  1284. package/src/browser/widgets/extractable-widget.ts +33 -33
  1285. package/src/browser/widgets/index.ts +20 -20
  1286. package/src/browser/widgets/previewable-widget.ts +31 -31
  1287. package/src/browser/widgets/react-renderer.tsx +50 -50
  1288. package/src/browser/widgets/react-widget.tsx +51 -51
  1289. package/src/browser/widgets/select-component.tsx +367 -367
  1290. package/src/browser/widgets/widget.ts +406 -406
  1291. package/src/browser/window/browser-window-module.ts +32 -32
  1292. package/src/browser/window/default-secondary-window-service.ts +185 -187
  1293. package/src/browser/window/default-window-service.spec.ts +78 -78
  1294. package/src/browser/window/default-window-service.ts +171 -167
  1295. package/src/browser/window/secondary-window-service.ts +39 -39
  1296. package/src/browser/window/test/mock-window-service.ts +29 -28
  1297. package/src/browser/window/window-service.ts +78 -68
  1298. package/src/browser/window/window-title-service.ts +107 -107
  1299. package/src/browser/window/window-title-updater.ts +95 -95
  1300. package/src/browser/window-contribution.ts +64 -64
  1301. package/src/browser-only/frontend-only-application-module.ts +115 -115
  1302. package/src/browser-only/i18n/i18n-frontend-only-module.ts +37 -37
  1303. package/src/browser-only/logger-frontend-only-module.ts +63 -63
  1304. package/src/browser-only/messaging/frontend-only-service-connection-provider.ts +39 -39
  1305. package/src/browser-only/messaging/messaging-frontend-only-module.ts +42 -42
  1306. package/src/browser-only/preload/frontend-only-preload-module.ts +49 -49
  1307. package/src/common/accessibility.ts +33 -33
  1308. package/src/common/application-error.spec.ts +27 -27
  1309. package/src/common/application-error.ts +76 -76
  1310. package/src/common/application-protocol.ts +41 -41
  1311. package/src/common/array-utils.ts +129 -129
  1312. package/src/common/buffer.ts +228 -228
  1313. package/src/common/cancellation.ts +163 -163
  1314. package/src/common/char-code.ts +438 -438
  1315. package/src/common/collections.ts +125 -125
  1316. package/src/common/color.ts +103 -103
  1317. package/src/common/command.spec.ts +208 -208
  1318. package/src/common/command.ts +485 -485
  1319. package/src/common/contribution-filter/contribution-filter-registry.ts +79 -79
  1320. package/src/common/contribution-filter/contribution-filter.ts +64 -64
  1321. package/src/common/contribution-filter/filter.ts +23 -23
  1322. package/src/common/contribution-filter/index.ts +19 -19
  1323. package/src/common/contribution-provider.ts +96 -96
  1324. package/src/common/disposable.spec.ts +94 -94
  1325. package/src/common/disposable.ts +188 -188
  1326. package/src/common/encoding-service.ts +380 -380
  1327. package/src/common/encodings.ts +24 -24
  1328. package/src/common/env-variables/env-variables-protocol.ts +38 -38
  1329. package/src/common/env-variables/index.ts +17 -17
  1330. package/src/common/event.spec.ts +32 -32
  1331. package/src/common/event.ts +469 -469
  1332. package/src/common/file-uri.ts +61 -61
  1333. package/src/common/frontend-application-state.ts +38 -38
  1334. package/src/common/glob.ts +741 -741
  1335. package/src/common/hash.ts +85 -85
  1336. package/src/common/i18n/localization-server.ts +25 -25
  1337. package/src/common/i18n/localization.ts +80 -80
  1338. package/src/common/i18n/nls.metadata.json +31314 -31314
  1339. package/src/common/index.ts +51 -51
  1340. package/src/common/json-schema.ts +106 -106
  1341. package/src/common/key-store.ts +26 -26
  1342. package/src/common/keybinding.ts +152 -152
  1343. package/src/common/keyboard/keyboard-layout-provider.ts +51 -51
  1344. package/src/common/keys.ts +694 -694
  1345. package/src/common/label-protocol.ts +35 -35
  1346. package/src/common/logger-protocol.ts +119 -119
  1347. package/src/common/logger-watcher.ts +48 -48
  1348. package/src/common/logger.spec.ts +46 -46
  1349. package/src/common/logger.ts +389 -389
  1350. package/src/common/lsp-types.ts +34 -34
  1351. package/src/common/markdown-rendering/icon-utilities.ts +30 -30
  1352. package/src/common/markdown-rendering/index.ts +18 -18
  1353. package/src/common/markdown-rendering/markdown-string.ts +152 -152
  1354. package/src/common/menu/action-menu-node.ts +65 -65
  1355. package/src/common/menu/composite-menu-node.spec.ts +67 -67
  1356. package/src/common/menu/composite-menu-node.ts +114 -114
  1357. package/src/common/menu/index.ts +21 -21
  1358. package/src/common/menu/menu-adapter.ts +103 -103
  1359. package/src/common/menu/menu-model-registry.ts +343 -343
  1360. package/src/common/menu/menu-types.ts +219 -219
  1361. package/src/common/menu/menu.spec.ts +101 -101
  1362. package/src/common/message-rpc/channel.spec.ts +88 -88
  1363. package/src/common/message-rpc/channel.ts +300 -300
  1364. package/src/common/message-rpc/index.ts +22 -22
  1365. package/src/common/message-rpc/message-buffer.ts +105 -105
  1366. package/src/common/message-rpc/msg-pack-extension-manager.ts +70 -70
  1367. package/src/common/message-rpc/rpc-message-encoder.spec.ts +65 -65
  1368. package/src/common/message-rpc/rpc-message-encoder.ts +190 -190
  1369. package/src/common/message-rpc/rpc-protocol.ts +255 -255
  1370. package/src/common/message-rpc/uint8-array-message-buffer.spec.ts +41 -41
  1371. package/src/common/message-rpc/uint8-array-message-buffer.ts +213 -213
  1372. package/src/common/message-service-protocol.ts +148 -148
  1373. package/src/common/message-service.ts +226 -226
  1374. package/src/common/messaging/connection-error-handler.ts +73 -73
  1375. package/src/common/messaging/connection-management.ts +43 -43
  1376. package/src/common/messaging/handler.ts +26 -26
  1377. package/src/common/messaging/index.ts +19 -19
  1378. package/src/common/messaging/proxy-factory.spec.ts +108 -108
  1379. package/src/common/messaging/proxy-factory.ts +336 -336
  1380. package/src/common/messaging/socket-write-buffer.ts +52 -52
  1381. package/src/common/messaging/web-socket-channel.ts +76 -76
  1382. package/src/common/nls.ts +151 -149
  1383. package/src/common/numbers.ts +21 -21
  1384. package/src/common/objects.spec.ts +112 -112
  1385. package/src/common/objects.ts +123 -123
  1386. package/src/common/os.ts +82 -82
  1387. package/src/common/path.spec.ts +415 -415
  1388. package/src/common/path.ts +334 -334
  1389. package/src/common/paths.ts +250 -250
  1390. package/src/common/performance/index.ts +19 -19
  1391. package/src/common/performance/measurement-protocol.ts +104 -104
  1392. package/src/common/performance/measurement.ts +130 -130
  1393. package/src/common/performance/stopwatch.ts +183 -183
  1394. package/src/common/preferences/preference-schema.ts +95 -95
  1395. package/src/common/preferences/preference-scope.spec.ts +48 -48
  1396. package/src/common/preferences/preference-scope.ts +68 -68
  1397. package/src/common/prioritizeable.ts +58 -58
  1398. package/src/common/progress-service-protocol.ts +35 -35
  1399. package/src/common/progress-service.ts +82 -82
  1400. package/src/common/promise-util.spec.ts +102 -102
  1401. package/src/common/promise-util.ts +143 -143
  1402. package/src/common/quick-pick-service.ts +356 -355
  1403. package/src/common/reference.spec.ts +145 -145
  1404. package/src/common/reference.ts +230 -230
  1405. package/src/common/resource.ts +430 -430
  1406. package/src/common/selection-command-handler.ts +101 -101
  1407. package/src/common/selection-service.spec.ts +43 -43
  1408. package/src/common/selection-service.ts +49 -49
  1409. package/src/common/selection.ts +50 -50
  1410. package/src/common/severity.ts +111 -111
  1411. package/src/common/stream.ts +718 -718
  1412. package/src/common/strings.ts +231 -231
  1413. package/src/common/telemetry.ts +45 -45
  1414. package/src/common/ternary-search-tree.ts +417 -417
  1415. package/src/common/test/expect.ts +34 -34
  1416. package/src/common/test/mock-logger.ts +118 -118
  1417. package/src/common/test/mock-menu.ts +35 -35
  1418. package/src/common/test/mock-resource-provider.ts +33 -33
  1419. package/src/common/theme.ts +68 -68
  1420. package/src/common/types.spec.ts +86 -86
  1421. package/src/common/types.ts +140 -140
  1422. package/src/common/uri-command-handler.spec.ts +90 -90
  1423. package/src/common/uri-command-handler.ts +148 -148
  1424. package/src/common/uri.spec.ts +278 -278
  1425. package/src/common/uri.ts +279 -279
  1426. package/src/common/uuid.ts +45 -45
  1427. package/src/common/version.ts +17 -17
  1428. package/src/common/view-column.ts +33 -33
  1429. package/src/common/window.ts +34 -34
  1430. package/src/electron-browser/electron-clipboard-service.ts +32 -32
  1431. package/src/electron-browser/keyboard/electron-keyboard-layout-change-notifier.ts +39 -39
  1432. package/src/electron-browser/keyboard/electron-keyboard-module.ts +28 -28
  1433. package/src/electron-browser/menu/electron-context-menu-renderer.ts +122 -120
  1434. package/src/electron-browser/menu/electron-main-menu-factory.ts +335 -335
  1435. package/src/electron-browser/menu/electron-menu-contribution.ts +506 -506
  1436. package/src/electron-browser/menu/electron-menu-module.ts +40 -40
  1437. package/src/electron-browser/menu/electron-menu-style.css +110 -110
  1438. package/src/electron-browser/messaging/electron-frontend-id-provider.ts +25 -25
  1439. package/src/electron-browser/messaging/electron-ipc-connection-source.ts +65 -65
  1440. package/src/electron-browser/messaging/electron-local-ws-connection-source.ts +45 -45
  1441. package/src/electron-browser/messaging/electron-messaging-frontend-module.ts +78 -78
  1442. package/src/electron-browser/messaging/electron-ws-connection-source.ts +38 -38
  1443. package/src/electron-browser/preload.ts +246 -246
  1444. package/src/electron-browser/request/electron-browser-request-module.ts +26 -26
  1445. package/src/electron-browser/token/electron-token-frontend-module.ts +22 -22
  1446. package/src/electron-browser/window/electron-frontend-application-state.ts +26 -26
  1447. package/src/electron-browser/window/electron-secondary-window-service.ts +35 -39
  1448. package/src/electron-browser/window/electron-window-module.ts +41 -41
  1449. package/src/electron-browser/window/electron-window-preferences.ts +76 -76
  1450. package/src/electron-browser/window/electron-window-service.ts +109 -97
  1451. package/src/electron-common/electron-api.ts +148 -148
  1452. package/src/electron-common/electron-main-window-service.ts +24 -24
  1453. package/src/electron-common/electron-token.ts +27 -27
  1454. package/src/electron-main/electron-api-main.ts +340 -333
  1455. package/src/electron-main/electron-main-application-module.ts +65 -65
  1456. package/src/electron-main/electron-main-application.ts +685 -685
  1457. package/src/electron-main/electron-main-constants.ts +22 -22
  1458. package/src/electron-main/electron-main-window-service-impl.ts +44 -44
  1459. package/src/electron-main/electron-security-token-service.ts +36 -36
  1460. package/src/electron-main/event-utils.ts +36 -36
  1461. package/src/electron-main/messaging/electron-connection-handler.ts +21 -21
  1462. package/src/electron-main/messaging/electron-messaging-contribution.ts +143 -143
  1463. package/src/electron-main/messaging/electron-messaging-service.ts +35 -35
  1464. package/src/electron-main/theia-electron-window.ts +202 -202
  1465. package/src/electron-node/hosting/electron-backend-hosting-module.ts +24 -24
  1466. package/src/electron-node/hosting/electron-ws-origin-validator.ts +37 -37
  1467. package/src/electron-node/keyboard/electron-backend-keyboard-module.ts +30 -30
  1468. package/src/electron-node/keyboard/electron-keyboard-layout-provider.ts +35 -35
  1469. package/src/electron-node/request/electron-backend-request-module.ts +23 -23
  1470. package/src/electron-node/request/electron-backend-request-service.ts +78 -78
  1471. package/src/electron-node/token/electron-token-backend-contribution.ts +48 -48
  1472. package/src/electron-node/token/electron-token-backend-module.ts +28 -28
  1473. package/src/electron-node/token/electron-token-validator.ts +93 -93
  1474. package/src/node/application-server.ts +55 -55
  1475. package/src/node/backend-application-config-provider.spec.ts +29 -29
  1476. package/src/node/backend-application-config-provider.ts +48 -48
  1477. package/src/node/backend-application-module.ts +140 -140
  1478. package/src/node/backend-application.ts +382 -382
  1479. package/src/node/backend-remote-service.ts +25 -25
  1480. package/src/node/cli.spec.ts +94 -94
  1481. package/src/node/cli.ts +63 -63
  1482. package/src/node/console-logger-server.spec.ts +59 -59
  1483. package/src/node/console-logger-server.ts +76 -76
  1484. package/src/node/debug.ts +30 -30
  1485. package/src/node/dynamic-require.ts +56 -56
  1486. package/src/node/env-variables/env-variables-server.ts +120 -120
  1487. package/src/node/env-variables/index.ts +17 -17
  1488. package/src/node/environment-utils.spec.ts +92 -92
  1489. package/src/node/environment-utils.ts +66 -66
  1490. package/src/node/file-uri.spec.ts +76 -76
  1491. package/src/node/filesystem-locking.ts +77 -77
  1492. package/src/node/hosting/backend-application-hosts.ts +60 -60
  1493. package/src/node/hosting/backend-hosting-module.ts +26 -26
  1494. package/src/node/hosting/ws-origin-validator.ts +36 -36
  1495. package/src/node/i18n/i18n-backend-module.ts +42 -42
  1496. package/src/node/i18n/localization-contribution.ts +112 -112
  1497. package/src/node/i18n/localization-provider.ts +125 -125
  1498. package/src/node/i18n/localization-server.ts +52 -52
  1499. package/src/node/i18n/theia-localization-contribution.ts +36 -36
  1500. package/src/node/index.ts +22 -22
  1501. package/src/node/key-store-server.ts +162 -162
  1502. package/src/node/logger-backend-module.ts +88 -88
  1503. package/src/node/logger-cli-contribution.spec.ts +245 -245
  1504. package/src/node/logger-cli-contribution.ts +168 -168
  1505. package/src/node/main.ts +33 -33
  1506. package/src/node/messaging/binary-message-pipe.ts +168 -168
  1507. package/src/node/messaging/connection-container-module.ts +96 -96
  1508. package/src/node/messaging/default-messaging-service.ts +129 -129
  1509. package/src/node/messaging/frontend-connection-service.ts +24 -24
  1510. package/src/node/messaging/index.ts +19 -19
  1511. package/src/node/messaging/ipc-bootstrap.ts +27 -27
  1512. package/src/node/messaging/ipc-channel.ts +77 -77
  1513. package/src/node/messaging/ipc-connection-provider.ts +107 -107
  1514. package/src/node/messaging/ipc-protocol.ts +76 -76
  1515. package/src/node/messaging/messaging-backend-module.ts +52 -52
  1516. package/src/node/messaging/messaging-listeners.ts +52 -52
  1517. package/src/node/messaging/messaging-service.ts +46 -46
  1518. package/src/node/messaging/test/test-web-socket-channel.ts +61 -61
  1519. package/src/node/messaging/websocket-endpoint.ts +79 -79
  1520. package/src/node/messaging/websocket-frontend-connection-service.ts +176 -176
  1521. package/src/node/os-backend-provider.ts +25 -25
  1522. package/src/node/performance/index.ts +18 -18
  1523. package/src/node/performance/measurement-backend-bindings.ts +35 -35
  1524. package/src/node/performance/node-stopwatch.ts +40 -40
  1525. package/src/node/process-utils.spec.ts +48 -48
  1526. package/src/node/process-utils.ts +102 -102
  1527. package/src/node/request/backend-request-facade.ts +39 -39
  1528. package/src/node/request/backend-request-module.ts +25 -25
  1529. package/src/node/request/proxy-cli-contribution.ts +65 -65
  1530. package/src/node/ws-request-validators.ts +56 -56
  1531. package/src/typings/native-keymap.d.ts +108 -108
@@ -1,1640 +1,1640 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2018-2019 TypeFox and others.
3
- //
4
- // This program and the accompanying materials are made available under the
5
- // terms of the Eclipse Public License v. 2.0 which is available at
6
- // http://www.eclipse.org/legal/epl-2.0.
7
- //
8
- // This Source Code may also be made available under the following Secondary
9
- // Licenses when the conditions for such availability set forth in the Eclipse
10
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
- // with the GNU Classpath Exception which is available at
12
- // https://www.gnu.org/software/classpath/license.html.
13
- //
14
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
- // *****************************************************************************
16
-
17
- import { interfaces, injectable, inject, postConstruct } from 'inversify';
18
- import { IIterator, toArray, find, some, every, map, ArrayExt } from '@phosphor/algorithm';
19
- import {
20
- Widget, EXPANSION_TOGGLE_CLASS, COLLAPSED_CLASS, CODICON_TREE_ITEM_CLASSES, MessageLoop, Message, SplitPanel,
21
- BaseWidget, addEventListener, SplitLayout, LayoutItem, PanelLayout, addKeyListener, waitForRevealed, UnsafeWidgetUtilities, DockPanel, PINNED_CLASS
22
- } from './widgets';
23
- import { Event as CommonEvent, Emitter } from '../common/event';
24
- import { Disposable, DisposableCollection } from '../common/disposable';
25
- import { CommandRegistry } from '../common/command';
26
- import { MenuModelRegistry, MenuPath, MenuAction } from '../common/menu';
27
- import { ApplicationShell, StatefulWidget, SplitPositionHandler, SplitPositionOptions, SIDE_PANEL_TOOLBAR_CONTEXT_MENU } from './shell';
28
- import { MAIN_AREA_ID, BOTTOM_AREA_ID } from './shell/theia-dock-panel';
29
- import { FrontendApplicationStateService } from './frontend-application-state';
30
- import { ContextMenuRenderer, Anchor } from './context-menu-renderer';
31
- import { parseCssMagnitude } from './browser';
32
- import { TabBarToolbarRegistry, TabBarToolbarFactory, TabBarToolbar, TabBarDelegator, TabBarToolbarItem } from './shell/tab-bar-toolbar';
33
- import { isEmpty, isObject, nls } from '../common';
34
- import { WidgetManager } from './widget-manager';
35
- import { Key } from './keys';
36
- import { ProgressBarFactory } from './progress-bar-factory';
37
- import { Drag, IDragEvent } from '@phosphor/dragdrop';
38
- import { MimeData } from '@phosphor/coreutils';
39
- import { ElementExt } from '@phosphor/domutils';
40
- import { TabBarDecoratorService } from './shell/tab-bar-decorator';
41
-
42
- export interface ViewContainerTitleOptions {
43
- label: string;
44
- caption?: string;
45
- iconClass?: string;
46
- closeable?: boolean;
47
- }
48
-
49
- @injectable()
50
- export class ViewContainerIdentifier {
51
- id: string;
52
- progressLocationId?: string;
53
- }
54
-
55
- export interface DescriptionWidget {
56
- description: string;
57
- onDidChangeDescription: CommonEvent<void>;
58
- }
59
-
60
- export interface BadgeWidget {
61
- badge?: number;
62
- badgeTooltip?: string;
63
- onDidChangeBadge: CommonEvent<void>;
64
- onDidChangeBadgeTooltip: CommonEvent<void>;
65
- }
66
-
67
- export namespace DescriptionWidget {
68
- export function is(arg: unknown): arg is DescriptionWidget {
69
- return isObject(arg) && 'onDidChangeDescription' in arg;
70
- }
71
- }
72
-
73
- export namespace BadgeWidget {
74
- export function is(arg: unknown): arg is BadgeWidget {
75
- return isObject(arg) && 'onDidChangeBadge' in arg && 'onDidChangeBadgeTooltip' in arg;
76
- }
77
- }
78
-
79
- /**
80
- * A widget that may change it's internal structure dynamically.
81
- * Current use is to update the toolbar when a contributed view is constructed "lazily".
82
- */
83
- export interface DynamicToolbarWidget {
84
- onDidChangeToolbarItems: CommonEvent<void>;
85
- }
86
-
87
- export namespace DynamicToolbarWidget {
88
- export function is(arg: unknown): arg is DynamicToolbarWidget {
89
- return isObject(arg) && 'onDidChangeToolbarItems' in arg;
90
- }
91
- }
92
-
93
- /**
94
- * A view container holds an arbitrary number of widgets inside a split panel.
95
- * Each widget is wrapped in a _part_ that displays the widget title and toolbar
96
- * and allows to collapse / expand the widget content.
97
- */
98
- @injectable()
99
- export class ViewContainer extends BaseWidget implements StatefulWidget, ApplicationShell.TrackableWidgetProvider, TabBarDelegator {
100
-
101
- protected panel: SplitPanel;
102
-
103
- protected currentPart: ViewContainerPart | undefined;
104
-
105
- /**
106
- * Disable dragging parts from/to this view container.
107
- */
108
- disableDNDBetweenContainers = false;
109
-
110
- @inject(FrontendApplicationStateService)
111
- protected readonly applicationStateService: FrontendApplicationStateService;
112
-
113
- @inject(ContextMenuRenderer)
114
- protected readonly contextMenuRenderer: ContextMenuRenderer;
115
-
116
- @inject(CommandRegistry)
117
- protected readonly commandRegistry: CommandRegistry;
118
-
119
- @inject(MenuModelRegistry)
120
- protected readonly menuRegistry: MenuModelRegistry;
121
-
122
- @inject(WidgetManager)
123
- protected readonly widgetManager: WidgetManager;
124
-
125
- @inject(SplitPositionHandler)
126
- protected readonly splitPositionHandler: SplitPositionHandler;
127
-
128
- @inject(ViewContainerIdentifier)
129
- readonly options: ViewContainerIdentifier;
130
-
131
- @inject(TabBarToolbarRegistry)
132
- protected readonly toolbarRegistry: TabBarToolbarRegistry;
133
-
134
- @inject(TabBarToolbarFactory)
135
- protected readonly toolbarFactory: TabBarToolbarFactory;
136
-
137
- protected readonly onDidChangeTrackableWidgetsEmitter = new Emitter<Widget[]>();
138
- readonly onDidChangeTrackableWidgets = this.onDidChangeTrackableWidgetsEmitter.event;
139
-
140
- @inject(ProgressBarFactory)
141
- protected readonly progressBarFactory: ProgressBarFactory;
142
-
143
- @inject(ApplicationShell)
144
- protected readonly shell: ApplicationShell;
145
-
146
- @inject(TabBarDecoratorService)
147
- protected readonly decoratorService: TabBarDecoratorService;
148
-
149
- @postConstruct()
150
- protected init(): void {
151
- this.id = this.options.id;
152
- this.addClass('theia-view-container');
153
- const layout = new PanelLayout();
154
- this.layout = layout;
155
- this.panel = new SplitPanel({
156
- layout: new ViewContainerLayout({
157
- renderer: SplitPanel.defaultRenderer,
158
- orientation: this.orientation,
159
- spacing: 2,
160
- headerSize: ViewContainerPart.HEADER_HEIGHT,
161
- animationDuration: 200
162
- }, this.splitPositionHandler)
163
- });
164
- this.panel.node.tabIndex = -1;
165
- this.configureLayout(layout);
166
-
167
- const { commandRegistry, menuRegistry, contextMenuRenderer } = this;
168
- this.toDispose.pushAll([
169
- addEventListener(this.node, 'contextmenu', event => {
170
- if (event.button === 2 && every(this.containerLayout.iter(), part => !!part.isHidden)) {
171
- event.stopPropagation();
172
- event.preventDefault();
173
- contextMenuRenderer.render({ menuPath: this.contextMenuPath, anchor: event });
174
- }
175
- }),
176
- commandRegistry.registerCommand({ id: this.globalHideCommandId }, {
177
- execute: (anchor: Anchor) => {
178
- const toHide = this.findPartForAnchor(anchor);
179
- if (toHide && toHide.canHide) {
180
- toHide.hide();
181
- }
182
- },
183
- isVisible: (anchor: Anchor) => {
184
- const toHide = this.findPartForAnchor(anchor);
185
- if (toHide) {
186
- return toHide.canHide && !toHide.isHidden;
187
- } else {
188
- return some(this.containerLayout.iter(), part => !part.isHidden);
189
- }
190
- }
191
- }),
192
- menuRegistry.registerMenuAction([...this.contextMenuPath, '0_global'], {
193
- commandId: this.globalHideCommandId,
194
- label: nls.localizeByDefault('Hide')
195
- }),
196
- this.onDidChangeTrackableWidgetsEmitter,
197
- this.onDidChangeTrackableWidgets(() => this.decoratorService.fireDidChangeDecorations())
198
- ]);
199
- if (this.options.progressLocationId) {
200
- this.toDispose.push(this.progressBarFactory({ container: this.node, insertMode: 'prepend', locationId: this.options.progressLocationId }));
201
- }
202
- }
203
-
204
- protected configureLayout(layout: PanelLayout): void {
205
- layout.addWidget(this.panel);
206
- }
207
-
208
- protected readonly toDisposeOnCurrentPart = new DisposableCollection();
209
-
210
- protected updateCurrentPart(part?: ViewContainerPart): void {
211
- if (part && this.getParts().indexOf(part) !== -1) {
212
- this.currentPart = part;
213
- }
214
- if (this.currentPart && !this.currentPart.isDisposed) {
215
- return;
216
- }
217
- const visibleParts = this.getParts().filter(p => !p.isHidden);
218
- const expandedParts = visibleParts.filter(p => !p.collapsed);
219
- this.currentPart = expandedParts[0] || visibleParts[0];
220
- }
221
-
222
- protected updateSplitterVisibility(): void {
223
- const className = 'p-first-visible';
224
- let firstFound = false;
225
- for (const part of this.getParts()) {
226
- if (!part.isHidden && !firstFound) {
227
- part.addClass(className);
228
- firstFound = true;
229
- } else {
230
- part.removeClass(className);
231
- }
232
- }
233
- }
234
-
235
- protected titleOptions: ViewContainerTitleOptions | undefined;
236
-
237
- setTitleOptions(titleOptions: ViewContainerTitleOptions | undefined): void {
238
- this.titleOptions = titleOptions;
239
- this.updateTitle();
240
- }
241
-
242
- protected readonly toDisposeOnUpdateTitle = new DisposableCollection();
243
-
244
- protected _tabBarDelegate: Widget = this;
245
- updateTabBarDelegate(): void {
246
- const visibleParts = this.getParts().filter(part => !part.isHidden);
247
- if (visibleParts.length === 1) {
248
- this._tabBarDelegate = visibleParts[0].wrapped;
249
- } else {
250
- this._tabBarDelegate = this;
251
- }
252
- }
253
-
254
- getTabBarDelegate(): Widget | undefined {
255
- return this._tabBarDelegate;
256
- }
257
-
258
- protected updateTitle(): void {
259
- this.toDisposeOnUpdateTitle.dispose();
260
- this.toDispose.push(this.toDisposeOnUpdateTitle);
261
- this.updateTabBarDelegate();
262
- let title = Object.assign({}, this.titleOptions);
263
- if (isEmpty(title)) {
264
- return;
265
- }
266
- const allParts = this.getParts();
267
- const visibleParts = allParts.filter(part => !part.isHidden);
268
- this.title.label = title.label;
269
- // If there's only one visible part - inline it's title into the container title except in case the part
270
- // isn't originally belongs to this container but there are other **original** hidden parts.
271
- if (visibleParts.length === 1 && (visibleParts[0].originalContainerId === this.id || !this.findOriginalPart())) {
272
- const part = visibleParts[0];
273
- this.toDisposeOnUpdateTitle.push(part.onTitleChanged(() => this.updateTitle()));
274
- const partLabel = part.wrapped.title.label;
275
- // Change the container title if it contains only one part that originally belongs to another container.
276
- if (allParts.length === 1 && part.originalContainerId !== this.id && !this.isCurrentTitle(part.originalContainerTitle)) {
277
- title = Object.assign({}, part.originalContainerTitle);
278
- this.setTitleOptions(title);
279
- return;
280
- }
281
- if (partLabel) {
282
- if (this.title.label && this.title.label !== partLabel) {
283
- this.title.label += ': ' + partLabel;
284
- } else {
285
- this.title.label = partLabel;
286
- }
287
- }
288
- part.collapsed = false;
289
- part.hideTitle();
290
- } else {
291
- visibleParts.forEach(part => part.showTitle());
292
- // If at least one part originally belongs to this container the title should return to its original value.
293
- const originalPart = this.findOriginalPart();
294
- if (originalPart && !this.isCurrentTitle(originalPart.originalContainerTitle)) {
295
- title = Object.assign({}, originalPart.originalContainerTitle);
296
- this.setTitleOptions(title);
297
- return;
298
- }
299
- }
300
- this.updateToolbarItems(allParts);
301
- this.title.caption = title?.caption || title?.label;
302
- if (title.iconClass) {
303
- this.title.iconClass = title.iconClass;
304
- }
305
- if (this.title.className.includes(PINNED_CLASS)) {
306
- this.title.closable &&= false;
307
- } else if (title.closeable !== undefined) {
308
- this.title.closable = title.closeable;
309
- }
310
- }
311
-
312
- protected updateToolbarItems(allParts: ViewContainerPart[]): void {
313
- if (allParts.length > 1) {
314
- const group = this.getToggleVisibilityGroupLabel();
315
- for (const part of allParts) {
316
- const existingId = this.toggleVisibilityCommandId(part);
317
- const { caption, label, dataset: { visibilityCommandLabel } } = part.wrapped.title;
318
- this.registerToolbarItem(existingId, { tooltip: visibilityCommandLabel || caption || label, group });
319
- }
320
- }
321
- }
322
-
323
- protected getToggleVisibilityGroupLabel(): string {
324
- return 'view';
325
- }
326
-
327
- protected registerToolbarItem(commandId: string, options?: Partial<Omit<TabBarToolbarItem, 'id' | 'command'>>): void {
328
- const newId = `${this.id}-tabbar-toolbar-${commandId}`;
329
- const existingHandler = this.commandRegistry.getAllHandlers(commandId)[0];
330
- const existingCommand = this.commandRegistry.getCommand(commandId);
331
- if (existingHandler && existingCommand) {
332
- this.toDisposeOnUpdateTitle.push(this.commandRegistry.registerCommand({ ...existingCommand, id: newId }, {
333
- execute: (_widget, ...args) => this.commandRegistry.executeCommand(commandId, ...args),
334
- isToggled: (_widget, ...args) => this.commandRegistry.isToggled(commandId, ...args),
335
- isEnabled: (_widget, ...args) => this.commandRegistry.isEnabled(commandId, ...args),
336
- isVisible: (widget, ...args) => widget === this.getTabBarDelegate() && this.commandRegistry.isVisible(commandId, ...args),
337
- }));
338
- this.toDisposeOnUpdateTitle.push(this.toolbarRegistry.registerItem({
339
- ...options,
340
- id: newId,
341
- command: newId,
342
- }));
343
- }
344
- }
345
-
346
- protected findOriginalPart(): ViewContainerPart | undefined {
347
- return this.getParts().find(part => part.originalContainerId === this.id);
348
- }
349
-
350
- protected isCurrentTitle(titleOptions: ViewContainerTitleOptions | undefined): boolean {
351
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
352
- return (!!titleOptions && !!this.titleOptions && Object.keys(titleOptions).every(key => (titleOptions as any)[key] === (this.titleOptions as any)[key]))
353
- || (!titleOptions && !this.titleOptions);
354
- }
355
-
356
- protected findPartForAnchor(anchor: Anchor): ViewContainerPart | undefined {
357
- const element = document.elementFromPoint(anchor.x, anchor.y);
358
- if (element instanceof Element) {
359
- const closestPart = ViewContainerPart.closestPart(element);
360
- if (closestPart && closestPart.id) {
361
- return find(this.containerLayout.iter(), part => part.id === closestPart.id);
362
- }
363
- }
364
- return undefined;
365
- }
366
-
367
- protected readonly toRemoveWidgets = new Map<string, DisposableCollection>();
368
-
369
- protected createPartId(widget: Widget): string {
370
- const description = this.widgetManager.getDescription(widget);
371
- return widget.id || JSON.stringify(description);
372
- }
373
-
374
- addWidget(widget: Widget, options?: ViewContainer.Factory.WidgetOptions, originalContainerId?: string, originalContainerTitle?: ViewContainerTitleOptions): Disposable {
375
- const existing = this.toRemoveWidgets.get(widget.id);
376
- if (existing) {
377
- return existing;
378
- }
379
- const partId = this.createPartId(widget);
380
- const newPart = this.createPart(widget, partId, originalContainerId || this.id, originalContainerTitle || this.titleOptions, options);
381
- return this.attachNewPart(newPart);
382
- }
383
-
384
- protected attachNewPart(newPart: ViewContainerPart, insertIndex?: number): Disposable {
385
- const toRemoveWidget = new DisposableCollection();
386
- this.toDispose.push(toRemoveWidget);
387
- this.toRemoveWidgets.set(newPart.wrapped.id, toRemoveWidget);
388
- toRemoveWidget.push(Disposable.create(() => this.toRemoveWidgets.delete(newPart.wrapped.id)));
389
- this.registerPart(newPart);
390
- if (insertIndex !== undefined || (newPart.options && newPart.options.order !== undefined)) {
391
- const index = insertIndex ?? this.getParts().findIndex(part => part.options.order === undefined || part.options.order > newPart.options.order!);
392
- if (index >= 0) {
393
- this.containerLayout.insertWidget(index, newPart);
394
- } else {
395
- this.containerLayout.addWidget(newPart);
396
- }
397
- } else {
398
- this.containerLayout.addWidget(newPart);
399
- }
400
- this.refreshMenu(newPart);
401
- this.updateTitle();
402
- this.updateCurrentPart();
403
- this.updateSplitterVisibility();
404
- this.update();
405
- this.fireDidChangeTrackableWidgets();
406
- toRemoveWidget.pushAll([
407
- Disposable.create(() => {
408
- if (newPart.currentViewContainerId === this.id) {
409
- newPart.dispose();
410
- }
411
- this.unregisterPart(newPart);
412
- if (!newPart.isDisposed && this.getPartIndex(newPart.id) > -1) {
413
- this.containerLayout.removeWidget(newPart);
414
- }
415
- if (!this.isDisposed) {
416
- this.update();
417
- this.updateTitle();
418
- this.updateCurrentPart();
419
- this.updateSplitterVisibility();
420
- this.fireDidChangeTrackableWidgets();
421
- }
422
- }),
423
- this.registerDND(newPart),
424
- newPart.onDidChangeVisibility(() => {
425
- this.updateTitle();
426
- this.updateCurrentPart();
427
- this.updateSplitterVisibility();
428
- this.containerLayout.updateSashes();
429
- }),
430
- newPart.onCollapsed(() => {
431
- this.containerLayout.updateCollapsed(newPart, this.enableAnimation);
432
- this.containerLayout.updateSashes();
433
- this.updateCurrentPart();
434
- }),
435
- newPart.onContextMenu(event => {
436
- if (event.button === 2) {
437
- event.preventDefault();
438
- event.stopPropagation();
439
- this.contextMenuRenderer.render({ menuPath: this.contextMenuPath, anchor: event });
440
- }
441
- }),
442
- newPart.onTitleChanged(() => this.refreshMenu(newPart)),
443
- newPart.onDidFocus(() => this.updateCurrentPart(newPart))
444
- ]);
445
-
446
- newPart.disposed.connect(() => toRemoveWidget.dispose());
447
- return toRemoveWidget;
448
- }
449
-
450
- protected createPart(widget: Widget, partId: string, originalContainerId: string, originalContainerTitle?: ViewContainerTitleOptions,
451
- options?: ViewContainer.Factory.WidgetOptions): ViewContainerPart {
452
-
453
- return new ViewContainerPart(widget, partId, this.id, originalContainerId, originalContainerTitle, this.toolbarRegistry, this.toolbarFactory, options);
454
- }
455
-
456
- removeWidget(widget: Widget): boolean {
457
- const disposable = this.toRemoveWidgets.get(widget.id);
458
- if (disposable) {
459
- disposable.dispose();
460
- return true;
461
- }
462
- return false;
463
- }
464
-
465
- getParts(): ViewContainerPart[] {
466
- return this.containerLayout.widgets;
467
- }
468
-
469
- protected getPartIndex(partId: string | undefined): number {
470
- if (partId) {
471
- return this.getParts().findIndex(part => part.id === partId);
472
- }
473
- return -1;
474
- }
475
-
476
- getPartFor(widget: Widget): ViewContainerPart | undefined {
477
- return this.getParts().find(p => p.wrapped.id === widget.id);
478
- }
479
-
480
- get containerLayout(): ViewContainerLayout {
481
- const layout = this.panel.layout;
482
- if (layout instanceof ViewContainerLayout) {
483
- return layout;
484
- }
485
- throw new Error('view container is disposed');
486
- }
487
-
488
- protected get orientation(): SplitLayout.Orientation {
489
- return ViewContainer.getOrientation(this.node);
490
- }
491
-
492
- protected get enableAnimation(): boolean {
493
- return this.applicationStateService.state === 'ready';
494
- }
495
-
496
- protected lastVisibleState: ViewContainer.State | undefined;
497
-
498
- storeState(): ViewContainer.State {
499
- if (!this.isVisible && this.lastVisibleState) {
500
- return this.lastVisibleState;
501
- }
502
- return this.doStoreState();
503
- }
504
- protected doStoreState(): ViewContainer.State {
505
- const parts = this.getParts();
506
- const availableSize = this.containerLayout.getAvailableSize();
507
- const orientation = this.orientation;
508
- const partStates = parts.map(part => {
509
- let size = this.containerLayout.getPartSize(part);
510
- if (size && size > ViewContainerPart.HEADER_HEIGHT && orientation === 'vertical') {
511
- size -= ViewContainerPart.HEADER_HEIGHT;
512
- }
513
- return <ViewContainerPart.State>{
514
- widget: part.wrapped,
515
- partId: part.partId,
516
- collapsed: part.collapsed,
517
- hidden: part.isHidden,
518
- relativeSize: size && availableSize ? size / availableSize : undefined,
519
- originalContainerId: part.originalContainerId,
520
- originalContainerTitle: part.originalContainerTitle
521
- };
522
- });
523
- return { parts: partStates, title: this.titleOptions };
524
- }
525
-
526
- restoreState(state: ViewContainer.State): void {
527
- this.lastVisibleState = state;
528
- this.doRestoreState(state);
529
- }
530
- protected doRestoreState(state: ViewContainer.State): void {
531
- this.setTitleOptions(state.title);
532
- // restore widgets
533
- for (const part of state.parts) {
534
- if (part.widget) {
535
- this.addWidget(part.widget, undefined, part.originalContainerId, part.originalContainerTitle || {} as ViewContainerTitleOptions);
536
- }
537
- }
538
- const partStates = state.parts.filter(partState => some(this.containerLayout.iter(), p => p.partId === partState.partId));
539
-
540
- // Reorder the parts according to the stored state
541
- for (let index = 0; index < partStates.length; index++) {
542
- const partState = partStates[index];
543
- const widget = this.getParts().find(part => part.partId === partState.partId);
544
- if (widget) {
545
- this.containerLayout.insertWidget(index, widget);
546
- }
547
- }
548
-
549
- // Restore visibility and collapsed state
550
- const parts = this.getParts();
551
- for (let index = 0; index < parts.length; index++) {
552
- const part = parts[index];
553
- const partState = partStates.find(s => part.partId === s.partId);
554
- if (partState) {
555
- part.setHidden(partState.hidden);
556
- part.collapsed = partState.collapsed || !partState.relativeSize;
557
- } else if (part.canHide) {
558
- part.hide();
559
- }
560
- this.refreshMenu(part);
561
- }
562
-
563
- // Restore part sizes
564
- waitForRevealed(this).then(() => {
565
- this.containerLayout.setPartSizes(partStates.map(partState => partState.relativeSize));
566
- this.updateSplitterVisibility();
567
- });
568
- }
569
-
570
- /**
571
- * Register a command to toggle the visibility of the new part.
572
- */
573
- protected registerPart(toRegister: ViewContainerPart): void {
574
- const commandId = this.toggleVisibilityCommandId(toRegister);
575
- this.commandRegistry.registerCommand({ id: commandId }, {
576
- execute: () => {
577
- const toHide = find(this.containerLayout.iter(), part => part.id === toRegister.id);
578
- if (toHide) {
579
- toHide.setHidden(!toHide.isHidden);
580
- }
581
- },
582
- isToggled: () => {
583
- if (!toRegister.canHide) {
584
- return true;
585
- }
586
- const widgetToToggle = find(this.containerLayout.iter(), part => part.id === toRegister.id);
587
- if (widgetToToggle) {
588
- return !widgetToToggle.isHidden;
589
- }
590
- return false;
591
- },
592
- isEnabled: arg => toRegister.canHide && (!this.titleOptions || !(arg instanceof Widget) || (arg instanceof ViewContainer && arg.id === this.id)),
593
- isVisible: arg => !this.titleOptions || !(arg instanceof Widget) || (arg instanceof ViewContainer && arg.id === this.id)
594
- });
595
- }
596
-
597
- /**
598
- * Register a menu action to toggle the visibility of the new part.
599
- * The menu action is unregistered first to enable refreshing the order of menu actions.
600
- */
601
- protected refreshMenu(part: ViewContainerPart): void {
602
- const commandId = this.toggleVisibilityCommandId(part);
603
- this.menuRegistry.unregisterMenuAction(commandId);
604
- if (!part.wrapped.title.label) {
605
- return;
606
- }
607
- const { dataset: { visibilityCommandLabel }, caption, label } = part.wrapped.title;
608
- const action: MenuAction = {
609
- commandId: commandId,
610
- label: visibilityCommandLabel || caption || label,
611
- order: this.getParts().indexOf(part).toString()
612
- };
613
- this.menuRegistry.registerMenuAction([...this.contextMenuPath, '1_widgets'], action);
614
- if (this.titleOptions) {
615
- this.menuRegistry.registerMenuAction([...SIDE_PANEL_TOOLBAR_CONTEXT_MENU, 'navigation'], action);
616
- }
617
- }
618
-
619
- protected unregisterPart(part: ViewContainerPart): void {
620
- const commandId = this.toggleVisibilityCommandId(part);
621
- this.commandRegistry.unregisterCommand(commandId);
622
- this.menuRegistry.unregisterMenuAction(commandId);
623
- }
624
-
625
- protected get contextMenuPath(): MenuPath {
626
- return [`${this.id}-context-menu`];
627
- }
628
-
629
- protected toggleVisibilityCommandId(part: ViewContainerPart): string {
630
- return `${this.id}:toggle-visibility-${part.id}`;
631
- }
632
-
633
- protected get globalHideCommandId(): string {
634
- return `${this.id}:toggle-visibility`;
635
- }
636
-
637
- protected moveBefore(toMovedId: string, moveBeforeThisId: string): void {
638
- const parts = this.getParts();
639
- const indexToMove = parts.findIndex(part => part.id === toMovedId);
640
- const targetIndex = parts.findIndex(part => part.id === moveBeforeThisId);
641
- if (indexToMove >= 0 && targetIndex >= 0) {
642
- this.containerLayout.insertWidget(targetIndex, parts[indexToMove]);
643
- for (let index = Math.min(indexToMove, targetIndex); index < parts.length; index++) {
644
- this.refreshMenu(parts[index]);
645
- this.activate();
646
- }
647
- }
648
- this.updateSplitterVisibility();
649
- }
650
-
651
- getTrackableWidgets(): Widget[] {
652
- return this.getParts().map(w => w.wrapped);
653
- }
654
-
655
- protected fireDidChangeTrackableWidgets(): void {
656
- this.onDidChangeTrackableWidgetsEmitter.fire(this.getTrackableWidgets());
657
- }
658
-
659
- activateWidget(id: string): Widget | undefined {
660
- const part = this.revealPart(id);
661
- if (!part) {
662
- return undefined;
663
- }
664
- this.updateCurrentPart(part);
665
- part.collapsed = false;
666
- return part.wrapped;
667
- }
668
-
669
- revealWidget(id: string): Widget | undefined {
670
- const part = this.revealPart(id);
671
- return part && part.wrapped;
672
- }
673
-
674
- protected revealPart(id: string): ViewContainerPart | undefined {
675
- const part = this.getParts().find(p => p.wrapped.id === id);
676
- if (!part) {
677
- return undefined;
678
- }
679
- part.setHidden(false);
680
- return part;
681
- }
682
-
683
- protected override onActivateRequest(msg: Message): void {
684
- super.onActivateRequest(msg);
685
- if (this.currentPart) {
686
- this.currentPart.activate();
687
- } else {
688
- this.panel.node.focus({ preventScroll: true });
689
- }
690
- }
691
-
692
- protected override onAfterAttach(msg: Message): void {
693
- const orientation = this.orientation;
694
- this.containerLayout.orientation = orientation;
695
- if (orientation === 'horizontal') {
696
- for (const part of this.getParts()) {
697
- part.collapsed = false;
698
- }
699
- }
700
- super.onAfterAttach(msg);
701
- }
702
-
703
- protected override onBeforeHide(msg: Message): void {
704
- super.onBeforeHide(msg);
705
- this.lastVisibleState = this.storeState();
706
- }
707
-
708
- protected override onAfterShow(msg: Message): void {
709
- super.onAfterShow(msg);
710
- this.updateTitle();
711
- this.lastVisibleState = undefined;
712
- }
713
-
714
- protected override onBeforeAttach(msg: Message): void {
715
- super.onBeforeAttach(msg);
716
- this.node.addEventListener('p-dragenter', this, true);
717
- this.node.addEventListener('p-dragover', this, true);
718
- this.node.addEventListener('p-dragleave', this, true);
719
- this.node.addEventListener('p-drop', this, true);
720
- }
721
-
722
- protected override onAfterDetach(msg: Message): void {
723
- super.onAfterDetach(msg);
724
- this.node.removeEventListener('p-dragenter', this, true);
725
- this.node.removeEventListener('p-dragover', this, true);
726
- this.node.removeEventListener('p-dragleave', this, true);
727
- this.node.removeEventListener('p-drop', this, true);
728
- }
729
-
730
- handleEvent(event: Event): void {
731
- switch (event.type) {
732
- case 'p-dragenter':
733
- this.handleDragEnter(event as IDragEvent);
734
- break;
735
- case 'p-dragover':
736
- this.handleDragOver(event as IDragEvent);
737
- break;
738
- case 'p-dragleave':
739
- this.handleDragLeave(event as IDragEvent);
740
- break;
741
- case 'p-drop':
742
- this.handleDrop(event as IDragEvent);
743
- break;
744
- }
745
- }
746
-
747
- handleDragEnter(event: IDragEvent): void {
748
- if (event.mimeData.hasData('application/vnd.phosphor.view-container-factory')) {
749
- event.preventDefault();
750
- event.stopPropagation();
751
- }
752
- }
753
-
754
- toDisposeOnDragEnd = new DisposableCollection();
755
- handleDragOver(event: IDragEvent): void {
756
- const factory = event.mimeData.getData('application/vnd.phosphor.view-container-factory');
757
- const widget = factory && factory();
758
- if (!(widget instanceof ViewContainerPart)) {
759
- return;
760
- }
761
- event.preventDefault();
762
- event.stopPropagation();
763
-
764
- const sameContainers = this.id === widget.currentViewContainerId;
765
- const targetPart = ArrayExt.findFirstValue(this.getParts(), (p => ElementExt.hitTest(p.node, event.clientX, event.clientY)));
766
- if (!targetPart && sameContainers) {
767
- event.dropAction = 'none';
768
- return;
769
- }
770
- if (targetPart) {
771
- // add overlay class style to the `targetPart` node.
772
- targetPart.node.classList.add('drop-target');
773
- this.toDisposeOnDragEnd.push(Disposable.create(() => targetPart.node.classList.remove('drop-target')));
774
- } else {
775
- // show panel overlay.
776
- const dockPanel = this.getDockPanel();
777
- if (dockPanel) {
778
- dockPanel.overlay.show({ top: 0, bottom: 0, right: 0, left: 0 });
779
- this.toDisposeOnDragEnd.push(Disposable.create(() => dockPanel.overlay.hide(100)));
780
- }
781
- }
782
-
783
- const isDraggingOutsideDisabled = this.disableDNDBetweenContainers || widget.viewContainer?.disableDNDBetweenContainers
784
- || widget.options.disableDraggingToOtherContainers;
785
- if (isDraggingOutsideDisabled && !sameContainers) {
786
- const { target } = event;
787
- if (target instanceof HTMLElement) {
788
- target.classList.add('theia-cursor-no-drop');
789
- this.toDisposeOnDragEnd.push(Disposable.create(() => {
790
- target.classList.remove('theia-cursor-no-drop');
791
- }));
792
- }
793
- event.dropAction = 'none';
794
- return;
795
- };
796
-
797
- event.dropAction = event.proposedAction;
798
- };
799
-
800
- handleDragLeave(event: IDragEvent): void {
801
- this.toDisposeOnDragEnd.dispose();
802
- if (event.mimeData.hasData('application/vnd.phosphor.view-container-factory')) {
803
- event.preventDefault();
804
- event.stopPropagation();
805
- }
806
- };
807
-
808
- handleDrop(event: IDragEvent): void {
809
- this.toDisposeOnDragEnd.dispose();
810
- const factory = event.mimeData.getData('application/vnd.phosphor.view-container-factory');
811
- const draggedPart = factory && factory();
812
- if (!(draggedPart instanceof ViewContainerPart)) {
813
- event.dropAction = 'none';
814
- return;
815
- }
816
- event.preventDefault();
817
- event.stopPropagation();
818
- const parts = this.getParts();
819
- const toIndex = ArrayExt.findFirstIndex(parts, part => ElementExt.hitTest(part.node, event.clientX, event.clientY));
820
- if (draggedPart.currentViewContainerId !== this.id) {
821
- this.attachNewPart(draggedPart, toIndex > -1 ? toIndex + 1 : toIndex);
822
- draggedPart.onPartMoved(this);
823
- } else {
824
- this.moveBefore(draggedPart.id, parts[toIndex].id);
825
- }
826
- event.dropAction = event.proposedAction;
827
- }
828
-
829
- protected registerDND(part: ViewContainerPart): Disposable {
830
- part.headerElement.draggable = true;
831
-
832
- return new DisposableCollection(
833
- addEventListener(part.headerElement, 'dragstart',
834
- event => {
835
- event.preventDefault();
836
- const mimeData = new MimeData();
837
- mimeData.setData('application/vnd.phosphor.view-container-factory', () => part);
838
- const clonedHeader = part.headerElement.cloneNode(true) as HTMLElement;
839
- clonedHeader.style.width = part.node.style.width;
840
- clonedHeader.style.opacity = '0.6';
841
- const drag = new Drag({
842
- mimeData,
843
- dragImage: clonedHeader,
844
- proposedAction: 'move',
845
- supportedActions: 'move'
846
- });
847
- part.node.classList.add('p-mod-hidden');
848
- drag.start(event.clientX, event.clientY).then(dropAction => {
849
- // The promise is resolved when the drag has ended
850
- if (dropAction === 'move' && part.currentViewContainerId !== this.id) {
851
- this.removeWidget(part.wrapped);
852
- this.lastVisibleState = this.doStoreState();
853
- }
854
- });
855
- setTimeout(() => { part.node.classList.remove('p-mod-hidden'); }, 0);
856
- }, false));
857
- }
858
-
859
- protected getDockPanel(): DockPanel | undefined {
860
- let panel: DockPanel | undefined;
861
- let parent = this.parent;
862
- while (!panel && parent) {
863
- if (this.isSideDockPanel(parent)) {
864
- panel = parent as DockPanel;
865
- } else {
866
- parent = parent.parent;
867
- }
868
- }
869
- return panel;
870
- }
871
-
872
- protected isSideDockPanel(widget: Widget): boolean {
873
- const { leftPanelHandler, rightPanelHandler } = this.shell;
874
- if (widget instanceof DockPanel && (widget.id === rightPanelHandler.dockPanel.id || widget.id === leftPanelHandler.dockPanel.id)) {
875
- return true;
876
- }
877
- return false;
878
- }
879
-
880
- }
881
-
882
- export namespace ViewContainer {
883
-
884
- export const Factory = Symbol('ViewContainerFactory');
885
- export interface Factory {
886
- (options: ViewContainerIdentifier): ViewContainer;
887
- }
888
-
889
- export namespace Factory {
890
-
891
- export interface WidgetOptions {
892
- readonly order?: number;
893
- readonly weight?: number;
894
- readonly initiallyCollapsed?: boolean;
895
- readonly canHide?: boolean;
896
- readonly initiallyHidden?: boolean;
897
- /**
898
- * Disable dragging this part from its original container to other containers,
899
- * But allow dropping parts from other containers on it,
900
- * This option only applies to the `ViewContainerPart` and has no effect on the ViewContainer.
901
- */
902
- readonly disableDraggingToOtherContainers?: boolean;
903
- }
904
-
905
- export interface WidgetDescriptor {
906
- readonly widget: Widget | interfaces.ServiceIdentifier<Widget>;
907
- readonly options?: WidgetOptions;
908
- }
909
-
910
- }
911
-
912
- export interface State {
913
- title?: ViewContainerTitleOptions;
914
- parts: ViewContainerPart.State[]
915
- }
916
-
917
- export function getOrientation(node: HTMLElement): 'horizontal' | 'vertical' {
918
- if (node.closest(`#${MAIN_AREA_ID}`) || node.closest(`#${BOTTOM_AREA_ID}`)) {
919
- return 'horizontal';
920
- }
921
- return 'vertical';
922
- }
923
- }
924
-
925
- /**
926
- * Wrapper around a widget held by a view container. Adds a header to display the
927
- * title, toolbar, and collapse / expand handle.
928
- */
929
- export class ViewContainerPart extends BaseWidget {
930
-
931
- protected readonly header: HTMLElement;
932
- protected readonly body: HTMLElement;
933
- protected readonly collapsedEmitter = new Emitter<boolean>();
934
- protected readonly contextMenuEmitter = new Emitter<MouseEvent>();
935
-
936
- protected readonly onTitleChangedEmitter = new Emitter<void>();
937
- readonly onTitleChanged = this.onTitleChangedEmitter.event;
938
- protected readonly onDidFocusEmitter = new Emitter<this>();
939
- readonly onDidFocus = this.onDidFocusEmitter.event;
940
- protected readonly onPartMovedEmitter = new Emitter<ViewContainer>();
941
- readonly onDidMove = this.onPartMovedEmitter.event;
942
- protected readonly onDidChangeDescriptionEmitter = new Emitter<void>();
943
- readonly onDidChangeDescription = this.onDidChangeDescriptionEmitter.event;
944
- protected readonly onDidChangeBadgeEmitter = new Emitter<void>();
945
- readonly onDidChangeBadge = this.onDidChangeBadgeEmitter.event;
946
- protected readonly onDidChangeBadgeTooltipEmitter = new Emitter<void>();
947
- readonly onDidChangeBadgeTooltip = this.onDidChangeBadgeTooltipEmitter.event;
948
-
949
- protected readonly toolbar: TabBarToolbar;
950
-
951
- protected _collapsed: boolean;
952
-
953
- uncollapsedSize: number | undefined;
954
- animatedSize: number | undefined;
955
-
956
- protected readonly toNoDisposeWrapped: Disposable;
957
-
958
- constructor(
959
- readonly wrapped: Widget,
960
- readonly partId: string,
961
- protected currentContainerId: string,
962
- readonly originalContainerId: string,
963
- readonly originalContainerTitle: ViewContainerTitleOptions | undefined,
964
- protected readonly toolbarRegistry: TabBarToolbarRegistry,
965
- protected readonly toolbarFactory: TabBarToolbarFactory,
966
- readonly options: ViewContainer.Factory.WidgetOptions = {}
967
- ) {
968
- super();
969
- wrapped.parent = this;
970
- wrapped.disposed.connect(() => this.dispose());
971
- this.id = `${originalContainerId}--${wrapped.id}`;
972
- this.addClass('part');
973
-
974
- const fireTitleChanged = () => this.onTitleChangedEmitter.fire(undefined);
975
- this.wrapped.title.changed.connect(fireTitleChanged);
976
- this.toDispose.push(Disposable.create(() => this.wrapped.title.changed.disconnect(fireTitleChanged)));
977
-
978
- if (DescriptionWidget.is(this.wrapped)) {
979
- this.wrapped?.onDidChangeDescription(() => this.onDidChangeDescriptionEmitter.fire(), undefined, this.toDispose);
980
- }
981
-
982
- if (BadgeWidget.is(this.wrapped)) {
983
- this.wrapped.onDidChangeBadge(() => this.onDidChangeBadgeEmitter.fire(), undefined, this.toDispose);
984
- this.wrapped.onDidChangeBadgeTooltip(() => this.onDidChangeBadgeTooltipEmitter.fire(), undefined, this.toDispose);
985
- }
986
-
987
- if (DynamicToolbarWidget.is(this.wrapped)) {
988
- this.wrapped.onDidChangeToolbarItems(() => {
989
- this.toolbar.updateTarget(this.wrapped);
990
- this.viewContainer?.update();
991
- });
992
- }
993
-
994
- const { header, body, disposable } = this.createContent();
995
- this.header = header;
996
- this.body = body;
997
-
998
- this.toNoDisposeWrapped = this.toDispose.push(wrapped);
999
- this.toolbar = this.toolbarFactory();
1000
- this.toolbar.addClass('theia-view-container-part-title');
1001
-
1002
- this.toDispose.pushAll([
1003
- disposable,
1004
- this.toolbar,
1005
- this.toolbarRegistry.onDidChange(() => this.toolbar.updateTarget(this.wrapped)),
1006
- this.collapsedEmitter,
1007
- this.contextMenuEmitter,
1008
- this.onTitleChangedEmitter,
1009
- this.onDidChangeDescriptionEmitter,
1010
- this.onDidChangeBadgeEmitter,
1011
- this.onDidChangeBadgeTooltipEmitter,
1012
- this.registerContextMenu(),
1013
- this.onDidFocusEmitter,
1014
- // focus event does not bubble, capture it
1015
- addEventListener(this.node, 'focus', () => this.onDidFocusEmitter.fire(this), true)
1016
- ]);
1017
- this.scrollOptions = {
1018
- suppressScrollX: true,
1019
- minScrollbarLength: 35
1020
- };
1021
- this.collapsed = !!options.initiallyCollapsed;
1022
- if (options.initiallyHidden && this.canHide) {
1023
- this.hide();
1024
- }
1025
- }
1026
-
1027
- get viewContainer(): ViewContainer | undefined {
1028
- return this.parent ? this.parent.parent as ViewContainer : undefined;
1029
- }
1030
-
1031
- get currentViewContainerId(): string {
1032
- return this.currentContainerId;
1033
- }
1034
-
1035
- get headerElement(): HTMLElement {
1036
- return this.header;
1037
- }
1038
-
1039
- get collapsed(): boolean {
1040
- return this._collapsed;
1041
- }
1042
-
1043
- set collapsed(collapsed: boolean) {
1044
- // Cannot collapse/expand if the orientation of the container is `horizontal`.
1045
- const orientation = ViewContainer.getOrientation(this.node);
1046
- if (this._collapsed === collapsed || (orientation === 'horizontal' && collapsed)) {
1047
- return;
1048
- }
1049
- this._collapsed = collapsed;
1050
- this.node.classList.toggle('collapsed', collapsed);
1051
-
1052
- if (collapsed && this.wrapped.node.contains(document.activeElement)) {
1053
- this.header.focus();
1054
- }
1055
- this.wrapped.setHidden(collapsed);
1056
- const toggleIcon = this.header.querySelector(`span.${EXPANSION_TOGGLE_CLASS}`);
1057
- if (toggleIcon) {
1058
- if (collapsed) {
1059
- toggleIcon.classList.add(COLLAPSED_CLASS);
1060
- } else {
1061
- toggleIcon.classList.remove(COLLAPSED_CLASS);
1062
- }
1063
- }
1064
- this.update();
1065
- this.collapsedEmitter.fire(collapsed);
1066
- }
1067
-
1068
- onPartMoved(newContainer: ViewContainer): void {
1069
- this.currentContainerId = newContainer.id;
1070
- this.onPartMovedEmitter.fire(newContainer);
1071
- }
1072
-
1073
- override setHidden(hidden: boolean): void {
1074
- if (!this.canHide) {
1075
- return;
1076
- }
1077
- super.setHidden(hidden);
1078
- }
1079
-
1080
- get canHide(): boolean {
1081
- return this.options.canHide === undefined || this.options.canHide;
1082
- }
1083
-
1084
- get onCollapsed(): CommonEvent<boolean> {
1085
- return this.collapsedEmitter.event;
1086
- }
1087
-
1088
- get onContextMenu(): CommonEvent<MouseEvent> {
1089
- return this.contextMenuEmitter.event;
1090
- }
1091
-
1092
- get minSize(): number {
1093
- const style = getComputedStyle(this.body);
1094
- if (ViewContainer.getOrientation(this.node) === 'horizontal') {
1095
- return parseCssMagnitude(style.minWidth, 0);
1096
- } else {
1097
- return parseCssMagnitude(style.minHeight, 0);
1098
- }
1099
- }
1100
-
1101
- protected readonly toShowHeader = new DisposableCollection();
1102
- showTitle(): void {
1103
- this.toShowHeader.dispose();
1104
- }
1105
-
1106
- hideTitle(): void {
1107
- if (this.titleHidden) {
1108
- return;
1109
- }
1110
- const display = this.header.style.display;
1111
- const height = this.body.style.height;
1112
- this.body.style.height = '100%';
1113
- this.header.style.display = 'none';
1114
- this.toShowHeader.push(Disposable.create(() => {
1115
- this.header.style.display = display;
1116
- this.body.style.height = height;
1117
- }));
1118
- }
1119
-
1120
- get titleHidden(): boolean {
1121
- return !this.toShowHeader.disposed || this.collapsed;
1122
- }
1123
-
1124
- protected override getScrollContainer(): HTMLElement {
1125
- return this.body;
1126
- }
1127
-
1128
- protected registerContextMenu(): Disposable {
1129
- return new DisposableCollection(
1130
- addEventListener(this.header, 'contextmenu', event => {
1131
- this.contextMenuEmitter.fire(event);
1132
- })
1133
- );
1134
- }
1135
-
1136
- protected createContent(): { header: HTMLElement, body: HTMLElement, disposable: Disposable } {
1137
- const disposable = new DisposableCollection();
1138
- const { header, disposable: headerDisposable } = this.createHeader();
1139
- const body = document.createElement('div');
1140
- body.classList.add('body');
1141
- this.node.appendChild(header);
1142
- this.node.appendChild(body);
1143
- disposable.push(headerDisposable);
1144
- return {
1145
- header,
1146
- body,
1147
- disposable,
1148
- };
1149
- }
1150
-
1151
- protected createHeader(): { header: HTMLElement, disposable: Disposable } {
1152
- const disposable = new DisposableCollection();
1153
- const header = document.createElement('div');
1154
- header.tabIndex = 0;
1155
- header.classList.add('theia-header', 'header', 'theia-view-container-part-header');
1156
- disposable.push(addEventListener(header, 'click', event => {
1157
- if (this.toolbar && this.toolbar.shouldHandleMouseEvent(event)) {
1158
- return;
1159
- }
1160
- this.collapsed = !this.collapsed;
1161
- }));
1162
- disposable.push(addKeyListener(header, Key.ARROW_LEFT, () => this.collapsed = true));
1163
- disposable.push(addKeyListener(header, Key.ARROW_RIGHT, () => this.collapsed = false));
1164
- disposable.push(addKeyListener(header, Key.ENTER, () => this.collapsed = !this.collapsed));
1165
-
1166
- const toggleIcon = document.createElement('span');
1167
- toggleIcon.classList.add(EXPANSION_TOGGLE_CLASS, ...CODICON_TREE_ITEM_CLASSES);
1168
- if (this.collapsed) {
1169
- toggleIcon.classList.add(COLLAPSED_CLASS);
1170
- }
1171
- header.appendChild(toggleIcon);
1172
-
1173
- const title = document.createElement('span');
1174
- title.classList.add('label', 'noselect');
1175
-
1176
- const description = document.createElement('span');
1177
- description.classList.add('description');
1178
-
1179
- const badgeSpan = document.createElement('span');
1180
- badgeSpan.classList.add('notification-count');
1181
-
1182
- const badgeContainer = document.createElement('div');
1183
- badgeContainer.classList.add('notification-count-container');
1184
- badgeContainer.appendChild(badgeSpan);
1185
- const badgeContainerDisplay = badgeContainer.style.display;
1186
-
1187
- const updateTitle = () => {
1188
- if (this.currentContainerId !== this.originalContainerId && this.originalContainerTitle?.label) {
1189
- // Creating a title in format: <original_container_title>: <part_title>.
1190
- title.innerText = this.originalContainerTitle.label + ': ' + this.wrapped.title.label;
1191
- } else {
1192
- title.innerText = this.wrapped.title.label;
1193
- }
1194
- };
1195
- const updateCaption = () => title.title = this.wrapped.title.caption || this.wrapped.title.label;
1196
- const updateDescription = () => {
1197
- description.innerText = DescriptionWidget.is(this.wrapped) && !this.collapsed && this.wrapped.description || '';
1198
- };
1199
- const updateBadge = () => {
1200
- if (BadgeWidget.is(this.wrapped)) {
1201
- const visibleToolBarItems = this.toolbarRegistry.visibleItems(this.wrapped).length > 0;
1202
- const badge = this.wrapped.badge;
1203
- if (badge && !visibleToolBarItems) {
1204
- badgeSpan.innerText = badge.toString();
1205
- badgeSpan.title = this.wrapped.badgeTooltip || '';
1206
- badgeContainer.style.display = badgeContainerDisplay;
1207
- return;
1208
- }
1209
- }
1210
- badgeContainer.style.display = 'none';
1211
- };
1212
-
1213
- updateTitle();
1214
- updateCaption();
1215
- updateDescription();
1216
- updateBadge();
1217
-
1218
- disposable.pushAll([
1219
- this.onTitleChanged(updateTitle),
1220
- this.onTitleChanged(updateCaption),
1221
- this.onDidMove(updateTitle),
1222
- this.onDidChangeDescription(updateDescription),
1223
- this.onDidChangeBadge(updateBadge),
1224
- this.onDidChangeBadgeTooltip(updateBadge),
1225
- this.onCollapsed(updateDescription)
1226
- ]);
1227
- header.appendChild(title);
1228
- header.appendChild(description);
1229
- header.appendChild(badgeContainer);
1230
-
1231
- return {
1232
- header,
1233
- disposable
1234
- };
1235
- }
1236
-
1237
- protected handleResize(): void {
1238
- const handleMouseEnter = () => {
1239
- this.node?.classList.add('no-pointer-events');
1240
- setTimeout(() => {
1241
- this.node?.classList.remove('no-pointer-events');
1242
- this.node?.removeEventListener('mouseenter', handleMouseEnter);
1243
- }, 100);
1244
- };
1245
- this.node?.addEventListener('mouseenter', handleMouseEnter);
1246
- }
1247
-
1248
- protected override onResize(msg: Widget.ResizeMessage): void {
1249
- this.handleResize();
1250
- if (this.wrapped.isAttached && !this.collapsed) {
1251
- MessageLoop.sendMessage(this.wrapped, Widget.ResizeMessage.UnknownSize);
1252
- }
1253
- super.onResize(msg);
1254
- }
1255
-
1256
- protected override onUpdateRequest(msg: Message): void {
1257
- if (this.wrapped.isAttached && !this.collapsed) {
1258
- MessageLoop.sendMessage(this.wrapped, msg);
1259
- }
1260
- super.onUpdateRequest(msg);
1261
- }
1262
-
1263
- protected override onAfterAttach(msg: Message): void {
1264
- if (!this.wrapped.isAttached) {
1265
- UnsafeWidgetUtilities.attach(this.wrapped, this.body);
1266
- }
1267
- UnsafeWidgetUtilities.attach(this.toolbar, this.header);
1268
- super.onAfterAttach(msg);
1269
- }
1270
-
1271
- protected override onBeforeDetach(msg: Message): void {
1272
- super.onBeforeDetach(msg);
1273
- if (this.toolbar.isAttached) {
1274
- Widget.detach(this.toolbar);
1275
- }
1276
- if (this.wrapped.isAttached) {
1277
- UnsafeWidgetUtilities.detach(this.wrapped);
1278
- }
1279
- }
1280
-
1281
- protected override onBeforeShow(msg: Message): void {
1282
- if (this.wrapped.isAttached && !this.collapsed) {
1283
- MessageLoop.sendMessage(this.wrapped, msg);
1284
- }
1285
- super.onBeforeShow(msg);
1286
- }
1287
-
1288
- protected override onAfterShow(msg: Message): void {
1289
- super.onAfterShow(msg);
1290
- if (this.wrapped.isAttached && !this.collapsed) {
1291
- MessageLoop.sendMessage(this.wrapped, msg);
1292
- }
1293
- }
1294
-
1295
- protected override onBeforeHide(msg: Message): void {
1296
- if (this.wrapped.isAttached && !this.collapsed) {
1297
- MessageLoop.sendMessage(this.wrapped, msg);
1298
- }
1299
- super.onBeforeShow(msg);
1300
- }
1301
-
1302
- protected override onAfterHide(msg: Message): void {
1303
- super.onAfterHide(msg);
1304
- if (this.wrapped.isAttached && !this.collapsed) {
1305
- MessageLoop.sendMessage(this.wrapped, msg);
1306
- }
1307
- }
1308
-
1309
- protected override onChildRemoved(msg: Widget.ChildMessage): void {
1310
- super.onChildRemoved(msg);
1311
- // if wrapped is not disposed, but detached then we should not dispose it, but only get rid of this part
1312
- this.toNoDisposeWrapped.dispose();
1313
- this.dispose();
1314
- }
1315
-
1316
- protected override onActivateRequest(msg: Message): void {
1317
- super.onActivateRequest(msg);
1318
- if (this.collapsed) {
1319
- this.header.focus();
1320
- } else {
1321
- this.wrapped.activate();
1322
- }
1323
- }
1324
- }
1325
-
1326
- export namespace ViewContainerPart {
1327
-
1328
- /**
1329
- * Make sure to adjust the `line-height` of the `.theia-view-container .part > .header` CSS class when modifying this, and vice versa.
1330
- */
1331
- export const HEADER_HEIGHT = 22;
1332
-
1333
- export interface State {
1334
- widget?: Widget
1335
- partId: string;
1336
- collapsed: boolean;
1337
- hidden: boolean;
1338
- relativeSize?: number;
1339
- description?: string;
1340
- /** The original container to which this part belongs */
1341
- originalContainerId: string;
1342
- originalContainerTitle?: ViewContainerTitleOptions;
1343
- }
1344
-
1345
- export function closestPart(element: Element | EventTarget | null, selector: string = 'div.part'): Element | undefined {
1346
- if (element instanceof Element) {
1347
- const part = element.closest(selector);
1348
- if (part instanceof Element) {
1349
- return part;
1350
- }
1351
- }
1352
- return undefined;
1353
- }
1354
- }
1355
-
1356
- export class ViewContainerLayout extends SplitLayout {
1357
-
1358
- constructor(protected options: ViewContainerLayout.Options, protected readonly splitPositionHandler: SplitPositionHandler) {
1359
- super(options);
1360
- }
1361
-
1362
- protected get items(): ReadonlyArray<LayoutItem & ViewContainerLayout.Item> {
1363
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1364
- return (this as any)._items as Array<LayoutItem & ViewContainerLayout.Item>;
1365
- }
1366
-
1367
- override iter(): IIterator<ViewContainerPart> {
1368
- return map(this.items, item => item.widget);
1369
- }
1370
-
1371
- // @ts-expect-error TS2611 `SplitLayout.widgets` is declared as `readonly widgets` but is implemented as a getter.
1372
- get widgets(): ViewContainerPart[] {
1373
- return toArray(this.iter());
1374
- }
1375
-
1376
- override attachWidget(index: number, widget: ViewContainerPart): void {
1377
- super.attachWidget(index, widget);
1378
- if (index > -1 && this.parent && this.parent.node.contains(this.widgets[index + 1]?.node)) {
1379
- // Set the correct attach index to the DOM elements.
1380
- const ref = this.widgets[index + 1].node;
1381
- this.parent.node.insertBefore(widget.node, ref);
1382
- this.parent.node.insertBefore(this.handles[index], ref);
1383
- this.parent.fit();
1384
- }
1385
- }
1386
-
1387
- getPartSize(part: ViewContainerPart): number | undefined {
1388
- if (part.collapsed || part.isHidden) {
1389
- return part.uncollapsedSize;
1390
- }
1391
- if (this.orientation === 'horizontal') {
1392
- return part.node.offsetWidth;
1393
- } else {
1394
- return part.node.offsetHeight;
1395
- }
1396
- }
1397
-
1398
- /**
1399
- * Set the sizes of the view container parts according to the given weights
1400
- * by moving the split handles. This is similar to `setRelativeSizes` defined
1401
- * in `SplitLayout`, but here we properly consider the collapsed / expanded state.
1402
- */
1403
- setPartSizes(weights: (number | undefined)[]): void {
1404
- const parts = this.widgets;
1405
- const availableSize = this.getAvailableSize();
1406
-
1407
- // Sum up the weights of visible parts
1408
- let totalWeight = 0;
1409
- let weightCount = 0;
1410
- for (let index = 0; index < weights.length && index < parts.length; index++) {
1411
- const part = parts[index];
1412
- const weight = weights[index];
1413
- if (weight && !part.isHidden && !part.collapsed) {
1414
- totalWeight += weight;
1415
- weightCount++;
1416
- }
1417
- }
1418
- if (weightCount === 0 || availableSize === 0) {
1419
- return;
1420
- }
1421
-
1422
- // Add the average weight for visible parts without weight
1423
- const averageWeight = totalWeight / weightCount;
1424
- for (let index = 0; index < weights.length && index < parts.length; index++) {
1425
- const part = parts[index];
1426
- const weight = weights[index];
1427
- if (!weight && !part.isHidden && !part.collapsed) {
1428
- totalWeight += averageWeight;
1429
- }
1430
- }
1431
-
1432
- // Apply the weights to compute actual sizes
1433
- let position = 0;
1434
- for (let index = 0; index < weights.length && index < parts.length - 1; index++) {
1435
- const part = parts[index];
1436
- if (!part.isHidden) {
1437
- if (this.orientation === 'vertical') {
1438
- position += this.options.headerSize;
1439
- }
1440
- const weight = weights[index];
1441
- if (part.collapsed) {
1442
- if (weight) {
1443
- part.uncollapsedSize = weight / totalWeight * availableSize;
1444
- }
1445
- } else {
1446
- let contentSize = (weight || averageWeight) / totalWeight * availableSize;
1447
- const minSize = part.minSize;
1448
- if (contentSize < minSize) {
1449
- contentSize = minSize;
1450
- }
1451
- position += contentSize;
1452
- }
1453
- this.setHandlePosition(index, position);
1454
- position += this.spacing;
1455
- }
1456
- }
1457
- }
1458
-
1459
- /**
1460
- * Determine the size of the split panel area that is available for widget content,
1461
- * i.e. excluding part headers and split handles.
1462
- */
1463
- getAvailableSize(): number {
1464
- if (!this.parent || !this.parent.isAttached) {
1465
- return 0;
1466
- }
1467
- const parts = this.widgets;
1468
- const visiblePartCount = parts.filter(part => !part.isHidden).length;
1469
- let availableSize: number;
1470
- if (this.orientation === 'horizontal') {
1471
- availableSize = this.parent.node.offsetWidth;
1472
- } else {
1473
- availableSize = this.parent.node.offsetHeight;
1474
- availableSize -= visiblePartCount * this.options.headerSize;
1475
- }
1476
- availableSize -= (visiblePartCount - 1) * this.spacing;
1477
- if (availableSize < 0) {
1478
- return 0;
1479
- }
1480
- return availableSize;
1481
- }
1482
-
1483
- /**
1484
- * Update a view container part that has been collapsed or expanded. The transition
1485
- * to the new state is animated.
1486
- */
1487
- updateCollapsed(part: ViewContainerPart, enableAnimation: boolean): void {
1488
- const index = this.items.findIndex(item => item.widget === part);
1489
- if (index < 0 || !this.parent || part.isHidden) {
1490
- return;
1491
- }
1492
- // Do not store the height of the "stretched item". Otherwise, we mess up the "hint height".
1493
- // Store the height only if there are other expanded items.
1494
- const currentSize = this.orientation === 'horizontal' ? part.node.offsetWidth : part.node.offsetHeight;
1495
- if (part.collapsed && this.items.some(item => !item.widget.collapsed && !item.widget.isHidden)) {
1496
- part.uncollapsedSize = currentSize;
1497
- }
1498
-
1499
- if (!enableAnimation || this.options.animationDuration <= 0) {
1500
- MessageLoop.postMessage(this.parent, Widget.Msg.FitRequest);
1501
- return;
1502
- }
1503
- let startTime: number | undefined = undefined;
1504
- const duration = this.options.animationDuration;
1505
- const direction = part.collapsed ? 'collapse' : 'expand';
1506
- let fullSize: number;
1507
- if (direction === 'collapse') {
1508
- fullSize = currentSize - this.options.headerSize;
1509
- } else {
1510
- fullSize = Math.max((part.uncollapsedSize || 0) - this.options.headerSize, part.minSize);
1511
- if (this.items.filter(item => !item.widget.collapsed && !item.widget.isHidden).length === 1) {
1512
- // Expand to full available size
1513
- fullSize = Math.max(fullSize, this.getAvailableSize());
1514
- }
1515
- }
1516
-
1517
- // The update function is called on every animation frame until the predefined duration has elapsed.
1518
- const updateFunc = (time: number) => {
1519
- if (!this.parent) {
1520
- part.animatedSize = undefined;
1521
- return;
1522
- }
1523
- if (startTime === undefined) {
1524
- startTime = time;
1525
- }
1526
- if (time - startTime < duration) {
1527
- // Render an intermediate state for the animation
1528
- const t = this.tween((time - startTime) / duration);
1529
- if (direction === 'collapse') {
1530
- part.animatedSize = (1 - t) * fullSize;
1531
- } else {
1532
- part.animatedSize = t * fullSize;
1533
- }
1534
- requestAnimationFrame(updateFunc);
1535
- } else {
1536
- // The animation is finished
1537
- if (direction === 'collapse') {
1538
- part.animatedSize = undefined;
1539
- } else {
1540
- part.animatedSize = fullSize;
1541
- // Request another frame to reset the part to variable size
1542
- requestAnimationFrame(() => {
1543
- part.animatedSize = undefined;
1544
- if (this.parent) {
1545
- MessageLoop.sendMessage(this.parent, Widget.Msg.FitRequest);
1546
- }
1547
- });
1548
- }
1549
- }
1550
- MessageLoop.sendMessage(this.parent, Widget.Msg.FitRequest);
1551
- };
1552
- requestAnimationFrame(updateFunc);
1553
- }
1554
-
1555
- updateSashes(): void {
1556
- const { widgets, handles } = this;
1557
- if (widgets.length !== handles.length) {
1558
- console.warn('Unexpected mismatch between number of widgets and number of handles.');
1559
- return;
1560
- }
1561
- const firstUncollapsed = this.getFirstUncollapsedWidgetIndex();
1562
- const lastUncollapsed = firstUncollapsed === undefined ? undefined : this.getLastUncollapsedWidgetIndex();
1563
- const allHidden = firstUncollapsed === lastUncollapsed;
1564
- for (const [index, handle] of this.handles.entries()) {
1565
- // The or clauses are added for type checking. If they're true, allHidden will also have been true.
1566
- if (allHidden || firstUncollapsed === undefined || lastUncollapsed === undefined) {
1567
- handle.classList.add('sash-hidden');
1568
- } else if (index < lastUncollapsed && index >= firstUncollapsed) {
1569
- handle.classList.remove('sash-hidden');
1570
- } else {
1571
- handle.classList.add('sash-hidden');
1572
- }
1573
- }
1574
- }
1575
-
1576
- protected getFirstUncollapsedWidgetIndex(): number | undefined {
1577
- const index = this.widgets.findIndex(widget => !widget.collapsed && !widget.isHidden);
1578
- return index === -1 ? undefined : index;
1579
- }
1580
-
1581
- protected getLastUncollapsedWidgetIndex(): number | undefined {
1582
- for (let i = this.widgets.length - 1; i >= 0; i--) {
1583
- if (!this.widgets[i].collapsed && !this.widgets[i].isHidden) {
1584
- return i;
1585
- }
1586
- }
1587
- }
1588
-
1589
- protected override onFitRequest(msg: Message): void {
1590
- for (const part of this.widgets) {
1591
- const style = part.node.style;
1592
- if (part.animatedSize !== undefined) {
1593
- // The part size has been fixed for animating the transition to collapsed / expanded state
1594
- const fixedSize = `${this.options.headerSize + part.animatedSize}px`;
1595
- style.minHeight = fixedSize;
1596
- style.maxHeight = fixedSize;
1597
- } else if (part.collapsed) {
1598
- // The part size is fixed to the header size
1599
- const fixedSize = `${this.options.headerSize}px`;
1600
- style.minHeight = fixedSize;
1601
- style.maxHeight = fixedSize;
1602
- } else {
1603
- const minSize = `${this.options.headerSize + part.minSize}px`;
1604
- style.minHeight = minSize;
1605
- style.maxHeight = '';
1606
- }
1607
- }
1608
- super.onFitRequest(msg);
1609
- }
1610
-
1611
- /**
1612
- * Sinusoidal tween function for smooth animation.
1613
- */
1614
- protected tween(t: number): number {
1615
- return 0.5 * (1 - Math.cos(Math.PI * t));
1616
- }
1617
-
1618
- setHandlePosition(index: number, position: number): Promise<void> {
1619
- const options: SplitPositionOptions = {
1620
- referenceWidget: this.widgets[index],
1621
- duration: 0
1622
- };
1623
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1624
- return this.splitPositionHandler.setSplitHandlePosition(this.parent as SplitPanel, index, position, options) as Promise<any>;
1625
- }
1626
-
1627
- }
1628
-
1629
- export namespace ViewContainerLayout {
1630
-
1631
- export interface Options extends SplitLayout.IOptions {
1632
- headerSize: number;
1633
- animationDuration: number;
1634
- }
1635
-
1636
- export interface Item {
1637
- readonly widget: ViewContainerPart;
1638
- }
1639
-
1640
- }
1
+ // *****************************************************************************
2
+ // Copyright (C) 2018-2019 TypeFox and others.
3
+ //
4
+ // This program and the accompanying materials are made available under the
5
+ // terms of the Eclipse Public License v. 2.0 which is available at
6
+ // http://www.eclipse.org/legal/epl-2.0.
7
+ //
8
+ // This Source Code may also be made available under the following Secondary
9
+ // Licenses when the conditions for such availability set forth in the Eclipse
10
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
+ // with the GNU Classpath Exception which is available at
12
+ // https://www.gnu.org/software/classpath/license.html.
13
+ //
14
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
+ // *****************************************************************************
16
+
17
+ import { interfaces, injectable, inject, postConstruct } from 'inversify';
18
+ import { IIterator, toArray, find, some, every, map, ArrayExt } from '@phosphor/algorithm';
19
+ import {
20
+ Widget, EXPANSION_TOGGLE_CLASS, COLLAPSED_CLASS, CODICON_TREE_ITEM_CLASSES, MessageLoop, Message, SplitPanel,
21
+ BaseWidget, addEventListener, SplitLayout, LayoutItem, PanelLayout, addKeyListener, waitForRevealed, UnsafeWidgetUtilities, DockPanel, PINNED_CLASS
22
+ } from './widgets';
23
+ import { Event as CommonEvent, Emitter } from '../common/event';
24
+ import { Disposable, DisposableCollection } from '../common/disposable';
25
+ import { CommandRegistry } from '../common/command';
26
+ import { MenuModelRegistry, MenuPath, MenuAction } from '../common/menu';
27
+ import { ApplicationShell, StatefulWidget, SplitPositionHandler, SplitPositionOptions, SIDE_PANEL_TOOLBAR_CONTEXT_MENU } from './shell';
28
+ import { MAIN_AREA_ID, BOTTOM_AREA_ID } from './shell/theia-dock-panel';
29
+ import { FrontendApplicationStateService } from './frontend-application-state';
30
+ import { ContextMenuRenderer, Anchor } from './context-menu-renderer';
31
+ import { parseCssMagnitude } from './browser';
32
+ import { TabBarToolbarRegistry, TabBarToolbarFactory, TabBarToolbar, TabBarDelegator, TabBarToolbarItem } from './shell/tab-bar-toolbar';
33
+ import { isEmpty, isObject, nls } from '../common';
34
+ import { WidgetManager } from './widget-manager';
35
+ import { Key } from './keys';
36
+ import { ProgressBarFactory } from './progress-bar-factory';
37
+ import { Drag, IDragEvent } from '@phosphor/dragdrop';
38
+ import { MimeData } from '@phosphor/coreutils';
39
+ import { ElementExt } from '@phosphor/domutils';
40
+ import { TabBarDecoratorService } from './shell/tab-bar-decorator';
41
+
42
+ export interface ViewContainerTitleOptions {
43
+ label: string;
44
+ caption?: string;
45
+ iconClass?: string;
46
+ closeable?: boolean;
47
+ }
48
+
49
+ @injectable()
50
+ export class ViewContainerIdentifier {
51
+ id: string;
52
+ progressLocationId?: string;
53
+ }
54
+
55
+ export interface DescriptionWidget {
56
+ description: string;
57
+ onDidChangeDescription: CommonEvent<void>;
58
+ }
59
+
60
+ export interface BadgeWidget {
61
+ badge?: number;
62
+ badgeTooltip?: string;
63
+ onDidChangeBadge: CommonEvent<void>;
64
+ onDidChangeBadgeTooltip: CommonEvent<void>;
65
+ }
66
+
67
+ export namespace DescriptionWidget {
68
+ export function is(arg: unknown): arg is DescriptionWidget {
69
+ return isObject(arg) && 'onDidChangeDescription' in arg;
70
+ }
71
+ }
72
+
73
+ export namespace BadgeWidget {
74
+ export function is(arg: unknown): arg is BadgeWidget {
75
+ return isObject(arg) && 'onDidChangeBadge' in arg && 'onDidChangeBadgeTooltip' in arg;
76
+ }
77
+ }
78
+
79
+ /**
80
+ * A widget that may change it's internal structure dynamically.
81
+ * Current use is to update the toolbar when a contributed view is constructed "lazily".
82
+ */
83
+ export interface DynamicToolbarWidget {
84
+ onDidChangeToolbarItems: CommonEvent<void>;
85
+ }
86
+
87
+ export namespace DynamicToolbarWidget {
88
+ export function is(arg: unknown): arg is DynamicToolbarWidget {
89
+ return isObject(arg) && 'onDidChangeToolbarItems' in arg;
90
+ }
91
+ }
92
+
93
+ /**
94
+ * A view container holds an arbitrary number of widgets inside a split panel.
95
+ * Each widget is wrapped in a _part_ that displays the widget title and toolbar
96
+ * and allows to collapse / expand the widget content.
97
+ */
98
+ @injectable()
99
+ export class ViewContainer extends BaseWidget implements StatefulWidget, ApplicationShell.TrackableWidgetProvider, TabBarDelegator {
100
+
101
+ protected panel: SplitPanel;
102
+
103
+ protected currentPart: ViewContainerPart | undefined;
104
+
105
+ /**
106
+ * Disable dragging parts from/to this view container.
107
+ */
108
+ disableDNDBetweenContainers = false;
109
+
110
+ @inject(FrontendApplicationStateService)
111
+ protected readonly applicationStateService: FrontendApplicationStateService;
112
+
113
+ @inject(ContextMenuRenderer)
114
+ protected readonly contextMenuRenderer: ContextMenuRenderer;
115
+
116
+ @inject(CommandRegistry)
117
+ protected readonly commandRegistry: CommandRegistry;
118
+
119
+ @inject(MenuModelRegistry)
120
+ protected readonly menuRegistry: MenuModelRegistry;
121
+
122
+ @inject(WidgetManager)
123
+ protected readonly widgetManager: WidgetManager;
124
+
125
+ @inject(SplitPositionHandler)
126
+ protected readonly splitPositionHandler: SplitPositionHandler;
127
+
128
+ @inject(ViewContainerIdentifier)
129
+ readonly options: ViewContainerIdentifier;
130
+
131
+ @inject(TabBarToolbarRegistry)
132
+ protected readonly toolbarRegistry: TabBarToolbarRegistry;
133
+
134
+ @inject(TabBarToolbarFactory)
135
+ protected readonly toolbarFactory: TabBarToolbarFactory;
136
+
137
+ protected readonly onDidChangeTrackableWidgetsEmitter = new Emitter<Widget[]>();
138
+ readonly onDidChangeTrackableWidgets = this.onDidChangeTrackableWidgetsEmitter.event;
139
+
140
+ @inject(ProgressBarFactory)
141
+ protected readonly progressBarFactory: ProgressBarFactory;
142
+
143
+ @inject(ApplicationShell)
144
+ protected readonly shell: ApplicationShell;
145
+
146
+ @inject(TabBarDecoratorService)
147
+ protected readonly decoratorService: TabBarDecoratorService;
148
+
149
+ @postConstruct()
150
+ protected init(): void {
151
+ this.id = this.options.id;
152
+ this.addClass('theia-view-container');
153
+ const layout = new PanelLayout();
154
+ this.layout = layout;
155
+ this.panel = new SplitPanel({
156
+ layout: new ViewContainerLayout({
157
+ renderer: SplitPanel.defaultRenderer,
158
+ orientation: this.orientation,
159
+ spacing: 2,
160
+ headerSize: ViewContainerPart.HEADER_HEIGHT,
161
+ animationDuration: 200
162
+ }, this.splitPositionHandler)
163
+ });
164
+ this.panel.node.tabIndex = -1;
165
+ this.configureLayout(layout);
166
+
167
+ const { commandRegistry, menuRegistry, contextMenuRenderer } = this;
168
+ this.toDispose.pushAll([
169
+ addEventListener(this.node, 'contextmenu', event => {
170
+ if (event.button === 2 && every(this.containerLayout.iter(), part => !!part.isHidden)) {
171
+ event.stopPropagation();
172
+ event.preventDefault();
173
+ contextMenuRenderer.render({ menuPath: this.contextMenuPath, anchor: event });
174
+ }
175
+ }),
176
+ commandRegistry.registerCommand({ id: this.globalHideCommandId }, {
177
+ execute: (anchor: Anchor) => {
178
+ const toHide = this.findPartForAnchor(anchor);
179
+ if (toHide && toHide.canHide) {
180
+ toHide.hide();
181
+ }
182
+ },
183
+ isVisible: (anchor: Anchor) => {
184
+ const toHide = this.findPartForAnchor(anchor);
185
+ if (toHide) {
186
+ return toHide.canHide && !toHide.isHidden;
187
+ } else {
188
+ return some(this.containerLayout.iter(), part => !part.isHidden);
189
+ }
190
+ }
191
+ }),
192
+ menuRegistry.registerMenuAction([...this.contextMenuPath, '0_global'], {
193
+ commandId: this.globalHideCommandId,
194
+ label: nls.localizeByDefault('Hide')
195
+ }),
196
+ this.onDidChangeTrackableWidgetsEmitter,
197
+ this.onDidChangeTrackableWidgets(() => this.decoratorService.fireDidChangeDecorations())
198
+ ]);
199
+ if (this.options.progressLocationId) {
200
+ this.toDispose.push(this.progressBarFactory({ container: this.node, insertMode: 'prepend', locationId: this.options.progressLocationId }));
201
+ }
202
+ }
203
+
204
+ protected configureLayout(layout: PanelLayout): void {
205
+ layout.addWidget(this.panel);
206
+ }
207
+
208
+ protected readonly toDisposeOnCurrentPart = new DisposableCollection();
209
+
210
+ protected updateCurrentPart(part?: ViewContainerPart): void {
211
+ if (part && this.getParts().indexOf(part) !== -1) {
212
+ this.currentPart = part;
213
+ }
214
+ if (this.currentPart && !this.currentPart.isDisposed) {
215
+ return;
216
+ }
217
+ const visibleParts = this.getParts().filter(p => !p.isHidden);
218
+ const expandedParts = visibleParts.filter(p => !p.collapsed);
219
+ this.currentPart = expandedParts[0] || visibleParts[0];
220
+ }
221
+
222
+ protected updateSplitterVisibility(): void {
223
+ const className = 'p-first-visible';
224
+ let firstFound = false;
225
+ for (const part of this.getParts()) {
226
+ if (!part.isHidden && !firstFound) {
227
+ part.addClass(className);
228
+ firstFound = true;
229
+ } else {
230
+ part.removeClass(className);
231
+ }
232
+ }
233
+ }
234
+
235
+ protected titleOptions: ViewContainerTitleOptions | undefined;
236
+
237
+ setTitleOptions(titleOptions: ViewContainerTitleOptions | undefined): void {
238
+ this.titleOptions = titleOptions;
239
+ this.updateTitle();
240
+ }
241
+
242
+ protected readonly toDisposeOnUpdateTitle = new DisposableCollection();
243
+
244
+ protected _tabBarDelegate: Widget = this;
245
+ updateTabBarDelegate(): void {
246
+ const visibleParts = this.getParts().filter(part => !part.isHidden);
247
+ if (visibleParts.length === 1) {
248
+ this._tabBarDelegate = visibleParts[0].wrapped;
249
+ } else {
250
+ this._tabBarDelegate = this;
251
+ }
252
+ }
253
+
254
+ getTabBarDelegate(): Widget | undefined {
255
+ return this._tabBarDelegate;
256
+ }
257
+
258
+ protected updateTitle(): void {
259
+ this.toDisposeOnUpdateTitle.dispose();
260
+ this.toDispose.push(this.toDisposeOnUpdateTitle);
261
+ this.updateTabBarDelegate();
262
+ let title = Object.assign({}, this.titleOptions);
263
+ if (isEmpty(title)) {
264
+ return;
265
+ }
266
+ const allParts = this.getParts();
267
+ const visibleParts = allParts.filter(part => !part.isHidden);
268
+ this.title.label = title.label;
269
+ // If there's only one visible part - inline it's title into the container title except in case the part
270
+ // isn't originally belongs to this container but there are other **original** hidden parts.
271
+ if (visibleParts.length === 1 && (visibleParts[0].originalContainerId === this.id || !this.findOriginalPart())) {
272
+ const part = visibleParts[0];
273
+ this.toDisposeOnUpdateTitle.push(part.onTitleChanged(() => this.updateTitle()));
274
+ const partLabel = part.wrapped.title.label;
275
+ // Change the container title if it contains only one part that originally belongs to another container.
276
+ if (allParts.length === 1 && part.originalContainerId !== this.id && !this.isCurrentTitle(part.originalContainerTitle)) {
277
+ title = Object.assign({}, part.originalContainerTitle);
278
+ this.setTitleOptions(title);
279
+ return;
280
+ }
281
+ if (partLabel) {
282
+ if (this.title.label && this.title.label !== partLabel) {
283
+ this.title.label += ': ' + partLabel;
284
+ } else {
285
+ this.title.label = partLabel;
286
+ }
287
+ }
288
+ part.collapsed = false;
289
+ part.hideTitle();
290
+ } else {
291
+ visibleParts.forEach(part => part.showTitle());
292
+ // If at least one part originally belongs to this container the title should return to its original value.
293
+ const originalPart = this.findOriginalPart();
294
+ if (originalPart && !this.isCurrentTitle(originalPart.originalContainerTitle)) {
295
+ title = Object.assign({}, originalPart.originalContainerTitle);
296
+ this.setTitleOptions(title);
297
+ return;
298
+ }
299
+ }
300
+ this.updateToolbarItems(allParts);
301
+ this.title.caption = title?.caption || title?.label;
302
+ if (title.iconClass) {
303
+ this.title.iconClass = title.iconClass;
304
+ }
305
+ if (this.title.className.includes(PINNED_CLASS)) {
306
+ this.title.closable &&= false;
307
+ } else if (title.closeable !== undefined) {
308
+ this.title.closable = title.closeable;
309
+ }
310
+ }
311
+
312
+ protected updateToolbarItems(allParts: ViewContainerPart[]): void {
313
+ if (allParts.length > 1) {
314
+ const group = this.getToggleVisibilityGroupLabel();
315
+ for (const part of allParts) {
316
+ const existingId = this.toggleVisibilityCommandId(part);
317
+ const { caption, label, dataset: { visibilityCommandLabel } } = part.wrapped.title;
318
+ this.registerToolbarItem(existingId, { tooltip: visibilityCommandLabel || caption || label, group });
319
+ }
320
+ }
321
+ }
322
+
323
+ protected getToggleVisibilityGroupLabel(): string {
324
+ return 'view';
325
+ }
326
+
327
+ protected registerToolbarItem(commandId: string, options?: Partial<Omit<TabBarToolbarItem, 'id' | 'command'>>): void {
328
+ const newId = `${this.id}-tabbar-toolbar-${commandId}`;
329
+ const existingHandler = this.commandRegistry.getAllHandlers(commandId)[0];
330
+ const existingCommand = this.commandRegistry.getCommand(commandId);
331
+ if (existingHandler && existingCommand) {
332
+ this.toDisposeOnUpdateTitle.push(this.commandRegistry.registerCommand({ ...existingCommand, id: newId }, {
333
+ execute: (_widget, ...args) => this.commandRegistry.executeCommand(commandId, ...args),
334
+ isToggled: (_widget, ...args) => this.commandRegistry.isToggled(commandId, ...args),
335
+ isEnabled: (_widget, ...args) => this.commandRegistry.isEnabled(commandId, ...args),
336
+ isVisible: (widget, ...args) => widget === this.getTabBarDelegate() && this.commandRegistry.isVisible(commandId, ...args),
337
+ }));
338
+ this.toDisposeOnUpdateTitle.push(this.toolbarRegistry.registerItem({
339
+ ...options,
340
+ id: newId,
341
+ command: newId,
342
+ }));
343
+ }
344
+ }
345
+
346
+ protected findOriginalPart(): ViewContainerPart | undefined {
347
+ return this.getParts().find(part => part.originalContainerId === this.id);
348
+ }
349
+
350
+ protected isCurrentTitle(titleOptions: ViewContainerTitleOptions | undefined): boolean {
351
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
352
+ return (!!titleOptions && !!this.titleOptions && Object.keys(titleOptions).every(key => (titleOptions as any)[key] === (this.titleOptions as any)[key]))
353
+ || (!titleOptions && !this.titleOptions);
354
+ }
355
+
356
+ protected findPartForAnchor(anchor: Anchor): ViewContainerPart | undefined {
357
+ const element = document.elementFromPoint(anchor.x, anchor.y);
358
+ if (element instanceof Element) {
359
+ const closestPart = ViewContainerPart.closestPart(element);
360
+ if (closestPart && closestPart.id) {
361
+ return find(this.containerLayout.iter(), part => part.id === closestPart.id);
362
+ }
363
+ }
364
+ return undefined;
365
+ }
366
+
367
+ protected readonly toRemoveWidgets = new Map<string, DisposableCollection>();
368
+
369
+ protected createPartId(widget: Widget): string {
370
+ const description = this.widgetManager.getDescription(widget);
371
+ return widget.id || JSON.stringify(description);
372
+ }
373
+
374
+ addWidget(widget: Widget, options?: ViewContainer.Factory.WidgetOptions, originalContainerId?: string, originalContainerTitle?: ViewContainerTitleOptions): Disposable {
375
+ const existing = this.toRemoveWidgets.get(widget.id);
376
+ if (existing) {
377
+ return existing;
378
+ }
379
+ const partId = this.createPartId(widget);
380
+ const newPart = this.createPart(widget, partId, originalContainerId || this.id, originalContainerTitle || this.titleOptions, options);
381
+ return this.attachNewPart(newPart);
382
+ }
383
+
384
+ protected attachNewPart(newPart: ViewContainerPart, insertIndex?: number): Disposable {
385
+ const toRemoveWidget = new DisposableCollection();
386
+ this.toDispose.push(toRemoveWidget);
387
+ this.toRemoveWidgets.set(newPart.wrapped.id, toRemoveWidget);
388
+ toRemoveWidget.push(Disposable.create(() => this.toRemoveWidgets.delete(newPart.wrapped.id)));
389
+ this.registerPart(newPart);
390
+ if (insertIndex !== undefined || (newPart.options && newPart.options.order !== undefined)) {
391
+ const index = insertIndex ?? this.getParts().findIndex(part => part.options.order === undefined || part.options.order > newPart.options.order!);
392
+ if (index >= 0) {
393
+ this.containerLayout.insertWidget(index, newPart);
394
+ } else {
395
+ this.containerLayout.addWidget(newPart);
396
+ }
397
+ } else {
398
+ this.containerLayout.addWidget(newPart);
399
+ }
400
+ this.refreshMenu(newPart);
401
+ this.updateTitle();
402
+ this.updateCurrentPart();
403
+ this.updateSplitterVisibility();
404
+ this.update();
405
+ this.fireDidChangeTrackableWidgets();
406
+ toRemoveWidget.pushAll([
407
+ Disposable.create(() => {
408
+ if (newPart.currentViewContainerId === this.id) {
409
+ newPart.dispose();
410
+ }
411
+ this.unregisterPart(newPart);
412
+ if (!newPart.isDisposed && this.getPartIndex(newPart.id) > -1) {
413
+ this.containerLayout.removeWidget(newPart);
414
+ }
415
+ if (!this.isDisposed) {
416
+ this.update();
417
+ this.updateTitle();
418
+ this.updateCurrentPart();
419
+ this.updateSplitterVisibility();
420
+ this.fireDidChangeTrackableWidgets();
421
+ }
422
+ }),
423
+ this.registerDND(newPart),
424
+ newPart.onDidChangeVisibility(() => {
425
+ this.updateTitle();
426
+ this.updateCurrentPart();
427
+ this.updateSplitterVisibility();
428
+ this.containerLayout.updateSashes();
429
+ }),
430
+ newPart.onCollapsed(() => {
431
+ this.containerLayout.updateCollapsed(newPart, this.enableAnimation);
432
+ this.containerLayout.updateSashes();
433
+ this.updateCurrentPart();
434
+ }),
435
+ newPart.onContextMenu(event => {
436
+ if (event.button === 2) {
437
+ event.preventDefault();
438
+ event.stopPropagation();
439
+ this.contextMenuRenderer.render({ menuPath: this.contextMenuPath, anchor: event });
440
+ }
441
+ }),
442
+ newPart.onTitleChanged(() => this.refreshMenu(newPart)),
443
+ newPart.onDidFocus(() => this.updateCurrentPart(newPart))
444
+ ]);
445
+
446
+ newPart.disposed.connect(() => toRemoveWidget.dispose());
447
+ return toRemoveWidget;
448
+ }
449
+
450
+ protected createPart(widget: Widget, partId: string, originalContainerId: string, originalContainerTitle?: ViewContainerTitleOptions,
451
+ options?: ViewContainer.Factory.WidgetOptions): ViewContainerPart {
452
+
453
+ return new ViewContainerPart(widget, partId, this.id, originalContainerId, originalContainerTitle, this.toolbarRegistry, this.toolbarFactory, options);
454
+ }
455
+
456
+ removeWidget(widget: Widget): boolean {
457
+ const disposable = this.toRemoveWidgets.get(widget.id);
458
+ if (disposable) {
459
+ disposable.dispose();
460
+ return true;
461
+ }
462
+ return false;
463
+ }
464
+
465
+ getParts(): ViewContainerPart[] {
466
+ return this.containerLayout.widgets;
467
+ }
468
+
469
+ protected getPartIndex(partId: string | undefined): number {
470
+ if (partId) {
471
+ return this.getParts().findIndex(part => part.id === partId);
472
+ }
473
+ return -1;
474
+ }
475
+
476
+ getPartFor(widget: Widget): ViewContainerPart | undefined {
477
+ return this.getParts().find(p => p.wrapped.id === widget.id);
478
+ }
479
+
480
+ get containerLayout(): ViewContainerLayout {
481
+ const layout = this.panel.layout;
482
+ if (layout instanceof ViewContainerLayout) {
483
+ return layout;
484
+ }
485
+ throw new Error('view container is disposed');
486
+ }
487
+
488
+ protected get orientation(): SplitLayout.Orientation {
489
+ return ViewContainer.getOrientation(this.node);
490
+ }
491
+
492
+ protected get enableAnimation(): boolean {
493
+ return this.applicationStateService.state === 'ready';
494
+ }
495
+
496
+ protected lastVisibleState: ViewContainer.State | undefined;
497
+
498
+ storeState(): ViewContainer.State {
499
+ if (!this.isVisible && this.lastVisibleState) {
500
+ return this.lastVisibleState;
501
+ }
502
+ return this.doStoreState();
503
+ }
504
+ protected doStoreState(): ViewContainer.State {
505
+ const parts = this.getParts();
506
+ const availableSize = this.containerLayout.getAvailableSize();
507
+ const orientation = this.orientation;
508
+ const partStates = parts.map(part => {
509
+ let size = this.containerLayout.getPartSize(part);
510
+ if (size && size > ViewContainerPart.HEADER_HEIGHT && orientation === 'vertical') {
511
+ size -= ViewContainerPart.HEADER_HEIGHT;
512
+ }
513
+ return <ViewContainerPart.State>{
514
+ widget: part.wrapped,
515
+ partId: part.partId,
516
+ collapsed: part.collapsed,
517
+ hidden: part.isHidden,
518
+ relativeSize: size && availableSize ? size / availableSize : undefined,
519
+ originalContainerId: part.originalContainerId,
520
+ originalContainerTitle: part.originalContainerTitle
521
+ };
522
+ });
523
+ return { parts: partStates, title: this.titleOptions };
524
+ }
525
+
526
+ restoreState(state: ViewContainer.State): void {
527
+ this.lastVisibleState = state;
528
+ this.doRestoreState(state);
529
+ }
530
+ protected doRestoreState(state: ViewContainer.State): void {
531
+ this.setTitleOptions(state.title);
532
+ // restore widgets
533
+ for (const part of state.parts) {
534
+ if (part.widget) {
535
+ this.addWidget(part.widget, undefined, part.originalContainerId, part.originalContainerTitle || {} as ViewContainerTitleOptions);
536
+ }
537
+ }
538
+ const partStates = state.parts.filter(partState => some(this.containerLayout.iter(), p => p.partId === partState.partId));
539
+
540
+ // Reorder the parts according to the stored state
541
+ for (let index = 0; index < partStates.length; index++) {
542
+ const partState = partStates[index];
543
+ const widget = this.getParts().find(part => part.partId === partState.partId);
544
+ if (widget) {
545
+ this.containerLayout.insertWidget(index, widget);
546
+ }
547
+ }
548
+
549
+ // Restore visibility and collapsed state
550
+ const parts = this.getParts();
551
+ for (let index = 0; index < parts.length; index++) {
552
+ const part = parts[index];
553
+ const partState = partStates.find(s => part.partId === s.partId);
554
+ if (partState) {
555
+ part.setHidden(partState.hidden);
556
+ part.collapsed = partState.collapsed || !partState.relativeSize;
557
+ } else if (part.canHide) {
558
+ part.hide();
559
+ }
560
+ this.refreshMenu(part);
561
+ }
562
+
563
+ // Restore part sizes
564
+ waitForRevealed(this).then(() => {
565
+ this.containerLayout.setPartSizes(partStates.map(partState => partState.relativeSize));
566
+ this.updateSplitterVisibility();
567
+ });
568
+ }
569
+
570
+ /**
571
+ * Register a command to toggle the visibility of the new part.
572
+ */
573
+ protected registerPart(toRegister: ViewContainerPart): void {
574
+ const commandId = this.toggleVisibilityCommandId(toRegister);
575
+ this.commandRegistry.registerCommand({ id: commandId }, {
576
+ execute: () => {
577
+ const toHide = find(this.containerLayout.iter(), part => part.id === toRegister.id);
578
+ if (toHide) {
579
+ toHide.setHidden(!toHide.isHidden);
580
+ }
581
+ },
582
+ isToggled: () => {
583
+ if (!toRegister.canHide) {
584
+ return true;
585
+ }
586
+ const widgetToToggle = find(this.containerLayout.iter(), part => part.id === toRegister.id);
587
+ if (widgetToToggle) {
588
+ return !widgetToToggle.isHidden;
589
+ }
590
+ return false;
591
+ },
592
+ isEnabled: arg => toRegister.canHide && (!this.titleOptions || !(arg instanceof Widget) || (arg instanceof ViewContainer && arg.id === this.id)),
593
+ isVisible: arg => !this.titleOptions || !(arg instanceof Widget) || (arg instanceof ViewContainer && arg.id === this.id)
594
+ });
595
+ }
596
+
597
+ /**
598
+ * Register a menu action to toggle the visibility of the new part.
599
+ * The menu action is unregistered first to enable refreshing the order of menu actions.
600
+ */
601
+ protected refreshMenu(part: ViewContainerPart): void {
602
+ const commandId = this.toggleVisibilityCommandId(part);
603
+ this.menuRegistry.unregisterMenuAction(commandId);
604
+ if (!part.wrapped.title.label) {
605
+ return;
606
+ }
607
+ const { dataset: { visibilityCommandLabel }, caption, label } = part.wrapped.title;
608
+ const action: MenuAction = {
609
+ commandId: commandId,
610
+ label: visibilityCommandLabel || caption || label,
611
+ order: this.getParts().indexOf(part).toString()
612
+ };
613
+ this.menuRegistry.registerMenuAction([...this.contextMenuPath, '1_widgets'], action);
614
+ if (this.titleOptions) {
615
+ this.menuRegistry.registerMenuAction([...SIDE_PANEL_TOOLBAR_CONTEXT_MENU, 'navigation'], action);
616
+ }
617
+ }
618
+
619
+ protected unregisterPart(part: ViewContainerPart): void {
620
+ const commandId = this.toggleVisibilityCommandId(part);
621
+ this.commandRegistry.unregisterCommand(commandId);
622
+ this.menuRegistry.unregisterMenuAction(commandId);
623
+ }
624
+
625
+ protected get contextMenuPath(): MenuPath {
626
+ return [`${this.id}-context-menu`];
627
+ }
628
+
629
+ protected toggleVisibilityCommandId(part: ViewContainerPart): string {
630
+ return `${this.id}:toggle-visibility-${part.id}`;
631
+ }
632
+
633
+ protected get globalHideCommandId(): string {
634
+ return `${this.id}:toggle-visibility`;
635
+ }
636
+
637
+ protected moveBefore(toMovedId: string, moveBeforeThisId: string): void {
638
+ const parts = this.getParts();
639
+ const indexToMove = parts.findIndex(part => part.id === toMovedId);
640
+ const targetIndex = parts.findIndex(part => part.id === moveBeforeThisId);
641
+ if (indexToMove >= 0 && targetIndex >= 0) {
642
+ this.containerLayout.insertWidget(targetIndex, parts[indexToMove]);
643
+ for (let index = Math.min(indexToMove, targetIndex); index < parts.length; index++) {
644
+ this.refreshMenu(parts[index]);
645
+ this.activate();
646
+ }
647
+ }
648
+ this.updateSplitterVisibility();
649
+ }
650
+
651
+ getTrackableWidgets(): Widget[] {
652
+ return this.getParts().map(w => w.wrapped);
653
+ }
654
+
655
+ protected fireDidChangeTrackableWidgets(): void {
656
+ this.onDidChangeTrackableWidgetsEmitter.fire(this.getTrackableWidgets());
657
+ }
658
+
659
+ activateWidget(id: string): Widget | undefined {
660
+ const part = this.revealPart(id);
661
+ if (!part) {
662
+ return undefined;
663
+ }
664
+ this.updateCurrentPart(part);
665
+ part.collapsed = false;
666
+ return part.wrapped;
667
+ }
668
+
669
+ revealWidget(id: string): Widget | undefined {
670
+ const part = this.revealPart(id);
671
+ return part && part.wrapped;
672
+ }
673
+
674
+ protected revealPart(id: string): ViewContainerPart | undefined {
675
+ const part = this.getParts().find(p => p.wrapped.id === id);
676
+ if (!part) {
677
+ return undefined;
678
+ }
679
+ part.setHidden(false);
680
+ return part;
681
+ }
682
+
683
+ protected override onActivateRequest(msg: Message): void {
684
+ super.onActivateRequest(msg);
685
+ if (this.currentPart) {
686
+ this.currentPart.activate();
687
+ } else {
688
+ this.panel.node.focus({ preventScroll: true });
689
+ }
690
+ }
691
+
692
+ protected override onAfterAttach(msg: Message): void {
693
+ const orientation = this.orientation;
694
+ this.containerLayout.orientation = orientation;
695
+ if (orientation === 'horizontal') {
696
+ for (const part of this.getParts()) {
697
+ part.collapsed = false;
698
+ }
699
+ }
700
+ super.onAfterAttach(msg);
701
+ }
702
+
703
+ protected override onBeforeHide(msg: Message): void {
704
+ super.onBeforeHide(msg);
705
+ this.lastVisibleState = this.storeState();
706
+ }
707
+
708
+ protected override onAfterShow(msg: Message): void {
709
+ super.onAfterShow(msg);
710
+ this.updateTitle();
711
+ this.lastVisibleState = undefined;
712
+ }
713
+
714
+ protected override onBeforeAttach(msg: Message): void {
715
+ super.onBeforeAttach(msg);
716
+ this.node.addEventListener('p-dragenter', this, true);
717
+ this.node.addEventListener('p-dragover', this, true);
718
+ this.node.addEventListener('p-dragleave', this, true);
719
+ this.node.addEventListener('p-drop', this, true);
720
+ }
721
+
722
+ protected override onAfterDetach(msg: Message): void {
723
+ super.onAfterDetach(msg);
724
+ this.node.removeEventListener('p-dragenter', this, true);
725
+ this.node.removeEventListener('p-dragover', this, true);
726
+ this.node.removeEventListener('p-dragleave', this, true);
727
+ this.node.removeEventListener('p-drop', this, true);
728
+ }
729
+
730
+ handleEvent(event: Event): void {
731
+ switch (event.type) {
732
+ case 'p-dragenter':
733
+ this.handleDragEnter(event as IDragEvent);
734
+ break;
735
+ case 'p-dragover':
736
+ this.handleDragOver(event as IDragEvent);
737
+ break;
738
+ case 'p-dragleave':
739
+ this.handleDragLeave(event as IDragEvent);
740
+ break;
741
+ case 'p-drop':
742
+ this.handleDrop(event as IDragEvent);
743
+ break;
744
+ }
745
+ }
746
+
747
+ handleDragEnter(event: IDragEvent): void {
748
+ if (event.mimeData.hasData('application/vnd.phosphor.view-container-factory')) {
749
+ event.preventDefault();
750
+ event.stopPropagation();
751
+ }
752
+ }
753
+
754
+ toDisposeOnDragEnd = new DisposableCollection();
755
+ handleDragOver(event: IDragEvent): void {
756
+ const factory = event.mimeData.getData('application/vnd.phosphor.view-container-factory');
757
+ const widget = factory && factory();
758
+ if (!(widget instanceof ViewContainerPart)) {
759
+ return;
760
+ }
761
+ event.preventDefault();
762
+ event.stopPropagation();
763
+
764
+ const sameContainers = this.id === widget.currentViewContainerId;
765
+ const targetPart = ArrayExt.findFirstValue(this.getParts(), (p => ElementExt.hitTest(p.node, event.clientX, event.clientY)));
766
+ if (!targetPart && sameContainers) {
767
+ event.dropAction = 'none';
768
+ return;
769
+ }
770
+ if (targetPart) {
771
+ // add overlay class style to the `targetPart` node.
772
+ targetPart.node.classList.add('drop-target');
773
+ this.toDisposeOnDragEnd.push(Disposable.create(() => targetPart.node.classList.remove('drop-target')));
774
+ } else {
775
+ // show panel overlay.
776
+ const dockPanel = this.getDockPanel();
777
+ if (dockPanel) {
778
+ dockPanel.overlay.show({ top: 0, bottom: 0, right: 0, left: 0 });
779
+ this.toDisposeOnDragEnd.push(Disposable.create(() => dockPanel.overlay.hide(100)));
780
+ }
781
+ }
782
+
783
+ const isDraggingOutsideDisabled = this.disableDNDBetweenContainers || widget.viewContainer?.disableDNDBetweenContainers
784
+ || widget.options.disableDraggingToOtherContainers;
785
+ if (isDraggingOutsideDisabled && !sameContainers) {
786
+ const { target } = event;
787
+ if (target instanceof HTMLElement) {
788
+ target.classList.add('theia-cursor-no-drop');
789
+ this.toDisposeOnDragEnd.push(Disposable.create(() => {
790
+ target.classList.remove('theia-cursor-no-drop');
791
+ }));
792
+ }
793
+ event.dropAction = 'none';
794
+ return;
795
+ };
796
+
797
+ event.dropAction = event.proposedAction;
798
+ };
799
+
800
+ handleDragLeave(event: IDragEvent): void {
801
+ this.toDisposeOnDragEnd.dispose();
802
+ if (event.mimeData.hasData('application/vnd.phosphor.view-container-factory')) {
803
+ event.preventDefault();
804
+ event.stopPropagation();
805
+ }
806
+ };
807
+
808
+ handleDrop(event: IDragEvent): void {
809
+ this.toDisposeOnDragEnd.dispose();
810
+ const factory = event.mimeData.getData('application/vnd.phosphor.view-container-factory');
811
+ const draggedPart = factory && factory();
812
+ if (!(draggedPart instanceof ViewContainerPart)) {
813
+ event.dropAction = 'none';
814
+ return;
815
+ }
816
+ event.preventDefault();
817
+ event.stopPropagation();
818
+ const parts = this.getParts();
819
+ const toIndex = ArrayExt.findFirstIndex(parts, part => ElementExt.hitTest(part.node, event.clientX, event.clientY));
820
+ if (draggedPart.currentViewContainerId !== this.id) {
821
+ this.attachNewPart(draggedPart, toIndex > -1 ? toIndex + 1 : toIndex);
822
+ draggedPart.onPartMoved(this);
823
+ } else {
824
+ this.moveBefore(draggedPart.id, parts[toIndex].id);
825
+ }
826
+ event.dropAction = event.proposedAction;
827
+ }
828
+
829
+ protected registerDND(part: ViewContainerPart): Disposable {
830
+ part.headerElement.draggable = true;
831
+
832
+ return new DisposableCollection(
833
+ addEventListener(part.headerElement, 'dragstart',
834
+ event => {
835
+ event.preventDefault();
836
+ const mimeData = new MimeData();
837
+ mimeData.setData('application/vnd.phosphor.view-container-factory', () => part);
838
+ const clonedHeader = part.headerElement.cloneNode(true) as HTMLElement;
839
+ clonedHeader.style.width = part.node.style.width;
840
+ clonedHeader.style.opacity = '0.6';
841
+ const drag = new Drag({
842
+ mimeData,
843
+ dragImage: clonedHeader,
844
+ proposedAction: 'move',
845
+ supportedActions: 'move'
846
+ });
847
+ part.node.classList.add('p-mod-hidden');
848
+ drag.start(event.clientX, event.clientY).then(dropAction => {
849
+ // The promise is resolved when the drag has ended
850
+ if (dropAction === 'move' && part.currentViewContainerId !== this.id) {
851
+ this.removeWidget(part.wrapped);
852
+ this.lastVisibleState = this.doStoreState();
853
+ }
854
+ });
855
+ setTimeout(() => { part.node.classList.remove('p-mod-hidden'); }, 0);
856
+ }, false));
857
+ }
858
+
859
+ protected getDockPanel(): DockPanel | undefined {
860
+ let panel: DockPanel | undefined;
861
+ let parent = this.parent;
862
+ while (!panel && parent) {
863
+ if (this.isSideDockPanel(parent)) {
864
+ panel = parent as DockPanel;
865
+ } else {
866
+ parent = parent.parent;
867
+ }
868
+ }
869
+ return panel;
870
+ }
871
+
872
+ protected isSideDockPanel(widget: Widget): boolean {
873
+ const { leftPanelHandler, rightPanelHandler } = this.shell;
874
+ if (widget instanceof DockPanel && (widget.id === rightPanelHandler.dockPanel.id || widget.id === leftPanelHandler.dockPanel.id)) {
875
+ return true;
876
+ }
877
+ return false;
878
+ }
879
+
880
+ }
881
+
882
+ export namespace ViewContainer {
883
+
884
+ export const Factory = Symbol('ViewContainerFactory');
885
+ export interface Factory {
886
+ (options: ViewContainerIdentifier): ViewContainer;
887
+ }
888
+
889
+ export namespace Factory {
890
+
891
+ export interface WidgetOptions {
892
+ readonly order?: number;
893
+ readonly weight?: number;
894
+ readonly initiallyCollapsed?: boolean;
895
+ readonly canHide?: boolean;
896
+ readonly initiallyHidden?: boolean;
897
+ /**
898
+ * Disable dragging this part from its original container to other containers,
899
+ * But allow dropping parts from other containers on it,
900
+ * This option only applies to the `ViewContainerPart` and has no effect on the ViewContainer.
901
+ */
902
+ readonly disableDraggingToOtherContainers?: boolean;
903
+ }
904
+
905
+ export interface WidgetDescriptor {
906
+ readonly widget: Widget | interfaces.ServiceIdentifier<Widget>;
907
+ readonly options?: WidgetOptions;
908
+ }
909
+
910
+ }
911
+
912
+ export interface State {
913
+ title?: ViewContainerTitleOptions;
914
+ parts: ViewContainerPart.State[]
915
+ }
916
+
917
+ export function getOrientation(node: HTMLElement): 'horizontal' | 'vertical' {
918
+ if (node.closest(`#${MAIN_AREA_ID}`) || node.closest(`#${BOTTOM_AREA_ID}`)) {
919
+ return 'horizontal';
920
+ }
921
+ return 'vertical';
922
+ }
923
+ }
924
+
925
+ /**
926
+ * Wrapper around a widget held by a view container. Adds a header to display the
927
+ * title, toolbar, and collapse / expand handle.
928
+ */
929
+ export class ViewContainerPart extends BaseWidget {
930
+
931
+ protected readonly header: HTMLElement;
932
+ protected readonly body: HTMLElement;
933
+ protected readonly collapsedEmitter = new Emitter<boolean>();
934
+ protected readonly contextMenuEmitter = new Emitter<MouseEvent>();
935
+
936
+ protected readonly onTitleChangedEmitter = new Emitter<void>();
937
+ readonly onTitleChanged = this.onTitleChangedEmitter.event;
938
+ protected readonly onDidFocusEmitter = new Emitter<this>();
939
+ readonly onDidFocus = this.onDidFocusEmitter.event;
940
+ protected readonly onPartMovedEmitter = new Emitter<ViewContainer>();
941
+ readonly onDidMove = this.onPartMovedEmitter.event;
942
+ protected readonly onDidChangeDescriptionEmitter = new Emitter<void>();
943
+ readonly onDidChangeDescription = this.onDidChangeDescriptionEmitter.event;
944
+ protected readonly onDidChangeBadgeEmitter = new Emitter<void>();
945
+ readonly onDidChangeBadge = this.onDidChangeBadgeEmitter.event;
946
+ protected readonly onDidChangeBadgeTooltipEmitter = new Emitter<void>();
947
+ readonly onDidChangeBadgeTooltip = this.onDidChangeBadgeTooltipEmitter.event;
948
+
949
+ protected readonly toolbar: TabBarToolbar;
950
+
951
+ protected _collapsed: boolean;
952
+
953
+ uncollapsedSize: number | undefined;
954
+ animatedSize: number | undefined;
955
+
956
+ protected readonly toNoDisposeWrapped: Disposable;
957
+
958
+ constructor(
959
+ readonly wrapped: Widget,
960
+ readonly partId: string,
961
+ protected currentContainerId: string,
962
+ readonly originalContainerId: string,
963
+ readonly originalContainerTitle: ViewContainerTitleOptions | undefined,
964
+ protected readonly toolbarRegistry: TabBarToolbarRegistry,
965
+ protected readonly toolbarFactory: TabBarToolbarFactory,
966
+ readonly options: ViewContainer.Factory.WidgetOptions = {}
967
+ ) {
968
+ super();
969
+ wrapped.parent = this;
970
+ wrapped.disposed.connect(() => this.dispose());
971
+ this.id = `${originalContainerId}--${wrapped.id}`;
972
+ this.addClass('part');
973
+
974
+ const fireTitleChanged = () => this.onTitleChangedEmitter.fire(undefined);
975
+ this.wrapped.title.changed.connect(fireTitleChanged);
976
+ this.toDispose.push(Disposable.create(() => this.wrapped.title.changed.disconnect(fireTitleChanged)));
977
+
978
+ if (DescriptionWidget.is(this.wrapped)) {
979
+ this.wrapped?.onDidChangeDescription(() => this.onDidChangeDescriptionEmitter.fire(), undefined, this.toDispose);
980
+ }
981
+
982
+ if (BadgeWidget.is(this.wrapped)) {
983
+ this.wrapped.onDidChangeBadge(() => this.onDidChangeBadgeEmitter.fire(), undefined, this.toDispose);
984
+ this.wrapped.onDidChangeBadgeTooltip(() => this.onDidChangeBadgeTooltipEmitter.fire(), undefined, this.toDispose);
985
+ }
986
+
987
+ if (DynamicToolbarWidget.is(this.wrapped)) {
988
+ this.wrapped.onDidChangeToolbarItems(() => {
989
+ this.toolbar.updateTarget(this.wrapped);
990
+ this.viewContainer?.update();
991
+ });
992
+ }
993
+
994
+ const { header, body, disposable } = this.createContent();
995
+ this.header = header;
996
+ this.body = body;
997
+
998
+ this.toNoDisposeWrapped = this.toDispose.push(wrapped);
999
+ this.toolbar = this.toolbarFactory();
1000
+ this.toolbar.addClass('theia-view-container-part-title');
1001
+
1002
+ this.toDispose.pushAll([
1003
+ disposable,
1004
+ this.toolbar,
1005
+ this.toolbarRegistry.onDidChange(() => this.toolbar.updateTarget(this.wrapped)),
1006
+ this.collapsedEmitter,
1007
+ this.contextMenuEmitter,
1008
+ this.onTitleChangedEmitter,
1009
+ this.onDidChangeDescriptionEmitter,
1010
+ this.onDidChangeBadgeEmitter,
1011
+ this.onDidChangeBadgeTooltipEmitter,
1012
+ this.registerContextMenu(),
1013
+ this.onDidFocusEmitter,
1014
+ // focus event does not bubble, capture it
1015
+ addEventListener(this.node, 'focus', () => this.onDidFocusEmitter.fire(this), true)
1016
+ ]);
1017
+ this.scrollOptions = {
1018
+ suppressScrollX: true,
1019
+ minScrollbarLength: 35
1020
+ };
1021
+ this.collapsed = !!options.initiallyCollapsed;
1022
+ if (options.initiallyHidden && this.canHide) {
1023
+ this.hide();
1024
+ }
1025
+ }
1026
+
1027
+ get viewContainer(): ViewContainer | undefined {
1028
+ return this.parent ? this.parent.parent as ViewContainer : undefined;
1029
+ }
1030
+
1031
+ get currentViewContainerId(): string {
1032
+ return this.currentContainerId;
1033
+ }
1034
+
1035
+ get headerElement(): HTMLElement {
1036
+ return this.header;
1037
+ }
1038
+
1039
+ get collapsed(): boolean {
1040
+ return this._collapsed;
1041
+ }
1042
+
1043
+ set collapsed(collapsed: boolean) {
1044
+ // Cannot collapse/expand if the orientation of the container is `horizontal`.
1045
+ const orientation = ViewContainer.getOrientation(this.node);
1046
+ if (this._collapsed === collapsed || (orientation === 'horizontal' && collapsed)) {
1047
+ return;
1048
+ }
1049
+ this._collapsed = collapsed;
1050
+ this.node.classList.toggle('collapsed', collapsed);
1051
+
1052
+ if (collapsed && this.wrapped.node.contains(document.activeElement)) {
1053
+ this.header.focus();
1054
+ }
1055
+ this.wrapped.setHidden(collapsed);
1056
+ const toggleIcon = this.header.querySelector(`span.${EXPANSION_TOGGLE_CLASS}`);
1057
+ if (toggleIcon) {
1058
+ if (collapsed) {
1059
+ toggleIcon.classList.add(COLLAPSED_CLASS);
1060
+ } else {
1061
+ toggleIcon.classList.remove(COLLAPSED_CLASS);
1062
+ }
1063
+ }
1064
+ this.update();
1065
+ this.collapsedEmitter.fire(collapsed);
1066
+ }
1067
+
1068
+ onPartMoved(newContainer: ViewContainer): void {
1069
+ this.currentContainerId = newContainer.id;
1070
+ this.onPartMovedEmitter.fire(newContainer);
1071
+ }
1072
+
1073
+ override setHidden(hidden: boolean): void {
1074
+ if (!this.canHide) {
1075
+ return;
1076
+ }
1077
+ super.setHidden(hidden);
1078
+ }
1079
+
1080
+ get canHide(): boolean {
1081
+ return this.options.canHide === undefined || this.options.canHide;
1082
+ }
1083
+
1084
+ get onCollapsed(): CommonEvent<boolean> {
1085
+ return this.collapsedEmitter.event;
1086
+ }
1087
+
1088
+ get onContextMenu(): CommonEvent<MouseEvent> {
1089
+ return this.contextMenuEmitter.event;
1090
+ }
1091
+
1092
+ get minSize(): number {
1093
+ const style = getComputedStyle(this.body);
1094
+ if (ViewContainer.getOrientation(this.node) === 'horizontal') {
1095
+ return parseCssMagnitude(style.minWidth, 0);
1096
+ } else {
1097
+ return parseCssMagnitude(style.minHeight, 0);
1098
+ }
1099
+ }
1100
+
1101
+ protected readonly toShowHeader = new DisposableCollection();
1102
+ showTitle(): void {
1103
+ this.toShowHeader.dispose();
1104
+ }
1105
+
1106
+ hideTitle(): void {
1107
+ if (this.titleHidden) {
1108
+ return;
1109
+ }
1110
+ const display = this.header.style.display;
1111
+ const height = this.body.style.height;
1112
+ this.body.style.height = '100%';
1113
+ this.header.style.display = 'none';
1114
+ this.toShowHeader.push(Disposable.create(() => {
1115
+ this.header.style.display = display;
1116
+ this.body.style.height = height;
1117
+ }));
1118
+ }
1119
+
1120
+ get titleHidden(): boolean {
1121
+ return !this.toShowHeader.disposed || this.collapsed;
1122
+ }
1123
+
1124
+ protected override getScrollContainer(): HTMLElement {
1125
+ return this.body;
1126
+ }
1127
+
1128
+ protected registerContextMenu(): Disposable {
1129
+ return new DisposableCollection(
1130
+ addEventListener(this.header, 'contextmenu', event => {
1131
+ this.contextMenuEmitter.fire(event);
1132
+ })
1133
+ );
1134
+ }
1135
+
1136
+ protected createContent(): { header: HTMLElement, body: HTMLElement, disposable: Disposable } {
1137
+ const disposable = new DisposableCollection();
1138
+ const { header, disposable: headerDisposable } = this.createHeader();
1139
+ const body = document.createElement('div');
1140
+ body.classList.add('body');
1141
+ this.node.appendChild(header);
1142
+ this.node.appendChild(body);
1143
+ disposable.push(headerDisposable);
1144
+ return {
1145
+ header,
1146
+ body,
1147
+ disposable,
1148
+ };
1149
+ }
1150
+
1151
+ protected createHeader(): { header: HTMLElement, disposable: Disposable } {
1152
+ const disposable = new DisposableCollection();
1153
+ const header = document.createElement('div');
1154
+ header.tabIndex = 0;
1155
+ header.classList.add('theia-header', 'header', 'theia-view-container-part-header');
1156
+ disposable.push(addEventListener(header, 'click', event => {
1157
+ if (this.toolbar && this.toolbar.shouldHandleMouseEvent(event)) {
1158
+ return;
1159
+ }
1160
+ this.collapsed = !this.collapsed;
1161
+ }));
1162
+ disposable.push(addKeyListener(header, Key.ARROW_LEFT, () => this.collapsed = true));
1163
+ disposable.push(addKeyListener(header, Key.ARROW_RIGHT, () => this.collapsed = false));
1164
+ disposable.push(addKeyListener(header, Key.ENTER, () => this.collapsed = !this.collapsed));
1165
+
1166
+ const toggleIcon = document.createElement('span');
1167
+ toggleIcon.classList.add(EXPANSION_TOGGLE_CLASS, ...CODICON_TREE_ITEM_CLASSES);
1168
+ if (this.collapsed) {
1169
+ toggleIcon.classList.add(COLLAPSED_CLASS);
1170
+ }
1171
+ header.appendChild(toggleIcon);
1172
+
1173
+ const title = document.createElement('span');
1174
+ title.classList.add('label', 'noselect');
1175
+
1176
+ const description = document.createElement('span');
1177
+ description.classList.add('description');
1178
+
1179
+ const badgeSpan = document.createElement('span');
1180
+ badgeSpan.classList.add('notification-count');
1181
+
1182
+ const badgeContainer = document.createElement('div');
1183
+ badgeContainer.classList.add('notification-count-container');
1184
+ badgeContainer.appendChild(badgeSpan);
1185
+ const badgeContainerDisplay = badgeContainer.style.display;
1186
+
1187
+ const updateTitle = () => {
1188
+ if (this.currentContainerId !== this.originalContainerId && this.originalContainerTitle?.label) {
1189
+ // Creating a title in format: <original_container_title>: <part_title>.
1190
+ title.innerText = this.originalContainerTitle.label + ': ' + this.wrapped.title.label;
1191
+ } else {
1192
+ title.innerText = this.wrapped.title.label;
1193
+ }
1194
+ };
1195
+ const updateCaption = () => title.title = this.wrapped.title.caption || this.wrapped.title.label;
1196
+ const updateDescription = () => {
1197
+ description.innerText = DescriptionWidget.is(this.wrapped) && !this.collapsed && this.wrapped.description || '';
1198
+ };
1199
+ const updateBadge = () => {
1200
+ if (BadgeWidget.is(this.wrapped)) {
1201
+ const visibleToolBarItems = this.toolbarRegistry.visibleItems(this.wrapped).length > 0;
1202
+ const badge = this.wrapped.badge;
1203
+ if (badge && !visibleToolBarItems) {
1204
+ badgeSpan.innerText = badge.toString();
1205
+ badgeSpan.title = this.wrapped.badgeTooltip || '';
1206
+ badgeContainer.style.display = badgeContainerDisplay;
1207
+ return;
1208
+ }
1209
+ }
1210
+ badgeContainer.style.display = 'none';
1211
+ };
1212
+
1213
+ updateTitle();
1214
+ updateCaption();
1215
+ updateDescription();
1216
+ updateBadge();
1217
+
1218
+ disposable.pushAll([
1219
+ this.onTitleChanged(updateTitle),
1220
+ this.onTitleChanged(updateCaption),
1221
+ this.onDidMove(updateTitle),
1222
+ this.onDidChangeDescription(updateDescription),
1223
+ this.onDidChangeBadge(updateBadge),
1224
+ this.onDidChangeBadgeTooltip(updateBadge),
1225
+ this.onCollapsed(updateDescription)
1226
+ ]);
1227
+ header.appendChild(title);
1228
+ header.appendChild(description);
1229
+ header.appendChild(badgeContainer);
1230
+
1231
+ return {
1232
+ header,
1233
+ disposable
1234
+ };
1235
+ }
1236
+
1237
+ protected handleResize(): void {
1238
+ const handleMouseEnter = () => {
1239
+ this.node?.classList.add('no-pointer-events');
1240
+ setTimeout(() => {
1241
+ this.node?.classList.remove('no-pointer-events');
1242
+ this.node?.removeEventListener('mouseenter', handleMouseEnter);
1243
+ }, 100);
1244
+ };
1245
+ this.node?.addEventListener('mouseenter', handleMouseEnter);
1246
+ }
1247
+
1248
+ protected override onResize(msg: Widget.ResizeMessage): void {
1249
+ this.handleResize();
1250
+ if (this.wrapped.isAttached && !this.collapsed) {
1251
+ MessageLoop.sendMessage(this.wrapped, Widget.ResizeMessage.UnknownSize);
1252
+ }
1253
+ super.onResize(msg);
1254
+ }
1255
+
1256
+ protected override onUpdateRequest(msg: Message): void {
1257
+ if (this.wrapped.isAttached && !this.collapsed) {
1258
+ MessageLoop.sendMessage(this.wrapped, msg);
1259
+ }
1260
+ super.onUpdateRequest(msg);
1261
+ }
1262
+
1263
+ protected override onAfterAttach(msg: Message): void {
1264
+ if (!this.wrapped.isAttached) {
1265
+ UnsafeWidgetUtilities.attach(this.wrapped, this.body);
1266
+ }
1267
+ UnsafeWidgetUtilities.attach(this.toolbar, this.header);
1268
+ super.onAfterAttach(msg);
1269
+ }
1270
+
1271
+ protected override onBeforeDetach(msg: Message): void {
1272
+ super.onBeforeDetach(msg);
1273
+ if (this.toolbar.isAttached) {
1274
+ Widget.detach(this.toolbar);
1275
+ }
1276
+ if (this.wrapped.isAttached) {
1277
+ UnsafeWidgetUtilities.detach(this.wrapped);
1278
+ }
1279
+ }
1280
+
1281
+ protected override onBeforeShow(msg: Message): void {
1282
+ if (this.wrapped.isAttached && !this.collapsed) {
1283
+ MessageLoop.sendMessage(this.wrapped, msg);
1284
+ }
1285
+ super.onBeforeShow(msg);
1286
+ }
1287
+
1288
+ protected override onAfterShow(msg: Message): void {
1289
+ super.onAfterShow(msg);
1290
+ if (this.wrapped.isAttached && !this.collapsed) {
1291
+ MessageLoop.sendMessage(this.wrapped, msg);
1292
+ }
1293
+ }
1294
+
1295
+ protected override onBeforeHide(msg: Message): void {
1296
+ if (this.wrapped.isAttached && !this.collapsed) {
1297
+ MessageLoop.sendMessage(this.wrapped, msg);
1298
+ }
1299
+ super.onBeforeShow(msg);
1300
+ }
1301
+
1302
+ protected override onAfterHide(msg: Message): void {
1303
+ super.onAfterHide(msg);
1304
+ if (this.wrapped.isAttached && !this.collapsed) {
1305
+ MessageLoop.sendMessage(this.wrapped, msg);
1306
+ }
1307
+ }
1308
+
1309
+ protected override onChildRemoved(msg: Widget.ChildMessage): void {
1310
+ super.onChildRemoved(msg);
1311
+ // if wrapped is not disposed, but detached then we should not dispose it, but only get rid of this part
1312
+ this.toNoDisposeWrapped.dispose();
1313
+ this.dispose();
1314
+ }
1315
+
1316
+ protected override onActivateRequest(msg: Message): void {
1317
+ super.onActivateRequest(msg);
1318
+ if (this.collapsed) {
1319
+ this.header.focus();
1320
+ } else {
1321
+ this.wrapped.activate();
1322
+ }
1323
+ }
1324
+ }
1325
+
1326
+ export namespace ViewContainerPart {
1327
+
1328
+ /**
1329
+ * Make sure to adjust the `line-height` of the `.theia-view-container .part > .header` CSS class when modifying this, and vice versa.
1330
+ */
1331
+ export const HEADER_HEIGHT = 22;
1332
+
1333
+ export interface State {
1334
+ widget?: Widget
1335
+ partId: string;
1336
+ collapsed: boolean;
1337
+ hidden: boolean;
1338
+ relativeSize?: number;
1339
+ description?: string;
1340
+ /** The original container to which this part belongs */
1341
+ originalContainerId: string;
1342
+ originalContainerTitle?: ViewContainerTitleOptions;
1343
+ }
1344
+
1345
+ export function closestPart(element: Element | EventTarget | null, selector: string = 'div.part'): Element | undefined {
1346
+ if (element instanceof Element) {
1347
+ const part = element.closest(selector);
1348
+ if (part instanceof Element) {
1349
+ return part;
1350
+ }
1351
+ }
1352
+ return undefined;
1353
+ }
1354
+ }
1355
+
1356
+ export class ViewContainerLayout extends SplitLayout {
1357
+
1358
+ constructor(protected options: ViewContainerLayout.Options, protected readonly splitPositionHandler: SplitPositionHandler) {
1359
+ super(options);
1360
+ }
1361
+
1362
+ protected get items(): ReadonlyArray<LayoutItem & ViewContainerLayout.Item> {
1363
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
1364
+ return (this as any)._items as Array<LayoutItem & ViewContainerLayout.Item>;
1365
+ }
1366
+
1367
+ override iter(): IIterator<ViewContainerPart> {
1368
+ return map(this.items, item => item.widget);
1369
+ }
1370
+
1371
+ // @ts-expect-error TS2611 `SplitLayout.widgets` is declared as `readonly widgets` but is implemented as a getter.
1372
+ get widgets(): ViewContainerPart[] {
1373
+ return toArray(this.iter());
1374
+ }
1375
+
1376
+ override attachWidget(index: number, widget: ViewContainerPart): void {
1377
+ super.attachWidget(index, widget);
1378
+ if (index > -1 && this.parent && this.parent.node.contains(this.widgets[index + 1]?.node)) {
1379
+ // Set the correct attach index to the DOM elements.
1380
+ const ref = this.widgets[index + 1].node;
1381
+ this.parent.node.insertBefore(widget.node, ref);
1382
+ this.parent.node.insertBefore(this.handles[index], ref);
1383
+ this.parent.fit();
1384
+ }
1385
+ }
1386
+
1387
+ getPartSize(part: ViewContainerPart): number | undefined {
1388
+ if (part.collapsed || part.isHidden) {
1389
+ return part.uncollapsedSize;
1390
+ }
1391
+ if (this.orientation === 'horizontal') {
1392
+ return part.node.offsetWidth;
1393
+ } else {
1394
+ return part.node.offsetHeight;
1395
+ }
1396
+ }
1397
+
1398
+ /**
1399
+ * Set the sizes of the view container parts according to the given weights
1400
+ * by moving the split handles. This is similar to `setRelativeSizes` defined
1401
+ * in `SplitLayout`, but here we properly consider the collapsed / expanded state.
1402
+ */
1403
+ setPartSizes(weights: (number | undefined)[]): void {
1404
+ const parts = this.widgets;
1405
+ const availableSize = this.getAvailableSize();
1406
+
1407
+ // Sum up the weights of visible parts
1408
+ let totalWeight = 0;
1409
+ let weightCount = 0;
1410
+ for (let index = 0; index < weights.length && index < parts.length; index++) {
1411
+ const part = parts[index];
1412
+ const weight = weights[index];
1413
+ if (weight && !part.isHidden && !part.collapsed) {
1414
+ totalWeight += weight;
1415
+ weightCount++;
1416
+ }
1417
+ }
1418
+ if (weightCount === 0 || availableSize === 0) {
1419
+ return;
1420
+ }
1421
+
1422
+ // Add the average weight for visible parts without weight
1423
+ const averageWeight = totalWeight / weightCount;
1424
+ for (let index = 0; index < weights.length && index < parts.length; index++) {
1425
+ const part = parts[index];
1426
+ const weight = weights[index];
1427
+ if (!weight && !part.isHidden && !part.collapsed) {
1428
+ totalWeight += averageWeight;
1429
+ }
1430
+ }
1431
+
1432
+ // Apply the weights to compute actual sizes
1433
+ let position = 0;
1434
+ for (let index = 0; index < weights.length && index < parts.length - 1; index++) {
1435
+ const part = parts[index];
1436
+ if (!part.isHidden) {
1437
+ if (this.orientation === 'vertical') {
1438
+ position += this.options.headerSize;
1439
+ }
1440
+ const weight = weights[index];
1441
+ if (part.collapsed) {
1442
+ if (weight) {
1443
+ part.uncollapsedSize = weight / totalWeight * availableSize;
1444
+ }
1445
+ } else {
1446
+ let contentSize = (weight || averageWeight) / totalWeight * availableSize;
1447
+ const minSize = part.minSize;
1448
+ if (contentSize < minSize) {
1449
+ contentSize = minSize;
1450
+ }
1451
+ position += contentSize;
1452
+ }
1453
+ this.setHandlePosition(index, position);
1454
+ position += this.spacing;
1455
+ }
1456
+ }
1457
+ }
1458
+
1459
+ /**
1460
+ * Determine the size of the split panel area that is available for widget content,
1461
+ * i.e. excluding part headers and split handles.
1462
+ */
1463
+ getAvailableSize(): number {
1464
+ if (!this.parent || !this.parent.isAttached) {
1465
+ return 0;
1466
+ }
1467
+ const parts = this.widgets;
1468
+ const visiblePartCount = parts.filter(part => !part.isHidden).length;
1469
+ let availableSize: number;
1470
+ if (this.orientation === 'horizontal') {
1471
+ availableSize = this.parent.node.offsetWidth;
1472
+ } else {
1473
+ availableSize = this.parent.node.offsetHeight;
1474
+ availableSize -= visiblePartCount * this.options.headerSize;
1475
+ }
1476
+ availableSize -= (visiblePartCount - 1) * this.spacing;
1477
+ if (availableSize < 0) {
1478
+ return 0;
1479
+ }
1480
+ return availableSize;
1481
+ }
1482
+
1483
+ /**
1484
+ * Update a view container part that has been collapsed or expanded. The transition
1485
+ * to the new state is animated.
1486
+ */
1487
+ updateCollapsed(part: ViewContainerPart, enableAnimation: boolean): void {
1488
+ const index = this.items.findIndex(item => item.widget === part);
1489
+ if (index < 0 || !this.parent || part.isHidden) {
1490
+ return;
1491
+ }
1492
+ // Do not store the height of the "stretched item". Otherwise, we mess up the "hint height".
1493
+ // Store the height only if there are other expanded items.
1494
+ const currentSize = this.orientation === 'horizontal' ? part.node.offsetWidth : part.node.offsetHeight;
1495
+ if (part.collapsed && this.items.some(item => !item.widget.collapsed && !item.widget.isHidden)) {
1496
+ part.uncollapsedSize = currentSize;
1497
+ }
1498
+
1499
+ if (!enableAnimation || this.options.animationDuration <= 0) {
1500
+ MessageLoop.postMessage(this.parent, Widget.Msg.FitRequest);
1501
+ return;
1502
+ }
1503
+ let startTime: number | undefined = undefined;
1504
+ const duration = this.options.animationDuration;
1505
+ const direction = part.collapsed ? 'collapse' : 'expand';
1506
+ let fullSize: number;
1507
+ if (direction === 'collapse') {
1508
+ fullSize = currentSize - this.options.headerSize;
1509
+ } else {
1510
+ fullSize = Math.max((part.uncollapsedSize || 0) - this.options.headerSize, part.minSize);
1511
+ if (this.items.filter(item => !item.widget.collapsed && !item.widget.isHidden).length === 1) {
1512
+ // Expand to full available size
1513
+ fullSize = Math.max(fullSize, this.getAvailableSize());
1514
+ }
1515
+ }
1516
+
1517
+ // The update function is called on every animation frame until the predefined duration has elapsed.
1518
+ const updateFunc = (time: number) => {
1519
+ if (!this.parent) {
1520
+ part.animatedSize = undefined;
1521
+ return;
1522
+ }
1523
+ if (startTime === undefined) {
1524
+ startTime = time;
1525
+ }
1526
+ if (time - startTime < duration) {
1527
+ // Render an intermediate state for the animation
1528
+ const t = this.tween((time - startTime) / duration);
1529
+ if (direction === 'collapse') {
1530
+ part.animatedSize = (1 - t) * fullSize;
1531
+ } else {
1532
+ part.animatedSize = t * fullSize;
1533
+ }
1534
+ requestAnimationFrame(updateFunc);
1535
+ } else {
1536
+ // The animation is finished
1537
+ if (direction === 'collapse') {
1538
+ part.animatedSize = undefined;
1539
+ } else {
1540
+ part.animatedSize = fullSize;
1541
+ // Request another frame to reset the part to variable size
1542
+ requestAnimationFrame(() => {
1543
+ part.animatedSize = undefined;
1544
+ if (this.parent) {
1545
+ MessageLoop.sendMessage(this.parent, Widget.Msg.FitRequest);
1546
+ }
1547
+ });
1548
+ }
1549
+ }
1550
+ MessageLoop.sendMessage(this.parent, Widget.Msg.FitRequest);
1551
+ };
1552
+ requestAnimationFrame(updateFunc);
1553
+ }
1554
+
1555
+ updateSashes(): void {
1556
+ const { widgets, handles } = this;
1557
+ if (widgets.length !== handles.length) {
1558
+ console.warn('Unexpected mismatch between number of widgets and number of handles.');
1559
+ return;
1560
+ }
1561
+ const firstUncollapsed = this.getFirstUncollapsedWidgetIndex();
1562
+ const lastUncollapsed = firstUncollapsed === undefined ? undefined : this.getLastUncollapsedWidgetIndex();
1563
+ const allHidden = firstUncollapsed === lastUncollapsed;
1564
+ for (const [index, handle] of this.handles.entries()) {
1565
+ // The or clauses are added for type checking. If they're true, allHidden will also have been true.
1566
+ if (allHidden || firstUncollapsed === undefined || lastUncollapsed === undefined) {
1567
+ handle.classList.add('sash-hidden');
1568
+ } else if (index < lastUncollapsed && index >= firstUncollapsed) {
1569
+ handle.classList.remove('sash-hidden');
1570
+ } else {
1571
+ handle.classList.add('sash-hidden');
1572
+ }
1573
+ }
1574
+ }
1575
+
1576
+ protected getFirstUncollapsedWidgetIndex(): number | undefined {
1577
+ const index = this.widgets.findIndex(widget => !widget.collapsed && !widget.isHidden);
1578
+ return index === -1 ? undefined : index;
1579
+ }
1580
+
1581
+ protected getLastUncollapsedWidgetIndex(): number | undefined {
1582
+ for (let i = this.widgets.length - 1; i >= 0; i--) {
1583
+ if (!this.widgets[i].collapsed && !this.widgets[i].isHidden) {
1584
+ return i;
1585
+ }
1586
+ }
1587
+ }
1588
+
1589
+ protected override onFitRequest(msg: Message): void {
1590
+ for (const part of this.widgets) {
1591
+ const style = part.node.style;
1592
+ if (part.animatedSize !== undefined) {
1593
+ // The part size has been fixed for animating the transition to collapsed / expanded state
1594
+ const fixedSize = `${this.options.headerSize + part.animatedSize}px`;
1595
+ style.minHeight = fixedSize;
1596
+ style.maxHeight = fixedSize;
1597
+ } else if (part.collapsed) {
1598
+ // The part size is fixed to the header size
1599
+ const fixedSize = `${this.options.headerSize}px`;
1600
+ style.minHeight = fixedSize;
1601
+ style.maxHeight = fixedSize;
1602
+ } else {
1603
+ const minSize = `${this.options.headerSize + part.minSize}px`;
1604
+ style.minHeight = minSize;
1605
+ style.maxHeight = '';
1606
+ }
1607
+ }
1608
+ super.onFitRequest(msg);
1609
+ }
1610
+
1611
+ /**
1612
+ * Sinusoidal tween function for smooth animation.
1613
+ */
1614
+ protected tween(t: number): number {
1615
+ return 0.5 * (1 - Math.cos(Math.PI * t));
1616
+ }
1617
+
1618
+ setHandlePosition(index: number, position: number): Promise<void> {
1619
+ const options: SplitPositionOptions = {
1620
+ referenceWidget: this.widgets[index],
1621
+ duration: 0
1622
+ };
1623
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
1624
+ return this.splitPositionHandler.setSplitHandlePosition(this.parent as SplitPanel, index, position, options) as Promise<any>;
1625
+ }
1626
+
1627
+ }
1628
+
1629
+ export namespace ViewContainerLayout {
1630
+
1631
+ export interface Options extends SplitLayout.IOptions {
1632
+ headerSize: number;
1633
+ animationDuration: number;
1634
+ }
1635
+
1636
+ export interface Item {
1637
+ readonly widget: ViewContainerPart;
1638
+ }
1639
+
1640
+ }