@theia/core 1.45.0 → 1.46.0-next.72

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1591) hide show
  1. package/README.md +6 -6
  2. package/i18n/nls.cs.json +524 -520
  3. package/i18n/nls.de.json +524 -520
  4. package/i18n/nls.es.json +524 -520
  5. package/i18n/nls.fr.json +524 -520
  6. package/i18n/nls.hu.json +524 -520
  7. package/i18n/nls.it.json +524 -520
  8. package/i18n/nls.ja.json +524 -520
  9. package/i18n/nls.json +524 -520
  10. package/i18n/nls.pl.json +524 -520
  11. package/i18n/nls.pt-br.json +524 -520
  12. package/i18n/nls.pt-pt.json +524 -520
  13. package/i18n/nls.ru.json +524 -520
  14. package/i18n/nls.zh-cn.json +524 -520
  15. package/lib/browser/about-dialog.d.ts +33 -33
  16. package/lib/browser/about-dialog.js +136 -136
  17. package/lib/browser/authentication-service.d.ts +144 -144
  18. package/lib/browser/authentication-service.js +332 -332
  19. package/lib/browser/breadcrumbs/breadcrumb-popup-container.d.ts +34 -34
  20. package/lib/browser/breadcrumbs/breadcrumb-popup-container.js +114 -114
  21. package/lib/browser/breadcrumbs/breadcrumb-renderer.d.ts +12 -12
  22. package/lib/browser/breadcrumbs/breadcrumb-renderer.js +42 -42
  23. package/lib/browser/breadcrumbs/breadcrumbs-constants.d.ts +49 -49
  24. package/lib/browser/breadcrumbs/breadcrumbs-constants.js +27 -27
  25. package/lib/browser/breadcrumbs/breadcrumbs-renderer.d.ts +43 -43
  26. package/lib/browser/breadcrumbs/breadcrumbs-renderer.js +187 -187
  27. package/lib/browser/breadcrumbs/breadcrumbs-service.d.ts +32 -32
  28. package/lib/browser/breadcrumbs/breadcrumbs-service.js +119 -119
  29. package/lib/browser/breadcrumbs/index.d.ts +5 -5
  30. package/lib/browser/breadcrumbs/index.js +32 -32
  31. package/lib/browser/browser-clipboard-service.d.ts +23 -23
  32. package/lib/browser/browser-clipboard-service.js +115 -115
  33. package/lib/browser/browser.d.ts +37 -34
  34. package/lib/browser/browser.d.ts.map +1 -1
  35. package/lib/browser/browser.js +196 -192
  36. package/lib/browser/browser.js.map +1 -1
  37. package/lib/browser/clipboard-service.d.ts +6 -6
  38. package/lib/browser/clipboard-service.js +19 -19
  39. package/lib/browser/color-application-contribution.d.ts +24 -24
  40. package/lib/browser/color-application-contribution.js +108 -108
  41. package/lib/browser/color-registry.d.ts +14 -14
  42. package/lib/browser/color-registry.js +63 -63
  43. package/lib/browser/command-open-handler.d.ts +9 -9
  44. package/lib/browser/command-open-handler.js +66 -66
  45. package/lib/browser/common-frontend-contribution.d.ts +206 -206
  46. package/lib/browser/common-frontend-contribution.d.ts.map +1 -1
  47. package/lib/browser/common-frontend-contribution.js +2307 -2307
  48. package/lib/browser/common-frontend-contribution.js.map +1 -1
  49. package/lib/browser/common-styling-participants.d.ts +27 -27
  50. package/lib/browser/common-styling-participants.js +370 -370
  51. package/lib/browser/connection-status-service.d.ts +77 -77
  52. package/lib/browser/connection-status-service.js +209 -209
  53. package/lib/browser/connection-status-service.spec.d.ts +1 -1
  54. package/lib/browser/connection-status-service.spec.js +161 -161
  55. package/lib/browser/context-key-service.d.ts +82 -83
  56. package/lib/browser/context-key-service.d.ts.map +1 -1
  57. package/lib/browser/context-key-service.js +88 -88
  58. package/lib/browser/context-key-service.js.map +1 -1
  59. package/lib/browser/context-menu-renderer.d.ts +54 -55
  60. package/lib/browser/context-menu-renderer.d.ts.map +1 -1
  61. package/lib/browser/context-menu-renderer.js +92 -96
  62. package/lib/browser/context-menu-renderer.js.map +1 -1
  63. package/lib/browser/core-preferences.d.ts +37 -36
  64. package/lib/browser/core-preferences.d.ts.map +1 -1
  65. package/lib/browser/core-preferences.js +300 -295
  66. package/lib/browser/core-preferences.js.map +1 -1
  67. package/lib/browser/credentials-service.d.ts +35 -35
  68. package/lib/browser/credentials-service.js +91 -91
  69. package/lib/browser/decoration-style.d.ts +6 -6
  70. package/lib/browser/decoration-style.js +64 -64
  71. package/lib/browser/decorations-service.d.ts +30 -30
  72. package/lib/browser/decorations-service.js +163 -163
  73. package/lib/browser/dialogs/react-dialog.d.ts +17 -17
  74. package/lib/browser/dialogs/react-dialog.js +60 -60
  75. package/lib/browser/dialogs.d.ts +135 -135
  76. package/lib/browser/dialogs.js +457 -457
  77. package/lib/browser/diff-uris.d.ts +17 -17
  78. package/lib/browser/diff-uris.js +126 -126
  79. package/lib/browser/encoding-registry.d.ts +18 -18
  80. package/lib/browser/encoding-registry.js +96 -96
  81. package/lib/browser/endpoint.d.ts +42 -42
  82. package/lib/browser/endpoint.js +120 -120
  83. package/lib/browser/endpoint.spec.d.ts +1 -1
  84. package/lib/browser/endpoint.spec.js +122 -122
  85. package/lib/browser/external-uri-service.d.ts +24 -24
  86. package/lib/browser/external-uri-service.js +77 -77
  87. package/lib/browser/frontend-application-bindings.d.ts +5 -5
  88. package/lib/browser/frontend-application-bindings.js +56 -56
  89. package/lib/browser/frontend-application-config-provider.d.ts +8 -8
  90. package/lib/browser/frontend-application-config-provider.js +46 -46
  91. package/lib/browser/frontend-application-config-provider.spec.d.ts +1 -1
  92. package/lib/browser/frontend-application-config-provider.spec.js +40 -40
  93. package/lib/browser/frontend-application-contribution.d.ts +75 -75
  94. package/lib/browser/frontend-application-contribution.js +50 -50
  95. package/lib/browser/frontend-application-module.d.ts +8 -8
  96. package/lib/browser/frontend-application-module.d.ts.map +1 -1
  97. package/lib/browser/frontend-application-module.js +354 -353
  98. package/lib/browser/frontend-application-module.js.map +1 -1
  99. package/lib/browser/frontend-application-state.d.ts +19 -19
  100. package/lib/browser/frontend-application-state.js +79 -79
  101. package/lib/browser/frontend-application.d.ts +86 -86
  102. package/lib/browser/frontend-application.js +319 -319
  103. package/lib/browser/hover-service.d.ts +50 -50
  104. package/lib/browser/hover-service.js +207 -207
  105. package/lib/browser/http-open-handler.d.ts +14 -14
  106. package/lib/browser/http-open-handler.js +54 -54
  107. package/lib/browser/i18n/i18n-frontend-module.d.ts +3 -3
  108. package/lib/browser/i18n/i18n-frontend-module.js +25 -25
  109. package/lib/browser/i18n/language-quick-pick-service.d.ts +15 -15
  110. package/lib/browser/i18n/language-quick-pick-service.js +144 -144
  111. package/lib/browser/icon-registry.d.ts +56 -62
  112. package/lib/browser/icon-registry.d.ts.map +1 -1
  113. package/lib/browser/icon-registry.js +24 -24
  114. package/lib/browser/icon-registry.js.map +1 -1
  115. package/lib/browser/icon-theme-contribution.d.ts +23 -23
  116. package/lib/browser/icon-theme-contribution.js +72 -72
  117. package/lib/browser/icon-theme-service.d.ts +63 -63
  118. package/lib/browser/icon-theme-service.js +206 -206
  119. package/lib/browser/index.d.ts +31 -31
  120. package/lib/browser/index.js +58 -58
  121. package/lib/browser/json-schema-store.d.ts +37 -37
  122. package/lib/browser/json-schema-store.js +119 -119
  123. package/lib/browser/keybinding.d.ts +288 -288
  124. package/lib/browser/keybinding.js +682 -682
  125. package/lib/browser/keybinding.spec.d.ts +1 -1
  126. package/lib/browser/keybinding.spec.js +456 -456
  127. package/lib/browser/keyboard/browser-keyboard-frontend-contribution.d.ts +13 -13
  128. package/lib/browser/keyboard/browser-keyboard-frontend-contribution.js +118 -118
  129. package/lib/browser/keyboard/browser-keyboard-layout-provider.d.ts +91 -91
  130. package/lib/browser/keyboard/browser-keyboard-layout-provider.js +426 -426
  131. package/lib/browser/keyboard/browser-keyboard-layout-provider.spec.d.ts +1 -1
  132. package/lib/browser/keyboard/browser-keyboard-layout-provider.spec.js +157 -157
  133. package/lib/browser/keyboard/browser-keyboard-module.d.ts +3 -3
  134. package/lib/browser/keyboard/browser-keyboard-module.js +30 -30
  135. package/lib/browser/keyboard/index.d.ts +4 -4
  136. package/lib/browser/keyboard/index.js +31 -31
  137. package/lib/browser/keyboard/keyboard-layout-service.d.ts +49 -49
  138. package/lib/browser/keyboard/keyboard-layout-service.js +435 -435
  139. package/lib/browser/keyboard/keyboard-layout-service.spec.d.ts +1 -1
  140. package/lib/browser/keyboard/keyboard-layout-service.spec.js +115 -115
  141. package/lib/browser/keyboard/keys.d.ts +4 -4
  142. package/lib/browser/keyboard/keys.js +31 -31
  143. package/lib/browser/keyboard/keys.spec.d.ts +1 -1
  144. package/lib/browser/keyboard/keys.spec.js +205 -205
  145. package/lib/browser/keys.d.ts +2 -2
  146. package/lib/browser/keys.js +28 -28
  147. package/lib/browser/label-parser.d.ts +34 -34
  148. package/lib/browser/label-parser.js +112 -112
  149. package/lib/browser/label-parser.spec.d.ts +1 -1
  150. package/lib/browser/label-parser.spec.js +146 -146
  151. package/lib/browser/label-provider.d.ts +140 -140
  152. package/lib/browser/label-provider.js +318 -318
  153. package/lib/browser/label-provider.spec.d.ts +1 -1
  154. package/lib/browser/label-provider.spec.js +53 -53
  155. package/lib/browser/language-icon-provider.d.ts +14 -14
  156. package/lib/browser/language-icon-provider.js +73 -73
  157. package/lib/browser/language-service.d.ts +38 -38
  158. package/lib/browser/language-service.js +71 -71
  159. package/lib/browser/logger-frontend-module.d.ts +2 -2
  160. package/lib/browser/logger-frontend-module.js +63 -63
  161. package/lib/browser/markdown-rendering/markdown-renderer.d.ts +39 -39
  162. package/lib/browser/markdown-rendering/markdown-renderer.d.ts.map +1 -1
  163. package/lib/browser/markdown-rendering/markdown-renderer.js +80 -80
  164. package/lib/browser/menu/browser-context-menu-renderer.d.ts +12 -12
  165. package/lib/browser/menu/browser-context-menu-renderer.js +61 -61
  166. package/lib/browser/menu/browser-menu-module.d.ts +3 -3
  167. package/lib/browser/menu/browser-menu-module.js +28 -28
  168. package/lib/browser/menu/browser-menu-plugin.d.ts +103 -103
  169. package/lib/browser/menu/browser-menu-plugin.js +450 -450
  170. package/lib/browser/menu/context-menu-context.d.ts +7 -7
  171. package/lib/browser/menu/context-menu-context.js +50 -50
  172. package/lib/browser/messaging/connection-source.d.ts +8 -8
  173. package/lib/browser/messaging/connection-source.js +19 -19
  174. package/lib/browser/messaging/frontend-id-provider.d.ts +12 -12
  175. package/lib/browser/messaging/frontend-id-provider.js +39 -39
  176. package/lib/browser/messaging/index.d.ts +1 -1
  177. package/lib/browser/messaging/index.js +28 -28
  178. package/lib/browser/messaging/messaging-frontend-module.d.ts +2 -2
  179. package/lib/browser/messaging/messaging-frontend-module.js +41 -41
  180. package/lib/browser/messaging/service-connection-provider.d.ts +47 -47
  181. package/lib/browser/messaging/service-connection-provider.js +114 -114
  182. package/lib/browser/messaging/ws-connection-provider.d.ts +12 -12
  183. package/lib/browser/messaging/ws-connection-provider.js +57 -57
  184. package/lib/browser/messaging/ws-connection-source.d.ts +42 -40
  185. package/lib/browser/messaging/ws-connection-source.d.ts.map +1 -1
  186. package/lib/browser/messaging/ws-connection-source.js +225 -209
  187. package/lib/browser/messaging/ws-connection-source.js.map +1 -1
  188. package/lib/browser/mime-service.d.ts +7 -7
  189. package/lib/browser/mime-service.js +35 -35
  190. package/lib/browser/navigatable-types.d.ts +33 -33
  191. package/lib/browser/navigatable-types.js +63 -63
  192. package/lib/browser/navigatable.d.ts +8 -8
  193. package/lib/browser/navigatable.js +47 -47
  194. package/lib/browser/opener-service.d.ts +79 -79
  195. package/lib/browser/opener-service.js +90 -90
  196. package/lib/browser/opener-service.spec.d.ts +1 -1
  197. package/lib/browser/opener-service.spec.js +46 -46
  198. package/lib/browser/performance/frontend-stopwatch.d.ts +20 -20
  199. package/lib/browser/performance/frontend-stopwatch.js +74 -74
  200. package/lib/browser/performance/index.d.ts +2 -2
  201. package/lib/browser/performance/index.js +29 -29
  202. package/lib/browser/performance/measurement-frontend-bindings.d.ts +19 -19
  203. package/lib/browser/performance/measurement-frontend-bindings.js +32 -32
  204. package/lib/browser/preferences/index.d.ts +7 -7
  205. package/lib/browser/preferences/index.js +34 -34
  206. package/lib/browser/preferences/injectable-preference-proxy.d.ts +51 -51
  207. package/lib/browser/preferences/injectable-preference-proxy.js +284 -284
  208. package/lib/browser/preferences/preference-configurations.d.ts +22 -22
  209. package/lib/browser/preferences/preference-configurations.js +80 -80
  210. package/lib/browser/preferences/preference-contribution.d.ts +111 -111
  211. package/lib/browser/preferences/preference-contribution.js +394 -394
  212. package/lib/browser/preferences/preference-language-override-service.d.ts +39 -39
  213. package/lib/browser/preferences/preference-language-override-service.js +112 -112
  214. package/lib/browser/preferences/preference-provider.d.ts +132 -132
  215. package/lib/browser/preferences/preference-provider.js +227 -227
  216. package/lib/browser/preferences/preference-provider.spec.d.ts +1 -1
  217. package/lib/browser/preferences/preference-provider.spec.js +33 -33
  218. package/lib/browser/preferences/preference-proxy.d.ts +150 -150
  219. package/lib/browser/preferences/preference-proxy.js +229 -229
  220. package/lib/browser/preferences/preference-proxy.spec.d.ts +1 -1
  221. package/lib/browser/preferences/preference-proxy.spec.js +337 -337
  222. package/lib/browser/preferences/preference-schema-provider.spec.d.ts +1 -1
  223. package/lib/browser/preferences/preference-schema-provider.spec.js +115 -115
  224. package/lib/browser/preferences/preference-scope.d.ts +2 -2
  225. package/lib/browser/preferences/preference-scope.js +20 -20
  226. package/lib/browser/preferences/preference-service.d.ts +278 -278
  227. package/lib/browser/preferences/preference-service.js +358 -358
  228. package/lib/browser/preferences/preference-service.spec.d.ts +1 -1
  229. package/lib/browser/preferences/preference-service.spec.js +505 -505
  230. package/lib/browser/preferences/preference-validation-service.d.ts +57 -57
  231. package/lib/browser/preferences/preference-validation-service.js +354 -354
  232. package/lib/browser/preferences/preference-validation-service.spec.d.ts +1 -1
  233. package/lib/browser/preferences/preference-validation-service.spec.js +330 -330
  234. package/lib/browser/preferences/test/index.d.ts +3 -3
  235. package/lib/browser/preferences/test/index.js +30 -30
  236. package/lib/browser/preferences/test/mock-preference-provider.d.ts +16 -16
  237. package/lib/browser/preferences/test/mock-preference-provider.js +46 -46
  238. package/lib/browser/preferences/test/mock-preference-proxy.d.ts +3 -3
  239. package/lib/browser/preferences/test/mock-preference-proxy.js +49 -49
  240. package/lib/browser/preferences/test/mock-preference-service.d.ts +28 -28
  241. package/lib/browser/preferences/test/mock-preference-service.js +67 -67
  242. package/lib/browser/preload/i18n-preload-contribution.d.ts +6 -6
  243. package/lib/browser/preload/i18n-preload-contribution.js +62 -62
  244. package/lib/browser/preload/os-preload-contribution.d.ts +6 -6
  245. package/lib/browser/preload/os-preload-contribution.js +48 -48
  246. package/lib/browser/preload/preload-module.d.ts +3 -3
  247. package/lib/browser/preload/preload-module.js +38 -38
  248. package/lib/browser/preload/preloader.d.ts +11 -11
  249. package/lib/browser/preload/preloader.js +44 -44
  250. package/lib/browser/preload/theme-preload-contribution.d.ts +4 -4
  251. package/lib/browser/preload/theme-preload-contribution.js +39 -39
  252. package/lib/browser/progress-bar-factory.d.ts +11 -11
  253. package/lib/browser/progress-bar-factory.js +20 -20
  254. package/lib/browser/progress-bar.d.ts +15 -15
  255. package/lib/browser/progress-bar.js +89 -89
  256. package/lib/browser/progress-client.d.ts +12 -12
  257. package/lib/browser/progress-client.js +61 -61
  258. package/lib/browser/progress-location-service.d.ts +21 -21
  259. package/lib/browser/progress-location-service.js +96 -96
  260. package/lib/browser/progress-location-service.spec.d.ts +1 -1
  261. package/lib/browser/progress-location-service.spec.js +44 -44
  262. package/lib/browser/progress-status-bar-item.d.ts +16 -16
  263. package/lib/browser/progress-status-bar-item.js +89 -89
  264. package/lib/browser/quick-input/index.d.ts +8 -8
  265. package/lib/browser/quick-input/index.js +35 -35
  266. package/lib/browser/quick-input/quick-access.d.ts +53 -53
  267. package/lib/browser/quick-input/quick-access.js +20 -20
  268. package/lib/browser/quick-input/quick-command-frontend-contribution.d.ts +11 -11
  269. package/lib/browser/quick-input/quick-command-frontend-contribution.js +104 -104
  270. package/lib/browser/quick-input/quick-command-service.d.ts +59 -59
  271. package/lib/browser/quick-input/quick-command-service.js +233 -233
  272. package/lib/browser/quick-input/quick-help-service.d.ts +11 -11
  273. package/lib/browser/quick-input/quick-help-service.js +91 -91
  274. package/lib/browser/quick-input/quick-input-frontend-contribution.d.ts +7 -7
  275. package/lib/browser/quick-input/quick-input-frontend-contribution.js +46 -46
  276. package/lib/browser/quick-input/quick-input-service.d.ts +1 -1
  277. package/lib/browser/quick-input/quick-input-service.js +28 -28
  278. package/lib/browser/quick-input/quick-input-service.spec.d.ts +1 -1
  279. package/lib/browser/quick-input/quick-input-service.spec.js +159 -159
  280. package/lib/browser/quick-input/quick-pick-service-impl.d.ts +30 -30
  281. package/lib/browser/quick-input/quick-pick-service-impl.js +77 -77
  282. package/lib/browser/quick-input/quick-view-service.d.ts +23 -23
  283. package/lib/browser/quick-input/quick-view-service.js +86 -86
  284. package/lib/browser/request/browser-request-module.d.ts +18 -18
  285. package/lib/browser/request/browser-request-module.js +23 -23
  286. package/lib/browser/request/browser-request-service.d.ts +41 -41
  287. package/lib/browser/request/browser-request-service.js +180 -180
  288. package/lib/browser/resource-context-key.d.ts +19 -19
  289. package/lib/browser/resource-context-key.js +83 -83
  290. package/lib/browser/save-resource-service.d.ts +35 -35
  291. package/lib/browser/save-resource-service.d.ts.map +1 -1
  292. package/lib/browser/save-resource-service.js +72 -71
  293. package/lib/browser/save-resource-service.js.map +1 -1
  294. package/lib/browser/saveable.d.ts +124 -124
  295. package/lib/browser/saveable.js +274 -274
  296. package/lib/browser/secondary-window-handler.d.ts +64 -64
  297. package/lib/browser/secondary-window-handler.js +208 -208
  298. package/lib/browser/shell/additional-views-menu-widget.d.ts +19 -19
  299. package/lib/browser/shell/additional-views-menu-widget.js +81 -81
  300. package/lib/browser/shell/application-shell-mouse-tracker.d.ts +30 -30
  301. package/lib/browser/shell/application-shell-mouse-tracker.js +107 -107
  302. package/lib/browser/shell/application-shell.d.ts +572 -572
  303. package/lib/browser/shell/application-shell.d.ts.map +1 -1
  304. package/lib/browser/shell/application-shell.js +1995 -1990
  305. package/lib/browser/shell/application-shell.js.map +1 -1
  306. package/lib/browser/shell/current-widget-command-adapter.d.ts +23 -23
  307. package/lib/browser/shell/current-widget-command-adapter.js +41 -41
  308. package/lib/browser/shell/index.d.ts +7 -7
  309. package/lib/browser/shell/index.js +34 -34
  310. package/lib/browser/shell/shell-layout-restorer.d.ts +123 -123
  311. package/lib/browser/shell/shell-layout-restorer.js +347 -347
  312. package/lib/browser/shell/side-panel-handler.d.ts +286 -286
  313. package/lib/browser/shell/side-panel-handler.js +667 -667
  314. package/lib/browser/shell/side-panel-toolbar.d.ts +25 -25
  315. package/lib/browser/shell/side-panel-toolbar.js +96 -96
  316. package/lib/browser/shell/sidebar-bottom-menu-widget.d.ts +9 -9
  317. package/lib/browser/shell/sidebar-bottom-menu-widget.js +46 -46
  318. package/lib/browser/shell/sidebar-menu-widget.d.ts +38 -38
  319. package/lib/browser/shell/sidebar-menu-widget.js +121 -121
  320. package/lib/browser/shell/sidebar-top-menu-widget.d.ts +6 -6
  321. package/lib/browser/shell/sidebar-top-menu-widget.js +35 -35
  322. package/lib/browser/shell/split-panels.d.ts +42 -42
  323. package/lib/browser/shell/split-panels.js +177 -177
  324. package/lib/browser/shell/tab-bar-decorator.d.ts +40 -35
  325. package/lib/browser/shell/tab-bar-decorator.d.ts.map +1 -1
  326. package/lib/browser/shell/tab-bar-decorator.js +95 -64
  327. package/lib/browser/shell/tab-bar-decorator.js.map +1 -1
  328. package/lib/browser/shell/tab-bar-toolbar/index.d.ts +3 -3
  329. package/lib/browser/shell/tab-bar-toolbar/index.js +30 -30
  330. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-menu-adapters.d.ts +15 -15
  331. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-menu-adapters.js +35 -35
  332. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-registry.d.ts +95 -95
  333. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-registry.js +253 -253
  334. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-types.d.ts +136 -136
  335. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar-types.js +88 -88
  336. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.d.ts +88 -88
  337. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.js +417 -417
  338. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.spec.d.ts +1 -1
  339. package/lib/browser/shell/tab-bar-toolbar/tab-bar-toolbar.spec.js +51 -51
  340. package/lib/browser/shell/tab-bars.d.ts +339 -338
  341. package/lib/browser/shell/tab-bars.d.ts.map +1 -1
  342. package/lib/browser/shell/tab-bars.js +1309 -1277
  343. package/lib/browser/shell/tab-bars.js.map +1 -1
  344. package/lib/browser/shell/tab-bars.spec.d.ts +1 -1
  345. package/lib/browser/shell/tab-bars.spec.js +56 -56
  346. package/lib/browser/shell/theia-dock-panel.d.ts +59 -59
  347. package/lib/browser/shell/theia-dock-panel.js +226 -226
  348. package/lib/browser/shell/view-contribution.d.ts +43 -43
  349. package/lib/browser/shell/view-contribution.js +167 -167
  350. package/lib/browser/source-tree/index.d.ts +3 -3
  351. package/lib/browser/source-tree/index.js +30 -30
  352. package/lib/browser/source-tree/source-tree-widget.d.ts +21 -21
  353. package/lib/browser/source-tree/source-tree-widget.js +118 -118
  354. package/lib/browser/source-tree/source-tree.d.ts +36 -36
  355. package/lib/browser/source-tree/source-tree.js +134 -134
  356. package/lib/browser/source-tree/tree-source.d.ts +35 -35
  357. package/lib/browser/source-tree/tree-source.js +64 -64
  358. package/lib/browser/status-bar/index.d.ts +5 -5
  359. package/lib/browser/status-bar/index.js +40 -40
  360. package/lib/browser/status-bar/status-bar-types.d.ts +72 -72
  361. package/lib/browser/status-bar/status-bar-types.js +25 -25
  362. package/lib/browser/status-bar/status-bar-view-model.d.ts +35 -35
  363. package/lib/browser/status-bar/status-bar-view-model.js +212 -212
  364. package/lib/browser/status-bar/status-bar.d.ts +34 -34
  365. package/lib/browser/status-bar/status-bar.js +192 -192
  366. package/lib/browser/storage-service.d.ts +35 -35
  367. package/lib/browser/storage-service.js +130 -130
  368. package/lib/browser/storage-service.spec.d.ts +1 -1
  369. package/lib/browser/storage-service.spec.js +68 -68
  370. package/lib/browser/styling-service.d.ts +28 -28
  371. package/lib/browser/styling-service.js +85 -85
  372. package/lib/browser/supported-encodings.d.ts +9 -9
  373. package/lib/browser/supported-encodings.js +263 -263
  374. package/lib/browser/test/jsdom.d.ts +8 -8
  375. package/lib/browser/test/jsdom.js +69 -69
  376. package/lib/browser/test/mock-connection-status-service.d.ts +5 -5
  377. package/lib/browser/test/mock-connection-status-service.js +32 -32
  378. package/lib/browser/test/mock-env-variables-server.d.ts +12 -12
  379. package/lib/browser/test/mock-env-variables-server.js +42 -42
  380. package/lib/browser/test/mock-opener-service.d.ts +8 -8
  381. package/lib/browser/test/mock-opener-service.js +40 -40
  382. package/lib/browser/test/mock-storage-service.d.ts +11 -11
  383. package/lib/browser/test/mock-storage-service.js +54 -54
  384. package/lib/browser/theming.d.ts +50 -50
  385. package/lib/browser/theming.js +211 -211
  386. package/lib/browser/tooltip-service.d.ts +34 -34
  387. package/lib/browser/tooltip-service.js +87 -87
  388. package/lib/browser/tooltip-service.js.map +1 -1
  389. package/lib/browser/tree/fuzzy-search.d.ts +60 -60
  390. package/lib/browser/tree/fuzzy-search.js +80 -80
  391. package/lib/browser/tree/fuzzy-search.spec.d.ts +1 -1
  392. package/lib/browser/tree/fuzzy-search.spec.js +89 -89
  393. package/lib/browser/tree/index.d.ts +13 -12
  394. package/lib/browser/tree/index.d.ts.map +1 -1
  395. package/lib/browser/tree/index.js +40 -39
  396. package/lib/browser/tree/index.js.map +1 -1
  397. package/lib/browser/tree/search-box-debounce.d.ts +33 -33
  398. package/lib/browser/tree/search-box-debounce.js +75 -75
  399. package/lib/browser/tree/search-box.d.ts +105 -105
  400. package/lib/browser/tree/search-box.js +265 -265
  401. package/lib/browser/tree/test/mock-selectable-tree-model.d.ts +15 -0
  402. package/lib/browser/tree/test/mock-selectable-tree-model.d.ts.map +1 -0
  403. package/lib/browser/tree/test/mock-selectable-tree-model.js +103 -0
  404. package/lib/browser/tree/test/mock-selectable-tree-model.js.map +1 -0
  405. package/lib/browser/tree/test/mock-tree-model.d.ts +12 -12
  406. package/lib/browser/tree/test/mock-tree-model.js +129 -129
  407. package/lib/browser/tree/test/tree-test-container.d.ts +2 -2
  408. package/lib/browser/tree/test/tree-test-container.js +52 -52
  409. package/lib/browser/tree/tree-compression/compressed-tree-expansion-service.d.ts +8 -8
  410. package/lib/browser/tree/tree-compression/compressed-tree-expansion-service.js +67 -67
  411. package/lib/browser/tree/tree-compression/compressed-tree-model.d.ts +23 -23
  412. package/lib/browser/tree/tree-compression/compressed-tree-model.js +97 -97
  413. package/lib/browser/tree/tree-compression/compressed-tree-widget.d.ts +38 -38
  414. package/lib/browser/tree/tree-compression/compressed-tree-widget.js +198 -198
  415. package/lib/browser/tree/tree-compression/index.d.ts +4 -4
  416. package/lib/browser/tree/tree-compression/index.js +31 -31
  417. package/lib/browser/tree/tree-compression/tree-compression-service.d.ts +58 -58
  418. package/lib/browser/tree/tree-compression/tree-compression-service.js +103 -103
  419. package/lib/browser/tree/tree-consistency.spec.d.ts +1 -1
  420. package/lib/browser/tree/tree-consistency.spec.js +104 -104
  421. package/lib/browser/tree/tree-container.d.ts +51 -51
  422. package/lib/browser/tree/tree-container.js +115 -115
  423. package/lib/browser/tree/tree-container.spec.d.ts +1 -1
  424. package/lib/browser/tree/tree-container.spec.js +45 -45
  425. package/lib/browser/tree/tree-decorator.d.ts +143 -143
  426. package/lib/browser/tree/tree-decorator.js +123 -123
  427. package/lib/browser/tree/tree-decorator.spec.d.ts +1 -1
  428. package/lib/browser/tree/tree-decorator.spec.js +145 -145
  429. package/lib/browser/tree/tree-expansion.d.ts +65 -65
  430. package/lib/browser/tree/tree-expansion.js +132 -132
  431. package/lib/browser/tree/tree-expansion.spec.d.ts +1 -1
  432. package/lib/browser/tree/tree-expansion.spec.js +155 -155
  433. package/lib/browser/tree/tree-focus-service.d.ts +19 -19
  434. package/lib/browser/tree/tree-focus-service.js +61 -61
  435. package/lib/browser/tree/tree-iterator.d.ts +94 -94
  436. package/lib/browser/tree/tree-iterator.js +223 -223
  437. package/lib/browser/tree/tree-iterator.spec.d.ts +1 -1
  438. package/lib/browser/tree/tree-iterator.spec.js +150 -150
  439. package/lib/browser/tree/tree-label-provider.d.ts +8 -8
  440. package/lib/browser/tree/tree-label-provider.js +44 -44
  441. package/lib/browser/tree/tree-model.d.ts +202 -178
  442. package/lib/browser/tree/tree-model.d.ts.map +1 -1
  443. package/lib/browser/tree/tree-model.js +403 -357
  444. package/lib/browser/tree/tree-model.js.map +1 -1
  445. package/lib/browser/tree/tree-navigation.d.ts +10 -10
  446. package/lib/browser/tree/tree-navigation.js +62 -62
  447. package/lib/browser/tree/tree-preference.d.ts +11 -0
  448. package/lib/browser/tree/tree-preference.d.ts.map +1 -0
  449. package/lib/browser/tree/tree-preference.js +47 -0
  450. package/lib/browser/tree/tree-preference.js.map +1 -0
  451. package/lib/browser/tree/tree-search.d.ts +36 -36
  452. package/lib/browser/tree/tree-search.js +138 -138
  453. package/lib/browser/tree/tree-selectable.spec.d.ts +2 -0
  454. package/lib/browser/tree/tree-selectable.spec.d.ts.map +1 -0
  455. package/lib/browser/tree/tree-selectable.spec.js +147 -0
  456. package/lib/browser/tree/tree-selectable.spec.js.map +1 -0
  457. package/lib/browser/tree/tree-selection-impl.d.ts +44 -44
  458. package/lib/browser/tree/tree-selection-impl.js +166 -166
  459. package/lib/browser/tree/tree-selection-state.d.ts +48 -48
  460. package/lib/browser/tree/tree-selection-state.js +227 -227
  461. package/lib/browser/tree/tree-selection-state.spec.d.ts +1 -1
  462. package/lib/browser/tree/tree-selection-state.spec.js +420 -420
  463. package/lib/browser/tree/tree-selection.d.ts +86 -86
  464. package/lib/browser/tree/tree-selection.js +86 -86
  465. package/lib/browser/tree/tree-view-welcome-widget.d.ts +45 -45
  466. package/lib/browser/tree/tree-view-welcome-widget.js +200 -200
  467. package/lib/browser/tree/tree-widget-selection.d.ts +11 -11
  468. package/lib/browser/tree/tree-widget-selection.js +46 -46
  469. package/lib/browser/tree/tree-widget.d.ts +559 -556
  470. package/lib/browser/tree/tree-widget.d.ts.map +1 -1
  471. package/lib/browser/tree/tree-widget.js +1363 -1342
  472. package/lib/browser/tree/tree-widget.js.map +1 -1
  473. package/lib/browser/tree/tree.d.ts +180 -180
  474. package/lib/browser/tree/tree.d.ts.map +1 -1
  475. package/lib/browser/tree/tree.js +296 -293
  476. package/lib/browser/tree/tree.js.map +1 -1
  477. package/lib/browser/tree/tree.spec.d.ts +1 -1
  478. package/lib/browser/tree/tree.spec.js +226 -226
  479. package/lib/browser/user-working-directory-provider.d.ts +23 -23
  480. package/lib/browser/user-working-directory-provider.js +84 -84
  481. package/lib/browser/view-container.d.ts +312 -312
  482. package/lib/browser/view-container.js +1466 -1466
  483. package/lib/browser/widget-decoration.d.ts +299 -299
  484. package/lib/browser/widget-decoration.js +140 -140
  485. package/lib/browser/widget-manager.d.ts +172 -163
  486. package/lib/browser/widget-manager.d.ts.map +1 -1
  487. package/lib/browser/widget-manager.js +230 -207
  488. package/lib/browser/widget-manager.js.map +1 -1
  489. package/lib/browser/widget-manager.spec.d.ts +1 -1
  490. package/lib/browser/widget-manager.spec.js +91 -91
  491. package/lib/browser/widget-open-handler.d.ts +88 -88
  492. package/lib/browser/widget-open-handler.js +145 -145
  493. package/lib/browser/widgets/alert-message.d.ts +23 -23
  494. package/lib/browser/widgets/alert-message.js +38 -38
  495. package/lib/browser/widgets/enhanced-preview-widget.d.ts +6 -6
  496. package/lib/browser/widgets/enhanced-preview-widget.js +26 -26
  497. package/lib/browser/widgets/extractable-widget.d.ts +13 -13
  498. package/lib/browser/widgets/extractable-widget.js +26 -26
  499. package/lib/browser/widgets/index.d.ts +4 -4
  500. package/lib/browser/widgets/index.js +31 -31
  501. package/lib/browser/widgets/previewable-widget.d.ts +8 -8
  502. package/lib/browser/widgets/previewable-widget.js +30 -30
  503. package/lib/browser/widgets/react-renderer.d.ts +14 -14
  504. package/lib/browser/widgets/react-renderer.js +59 -59
  505. package/lib/browser/widgets/react-widget.d.ts +16 -16
  506. package/lib/browser/widgets/react-widget.js +57 -57
  507. package/lib/browser/widgets/select-component.d.ts +53 -53
  508. package/lib/browser/widgets/select-component.d.ts.map +1 -1
  509. package/lib/browser/widgets/select-component.js +307 -306
  510. package/lib/browser/widgets/select-component.js.map +1 -1
  511. package/lib/browser/widgets/widget.d.ts +108 -106
  512. package/lib/browser/widgets/widget.d.ts.map +1 -1
  513. package/lib/browser/widgets/widget.js +385 -377
  514. package/lib/browser/widgets/widget.js.map +1 -1
  515. package/lib/browser/window/browser-window-module.d.ts +3 -3
  516. package/lib/browser/window/browser-window-module.js +32 -32
  517. package/lib/browser/window/default-secondary-window-service.d.ts +25 -25
  518. package/lib/browser/window/default-secondary-window-service.js +198 -198
  519. package/lib/browser/window/default-window-service.d.ts +49 -49
  520. package/lib/browser/window/default-window-service.js +172 -172
  521. package/lib/browser/window/default-window-service.spec.d.ts +1 -1
  522. package/lib/browser/window/default-window-service.spec.js +80 -80
  523. package/lib/browser/window/secondary-window-service.d.ts +20 -20
  524. package/lib/browser/window/secondary-window-service.js +19 -19
  525. package/lib/browser/window/test/mock-window-service.d.ts +10 -10
  526. package/lib/browser/window/test/mock-window-service.js +38 -38
  527. package/lib/browser/window/window-service.d.ts +45 -45
  528. package/lib/browser/window/window-service.js +22 -22
  529. package/lib/browser/window/window-title-service.d.ts +31 -31
  530. package/lib/browser/window/window-title-service.js +120 -120
  531. package/lib/browser/window/window-title-updater.d.ts +19 -19
  532. package/lib/browser/window/window-title-updater.js +107 -107
  533. package/lib/browser/window-contribution.d.ts +14 -14
  534. package/lib/browser/window-contribution.js +70 -70
  535. package/lib/browser-only/frontend-only-application-module.d.ts +5 -0
  536. package/lib/browser-only/frontend-only-application-module.d.ts.map +1 -0
  537. package/lib/browser-only/frontend-only-application-module.js +115 -0
  538. package/lib/browser-only/frontend-only-application-module.js.map +1 -0
  539. package/lib/browser-only/i18n/i18n-frontend-only-module.d.ts +4 -0
  540. package/lib/browser-only/i18n/i18n-frontend-only-module.d.ts.map +1 -0
  541. package/lib/browser-only/i18n/i18n-frontend-only-module.js +35 -0
  542. package/lib/browser-only/i18n/i18n-frontend-only-module.js.map +1 -0
  543. package/lib/browser-only/logger-frontend-only-module.d.ts +3 -0
  544. package/lib/browser-only/logger-frontend-only-module.d.ts.map +1 -0
  545. package/lib/browser-only/logger-frontend-only-module.js +61 -0
  546. package/lib/browser-only/logger-frontend-only-module.js.map +1 -0
  547. package/lib/browser-only/messaging/frontend-only-service-connection-provider.d.ts +14 -0
  548. package/lib/browser-only/messaging/frontend-only-service-connection-provider.d.ts.map +1 -0
  549. package/lib/browser-only/messaging/frontend-only-service-connection-provider.js +57 -0
  550. package/lib/browser-only/messaging/frontend-only-service-connection-provider.js.map +1 -0
  551. package/lib/browser-only/messaging/messaging-frontend-only-module.d.ts +3 -0
  552. package/lib/browser-only/messaging/messaging-frontend-only-module.d.ts.map +1 -0
  553. package/lib/browser-only/messaging/messaging-frontend-only-module.js +48 -0
  554. package/lib/browser-only/messaging/messaging-frontend-only-module.js.map +1 -0
  555. package/lib/browser-only/preload/frontend-only-preload-module.d.ts +4 -0
  556. package/lib/browser-only/preload/frontend-only-preload-module.d.ts.map +1 -0
  557. package/lib/browser-only/preload/frontend-only-preload-module.js +52 -0
  558. package/lib/browser-only/preload/frontend-only-preload-module.js.map +1 -0
  559. package/lib/common/accessibility.d.ts +16 -16
  560. package/lib/common/accessibility.js +17 -17
  561. package/lib/common/application-error.d.ts +20 -20
  562. package/lib/common/application-error.js +62 -62
  563. package/lib/common/application-error.spec.d.ts +1 -1
  564. package/lib/common/application-error.spec.js +26 -26
  565. package/lib/common/application-protocol.d.ts +20 -19
  566. package/lib/common/application-protocol.d.ts.map +1 -1
  567. package/lib/common/application-protocol.js +20 -20
  568. package/lib/common/array-utils.d.ts +55 -55
  569. package/lib/common/array-utils.js +118 -118
  570. package/lib/common/buffer.d.ts +43 -43
  571. package/lib/common/buffer.js +205 -205
  572. package/lib/common/cancellation.d.ts +24 -24
  573. package/lib/common/cancellation.js +142 -142
  574. package/lib/common/char-code.d.ts +401 -401
  575. package/lib/common/char-code.js +22 -22
  576. package/lib/common/collections.d.ts +29 -29
  577. package/lib/common/collections.js +121 -121
  578. package/lib/common/color.d.ts +71 -71
  579. package/lib/common/color.js +43 -43
  580. package/lib/common/command.d.ts +232 -232
  581. package/lib/common/command.js +364 -364
  582. package/lib/common/command.spec.d.ts +1 -1
  583. package/lib/common/command.spec.js +173 -173
  584. package/lib/common/contribution-filter/contribution-filter-registry.d.ts +17 -17
  585. package/lib/common/contribution-filter/contribution-filter-registry.js +88 -88
  586. package/lib/common/contribution-filter/contribution-filter.d.ts +41 -41
  587. package/lib/common/contribution-filter/contribution-filter.js +20 -20
  588. package/lib/common/contribution-filter/filter.d.ts +6 -6
  589. package/lib/common/contribution-filter/filter.js +19 -19
  590. package/lib/common/contribution-filter/index.d.ts +3 -3
  591. package/lib/common/contribution-filter/index.js +30 -30
  592. package/lib/common/contribution-provider.d.ts +20 -20
  593. package/lib/common/contribution-provider.js +82 -82
  594. package/lib/common/disposable.d.ts +80 -43
  595. package/lib/common/disposable.d.ts.map +1 -1
  596. package/lib/common/disposable.js +173 -120
  597. package/lib/common/disposable.js.map +1 -1
  598. package/lib/common/disposable.spec.d.ts +1 -1
  599. package/lib/common/disposable.spec.js +80 -29
  600. package/lib/common/disposable.spec.js.map +1 -1
  601. package/lib/common/encoding-service.d.ts +38 -38
  602. package/lib/common/encoding-service.js +307 -307
  603. package/lib/common/encodings.d.ts +7 -7
  604. package/lib/common/encodings.js +25 -25
  605. package/lib/common/env-variables/env-variables-protocol.d.ts +20 -20
  606. package/lib/common/env-variables/env-variables-protocol.js +20 -20
  607. package/lib/common/env-variables/index.d.ts +1 -1
  608. package/lib/common/env-variables/index.js +28 -28
  609. package/lib/common/event.d.ts +115 -115
  610. package/lib/common/event.js +385 -385
  611. package/lib/common/event.spec.d.ts +1 -1
  612. package/lib/common/event.spec.js +29 -29
  613. package/lib/{node → common}/file-uri.d.ts +14 -14
  614. package/lib/common/file-uri.d.ts.map +1 -0
  615. package/lib/{node → common}/file-uri.js +62 -62
  616. package/lib/common/file-uri.js.map +1 -0
  617. package/lib/common/frontend-application-state.d.ts +15 -15
  618. package/lib/common/frontend-application-state.js +33 -33
  619. package/lib/common/glob.d.ts +50 -50
  620. package/lib/common/glob.js +591 -591
  621. package/lib/common/hash.d.ts +7 -7
  622. package/lib/common/hash.js +84 -84
  623. package/lib/common/i18n/localization-server.d.ts +6 -6
  624. package/lib/common/i18n/localization-server.js +20 -20
  625. package/lib/common/i18n/localization.d.ts +34 -34
  626. package/lib/common/i18n/localization.js +59 -59
  627. package/lib/common/index.d.ts +35 -34
  628. package/lib/common/index.d.ts.map +1 -1
  629. package/lib/common/index.js +65 -64
  630. package/lib/common/index.js.map +1 -1
  631. package/lib/common/json-schema.d.ts +72 -72
  632. package/lib/common/json-schema.js +17 -17
  633. package/lib/common/key-store.d.ts +12 -12
  634. package/lib/common/key-store.js +20 -20
  635. package/lib/common/keybinding.d.ts +75 -75
  636. package/lib/common/keybinding.js +113 -113
  637. package/lib/common/keyboard/keyboard-layout-provider.d.ts +26 -26
  638. package/lib/common/keyboard/keyboard-layout-provider.js +22 -22
  639. package/lib/common/keys.d.ts +253 -253
  640. package/lib/common/keys.js +634 -634
  641. package/lib/common/label-protocol.d.ts +13 -13
  642. package/lib/common/label-protocol.js +17 -17
  643. package/lib/common/logger-protocol.d.ts +41 -41
  644. package/lib/common/logger-protocol.js +105 -105
  645. package/lib/common/logger-watcher.d.ts +9 -9
  646. package/lib/common/logger-watcher.js +54 -54
  647. package/lib/common/logger.d.ts +207 -207
  648. package/lib/common/logger.js +212 -212
  649. package/lib/common/logger.spec.d.ts +1 -1
  650. package/lib/common/logger.spec.js +41 -41
  651. package/lib/common/lsp-types.d.ts +9 -9
  652. package/lib/common/lsp-types.js +30 -30
  653. package/lib/common/markdown-rendering/icon-utilities.d.ts +7 -7
  654. package/lib/common/markdown-rendering/icon-utilities.js +32 -32
  655. package/lib/common/markdown-rendering/index.d.ts +2 -2
  656. package/lib/common/markdown-rendering/index.js +29 -29
  657. package/lib/common/markdown-rendering/markdown-string.d.ts +46 -43
  658. package/lib/common/markdown-rendering/markdown-string.d.ts.map +1 -1
  659. package/lib/common/markdown-rendering/markdown-string.js +126 -126
  660. package/lib/common/markdown-rendering/markdown-string.js.map +1 -1
  661. package/lib/common/menu/action-menu-node.d.ts +19 -19
  662. package/lib/common/menu/action-menu-node.js +56 -56
  663. package/lib/common/menu/composite-menu-node.d.ts +46 -46
  664. package/lib/common/menu/composite-menu-node.js +93 -93
  665. package/lib/common/menu/index.d.ts +5 -5
  666. package/lib/common/menu/index.js +32 -32
  667. package/lib/common/menu/menu-adapter.d.ts +35 -35
  668. package/lib/common/menu/menu-adapter.js +100 -100
  669. package/lib/common/menu/menu-model-registry.d.ts +145 -145
  670. package/lib/common/menu/menu-model-registry.d.ts.map +1 -1
  671. package/lib/common/menu/menu-model-registry.js +286 -272
  672. package/lib/common/menu/menu-model-registry.js.map +1 -1
  673. package/lib/common/menu/menu-types.d.ts +148 -148
  674. package/lib/common/menu/menu-types.js +93 -93
  675. package/lib/common/menu/menu.spec.d.ts +1 -1
  676. package/lib/common/menu/menu.spec.js +96 -69
  677. package/lib/common/menu/menu.spec.js.map +1 -1
  678. package/lib/common/message-rpc/channel.d.ts +123 -123
  679. package/lib/common/message-rpc/channel.js +230 -230
  680. package/lib/common/message-rpc/channel.spec.d.ts +8 -8
  681. package/lib/common/message-rpc/channel.spec.js +79 -79
  682. package/lib/common/message-rpc/index.d.ts +3 -3
  683. package/lib/common/message-rpc/index.js +24 -24
  684. package/lib/common/message-rpc/message-buffer.d.ts +51 -51
  685. package/lib/common/message-rpc/message-buffer.js +59 -59
  686. package/lib/common/message-rpc/msg-pack-extension-manager.d.ts +22 -22
  687. package/lib/common/message-rpc/msg-pack-extension-manager.js +57 -57
  688. package/lib/common/message-rpc/rpc-message-encoder.d.ts +103 -103
  689. package/lib/common/message-rpc/rpc-message-encoder.js +113 -113
  690. package/lib/common/message-rpc/rpc-message-encoder.spec.d.ts +1 -1
  691. package/lib/common/message-rpc/rpc-message-encoder.spec.js +58 -58
  692. package/lib/common/message-rpc/rpc-protocol.d.ts +67 -65
  693. package/lib/common/message-rpc/rpc-protocol.d.ts.map +1 -1
  694. package/lib/common/message-rpc/rpc-protocol.js +209 -191
  695. package/lib/common/message-rpc/rpc-protocol.js.map +1 -1
  696. package/lib/common/message-rpc/uint8-array-message-buffer.d.ts +52 -52
  697. package/lib/common/message-rpc/uint8-array-message-buffer.js +174 -174
  698. package/lib/common/message-rpc/uint8-array-message-buffer.spec.d.ts +1 -1
  699. package/lib/common/message-rpc/uint8-array-message-buffer.spec.js +38 -38
  700. package/lib/common/message-service-protocol.d.ts +110 -110
  701. package/lib/common/message-service-protocol.js +78 -78
  702. package/lib/common/message-service.d.ts +134 -134
  703. package/lib/common/message-service.js +162 -162
  704. package/lib/common/messaging/connection-error-handler.d.ts +28 -28
  705. package/lib/common/messaging/connection-error-handler.js +47 -47
  706. package/lib/common/messaging/connection-management.d.ts +24 -24
  707. package/lib/common/messaging/connection-management.js +37 -37
  708. package/lib/common/messaging/handler.d.ts +7 -7
  709. package/lib/common/messaging/handler.js +20 -20
  710. package/lib/common/messaging/index.d.ts +3 -3
  711. package/lib/common/messaging/index.js +30 -30
  712. package/lib/common/messaging/proxy-factory.d.ts +180 -180
  713. package/lib/common/messaging/proxy-factory.d.ts.map +1 -1
  714. package/lib/common/messaging/proxy-factory.js +280 -287
  715. package/lib/common/messaging/proxy-factory.js.map +1 -1
  716. package/lib/common/messaging/proxy-factory.spec.d.ts +1 -1
  717. package/lib/common/messaging/proxy-factory.spec.js +99 -99
  718. package/lib/common/messaging/socket-write-buffer.d.ts +10 -10
  719. package/lib/common/messaging/socket-write-buffer.js +49 -49
  720. package/lib/common/messaging/web-socket-channel.d.ts +19 -19
  721. package/lib/common/messaging/web-socket-channel.js +64 -64
  722. package/lib/common/nls.d.ts +15 -15
  723. package/lib/common/nls.js +133 -133
  724. package/lib/common/numbers.d.ts +5 -5
  725. package/lib/common/numbers.js +23 -23
  726. package/lib/common/objects.d.ts +8 -8
  727. package/lib/common/objects.js +118 -118
  728. package/lib/common/objects.spec.d.ts +1 -1
  729. package/lib/common/objects.spec.js +101 -101
  730. package/lib/common/os.d.ts +31 -31
  731. package/lib/common/os.js +73 -73
  732. package/lib/common/path.d.ts +93 -93
  733. package/lib/common/path.js +307 -307
  734. package/lib/common/path.spec.d.ts +1 -1
  735. package/lib/common/path.spec.js +350 -350
  736. package/lib/common/paths.d.ts +24 -24
  737. package/lib/common/paths.js +226 -226
  738. package/lib/common/performance/index.d.ts +3 -3
  739. package/lib/common/performance/index.js +30 -30
  740. package/lib/common/performance/measurement-protocol.d.ts +64 -64
  741. package/lib/common/performance/measurement-protocol.js +78 -78
  742. package/lib/common/performance/measurement.d.ts +111 -111
  743. package/lib/common/performance/measurement.js +17 -17
  744. package/lib/common/performance/stopwatch.d.ts +75 -75
  745. package/lib/common/performance/stopwatch.js +156 -156
  746. package/lib/common/preferences/preference-schema.d.ts +52 -52
  747. package/lib/common/preferences/preference-schema.js +58 -58
  748. package/lib/common/preferences/preference-scope.d.ts +19 -19
  749. package/lib/common/preferences/preference-scope.js +71 -71
  750. package/lib/common/preferences/preference-scope.spec.d.ts +1 -1
  751. package/lib/common/preferences/preference-scope.spec.js +44 -44
  752. package/lib/common/prioritizeable.d.ts +16 -16
  753. package/lib/common/prioritizeable.js +55 -55
  754. package/lib/common/progress-service-protocol.d.ts +13 -13
  755. package/lib/common/progress-service-protocol.js +19 -19
  756. package/lib/common/progress-service.d.ts +13 -13
  757. package/lib/common/progress-service.js +96 -96
  758. package/lib/common/promise-util.d.ts +51 -51
  759. package/lib/common/promise-util.js +132 -132
  760. package/lib/common/promise-util.spec.d.ts +1 -1
  761. package/lib/common/promise-util.spec.js +55 -55
  762. package/lib/common/quick-pick-service.d.ts +269 -280
  763. package/lib/common/quick-pick-service.d.ts.map +1 -1
  764. package/lib/common/quick-pick-service.js +133 -158
  765. package/lib/common/quick-pick-service.js.map +1 -1
  766. package/lib/common/reference.d.ts +95 -40
  767. package/lib/common/reference.d.ts.map +1 -1
  768. package/lib/common/reference.js +207 -152
  769. package/lib/common/reference.js.map +1 -1
  770. package/lib/common/reference.spec.d.ts +1 -1
  771. package/lib/common/reference.spec.js +125 -125
  772. package/lib/common/resource.d.ts +207 -205
  773. package/lib/common/resource.d.ts.map +1 -1
  774. package/lib/common/resource.js +333 -333
  775. package/lib/common/resource.js.map +1 -1
  776. package/lib/common/selection-command-handler.d.ts +24 -24
  777. package/lib/common/selection-command-handler.js +83 -83
  778. package/lib/common/selection-service.d.ts +18 -18
  779. package/lib/common/selection-service.js +48 -48
  780. package/lib/common/selection-service.spec.d.ts +1 -1
  781. package/lib/common/selection-service.spec.js +38 -38
  782. package/lib/common/selection.d.ts +9 -9
  783. package/lib/common/selection.js +47 -47
  784. package/lib/common/severity.d.ts +15 -15
  785. package/lib/common/severity.js +113 -113
  786. package/lib/common/stream.d.ts +176 -176
  787. package/lib/common/stream.js +474 -474
  788. package/lib/common/strings.d.ts +24 -24
  789. package/lib/common/strings.js +215 -215
  790. package/lib/common/telemetry.d.ts +19 -19
  791. package/lib/common/telemetry.js +24 -24
  792. package/lib/common/ternary-search-tree.d.ts +50 -50
  793. package/lib/common/ternary-search-tree.js +381 -381
  794. package/lib/common/test/expect.d.ts +2 -2
  795. package/lib/common/test/expect.js +34 -34
  796. package/lib/common/test/mock-logger.d.ts +27 -27
  797. package/lib/common/test/mock-logger.js +104 -104
  798. package/lib/common/test/mock-menu.d.ts +7 -7
  799. package/lib/common/test/mock-menu.js +34 -34
  800. package/lib/common/test/mock-resource-provider.d.ts +6 -6
  801. package/lib/common/test/mock-resource-provider.js +44 -44
  802. package/lib/common/theme.d.ts +40 -15
  803. package/lib/common/theme.d.ts.map +1 -1
  804. package/lib/common/theme.js +22 -22
  805. package/lib/common/theme.js.map +1 -1
  806. package/lib/common/types.d.ts +58 -58
  807. package/lib/common/types.js +126 -126
  808. package/lib/common/types.spec.d.ts +1 -1
  809. package/lib/common/types.spec.js +73 -73
  810. package/lib/common/uri-command-handler.d.ts +53 -53
  811. package/lib/common/uri-command-handler.js +99 -99
  812. package/lib/common/uri-command-handler.spec.d.ts +1 -1
  813. package/lib/common/uri-command-handler.spec.js +80 -80
  814. package/lib/common/uri.d.ts +87 -86
  815. package/lib/common/uri.d.ts.map +1 -1
  816. package/lib/common/uri.js +236 -236
  817. package/lib/common/uri.js.map +1 -1
  818. package/lib/common/uri.spec.d.ts +1 -1
  819. package/lib/common/uri.spec.js +230 -230
  820. package/lib/common/uuid.d.ts +8 -2
  821. package/lib/common/uuid.d.ts.map +1 -1
  822. package/lib/common/uuid.js +44 -85
  823. package/lib/common/uuid.js.map +1 -1
  824. package/lib/common/version.d.ts +1 -1
  825. package/lib/common/version.js +19 -19
  826. package/lib/common/view-column.d.ts +17 -17
  827. package/lib/common/view-column.js +36 -36
  828. package/lib/common/window.d.ts +16 -16
  829. package/lib/common/window.js +22 -22
  830. package/lib/electron-browser/electron-clipboard-service.d.ts +5 -5
  831. package/lib/electron-browser/electron-clipboard-service.js +38 -38
  832. package/lib/electron-browser/keyboard/electron-keyboard-layout-change-notifier.d.ts +11 -11
  833. package/lib/electron-browser/keyboard/electron-keyboard-layout-change-notifier.js +54 -54
  834. package/lib/electron-browser/keyboard/electron-keyboard-module.d.ts +3 -3
  835. package/lib/electron-browser/keyboard/electron-keyboard-module.js +26 -26
  836. package/lib/electron-browser/menu/electron-context-menu-renderer.d.ts +30 -30
  837. package/lib/electron-browser/menu/electron-context-menu-renderer.js +137 -137
  838. package/lib/electron-browser/menu/electron-main-menu-factory.d.ts +59 -59
  839. package/lib/electron-browser/menu/electron-main-menu-factory.js +282 -282
  840. package/lib/electron-browser/menu/electron-menu-contribution.d.ts +78 -77
  841. package/lib/electron-browser/menu/electron-menu-contribution.d.ts.map +1 -1
  842. package/lib/electron-browser/menu/electron-menu-contribution.js +482 -473
  843. package/lib/electron-browser/menu/electron-menu-contribution.js.map +1 -1
  844. package/lib/electron-browser/menu/electron-menu-module.d.ts +3 -3
  845. package/lib/electron-browser/menu/electron-menu-module.js +39 -39
  846. package/lib/electron-browser/messaging/electron-frontend-id-provider.d.ts +4 -4
  847. package/lib/electron-browser/messaging/electron-frontend-id-provider.js +34 -34
  848. package/lib/electron-browser/messaging/electron-ipc-connection-source.d.ts +23 -23
  849. package/lib/electron-browser/messaging/electron-ipc-connection-source.js +64 -64
  850. package/lib/electron-browser/messaging/electron-local-ws-connection-source.d.ts +6 -6
  851. package/lib/electron-browser/messaging/electron-local-ws-connection-source.js +54 -54
  852. package/lib/electron-browser/messaging/electron-messaging-frontend-module.d.ts +2 -2
  853. package/lib/electron-browser/messaging/electron-messaging-frontend-module.js +75 -75
  854. package/lib/electron-browser/messaging/electron-messaging-frontend-module.js.map +1 -1
  855. package/lib/electron-browser/messaging/electron-ws-connection-source.d.ts +11 -11
  856. package/lib/electron-browser/messaging/electron-ws-connection-source.js +50 -50
  857. package/lib/electron-browser/preload.d.ts +1 -1
  858. package/lib/electron-browser/preload.js +201 -201
  859. package/lib/electron-browser/request/electron-browser-request-module.d.ts +18 -18
  860. package/lib/electron-browser/request/electron-browser-request-module.js +26 -26
  861. package/lib/electron-browser/token/electron-token-frontend-module.d.ts +3 -3
  862. package/lib/electron-browser/token/electron-token-frontend-module.js +22 -22
  863. package/lib/electron-browser/window/electron-frontend-application-state.d.ts +4 -4
  864. package/lib/electron-browser/window/electron-frontend-application-state.js +36 -36
  865. package/lib/electron-browser/window/electron-secondary-window-service.d.ts +7 -7
  866. package/lib/electron-browser/window/electron-secondary-window-service.js +47 -47
  867. package/lib/electron-browser/window/electron-window-module.d.ts +3 -3
  868. package/lib/electron-browser/window/electron-window-module.js +39 -39
  869. package/lib/electron-browser/window/electron-window-preferences.d.ts +18 -18
  870. package/lib/electron-browser/window/electron-window-preferences.js +72 -72
  871. package/lib/electron-browser/window/electron-window-service.d.ts +29 -29
  872. package/lib/electron-browser/window/electron-window-service.js +114 -114
  873. package/lib/electron-common/electron-api.d.ts +104 -104
  874. package/lib/electron-common/electron-api.js +56 -56
  875. package/lib/electron-common/electron-main-window-service.d.ts +7 -7
  876. package/lib/electron-common/electron-main-window-service.js +20 -20
  877. package/lib/electron-common/electron-token.d.ts +10 -10
  878. package/lib/electron-common/electron-token.js +27 -27
  879. package/lib/electron-main/electron-api-main.d.ts +22 -22
  880. package/lib/electron-main/electron-api-main.js +294 -294
  881. package/lib/electron-main/electron-main-application-module.d.ts +3 -3
  882. package/lib/electron-main/electron-main-application-module.js +56 -56
  883. package/lib/electron-main/electron-main-application-module.js.map +1 -1
  884. package/lib/electron-main/electron-main-application.d.ts +159 -159
  885. package/lib/electron-main/electron-main-application.js +611 -611
  886. package/lib/electron-main/electron-main-application.js.map +1 -1
  887. package/lib/electron-main/electron-main-constants.d.ts +6 -6
  888. package/lib/electron-main/electron-main-constants.js +19 -19
  889. package/lib/electron-main/electron-main-window-service-impl.d.ts +8 -8
  890. package/lib/electron-main/electron-main-window-service-impl.js +54 -54
  891. package/lib/electron-main/electron-security-token-service.d.ts +5 -5
  892. package/lib/electron-main/electron-security-token-service.js +49 -49
  893. package/lib/electron-main/event-utils.d.ts +8 -8
  894. package/lib/electron-main/event-utils.js +33 -33
  895. package/lib/electron-main/messaging/electron-connection-handler.d.ts +5 -5
  896. package/lib/electron-main/messaging/electron-connection-handler.js +23 -23
  897. package/lib/electron-main/messaging/electron-messaging-contribution.d.ts +41 -41
  898. package/lib/electron-main/messaging/electron-messaging-contribution.js +150 -150
  899. package/lib/electron-main/messaging/electron-messaging-service.d.ts +17 -17
  900. package/lib/electron-main/messaging/electron-messaging-service.js +22 -22
  901. package/lib/electron-main/theia-electron-window.d.ts +53 -53
  902. package/lib/electron-main/theia-electron-window.js +194 -194
  903. package/lib/electron-main/theia-electron-window.js.map +1 -1
  904. package/lib/electron-node/hosting/electron-backend-hosting-module.d.ts +3 -3
  905. package/lib/electron-node/hosting/electron-backend-hosting-module.js +24 -24
  906. package/lib/electron-node/hosting/electron-ws-origin-validator.d.ts +8 -8
  907. package/lib/electron-node/hosting/electron-ws-origin-validator.js +48 -48
  908. package/lib/electron-node/keyboard/electron-backend-keyboard-module.d.ts +3 -3
  909. package/lib/electron-node/keyboard/electron-backend-keyboard-module.js +26 -26
  910. package/lib/electron-node/keyboard/electron-keyboard-layout-provider.d.ts +5 -5
  911. package/lib/electron-node/keyboard/electron-keyboard-layout-provider.js +41 -41
  912. package/lib/electron-node/request/electron-backend-request-module.d.ts +18 -18
  913. package/lib/electron-node/request/electron-backend-request-module.js +23 -23
  914. package/lib/electron-node/request/electron-backend-request-service.d.ts +22 -22
  915. package/lib/electron-node/request/electron-backend-request-service.js +86 -86
  916. package/lib/electron-node/token/electron-token-backend-contribution.d.ts +15 -15
  917. package/lib/electron-node/token/electron-token-backend-contribution.js +58 -58
  918. package/lib/electron-node/token/electron-token-backend-module.d.ts +3 -3
  919. package/lib/electron-node/token/electron-token-backend-module.js +28 -28
  920. package/lib/electron-node/token/electron-token-validator.d.ts +29 -29
  921. package/lib/electron-node/token/electron-token-validator.js +103 -103
  922. package/lib/node/application-server.d.ts +10 -9
  923. package/lib/node/application-server.d.ts.map +1 -1
  924. package/lib/node/application-server.js +63 -57
  925. package/lib/node/application-server.js.map +1 -1
  926. package/lib/node/backend-application-config-provider.d.ts +7 -7
  927. package/lib/node/backend-application-config-provider.js +45 -45
  928. package/lib/node/backend-application-config-provider.spec.d.ts +1 -1
  929. package/lib/node/backend-application-config-provider.spec.js +28 -28
  930. package/lib/node/backend-application-module.d.ts +2 -2
  931. package/lib/node/backend-application-module.js +108 -108
  932. package/lib/node/backend-application.d.ts +108 -108
  933. package/lib/node/backend-application.js +301 -301
  934. package/lib/node/backend-remote-service.d.ts +3 -3
  935. package/lib/node/backend-remote-service.js +34 -34
  936. package/lib/node/cli.d.ts +17 -17
  937. package/lib/node/cli.js +70 -70
  938. package/lib/node/cli.spec.d.ts +1 -1
  939. package/lib/node/cli.spec.js +89 -89
  940. package/lib/node/console-logger-server.d.ts +15 -15
  941. package/lib/node/console-logger-server.js +90 -90
  942. package/lib/node/console-logger-server.spec.d.ts +1 -1
  943. package/lib/node/console-logger-server.spec.js +69 -69
  944. package/lib/node/debug.d.ts +1 -1
  945. package/lib/node/debug.js +28 -28
  946. package/lib/node/dynamic-require.d.ts +7 -7
  947. package/lib/node/dynamic-require.js +56 -56
  948. package/lib/node/env-variables/env-variables-server.d.ts +23 -23
  949. package/lib/node/env-variables/env-variables-server.js +125 -125
  950. package/lib/node/env-variables/env-variables-server.js.map +1 -1
  951. package/lib/node/env-variables/index.d.ts +1 -1
  952. package/lib/node/env-variables/index.js +28 -28
  953. package/lib/node/environment-utils.d.ts +21 -21
  954. package/lib/node/environment-utils.js +77 -77
  955. package/lib/node/environment-utils.spec.d.ts +1 -1
  956. package/lib/node/environment-utils.spec.js +77 -77
  957. package/lib/node/file-uri.spec.d.ts +1 -1
  958. package/lib/node/file-uri.spec.js +66 -66
  959. package/lib/node/file-uri.spec.js.map +1 -1
  960. package/lib/node/filesystem-locking.d.ts +23 -23
  961. package/lib/node/filesystem-locking.js +70 -70
  962. package/lib/node/hosting/backend-application-hosts.d.ts +23 -23
  963. package/lib/node/hosting/backend-application-hosts.js +77 -77
  964. package/lib/node/hosting/backend-hosting-module.d.ts +3 -3
  965. package/lib/node/hosting/backend-hosting-module.js +26 -26
  966. package/lib/node/hosting/ws-origin-validator.d.ts +8 -8
  967. package/lib/node/hosting/ws-origin-validator.js +47 -47
  968. package/lib/node/i18n/i18n-backend-module.d.ts +3 -3
  969. package/lib/node/i18n/i18n-backend-module.js +38 -38
  970. package/lib/node/i18n/localization-contribution.d.ts +18 -18
  971. package/lib/node/i18n/localization-contribution.js +116 -116
  972. package/lib/node/i18n/localization-provider.d.ts +23 -23
  973. package/lib/node/i18n/localization-provider.js +114 -114
  974. package/lib/node/i18n/localization-server.d.ts +14 -14
  975. package/lib/node/i18n/localization-server.js +62 -62
  976. package/lib/node/i18n/theia-localization-contribution.d.ts +4 -4
  977. package/lib/node/i18n/theia-localization-contribution.js +45 -45
  978. package/lib/node/index.d.ts +6 -6
  979. package/lib/node/index.d.ts.map +1 -1
  980. package/lib/node/index.js +35 -35
  981. package/lib/node/index.js.map +1 -1
  982. package/lib/node/key-store-server.d.ts +27 -27
  983. package/lib/node/key-store-server.js +150 -150
  984. package/lib/node/logger-backend-module.d.ts +9 -9
  985. package/lib/node/logger-backend-module.js +78 -78
  986. package/lib/node/logger-cli-contribution.d.ts +33 -33
  987. package/lib/node/logger-cli-contribution.js +152 -152
  988. package/lib/node/logger-cli-contribution.spec.d.ts +1 -1
  989. package/lib/node/logger-cli-contribution.spec.js +207 -207
  990. package/lib/node/main.d.ts +7 -7
  991. package/lib/node/main.js +29 -29
  992. package/lib/node/messaging/binary-message-pipe.d.ts +44 -44
  993. package/lib/node/messaging/binary-message-pipe.js +151 -151
  994. package/lib/node/messaging/connection-container-module.d.ts +53 -53
  995. package/lib/node/messaging/connection-container-module.js +81 -81
  996. package/lib/node/messaging/default-messaging-service.d.ts +28 -28
  997. package/lib/node/messaging/default-messaging-service.js +139 -139
  998. package/lib/node/messaging/frontend-connection-service.d.ts +6 -6
  999. package/lib/node/messaging/frontend-connection-service.js +18 -18
  1000. package/lib/node/messaging/index.d.ts +3 -3
  1001. package/lib/node/messaging/index.js +30 -30
  1002. package/lib/node/messaging/ipc-bootstrap.d.ts +1 -1
  1003. package/lib/node/messaging/ipc-bootstrap.js +24 -24
  1004. package/lib/node/messaging/ipc-channel.d.ts +17 -17
  1005. package/lib/node/messaging/ipc-channel.js +69 -69
  1006. package/lib/node/messaging/ipc-connection-provider.d.ts +21 -21
  1007. package/lib/node/messaging/ipc-connection-provider.js +100 -100
  1008. package/lib/node/messaging/ipc-protocol.d.ts +19 -19
  1009. package/lib/node/messaging/ipc-protocol.js +68 -68
  1010. package/lib/node/messaging/messaging-backend-module.d.ts +2 -2
  1011. package/lib/node/messaging/messaging-backend-module.js +52 -52
  1012. package/lib/node/messaging/messaging-listeners.d.ts +27 -27
  1013. package/lib/node/messaging/messaging-listeners.js +53 -53
  1014. package/lib/node/messaging/messaging-service.d.ts +28 -28
  1015. package/lib/node/messaging/messaging-service.js +24 -24
  1016. package/lib/node/messaging/test/test-web-socket-channel.d.ts +12 -12
  1017. package/lib/node/messaging/test/test-web-socket-channel.js +62 -62
  1018. package/lib/node/messaging/websocket-endpoint.d.ts +20 -20
  1019. package/lib/node/messaging/websocket-endpoint.js +88 -88
  1020. package/lib/node/messaging/websocket-frontend-connection-service.d.ts +30 -29
  1021. package/lib/node/messaging/websocket-frontend-connection-service.d.ts.map +1 -1
  1022. package/lib/node/messaging/websocket-frontend-connection-service.js +177 -172
  1023. package/lib/node/messaging/websocket-frontend-connection-service.js.map +1 -1
  1024. package/lib/node/os-backend-provider.d.ts +4 -4
  1025. package/lib/node/os-backend-provider.js +35 -35
  1026. package/lib/node/performance/index.d.ts +2 -2
  1027. package/lib/node/performance/index.js +29 -29
  1028. package/lib/node/performance/measurement-backend-bindings.d.ts +19 -19
  1029. package/lib/node/performance/measurement-backend-bindings.js +30 -30
  1030. package/lib/node/performance/node-stopwatch.d.ts +20 -20
  1031. package/lib/node/performance/node-stopwatch.js +51 -51
  1032. package/lib/node/process-utils.d.ts +13 -13
  1033. package/lib/node/process-utils.js +110 -110
  1034. package/lib/node/process-utils.spec.d.ts +1 -1
  1035. package/lib/node/process-utils.spec.js +44 -44
  1036. package/lib/node/request/backend-request-facade.d.ts +22 -22
  1037. package/lib/node/request/backend-request-facade.js +49 -49
  1038. package/lib/node/request/backend-request-module.d.ts +18 -18
  1039. package/lib/node/request/backend-request-module.js +24 -24
  1040. package/lib/node/request/proxy-cli-contribution.d.ts +27 -27
  1041. package/lib/node/request/proxy-cli-contribution.js +72 -72
  1042. package/lib/node/ws-request-validators.d.ts +25 -25
  1043. package/lib/node/ws-request-validators.js +60 -60
  1044. package/package.json +13 -8
  1045. package/shared/ajv/index.d.ts +2 -2
  1046. package/shared/markdown-it.d.ts +2 -2
  1047. package/shared/markdown-it.js +1 -1
  1048. package/shared/reflect-metadata/index.d.ts +1 -1
  1049. package/shared/reflect-metadata/index.js +1 -1
  1050. package/shared/vscode-languageserver-types/index.d.ts +1 -1
  1051. package/src/browser/about-dialog.tsx +137 -137
  1052. package/src/browser/authentication-service.ts +456 -456
  1053. package/src/browser/breadcrumbs/breadcrumb-popup-container.ts +101 -101
  1054. package/src/browser/breadcrumbs/breadcrumb-renderer.tsx +41 -41
  1055. package/src/browser/breadcrumbs/breadcrumbs-constants.ts +79 -79
  1056. package/src/browser/breadcrumbs/breadcrumbs-renderer.tsx +185 -185
  1057. package/src/browser/breadcrumbs/breadcrumbs-service.ts +108 -108
  1058. package/src/browser/breadcrumbs/index.ts +21 -21
  1059. package/src/browser/browser-clipboard-service.ts +122 -122
  1060. package/src/browser/browser.ts +225 -220
  1061. package/src/browser/clipboard-service.ts +23 -23
  1062. package/src/browser/color-application-contribution.ts +101 -101
  1063. package/src/browser/color-registry.ts +60 -60
  1064. package/src/browser/command-open-handler.ts +54 -54
  1065. package/src/browser/common-frontend-contribution.ts +2526 -2526
  1066. package/src/browser/common-styling-participants.ts +361 -361
  1067. package/src/browser/connection-status-service.spec.ts +200 -200
  1068. package/src/browser/connection-status-service.ts +216 -216
  1069. package/src/browser/context-key-service.ts +142 -143
  1070. package/src/browser/context-menu-renderer.ts +124 -128
  1071. package/src/browser/core-preferences.ts +334 -328
  1072. package/src/browser/credentials-service.ts +106 -106
  1073. package/src/browser/decoration-style.ts +65 -65
  1074. package/src/browser/decorations-service.ts +209 -209
  1075. package/src/browser/dialogs/react-dialog.tsx +56 -56
  1076. package/src/browser/dialogs.ts +534 -534
  1077. package/src/browser/diff-uris.ts +117 -117
  1078. package/src/browser/encoding-registry.ts +97 -97
  1079. package/src/browser/endpoint.spec.ts +148 -148
  1080. package/src/browser/endpoint.ts +136 -136
  1081. package/src/browser/external-uri-service.ts +79 -79
  1082. package/src/browser/file-icons-js.d.ts +20 -20
  1083. package/src/browser/frontend-application-bindings.ts +62 -62
  1084. package/src/browser/frontend-application-config-provider.spec.ts +45 -45
  1085. package/src/browser/frontend-application-config-provider.ts +50 -50
  1086. package/src/browser/frontend-application-contribution.ts +110 -110
  1087. package/src/browser/frontend-application-module.ts +458 -457
  1088. package/src/browser/frontend-application-state.ts +74 -74
  1089. package/src/browser/frontend-application.ts +326 -326
  1090. package/src/browser/hover-service.ts +218 -218
  1091. package/src/browser/http-open-handler.ts +47 -47
  1092. package/src/browser/i18n/i18n-frontend-module.ts +27 -27
  1093. package/src/browser/i18n/language-quick-pick-service.ts +130 -130
  1094. package/src/browser/icon-registry.ts +87 -96
  1095. package/src/browser/icon-theme-contribution.ts +64 -64
  1096. package/src/browser/icon-theme-service.ts +217 -217
  1097. package/src/browser/icons/CollapseAll.svg +7 -7
  1098. package/src/browser/icons/CollapseAll_inverse.svg +7 -7
  1099. package/src/browser/icons/Refresh.svg +7 -7
  1100. package/src/browser/icons/Refresh_inverse.svg +7 -7
  1101. package/src/browser/icons/add-inverse.svg +4 -4
  1102. package/src/browser/icons/add.svg +4 -4
  1103. package/src/browser/icons/arrow-down-bright.svg +6 -6
  1104. package/src/browser/icons/arrow-down-dark.svg +6 -6
  1105. package/src/browser/icons/arrow-up-bright.svg +6 -6
  1106. package/src/browser/icons/arrow-up-dark.svg +6 -6
  1107. package/src/browser/icons/case-sensitive-dark.svg +16 -16
  1108. package/src/browser/icons/case-sensitive.svg +16 -16
  1109. package/src/browser/icons/chevron-right-dark.svg +5 -5
  1110. package/src/browser/icons/chevron-right-light.svg +6 -6
  1111. package/src/browser/icons/circle-bright.svg +7 -7
  1112. package/src/browser/icons/circle-dark.svg +7 -7
  1113. package/src/browser/icons/clear-search-results-dark.svg +7 -7
  1114. package/src/browser/icons/clear-search-results.svg +7 -7
  1115. package/src/browser/icons/close-all-bright.svg +7 -7
  1116. package/src/browser/icons/close-all-dark.svg +7 -7
  1117. package/src/browser/icons/close-bright.svg +7 -7
  1118. package/src/browser/icons/close-dark.svg +7 -7
  1119. package/src/browser/icons/collapse.svg +4 -4
  1120. package/src/browser/icons/edit-json-dark.svg +6 -6
  1121. package/src/browser/icons/edit-json.svg +6 -6
  1122. package/src/browser/icons/expand.svg +4 -4
  1123. package/src/browser/icons/loading-dark.svg +6 -6
  1124. package/src/browser/icons/loading-light.svg +6 -6
  1125. package/src/browser/icons/open-change-bright.svg +3 -3
  1126. package/src/browser/icons/open-change-dark.svg +4 -4
  1127. package/src/browser/icons/open-file-bright.svg +4 -4
  1128. package/src/browser/icons/open-file-dark.svg +4 -4
  1129. package/src/browser/icons/preview-bright.svg +3 -3
  1130. package/src/browser/icons/preview-dark.svg +3 -3
  1131. package/src/browser/icons/regex-dark.svg +10 -10
  1132. package/src/browser/icons/regex.svg +10 -10
  1133. package/src/browser/icons/remove-all-inverse.svg +4 -4
  1134. package/src/browser/icons/remove-all.svg +4 -4
  1135. package/src/browser/icons/replace-all-inverse.svg +13 -13
  1136. package/src/browser/icons/replace-all.svg +13 -13
  1137. package/src/browser/icons/replace-inverse.svg +15 -15
  1138. package/src/browser/icons/replace.svg +15 -15
  1139. package/src/browser/icons/whole-word-dark.svg +19 -19
  1140. package/src/browser/icons/whole-word.svg +19 -19
  1141. package/src/browser/index.ts +47 -47
  1142. package/src/browser/json-schema-store.ts +127 -127
  1143. package/src/browser/keybinding.spec.ts +553 -553
  1144. package/src/browser/keybinding.ts +756 -756
  1145. package/src/browser/keyboard/browser-keyboard-frontend-contribution.ts +108 -108
  1146. package/src/browser/keyboard/browser-keyboard-layout-provider.spec.ts +171 -171
  1147. package/src/browser/keyboard/browser-keyboard-layout-provider.ts +469 -469
  1148. package/src/browser/keyboard/browser-keyboard-module.ts +30 -30
  1149. package/src/browser/keyboard/index.ts +20 -20
  1150. package/src/browser/keyboard/keyboard-layout-service.spec.ts +121 -121
  1151. package/src/browser/keyboard/keyboard-layout-service.ts +455 -455
  1152. package/src/browser/keyboard/keys.spec.ts +258 -258
  1153. package/src/browser/keyboard/keys.ts +20 -20
  1154. package/src/browser/keys.ts +21 -21
  1155. package/src/browser/label-parser.spec.ts +165 -165
  1156. package/src/browser/label-parser.ts +108 -108
  1157. package/src/browser/label-provider.spec.ts +62 -62
  1158. package/src/browser/label-provider.ts +385 -385
  1159. package/src/browser/language-icon-provider.ts +55 -55
  1160. package/src/browser/language-service.ts +77 -77
  1161. package/src/browser/logger-frontend-module.ts +65 -65
  1162. package/src/browser/markdown-rendering/markdown-renderer.ts +98 -98
  1163. package/src/browser/menu/browser-context-menu-renderer.ts +47 -47
  1164. package/src/browser/menu/browser-menu-module.ts +28 -28
  1165. package/src/browser/menu/browser-menu-plugin.ts +484 -484
  1166. package/src/browser/menu/context-menu-context.ts +41 -41
  1167. package/src/browser/messaging/connection-source.ts +26 -26
  1168. package/src/browser/messaging/frontend-id-provider.ts +37 -37
  1169. package/src/browser/messaging/index.ts +17 -17
  1170. package/src/browser/messaging/messaging-frontend-module.ts +41 -41
  1171. package/src/browser/messaging/service-connection-provider.ts +126 -126
  1172. package/src/browser/messaging/ws-connection-provider.ts +48 -48
  1173. package/src/browser/messaging/ws-connection-source.ts +230 -210
  1174. package/src/browser/mime-service.ts +30 -30
  1175. package/src/browser/navigatable-types.ts +81 -81
  1176. package/src/browser/navigatable.ts +39 -39
  1177. package/src/browser/opener-service.spec.ts +49 -49
  1178. package/src/browser/opener-service.ts +146 -146
  1179. package/src/browser/performance/frontend-stopwatch.ts +65 -65
  1180. package/src/browser/performance/index.ts +18 -18
  1181. package/src/browser/performance/measurement-frontend-bindings.ts +31 -31
  1182. package/src/browser/preferences/index.ts +23 -23
  1183. package/src/browser/preferences/injectable-preference-proxy.ts +283 -283
  1184. package/src/browser/preferences/preference-configurations.ts +82 -82
  1185. package/src/browser/preferences/preference-contribution.ts +436 -436
  1186. package/src/browser/preferences/preference-language-override-service.ts +111 -111
  1187. package/src/browser/preferences/preference-provider.spec.ts +36 -36
  1188. package/src/browser/preferences/preference-provider.ts +277 -277
  1189. package/src/browser/preferences/preference-proxy.spec.ts +367 -367
  1190. package/src/browser/preferences/preference-proxy.ts +367 -367
  1191. package/src/browser/preferences/preference-schema-provider.spec.ts +130 -130
  1192. package/src/browser/preferences/preference-scope.ts +18 -18
  1193. package/src/browser/preferences/preference-service.spec.ts +613 -613
  1194. package/src/browser/preferences/preference-service.ts +594 -594
  1195. package/src/browser/preferences/preference-validation-service.spec.ts +334 -334
  1196. package/src/browser/preferences/preference-validation-service.ts +358 -358
  1197. package/src/browser/preferences/test/index.ts +19 -19
  1198. package/src/browser/preferences/test/mock-preference-provider.ts +50 -50
  1199. package/src/browser/preferences/test/mock-preference-proxy.ts +48 -48
  1200. package/src/browser/preferences/test/mock-preference-service.ts +63 -63
  1201. package/src/browser/preload/i18n-preload-contribution.ts +50 -50
  1202. package/src/browser/preload/os-preload-contribution.ts +37 -37
  1203. package/src/browser/preload/preload-module.ts +45 -45
  1204. package/src/browser/preload/preloader.ts +37 -37
  1205. package/src/browser/preload/theme-preload-contribution.ts +31 -31
  1206. package/src/browser/progress-bar-factory.ts +29 -29
  1207. package/src/browser/progress-bar.ts +76 -76
  1208. package/src/browser/progress-client.ts +53 -53
  1209. package/src/browser/progress-location-service.spec.ts +50 -50
  1210. package/src/browser/progress-location-service.ts +96 -96
  1211. package/src/browser/progress-status-bar-item.ts +83 -83
  1212. package/src/browser/quick-input/index.ts +23 -23
  1213. package/src/browser/quick-input/quick-access.ts +75 -75
  1214. package/src/browser/quick-input/quick-command-frontend-contribution.ts +89 -89
  1215. package/src/browser/quick-input/quick-command-service.ts +246 -246
  1216. package/src/browser/quick-input/quick-help-service.ts +87 -87
  1217. package/src/browser/quick-input/quick-input-frontend-contribution.ts +33 -33
  1218. package/src/browser/quick-input/quick-input-service.spec.ts +176 -176
  1219. package/src/browser/quick-input/quick-input-service.ts +17 -17
  1220. package/src/browser/quick-input/quick-pick-service-impl.ts +69 -69
  1221. package/src/browser/quick-input/quick-view-service.ts +83 -83
  1222. package/src/browser/request/browser-request-module.ts +23 -23
  1223. package/src/browser/request/browser-request-service.ts +172 -172
  1224. package/src/browser/resource-context-key.ts +77 -77
  1225. package/src/browser/save-resource-service.ts +60 -59
  1226. package/src/browser/saveable.ts +365 -365
  1227. package/src/browser/secondary-window-handler.ts +212 -212
  1228. package/src/browser/shell/additional-views-menu-widget.tsx +71 -71
  1229. package/src/browser/shell/application-shell-mouse-tracker.ts +103 -103
  1230. package/src/browser/shell/application-shell.ts +2254 -2249
  1231. package/src/browser/shell/current-widget-command-adapter.ts +57 -57
  1232. package/src/browser/shell/index.ts +23 -23
  1233. package/src/browser/shell/shell-layout-restorer.ts +399 -399
  1234. package/src/browser/shell/side-panel-handler.ts +793 -793
  1235. package/src/browser/shell/side-panel-toolbar.ts +111 -111
  1236. package/src/browser/shell/sidebar-bottom-menu-widget.tsx +39 -39
  1237. package/src/browser/shell/sidebar-menu-widget.tsx +140 -140
  1238. package/src/browser/shell/sidebar-top-menu-widget.tsx +26 -26
  1239. package/src/browser/shell/split-panels.ts +190 -190
  1240. package/src/browser/shell/tab-bar-decorator.ts +106 -76
  1241. package/src/browser/shell/tab-bar-toolbar/index.ts +19 -19
  1242. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar-menu-adapters.ts +31 -31
  1243. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar-registry.ts +256 -256
  1244. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar-types.ts +207 -207
  1245. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar.spec.ts +62 -62
  1246. package/src/browser/shell/tab-bar-toolbar/tab-bar-toolbar.tsx +423 -423
  1247. package/src/browser/shell/tab-bars.spec.ts +63 -63
  1248. package/src/browser/shell/tab-bars.ts +1481 -1449
  1249. package/src/browser/shell/theia-dock-panel.ts +255 -255
  1250. package/src/browser/shell/view-contribution.ts +177 -177
  1251. package/src/browser/source-tree/index.ts +19 -19
  1252. package/src/browser/source-tree/source-tree-widget.tsx +107 -107
  1253. package/src/browser/source-tree/source-tree.ts +146 -146
  1254. package/src/browser/source-tree/tree-source.ts +73 -73
  1255. package/src/browser/status-bar/index.ts +29 -29
  1256. package/src/browser/status-bar/status-bar-types.ts +97 -97
  1257. package/src/browser/status-bar/status-bar-view-model.ts +209 -209
  1258. package/src/browser/status-bar/status-bar.tsx +189 -189
  1259. package/src/browser/storage-service.spec.ts +76 -76
  1260. package/src/browser/storage-service.ts +129 -129
  1261. package/src/browser/style/about.css +36 -36
  1262. package/src/browser/style/alert-messages.css +62 -62
  1263. package/src/browser/style/ansi.css +88 -88
  1264. package/src/browser/style/breadcrumbs.css +130 -130
  1265. package/src/browser/style/dialog.css +126 -126
  1266. package/src/browser/style/dockpanel.css +76 -76
  1267. package/src/browser/style/hover-service.css +101 -101
  1268. package/src/browser/style/icons.css +61 -61
  1269. package/src/browser/style/index.css +351 -346
  1270. package/src/browser/style/materialcolors.css +278 -278
  1271. package/src/browser/style/menus.css +230 -230
  1272. package/src/browser/style/notification.css +39 -39
  1273. package/src/browser/style/os.css +87 -87
  1274. package/src/browser/style/progress-bar.css +43 -43
  1275. package/src/browser/style/quick-title-bar.css +45 -45
  1276. package/src/browser/style/scrollbars.css +172 -172
  1277. package/src/browser/style/search-box.css +123 -123
  1278. package/src/browser/style/select-component.css +107 -108
  1279. package/src/browser/style/sidepanel.css +364 -364
  1280. package/src/browser/style/status-bar.css +127 -127
  1281. package/src/browser/style/tabs.css +647 -641
  1282. package/src/browser/style/tooltip.css +28 -28
  1283. package/src/browser/style/tree-decorators.css +81 -81
  1284. package/src/browser/style/tree.css +232 -232
  1285. package/src/browser/style/view-container.css +194 -194
  1286. package/src/browser/style/widget.css +19 -19
  1287. package/src/browser/styling-service.ts +87 -87
  1288. package/src/browser/supported-encodings.ts +262 -262
  1289. package/src/browser/test/jsdom.ts +69 -69
  1290. package/src/browser/test/mock-connection-status-service.ts +33 -33
  1291. package/src/browser/test/mock-env-variables-server.ts +47 -47
  1292. package/src/browser/test/mock-opener-service.ts +34 -34
  1293. package/src/browser/test/mock-storage-service.ts +49 -49
  1294. package/src/browser/theming.ts +206 -206
  1295. package/src/browser/tooltip-service.tsx +96 -96
  1296. package/src/browser/tree/fuzzy-search.spec.ts +99 -99
  1297. package/src/browser/tree/fuzzy-search.ts +136 -136
  1298. package/src/browser/tree/index.ts +29 -28
  1299. package/src/browser/tree/search-box-debounce.ts +96 -96
  1300. package/src/browser/tree/search-box.ts +355 -355
  1301. package/src/browser/tree/test/mock-selectable-tree-model.ts +109 -0
  1302. package/src/browser/tree/test/mock-tree-model.ts +136 -136
  1303. package/src/browser/tree/test/tree-test-container.ts +50 -50
  1304. package/src/browser/tree/tree-compression/compressed-tree-expansion-service.ts +46 -46
  1305. package/src/browser/tree/tree-compression/compressed-tree-model.ts +88 -88
  1306. package/src/browser/tree/tree-compression/compressed-tree-widget.tsx +203 -203
  1307. package/src/browser/tree/tree-compression/index.ts +20 -20
  1308. package/src/browser/tree/tree-compression/tree-compression-service.ts +125 -125
  1309. package/src/browser/tree/tree-compression/tree-compression.css +28 -28
  1310. package/src/browser/tree/tree-consistency.spec.ts +105 -105
  1311. package/src/browser/tree/tree-container.spec.ts +45 -45
  1312. package/src/browser/tree/tree-container.ts +155 -155
  1313. package/src/browser/tree/tree-decorator.spec.ts +162 -162
  1314. package/src/browser/tree/tree-decorator.ts +238 -238
  1315. package/src/browser/tree/tree-expansion.spec.ts +173 -173
  1316. package/src/browser/tree/tree-expansion.ts +165 -165
  1317. package/src/browser/tree/tree-focus-service.ts +55 -55
  1318. package/src/browser/tree/tree-iterator.spec.ts +170 -170
  1319. package/src/browser/tree/tree-iterator.ts +256 -256
  1320. package/src/browser/tree/tree-label-provider.ts +40 -40
  1321. package/src/browser/tree/tree-model.ts +562 -488
  1322. package/src/browser/tree/tree-navigation.ts +58 -58
  1323. package/src/browser/tree/tree-preference.ts +50 -0
  1324. package/src/browser/tree/tree-search.ts +128 -128
  1325. package/src/browser/tree/tree-selectable.spec.ts +152 -0
  1326. package/src/browser/tree/tree-selection-impl.ts +176 -176
  1327. package/src/browser/tree/tree-selection-state.spec.ts +462 -462
  1328. package/src/browser/tree/tree-selection-state.ts +245 -245
  1329. package/src/browser/tree/tree-selection.ts +159 -159
  1330. package/src/browser/tree/tree-view-welcome-widget.tsx +263 -263
  1331. package/src/browser/tree/tree-widget-selection.ts +45 -45
  1332. package/src/browser/tree/tree-widget.tsx +1585 -1566
  1333. package/src/browser/tree/tree.spec.ts +241 -241
  1334. package/src/browser/tree/tree.ts +425 -424
  1335. package/src/browser/user-working-directory-provider.ts +77 -77
  1336. package/src/browser/view-container.ts +1640 -1640
  1337. package/src/browser/widget-decoration.ts +358 -358
  1338. package/src/browser/widget-manager.spec.ts +102 -102
  1339. package/src/browser/widget-manager.ts +310 -285
  1340. package/src/browser/widget-open-handler.ts +165 -165
  1341. package/src/browser/widgets/alert-message.tsx +56 -56
  1342. package/src/browser/widgets/enhanced-preview-widget.ts +27 -27
  1343. package/src/browser/widgets/extractable-widget.ts +33 -33
  1344. package/src/browser/widgets/index.ts +20 -20
  1345. package/src/browser/widgets/previewable-widget.ts +31 -31
  1346. package/src/browser/widgets/react-renderer.tsx +50 -50
  1347. package/src/browser/widgets/react-widget.tsx +51 -51
  1348. package/src/browser/widgets/select-component.tsx +367 -366
  1349. package/src/browser/widgets/widget.ts +406 -398
  1350. package/src/browser/window/browser-window-module.ts +32 -32
  1351. package/src/browser/window/default-secondary-window-service.ts +187 -187
  1352. package/src/browser/window/default-window-service.spec.ts +78 -78
  1353. package/src/browser/window/default-window-service.ts +167 -167
  1354. package/src/browser/window/secondary-window-service.ts +39 -39
  1355. package/src/browser/window/test/mock-window-service.ts +28 -28
  1356. package/src/browser/window/window-service.ts +68 -68
  1357. package/src/browser/window/window-title-service.ts +107 -107
  1358. package/src/browser/window/window-title-updater.ts +95 -95
  1359. package/src/browser/window-contribution.ts +64 -64
  1360. package/src/browser-only/frontend-only-application-module.ts +115 -0
  1361. package/src/browser-only/i18n/i18n-frontend-only-module.ts +37 -0
  1362. package/src/browser-only/logger-frontend-only-module.ts +63 -0
  1363. package/src/browser-only/messaging/frontend-only-service-connection-provider.ts +39 -0
  1364. package/src/browser-only/messaging/messaging-frontend-only-module.ts +42 -0
  1365. package/src/browser-only/preload/frontend-only-preload-module.ts +49 -0
  1366. package/src/common/accessibility.ts +33 -33
  1367. package/src/common/application-error.spec.ts +27 -27
  1368. package/src/common/application-error.ts +76 -76
  1369. package/src/common/application-protocol.ts +41 -40
  1370. package/src/common/array-utils.ts +129 -129
  1371. package/src/common/buffer.ts +228 -228
  1372. package/src/common/cancellation.ts +163 -163
  1373. package/src/common/char-code.ts +438 -438
  1374. package/src/common/collections.ts +125 -125
  1375. package/src/common/color.ts +103 -103
  1376. package/src/common/command.spec.ts +208 -208
  1377. package/src/common/command.ts +485 -485
  1378. package/src/common/contribution-filter/contribution-filter-registry.ts +79 -79
  1379. package/src/common/contribution-filter/contribution-filter.ts +64 -64
  1380. package/src/common/contribution-filter/filter.ts +23 -23
  1381. package/src/common/contribution-filter/index.ts +19 -19
  1382. package/src/common/contribution-provider.ts +96 -96
  1383. package/src/common/disposable.spec.ts +94 -29
  1384. package/src/common/disposable.ts +188 -135
  1385. package/src/common/encoding-service.ts +380 -380
  1386. package/src/common/encodings.ts +24 -24
  1387. package/src/common/env-variables/env-variables-protocol.ts +38 -38
  1388. package/src/common/env-variables/index.ts +17 -17
  1389. package/src/common/event.spec.ts +32 -32
  1390. package/src/common/event.ts +469 -469
  1391. package/src/{node → common}/file-uri.ts +61 -61
  1392. package/src/common/frontend-application-state.ts +38 -38
  1393. package/src/common/glob.ts +741 -741
  1394. package/src/common/hash.ts +85 -85
  1395. package/src/common/i18n/localization-server.ts +25 -25
  1396. package/src/common/i18n/localization.ts +80 -80
  1397. package/src/common/i18n/nls.metadata.json +31314 -31314
  1398. package/src/common/index.ts +51 -50
  1399. package/src/common/json-schema.ts +106 -106
  1400. package/src/common/key-store.ts +26 -26
  1401. package/src/common/keybinding.ts +152 -152
  1402. package/src/common/keyboard/keyboard-layout-provider.ts +51 -51
  1403. package/src/common/keys.ts +694 -694
  1404. package/src/common/label-protocol.ts +35 -35
  1405. package/src/common/logger-protocol.ts +119 -119
  1406. package/src/common/logger-watcher.ts +48 -48
  1407. package/src/common/logger.spec.ts +46 -46
  1408. package/src/common/logger.ts +389 -389
  1409. package/src/common/lsp-types.ts +34 -34
  1410. package/src/common/markdown-rendering/icon-utilities.ts +30 -30
  1411. package/src/common/markdown-rendering/index.ts +18 -18
  1412. package/src/common/markdown-rendering/markdown-string.ts +152 -149
  1413. package/src/common/menu/action-menu-node.ts +65 -65
  1414. package/src/common/menu/composite-menu-node.ts +114 -114
  1415. package/src/common/menu/index.ts +21 -21
  1416. package/src/common/menu/menu-adapter.ts +103 -103
  1417. package/src/common/menu/menu-model-registry.ts +343 -326
  1418. package/src/common/menu/menu-types.ts +219 -219
  1419. package/src/common/menu/menu.spec.ts +101 -73
  1420. package/src/common/message-rpc/channel.spec.ts +88 -88
  1421. package/src/common/message-rpc/channel.ts +300 -300
  1422. package/src/common/message-rpc/index.ts +22 -22
  1423. package/src/common/message-rpc/message-buffer.ts +105 -105
  1424. package/src/common/message-rpc/msg-pack-extension-manager.ts +70 -70
  1425. package/src/common/message-rpc/rpc-message-encoder.spec.ts +65 -65
  1426. package/src/common/message-rpc/rpc-message-encoder.ts +190 -190
  1427. package/src/common/message-rpc/rpc-protocol.ts +255 -235
  1428. package/src/common/message-rpc/uint8-array-message-buffer.spec.ts +41 -41
  1429. package/src/common/message-rpc/uint8-array-message-buffer.ts +213 -213
  1430. package/src/common/message-service-protocol.ts +148 -148
  1431. package/src/common/message-service.ts +226 -226
  1432. package/src/common/messaging/connection-error-handler.ts +73 -73
  1433. package/src/common/messaging/connection-management.ts +43 -43
  1434. package/src/common/messaging/handler.ts +26 -26
  1435. package/src/common/messaging/index.ts +19 -19
  1436. package/src/common/messaging/proxy-factory.spec.ts +108 -108
  1437. package/src/common/messaging/proxy-factory.ts +336 -343
  1438. package/src/common/messaging/socket-write-buffer.ts +52 -52
  1439. package/src/common/messaging/web-socket-channel.ts +76 -76
  1440. package/src/common/nls.ts +149 -149
  1441. package/src/common/numbers.ts +21 -21
  1442. package/src/common/objects.spec.ts +112 -112
  1443. package/src/common/objects.ts +123 -123
  1444. package/src/common/os.ts +82 -82
  1445. package/src/common/path.spec.ts +415 -415
  1446. package/src/common/path.ts +334 -334
  1447. package/src/common/paths.ts +250 -250
  1448. package/src/common/performance/index.ts +19 -19
  1449. package/src/common/performance/measurement-protocol.ts +104 -104
  1450. package/src/common/performance/measurement.ts +130 -130
  1451. package/src/common/performance/stopwatch.ts +183 -183
  1452. package/src/common/preferences/preference-schema.ts +95 -95
  1453. package/src/common/preferences/preference-scope.spec.ts +48 -48
  1454. package/src/common/preferences/preference-scope.ts +68 -68
  1455. package/src/common/prioritizeable.ts +58 -58
  1456. package/src/common/progress-service-protocol.ts +35 -35
  1457. package/src/common/progress-service.ts +82 -82
  1458. package/src/common/promise-util.spec.ts +72 -72
  1459. package/src/common/promise-util.ts +143 -143
  1460. package/src/common/quick-pick-service.ts +355 -377
  1461. package/src/common/reference.spec.ts +145 -145
  1462. package/src/common/reference.ts +230 -175
  1463. package/src/common/resource.ts +430 -426
  1464. package/src/common/selection-command-handler.ts +101 -101
  1465. package/src/common/selection-service.spec.ts +43 -43
  1466. package/src/common/selection-service.ts +49 -49
  1467. package/src/common/selection.ts +50 -50
  1468. package/src/common/severity.ts +111 -111
  1469. package/src/common/stream.ts +718 -718
  1470. package/src/common/strings.ts +231 -231
  1471. package/src/common/telemetry.ts +45 -45
  1472. package/src/common/ternary-search-tree.ts +417 -417
  1473. package/src/common/test/expect.ts +34 -34
  1474. package/src/common/test/mock-logger.ts +118 -118
  1475. package/src/common/test/mock-menu.ts +35 -35
  1476. package/src/common/test/mock-resource-provider.ts +33 -33
  1477. package/src/common/theme.ts +68 -36
  1478. package/src/common/types.spec.ts +86 -86
  1479. package/src/common/types.ts +140 -140
  1480. package/src/common/uri-command-handler.spec.ts +90 -90
  1481. package/src/common/uri-command-handler.ts +148 -148
  1482. package/src/common/uri.spec.ts +278 -278
  1483. package/src/common/uri.ts +279 -277
  1484. package/src/common/uuid.ts +45 -99
  1485. package/src/common/version.ts +17 -17
  1486. package/src/common/view-column.ts +33 -33
  1487. package/src/common/window.ts +34 -34
  1488. package/src/electron-browser/electron-clipboard-service.ts +32 -32
  1489. package/src/electron-browser/keyboard/electron-keyboard-layout-change-notifier.ts +39 -39
  1490. package/src/electron-browser/keyboard/electron-keyboard-module.ts +28 -28
  1491. package/src/electron-browser/menu/electron-context-menu-renderer.ts +120 -120
  1492. package/src/electron-browser/menu/electron-main-menu-factory.ts +335 -335
  1493. package/src/electron-browser/menu/electron-menu-contribution.ts +506 -498
  1494. package/src/electron-browser/menu/electron-menu-module.ts +40 -40
  1495. package/src/electron-browser/menu/electron-menu-style.css +110 -110
  1496. package/src/electron-browser/messaging/electron-frontend-id-provider.ts +25 -25
  1497. package/src/electron-browser/messaging/electron-ipc-connection-source.ts +65 -65
  1498. package/src/electron-browser/messaging/electron-local-ws-connection-source.ts +45 -45
  1499. package/src/electron-browser/messaging/electron-messaging-frontend-module.ts +78 -78
  1500. package/src/electron-browser/messaging/electron-ws-connection-source.ts +38 -38
  1501. package/src/electron-browser/preload.ts +246 -246
  1502. package/src/electron-browser/request/electron-browser-request-module.ts +26 -26
  1503. package/src/electron-browser/token/electron-token-frontend-module.ts +22 -22
  1504. package/src/electron-browser/window/electron-frontend-application-state.ts +26 -26
  1505. package/src/electron-browser/window/electron-secondary-window-service.ts +39 -39
  1506. package/src/electron-browser/window/electron-window-module.ts +41 -41
  1507. package/src/electron-browser/window/electron-window-preferences.ts +76 -76
  1508. package/src/electron-browser/window/electron-window-service.ts +97 -97
  1509. package/src/electron-common/electron-api.ts +148 -148
  1510. package/src/electron-common/electron-main-window-service.ts +24 -24
  1511. package/src/electron-common/electron-token.ts +27 -27
  1512. package/src/electron-main/electron-api-main.ts +333 -333
  1513. package/src/electron-main/electron-main-application-module.ts +65 -65
  1514. package/src/electron-main/electron-main-application.ts +685 -685
  1515. package/src/electron-main/electron-main-constants.ts +22 -22
  1516. package/src/electron-main/electron-main-window-service-impl.ts +44 -44
  1517. package/src/electron-main/electron-security-token-service.ts +36 -36
  1518. package/src/electron-main/event-utils.ts +36 -36
  1519. package/src/electron-main/messaging/electron-connection-handler.ts +21 -21
  1520. package/src/electron-main/messaging/electron-messaging-contribution.ts +143 -143
  1521. package/src/electron-main/messaging/electron-messaging-service.ts +35 -35
  1522. package/src/electron-main/theia-electron-window.ts +202 -202
  1523. package/src/electron-node/hosting/electron-backend-hosting-module.ts +24 -24
  1524. package/src/electron-node/hosting/electron-ws-origin-validator.ts +37 -37
  1525. package/src/electron-node/keyboard/electron-backend-keyboard-module.ts +30 -30
  1526. package/src/electron-node/keyboard/electron-keyboard-layout-provider.ts +35 -35
  1527. package/src/electron-node/request/electron-backend-request-module.ts +23 -23
  1528. package/src/electron-node/request/electron-backend-request-service.ts +78 -78
  1529. package/src/electron-node/token/electron-token-backend-contribution.ts +48 -48
  1530. package/src/electron-node/token/electron-token-backend-module.ts +28 -28
  1531. package/src/electron-node/token/electron-token-validator.ts +93 -93
  1532. package/src/node/application-server.ts +55 -48
  1533. package/src/node/backend-application-config-provider.spec.ts +29 -29
  1534. package/src/node/backend-application-config-provider.ts +48 -48
  1535. package/src/node/backend-application-module.ts +140 -140
  1536. package/src/node/backend-application.ts +382 -382
  1537. package/src/node/backend-remote-service.ts +25 -25
  1538. package/src/node/cli.spec.ts +94 -94
  1539. package/src/node/cli.ts +63 -63
  1540. package/src/node/console-logger-server.spec.ts +59 -59
  1541. package/src/node/console-logger-server.ts +76 -76
  1542. package/src/node/debug.ts +30 -30
  1543. package/src/node/dynamic-require.ts +56 -56
  1544. package/src/node/env-variables/env-variables-server.ts +120 -120
  1545. package/src/node/env-variables/index.ts +17 -17
  1546. package/src/node/environment-utils.spec.ts +92 -92
  1547. package/src/node/environment-utils.ts +66 -66
  1548. package/src/node/file-uri.spec.ts +76 -76
  1549. package/src/node/filesystem-locking.ts +77 -77
  1550. package/src/node/hosting/backend-application-hosts.ts +60 -60
  1551. package/src/node/hosting/backend-hosting-module.ts +26 -26
  1552. package/src/node/hosting/ws-origin-validator.ts +36 -36
  1553. package/src/node/i18n/i18n-backend-module.ts +42 -42
  1554. package/src/node/i18n/localization-contribution.ts +112 -112
  1555. package/src/node/i18n/localization-provider.ts +125 -125
  1556. package/src/node/i18n/localization-server.ts +52 -52
  1557. package/src/node/i18n/theia-localization-contribution.ts +36 -36
  1558. package/src/node/index.ts +22 -22
  1559. package/src/node/key-store-server.ts +162 -162
  1560. package/src/node/logger-backend-module.ts +88 -88
  1561. package/src/node/logger-cli-contribution.spec.ts +245 -245
  1562. package/src/node/logger-cli-contribution.ts +168 -168
  1563. package/src/node/main.ts +33 -33
  1564. package/src/node/messaging/binary-message-pipe.ts +168 -168
  1565. package/src/node/messaging/connection-container-module.ts +96 -96
  1566. package/src/node/messaging/default-messaging-service.ts +129 -129
  1567. package/src/node/messaging/frontend-connection-service.ts +24 -24
  1568. package/src/node/messaging/index.ts +19 -19
  1569. package/src/node/messaging/ipc-bootstrap.ts +27 -27
  1570. package/src/node/messaging/ipc-channel.ts +77 -77
  1571. package/src/node/messaging/ipc-connection-provider.ts +107 -107
  1572. package/src/node/messaging/ipc-protocol.ts +76 -76
  1573. package/src/node/messaging/messaging-backend-module.ts +52 -52
  1574. package/src/node/messaging/messaging-listeners.ts +52 -52
  1575. package/src/node/messaging/messaging-service.ts +46 -46
  1576. package/src/node/messaging/test/test-web-socket-channel.ts +61 -61
  1577. package/src/node/messaging/websocket-endpoint.ts +79 -79
  1578. package/src/node/messaging/websocket-frontend-connection-service.ts +176 -171
  1579. package/src/node/os-backend-provider.ts +25 -25
  1580. package/src/node/performance/index.ts +18 -18
  1581. package/src/node/performance/measurement-backend-bindings.ts +35 -35
  1582. package/src/node/performance/node-stopwatch.ts +40 -40
  1583. package/src/node/process-utils.spec.ts +48 -48
  1584. package/src/node/process-utils.ts +102 -102
  1585. package/src/node/request/backend-request-facade.ts +39 -39
  1586. package/src/node/request/backend-request-module.ts +25 -25
  1587. package/src/node/request/proxy-cli-contribution.ts +65 -65
  1588. package/src/node/ws-request-validators.ts +56 -56
  1589. package/src/typings/native-keymap.d.ts +108 -108
  1590. package/lib/node/file-uri.d.ts.map +0 -1
  1591. package/lib/node/file-uri.js.map +0 -1
@@ -1,1566 +1,1585 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2018 TypeFox and others.
3
- //
4
- // This program and the accompanying materials are made available under the
5
- // terms of the Eclipse Public License v. 2.0 which is available at
6
- // http://www.eclipse.org/legal/epl-2.0.
7
- //
8
- // This Source Code may also be made available under the following Secondary
9
- // Licenses when the conditions for such availability set forth in the Eclipse
10
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
- // with the GNU Classpath Exception which is available at
12
- // https://www.gnu.org/software/classpath/license.html.
13
- //
14
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
- // *****************************************************************************
16
-
17
- import { injectable, inject, postConstruct } from 'inversify';
18
- import { Message } from '@phosphor/messaging';
19
- import { Disposable, MenuPath, SelectionService } from '../../common';
20
- import { Key, KeyCode, KeyModifier } from '../keyboard/keys';
21
- import { ContextMenuRenderer } from '../context-menu-renderer';
22
- import { StatefulWidget } from '../shell';
23
- import {
24
- EXPANSION_TOGGLE_CLASS, SELECTED_CLASS, COLLAPSED_CLASS, FOCUS_CLASS, BUSY_CLASS, CODICON_TREE_ITEM_CLASSES, CODICON_LOADING_CLASSES, Widget, UnsafeWidgetUtilities
25
- } from '../widgets';
26
- import { TreeNode, CompositeTreeNode } from './tree';
27
- import { TreeModel } from './tree-model';
28
- import { ExpandableTreeNode } from './tree-expansion';
29
- import { SelectableTreeNode, TreeSelection } from './tree-selection';
30
- import { TreeDecoratorService, TreeDecoration, DecoratedTreeNode } from './tree-decorator';
31
- import { notEmpty } from '../../common/objects';
32
- import { isOSX } from '../../common/os';
33
- import { ReactWidget } from '../widgets/react-widget';
34
- import * as React from 'react';
35
- import { Virtuoso, VirtuosoHandle } from 'react-virtuoso';
36
- import { TopDownTreeIterator } from './tree-iterator';
37
- import { SearchBox, SearchBoxFactory, SearchBoxProps } from './search-box';
38
- import { TreeSearch } from './tree-search';
39
- import { ElementExt } from '@phosphor/domutils';
40
- import { TreeWidgetSelection } from './tree-widget-selection';
41
- import { MaybePromise } from '../../common/types';
42
- import { LabelProvider } from '../label-provider';
43
- import { CorePreferences } from '../core-preferences';
44
- import { TreeFocusService } from './tree-focus-service';
45
- import { useEffect } from 'react';
46
-
47
- const debounce = require('lodash.debounce');
48
-
49
- export const TREE_CLASS = 'theia-Tree';
50
- export const TREE_CONTAINER_CLASS = 'theia-TreeContainer';
51
- export const TREE_NODE_CLASS = 'theia-TreeNode';
52
- export const TREE_NODE_CONTENT_CLASS = 'theia-TreeNodeContent';
53
- export const TREE_NODE_INFO_CLASS = 'theia-TreeNodeInfo';
54
- export const TREE_NODE_TAIL_CLASS = 'theia-TreeNodeTail';
55
- export const TREE_NODE_SEGMENT_CLASS = 'theia-TreeNodeSegment';
56
- export const TREE_NODE_SEGMENT_GROW_CLASS = 'theia-TreeNodeSegmentGrow';
57
-
58
- export const EXPANDABLE_TREE_NODE_CLASS = 'theia-ExpandableTreeNode';
59
- export const COMPOSITE_TREE_NODE_CLASS = 'theia-CompositeTreeNode';
60
- export const TREE_NODE_CAPTION_CLASS = 'theia-TreeNodeCaption';
61
- export const TREE_NODE_INDENT_GUIDE_CLASS = 'theia-tree-node-indent';
62
-
63
- export const TreeProps = Symbol('TreeProps');
64
-
65
- /**
66
- * Representation of tree properties.
67
- */
68
- export interface TreeProps {
69
-
70
- /**
71
- * The path of the context menu that one can use to contribute context menu items to the tree widget.
72
- */
73
- readonly contextMenuPath?: MenuPath;
74
-
75
- /**
76
- * The size of the padding (in pixels) per hierarchy depth. The root element won't have left padding but
77
- * the padding for the children will be calculated as `leftPadding * hierarchyDepth` and so on.
78
- */
79
- readonly leftPadding: number;
80
-
81
- readonly expansionTogglePadding: number;
82
-
83
- /**
84
- * `true` if the tree widget support multi-selection. Otherwise, `false`. Defaults to `false`.
85
- */
86
- readonly multiSelect?: boolean;
87
-
88
- /**
89
- * `true` if the tree widget support searching. Otherwise, `false`. Defaults to `false`.
90
- */
91
- readonly search?: boolean
92
-
93
- /**
94
- * `true` if the tree widget should be virtualized searching. Otherwise, `false`. Defaults to `true`.
95
- */
96
- readonly virtualized?: boolean
97
-
98
- /**
99
- * `true` if the selected node should be auto scrolled only if the widget is active. Otherwise, `false`. Defaults to `false`.
100
- */
101
- readonly scrollIfActive?: boolean
102
-
103
- /**
104
- * `true` if a tree widget contributes to the global selection. Defaults to `false`.
105
- */
106
- readonly globalSelection?: boolean;
107
-
108
- /**
109
- * `true` if the tree widget supports expansion only when clicking the expansion toggle. Defaults to `false`.
110
- */
111
- readonly expandOnlyOnExpansionToggleClick?: boolean;
112
-
113
- }
114
-
115
- /**
116
- * Representation of node properties.
117
- */
118
- export interface NodeProps {
119
-
120
- /**
121
- * A root relative number representing the hierarchical depth of the actual node. Root is `0`, its children have `1` and so on.
122
- */
123
- readonly depth: number;
124
-
125
- }
126
-
127
- /**
128
- * The default tree properties.
129
- */
130
- export const defaultTreeProps: TreeProps = {
131
- leftPadding: 8,
132
- expansionTogglePadding: 22
133
- };
134
-
135
- export namespace TreeWidget {
136
-
137
- /**
138
- * Bare minimum common interface of the keyboard and the mouse event with respect to the key maskings.
139
- */
140
- export interface ModifierAwareEvent {
141
- /**
142
- * Determines if the modifier aware event has the `meta` key masking.
143
- */
144
- readonly metaKey: boolean;
145
- /**
146
- * Determines if the modifier aware event has the `ctrl` key masking.
147
- */
148
- readonly ctrlKey: boolean;
149
- /**
150
- * Determines if the modifier aware event has the `shift` key masking.
151
- */
152
- readonly shiftKey: boolean;
153
- }
154
-
155
- }
156
-
157
- @injectable()
158
- export class TreeWidget extends ReactWidget implements StatefulWidget {
159
-
160
- protected searchBox: SearchBox;
161
- protected searchHighlights: Map<string, TreeDecoration.CaptionHighlight>;
162
-
163
- @inject(TreeDecoratorService)
164
- protected readonly decoratorService: TreeDecoratorService;
165
- @inject(TreeSearch)
166
- protected readonly treeSearch: TreeSearch;
167
- @inject(SearchBoxFactory)
168
- protected readonly searchBoxFactory: SearchBoxFactory;
169
- @inject(TreeFocusService)
170
- protected readonly focusService: TreeFocusService;
171
-
172
- protected decorations: Map<string, TreeDecoration.Data[]> = new Map();
173
-
174
- @inject(SelectionService)
175
- protected readonly selectionService: SelectionService;
176
-
177
- @inject(LabelProvider)
178
- protected readonly labelProvider: LabelProvider;
179
-
180
- @inject(CorePreferences)
181
- protected readonly corePreferences: CorePreferences;
182
-
183
- protected shouldScrollToRow = true;
184
-
185
- constructor(
186
- @inject(TreeProps) readonly props: TreeProps,
187
- @inject(TreeModel) readonly model: TreeModel,
188
- @inject(ContextMenuRenderer) protected readonly contextMenuRenderer: ContextMenuRenderer,
189
- ) {
190
- super();
191
- this.scrollOptions = {
192
- suppressScrollX: true,
193
- minScrollbarLength: 35
194
- };
195
- this.addClass(TREE_CLASS);
196
- this.node.tabIndex = 0;
197
- }
198
-
199
- @postConstruct()
200
- protected init(): void {
201
- if (this.props.search) {
202
- this.searchBox = this.searchBoxFactory({ ...SearchBoxProps.DEFAULT, showButtons: true, showFilter: true });
203
- this.searchBox.node.addEventListener('focus', () => {
204
- this.node.focus();
205
- });
206
- this.toDispose.pushAll([
207
- this.searchBox,
208
- this.searchBox.onTextChange(async data => {
209
- await this.treeSearch.filter(data);
210
- this.searchHighlights = this.treeSearch.getHighlights();
211
- this.searchBox.updateHighlightInfo({
212
- filterText: data,
213
- total: this.rows.size,
214
- matched: this.searchHighlights.size
215
- });
216
- this.update();
217
- }),
218
- this.searchBox.onClose(data => this.treeSearch.filter(undefined)),
219
- this.searchBox.onNext(() => {
220
- // Enable next selection if there are currently highlights.
221
- if (this.searchHighlights.size > 1) {
222
- this.model.selectNextNode();
223
- }
224
- }),
225
- this.searchBox.onPrevious(() => {
226
- // Enable previous selection if there are currently highlights.
227
- if (this.searchHighlights.size > 1) {
228
- this.model.selectPrevNode();
229
- }
230
- }),
231
- this.searchBox.onFilterToggled(e => {
232
- this.updateRows();
233
- }),
234
- this.treeSearch,
235
- this.treeSearch.onFilteredNodesChanged(nodes => {
236
- if (this.searchBox.isFiltering) {
237
- this.updateRows();
238
- }
239
- const node = nodes.find(SelectableTreeNode.is);
240
- if (node) {
241
- this.model.selectNode(node);
242
- }
243
- }),
244
- ]);
245
- }
246
- this.node.addEventListener('mousedown', this.handleMiddleClickEvent.bind(this));
247
- this.node.addEventListener('mouseup', this.handleMiddleClickEvent.bind(this));
248
- this.node.addEventListener('auxclick', this.handleMiddleClickEvent.bind(this));
249
- this.toDispose.pushAll([
250
- this.model,
251
- this.model.onChanged(() => this.updateRows()),
252
- this.model.onSelectionChanged(() => this.scheduleUpdateScrollToRow({ resize: false })),
253
- this.focusService.onDidChangeFocus(() => this.scheduleUpdateScrollToRow({ resize: false })),
254
- this.model.onDidChangeBusy(() => this.update()),
255
- this.model.onDidUpdate(() => this.update()),
256
- this.model.onNodeRefreshed(() => this.updateDecorations()),
257
- this.model.onExpansionChanged(() => this.updateDecorations()),
258
- this.decoratorService,
259
- this.decoratorService.onDidChangeDecorations(() => this.updateDecorations()),
260
- this.labelProvider.onDidChange(e => {
261
- for (const row of this.rows.values()) {
262
- if (e.affects(row)) {
263
- this.update();
264
- return;
265
- }
266
- }
267
- })
268
- ]);
269
- setTimeout(() => {
270
- this.updateRows();
271
- this.updateDecorations();
272
- });
273
- if (this.props.globalSelection) {
274
- this.toDispose.pushAll([
275
- this.model.onSelectionChanged(() => {
276
- if (this.node.contains(document.activeElement)) {
277
- this.updateGlobalSelection();
278
- }
279
- }),
280
- this.focusService.onDidChangeFocus(focus => {
281
- if (focus && this.node.contains(document.activeElement) && this.model.selectedNodes[0] !== focus && this.model.selectedNodes.includes(focus)) {
282
- this.updateGlobalSelection();
283
- }
284
- }),
285
- Disposable.create(() => {
286
- const selection = this.selectionService.selection;
287
- if (TreeWidgetSelection.isSource(selection, this)) {
288
- this.selectionService.selection = undefined;
289
- }
290
- })
291
- ]);
292
- }
293
- this.toDispose.push(this.corePreferences.onPreferenceChanged(preference => {
294
- if (preference.preferenceName === 'workbench.tree.renderIndentGuides') {
295
- this.update();
296
- }
297
- }));
298
- }
299
-
300
- /**
301
- * Update the global selection for the tree.
302
- */
303
- protected updateGlobalSelection(): void {
304
- this.selectionService.selection = TreeWidgetSelection.create(this);
305
- }
306
-
307
- protected rows = new Map<string, TreeWidget.NodeRow>();
308
- protected updateRows = debounce(() => this.doUpdateRows(), 10);
309
- protected doUpdateRows(): void {
310
- const root = this.model.root;
311
- const rowsToUpdate: Array<[string, TreeWidget.NodeRow]> = [];
312
- if (root) {
313
- const depths = new Map<CompositeTreeNode | undefined, number>();
314
- let index = 0;
315
- for (const node of new TopDownTreeIterator(root, {
316
- pruneCollapsed: true,
317
- pruneSiblings: true
318
- })) {
319
- if (this.shouldDisplayNode(node)) {
320
- const depth = this.getDepthForNode(node, depths);
321
- if (CompositeTreeNode.is(node)) {
322
- depths.set(node, depth);
323
- }
324
- rowsToUpdate.push([node.id, this.toNodeRow(node, index++, depth)]);
325
- }
326
- }
327
- }
328
- this.rows = new Map(rowsToUpdate);
329
- this.updateScrollToRow();
330
- }
331
-
332
- protected getDepthForNode(node: TreeNode, depths: Map<CompositeTreeNode | undefined, number>): number {
333
- const parentDepth = depths.get(node.parent);
334
- return parentDepth === undefined ? 0 : TreeNode.isVisible(node.parent) ? parentDepth + 1 : parentDepth;
335
- }
336
-
337
- protected toNodeRow(node: TreeNode, index: number, depth: number): TreeWidget.NodeRow {
338
- return { node, index, depth };
339
- }
340
-
341
- protected shouldDisplayNode(node: TreeNode): boolean {
342
- return TreeNode.isVisible(node) && (!this.searchBox?.isFiltering || this.treeSearch.passesFilters(node));
343
- }
344
-
345
- /**
346
- * Row index to ensure visibility.
347
- * - Used to forcefully scroll if necessary.
348
- */
349
- protected scrollToRow: number | undefined;
350
- /**
351
- * Update the `scrollToRow`.
352
- * @param updateOptions the tree widget force update options.
353
- */
354
- protected updateScrollToRow(): void {
355
- this.scrollToRow = this.getScrollToRow();
356
- this.update();
357
- }
358
-
359
- protected scheduleUpdateScrollToRow = debounce(this.updateScrollToRow);
360
-
361
- /**
362
- * Get the `scrollToRow`.
363
- *
364
- * @returns the `scrollToRow` if available.
365
- */
366
- protected getScrollToRow(): number | undefined {
367
- if (!this.shouldScrollToRow) {
368
- return undefined;
369
- }
370
- const { focusedNode } = this.focusService;
371
- return focusedNode && this.rows.get(focusedNode.id)?.index;
372
- }
373
-
374
- /**
375
- * Update tree decorations.
376
- * - Updating decorations are debounced in order to limit the number of expensive updates.
377
- */
378
- protected readonly updateDecorations = debounce(() => this.doUpdateDecorations(), 150);
379
- protected async doUpdateDecorations(): Promise<void> {
380
- this.decorations = await this.decoratorService.getDecorations(this.model);
381
- this.update();
382
- }
383
-
384
- protected override onActivateRequest(msg: Message): void {
385
- super.onActivateRequest(msg);
386
- this.node.focus({ preventScroll: true });
387
- }
388
-
389
- /**
390
- * Actually focus the tree node.
391
- */
392
- protected doFocus(): void {
393
- if (!this.model.selectedNodes.length) {
394
- const node = this.getNodeToFocus();
395
- if (SelectableTreeNode.is(node)) {
396
- this.model.selectNode(node);
397
- }
398
- }
399
- }
400
-
401
- /**
402
- * Get the tree node to focus.
403
- *
404
- * @returns the node to focus if available.
405
- */
406
- protected getNodeToFocus(): SelectableTreeNode | undefined {
407
- const { focusedNode } = this.focusService;
408
- if (focusedNode) {
409
- return focusedNode;
410
- }
411
- const { root } = this.model;
412
- if (SelectableTreeNode.isVisible(root)) {
413
- return root;
414
- }
415
- return this.model.getNextSelectableNode(root);
416
- }
417
-
418
- protected override onUpdateRequest(msg: Message): void {
419
- if (!this.isAttached || !this.isVisible) {
420
- return;
421
- }
422
- super.onUpdateRequest(msg);
423
- }
424
-
425
- protected override onResize(msg: Widget.ResizeMessage): void {
426
- super.onResize(msg);
427
- this.update();
428
- }
429
-
430
- protected render(): React.ReactNode {
431
- return React.createElement('div', this.createContainerAttributes(), this.renderTree(this.model));
432
- }
433
-
434
- /**
435
- * Create the container attributes for the widget.
436
- */
437
- protected createContainerAttributes(): React.HTMLAttributes<HTMLElement> {
438
- const classNames = [TREE_CONTAINER_CLASS];
439
- if (!this.rows.size) {
440
- classNames.push('empty');
441
- }
442
- if (this.model.selectedNodes.length === 0 && !this.focusService.focusedNode) {
443
- classNames.push('focused');
444
- }
445
- return {
446
- className: classNames.join(' '),
447
- onContextMenu: event => this.handleContextMenuEvent(this.getContainerTreeNode(), event)
448
- };
449
- }
450
- /**
451
- * Get the container tree node.
452
- *
453
- * @returns the tree node for the container if available.
454
- */
455
- protected getContainerTreeNode(): TreeNode | undefined {
456
- return this.model.root;
457
- }
458
-
459
- protected ScrollingRowRenderer: React.FC<{ rows: TreeWidget.NodeRow[] }> = ({ rows }) => {
460
- useEffect(() => this.scrollToSelected());
461
- return <>{rows.map(row => <div key={row.index}>{this.renderNodeRow(row)}</div>)}</>;
462
- };
463
-
464
- protected view: TreeWidget.View | undefined;
465
- /**
466
- * Render the tree widget.
467
- * @param model the tree model.
468
- */
469
- protected renderTree(model: TreeModel): React.ReactNode {
470
- if (model.root) {
471
- const rows = Array.from(this.rows.values());
472
- if (this.props.virtualized === false) {
473
- return <this.ScrollingRowRenderer rows={rows} />;
474
- }
475
- return <TreeWidget.View
476
- ref={view => this.view = (view || undefined)}
477
- width={this.node.offsetWidth}
478
- height={this.node.offsetHeight}
479
- rows={rows}
480
- renderNodeRow={this.renderNodeRow}
481
- scrollToRow={this.scrollToRow}
482
- />;
483
- }
484
- // eslint-disable-next-line no-null/no-null
485
- return null;
486
- }
487
-
488
- scrollArea: Element = this.node;
489
- /**
490
- * Scroll to the selected tree node.
491
- */
492
- protected scrollToSelected(): void {
493
- if (this.props.scrollIfActive === true && !this.node.contains(document.activeElement)) {
494
- return;
495
- }
496
- const focus = this.node.getElementsByClassName(FOCUS_CLASS)[0];
497
- if (focus) {
498
- ElementExt.scrollIntoViewIfNeeded(this.scrollArea, focus);
499
- } else {
500
- const selected = this.node.getElementsByClassName(SELECTED_CLASS)[0];
501
- if (selected) {
502
- ElementExt.scrollIntoViewIfNeeded(this.scrollArea, selected);
503
- }
504
- }
505
- }
506
-
507
- /**
508
- * Render the node row.
509
- */
510
- protected readonly renderNodeRow = (row: TreeWidget.NodeRow) => this.doRenderNodeRow(row);
511
- /**
512
- * Actually render the node row.
513
- */
514
- protected doRenderNodeRow({ node, depth }: TreeWidget.NodeRow): React.ReactNode {
515
- return <React.Fragment>
516
- {this.renderIndent(node, { depth })}
517
- {this.renderNode(node, { depth })}
518
- </React.Fragment>;
519
- }
520
-
521
- /**
522
- * Render the tree node given the node properties.
523
- * @param node the tree node.
524
- * @param props the node properties.
525
- */
526
- protected renderIcon(node: TreeNode, props: NodeProps): React.ReactNode {
527
- // eslint-disable-next-line no-null/no-null
528
- return null;
529
- }
530
-
531
- /**
532
- * Toggle the node.
533
- */
534
- protected readonly toggle = (event: React.MouseEvent<HTMLElement>) => this.doToggle(event);
535
- /**
536
- * Actually toggle the tree node.
537
- * @param event the mouse click event.
538
- */
539
- protected doToggle(event: React.MouseEvent<HTMLElement>): void {
540
- const nodeId = event.currentTarget.getAttribute('data-node-id');
541
- if (nodeId) {
542
- const node = this.model.getNode(nodeId);
543
- if (node && this.props.expandOnlyOnExpansionToggleClick) {
544
- if (this.isExpandable(node) && !this.hasShiftMask(event) && !this.hasCtrlCmdMask(event)) {
545
- this.model.toggleNodeExpansion(node);
546
- }
547
- } else {
548
- this.handleClickEvent(node, event);
549
- }
550
- }
551
- event.stopPropagation();
552
- }
553
-
554
- /**
555
- * Render the node expansion toggle.
556
- * @param node the tree node.
557
- * @param props the node properties.
558
- */
559
- protected renderExpansionToggle(node: TreeNode, props: NodeProps): React.ReactNode {
560
- if (!this.isExpandable(node)) {
561
- // eslint-disable-next-line no-null/no-null
562
- return null;
563
- }
564
- const classes = [TREE_NODE_SEGMENT_CLASS, EXPANSION_TOGGLE_CLASS];
565
- if (!node.expanded) {
566
- classes.push(COLLAPSED_CLASS);
567
- }
568
- if (node.busy) {
569
- classes.push(BUSY_CLASS, ...CODICON_LOADING_CLASSES);
570
- } else {
571
- classes.push(...CODICON_TREE_ITEM_CLASSES);
572
- }
573
- const className = classes.join(' ');
574
- return <div
575
- data-node-id={node.id}
576
- className={className}
577
- onClick={this.toggle}
578
- onDoubleClick={this.handleExpansionToggleDblClickEvent}>
579
- </div>;
580
- }
581
-
582
- /**
583
- * Render the node expansion toggle.
584
- * @param node the tree node.
585
- * @param props the node properties.
586
- */
587
- protected renderCheckbox(node: TreeNode, props: NodeProps): React.ReactNode {
588
- if (node.checkboxInfo === undefined) {
589
- // eslint-disable-next-line no-null/no-null
590
- return null;
591
- }
592
- return <input data-node-id={node.id}
593
- readOnly
594
- type='checkbox'
595
- checked={!!node.checkboxInfo.checked}
596
- title={node.checkboxInfo.tooltip}
597
- aria-label={node.checkboxInfo.accessibilityInformation?.label}
598
- role={node.checkboxInfo.accessibilityInformation?.role}
599
- className='theia-input'
600
- onClick={event => this.toggleChecked(event)} />;
601
- }
602
-
603
- protected toggleChecked(event: React.MouseEvent<HTMLElement>): void {
604
- const nodeId = event.currentTarget.getAttribute('data-node-id');
605
- if (nodeId) {
606
- const node = this.model.getNode(nodeId);
607
- if (node) {
608
- this.model.markAsChecked(node, !node.checkboxInfo!.checked);
609
- } else {
610
- this.handleClickEvent(node, event);
611
- }
612
- }
613
- event.preventDefault();
614
- event.stopPropagation();
615
- }
616
- /**
617
- * Render the tree node caption given the node properties.
618
- * @param node the tree node.
619
- * @param props the node properties.
620
- */
621
- protected renderCaption(node: TreeNode, props: NodeProps): React.ReactNode {
622
- const attrs = this.getCaptionAttributes(node, props);
623
- const children = this.getCaptionChildren(node, props);
624
- return React.createElement('div', attrs, children);
625
- }
626
-
627
- protected getCaptionAttributes(node: TreeNode, props: NodeProps): React.Attributes & React.HTMLAttributes<HTMLElement> {
628
- const tooltip = this.getDecorationData(node, 'tooltip').filter(notEmpty).join(' • ');
629
- const classes = [TREE_NODE_SEGMENT_CLASS];
630
- if (!this.hasTrailingSuffixes(node)) {
631
- classes.push(TREE_NODE_SEGMENT_GROW_CLASS);
632
- }
633
- const className = classes.join(' ');
634
- let attrs = this.decorateCaption(node, {
635
- className, id: node.id
636
- });
637
- if (tooltip.length > 0) {
638
- attrs = {
639
- ...attrs,
640
- title: tooltip
641
- };
642
- }
643
- return attrs;
644
- }
645
-
646
- protected getCaptionChildren(node: TreeNode, props: NodeProps): React.ReactNode {
647
- const children = [];
648
- const caption = this.toNodeName(node);
649
- const highlight = this.getDecorationData(node, 'highlight')[0];
650
- if (highlight) {
651
- children.push(this.toReactNode(caption, highlight));
652
- }
653
- const searchHighlight = this.searchHighlights ? this.searchHighlights.get(node.id) : undefined;
654
- if (searchHighlight) {
655
- children.push(...this.toReactNode(caption, searchHighlight));
656
- } else if (!highlight) {
657
- children.push(caption);
658
- }
659
- return children;
660
- }
661
-
662
- /**
663
- * Update the node given the caption and highlight.
664
- * @param caption the caption.
665
- * @param highlight the tree decoration caption highlight.
666
- */
667
- protected toReactNode(caption: string, highlight: TreeDecoration.CaptionHighlight): React.ReactNode[] {
668
- let style: React.CSSProperties = {};
669
- if (highlight.color) {
670
- style = {
671
- ...style,
672
- color: highlight.color
673
- };
674
- }
675
- if (highlight.backgroundColor) {
676
- style = {
677
- ...style,
678
- backgroundColor: highlight.backgroundColor
679
- };
680
- }
681
- const createChildren = (fragment: TreeDecoration.CaptionHighlight.Fragment, index: number) => {
682
- const { data } = fragment;
683
- if (fragment.highlight) {
684
- return <mark className={TreeDecoration.Styles.CAPTION_HIGHLIGHT_CLASS} style={style} key={index}>{data}</mark>;
685
- } else {
686
- return data;
687
- }
688
- };
689
- return TreeDecoration.CaptionHighlight.split(caption, highlight).map(createChildren);
690
- }
691
-
692
- /**
693
- * Decorate the tree caption.
694
- * @param node the tree node.
695
- * @param attrs the additional attributes.
696
- */
697
- protected decorateCaption(node: TreeNode, attrs: React.HTMLAttributes<HTMLElement>): React.Attributes & React.HTMLAttributes<HTMLElement> {
698
- const style = this.getDecorationData(node, 'fontData')
699
- .filter(notEmpty)
700
- .reverse()
701
- .map(fontData => this.applyFontStyles({}, fontData))
702
- .reduce((acc, current) => ({
703
- ...acc,
704
- ...current
705
- }), {});
706
- return {
707
- ...attrs,
708
- style
709
- };
710
- }
711
-
712
- /**
713
- * Determine if the tree node contains trailing suffixes.
714
- * @param node the tree node.
715
- *
716
- * @returns `true` if the tree node contains trailing suffices.
717
- */
718
- protected hasTrailingSuffixes(node: TreeNode): boolean {
719
- return this.getDecorationData(node, 'captionSuffixes').filter(notEmpty).reduce((acc, current) => acc.concat(current), []).length > 0;
720
- }
721
-
722
- /**
723
- * Apply font styles to the tree.
724
- * @param original the original css properties.
725
- * @param fontData the optional `fontData`.
726
- */
727
- protected applyFontStyles(original: React.CSSProperties, fontData: TreeDecoration.FontData | undefined): React.CSSProperties {
728
- if (fontData === undefined) {
729
- return original;
730
- }
731
- const modified = { ...original }; // make a copy to mutate
732
- const { color, style } = fontData;
733
- if (color) {
734
- modified.color = color;
735
- }
736
- if (style) {
737
- (Array.isArray(style) ? style : [style]).forEach(s => {
738
- switch (s) {
739
- case 'bold':
740
- modified.fontWeight = s;
741
- break;
742
- case 'normal':
743
- case 'oblique':
744
- case 'italic':
745
- modified.fontStyle = s;
746
- break;
747
- case 'underline':
748
- case 'line-through':
749
- modified.textDecoration = s;
750
- break;
751
- default:
752
- throw new Error(`Unexpected font style: "${s}".`);
753
- }
754
- });
755
- }
756
- return modified;
757
- }
758
-
759
- /**
760
- * Render caption affixes for the given tree node.
761
- * @param node the tree node.
762
- * @param props the node properties.
763
- * @param affixKey the affix key.
764
- */
765
- protected renderCaptionAffixes(node: TreeNode, props: NodeProps, affixKey: 'captionPrefixes' | 'captionSuffixes'): React.ReactNode {
766
- const suffix = affixKey === 'captionSuffixes';
767
- const affixClass = suffix ? TreeDecoration.Styles.CAPTION_SUFFIX_CLASS : TreeDecoration.Styles.CAPTION_PREFIX_CLASS;
768
- const classes = [TREE_NODE_SEGMENT_CLASS, affixClass];
769
- const affixes = this.getDecorationData(node, affixKey).filter(notEmpty).reduce((acc, current) => acc.concat(current), []);
770
- const children: React.ReactNode[] = [];
771
- for (let i = 0; i < affixes.length; i++) {
772
- const affix = affixes[i];
773
- if (suffix && i === affixes.length - 1) {
774
- classes.push(TREE_NODE_SEGMENT_GROW_CLASS);
775
- }
776
- const style = this.applyFontStyles({}, affix.fontData);
777
- const className = classes.join(' ');
778
- const key = node.id + '_' + i;
779
- const attrs = {
780
- className,
781
- style,
782
- key
783
- };
784
- children.push(React.createElement('div', attrs, affix.data));
785
- }
786
- return <React.Fragment>{children}</React.Fragment>;
787
- }
788
-
789
- /**
790
- * Decorate the tree node icon.
791
- * @param node the tree node.
792
- * @param icon the icon.
793
- */
794
- protected decorateIcon(node: TreeNode, icon: React.ReactNode): React.ReactNode {
795
- if (!icon) {
796
- return;
797
- }
798
- const overlayIcons: React.ReactNode[] = [];
799
- // if multiple overlays have the same overlay.position attribute, we'll de-duplicate those and only process the first one from the decoration array
800
- const seenPositions = new Set<TreeDecoration.IconOverlayPosition>();
801
- const overlays = this.getDecorationData(node, 'iconOverlay').filter(notEmpty);
802
-
803
- for (const overlay of overlays) {
804
- if (!seenPositions.has(overlay.position)) {
805
- seenPositions.add(overlay.position);
806
- const iconClasses = [TreeDecoration.Styles.DECORATOR_SIZE_CLASS, TreeDecoration.IconOverlayPosition.getStyle(overlay.position)];
807
- const style = (color?: string) => color === undefined ? {} : { color };
808
-
809
- if (overlay.background) {
810
- overlayIcons.push(<span key={node.id + 'bg'} className={this.getIconClass(overlay.background.shape, iconClasses)}
811
- style={style(overlay.background.color)}></span>);
812
- }
813
-
814
- const overlayIcon = 'icon' in overlay ? overlay.icon : overlay.iconClass;
815
- overlayIcons.push(<span key={node.id} className={this.getIconClass(overlayIcon, iconClasses)} style={style(overlay.color)}></span>);
816
- }
817
- }
818
-
819
- if (overlayIcons.length > 0) {
820
- return <div className={TreeDecoration.Styles.ICON_WRAPPER_CLASS}>{icon}{overlayIcons}</div>;
821
- }
822
-
823
- return icon;
824
- }
825
-
826
- /**
827
- * Render the tree node tail decorations.
828
- * @param node the tree node.
829
- * @param props the node properties.
830
- */
831
- protected renderTailDecorations(node: TreeNode, props: NodeProps): React.ReactNode {
832
- const tailDecorations = this.getDecorationData(node, 'tailDecorations').reduce((acc, current) => acc.concat(current), []);
833
- if (tailDecorations.length === 0) {
834
- return;
835
- }
836
- return this.renderTailDecorationsForNode(node, props, tailDecorations);
837
- }
838
-
839
- protected renderTailDecorationsForNode(node: TreeNode, props: NodeProps, tailDecorations: TreeDecoration.TailDecoration.AnyPartial[]): React.ReactNode {
840
- let dotDecoration: TreeDecoration.TailDecoration.AnyPartial | undefined;
841
- const otherDecorations: TreeDecoration.TailDecoration.AnyPartial[] = [];
842
- tailDecorations.reverse().forEach(decoration => {
843
- if (TreeDecoration.TailDecoration.isDotDecoration(decoration)) {
844
- dotDecoration ||= decoration;
845
- } else if (decoration.data || decoration.icon || decoration.iconClass) {
846
- otherDecorations.push(decoration);
847
- }
848
- });
849
- const decorationsToRender = dotDecoration ? [dotDecoration, ...otherDecorations] : otherDecorations;
850
- return <React.Fragment>
851
- {decorationsToRender.map((decoration, index) => {
852
- const { tooltip, data, fontData, color, icon, iconClass } = decoration;
853
- const iconToRender = icon ?? iconClass;
854
- const className = [TREE_NODE_SEGMENT_CLASS, TREE_NODE_TAIL_CLASS, 'flex'].join(' ');
855
- const style = fontData ? this.applyFontStyles({}, fontData) : color ? { color } : undefined;
856
- const content = data ? data : iconToRender
857
- ? <span
858
- key={node.id + 'icon' + index}
859
- className={this.getIconClass(iconToRender, iconToRender === 'circle' ? [TreeDecoration.Styles.DECORATOR_SIZE_CLASS] : [])}
860
- ></span>
861
- : '';
862
- return <div key={node.id + className + index} className={className} style={style} title={tooltip}>
863
- {content}{index !== decorationsToRender.length - 1 ? ',' : ''}
864
- </div>;
865
- })}
866
- </React.Fragment>;
867
- }
868
-
869
- /**
870
- * Determine the classes to use for an icon
871
- * - Assumes a Font Awesome name when passed a single string, otherwise uses the passed string array
872
- * @param iconName the icon name or list of icon names.
873
- * @param additionalClasses additional CSS classes.
874
- *
875
- * @returns the icon class name.
876
- */
877
- protected getIconClass(iconName: string | string[], additionalClasses: string[] = []): string {
878
- const iconClass = (typeof iconName === 'string') ? ['a', 'fa', `fa-${iconName}`] : ['a'].concat(iconName);
879
- return iconClass.concat(additionalClasses).join(' ');
880
- }
881
-
882
- /**
883
- * Render indent for the file tree based on the depth
884
- * @param node the tree node.
885
- * @param depth the depth of the tree node.
886
- */
887
- protected renderIndent(node: TreeNode, props: NodeProps): React.ReactNode {
888
- const renderIndentGuides = this.corePreferences['workbench.tree.renderIndentGuides'];
889
- if (renderIndentGuides === 'none') {
890
- return undefined;
891
- }
892
-
893
- const indentDivs: React.ReactNode[] = [];
894
- let current: TreeNode | undefined = node;
895
- let depth = props.depth;
896
- while (current && depth) {
897
- if (this.shouldRenderIndent(current)) {
898
- const classNames: string[] = [TREE_NODE_INDENT_GUIDE_CLASS];
899
- if (this.needsActiveIndentGuideline(current)) {
900
- classNames.push('active');
901
- } else {
902
- classNames.push(renderIndentGuides === 'onHover' ? 'hover' : 'always');
903
- }
904
- const paddingLeft = this.getDepthPadding(depth);
905
- indentDivs.unshift(<div key={depth} className={classNames.join(' ')} style={{
906
- paddingLeft: `${paddingLeft}px`
907
- }} />);
908
- depth--;
909
- }
910
- current = current.parent;
911
- }
912
- return indentDivs;
913
- }
914
-
915
- /**
916
- * Determines whether an indentation div should be rendered for the specified tree node.
917
- * If there are multiple tree nodes inside of a single rendered row,
918
- * this method should only return true for the first node.
919
- */
920
- protected shouldRenderIndent(node: TreeNode): boolean {
921
- return true;
922
- }
923
-
924
- protected needsActiveIndentGuideline(node: TreeNode): boolean {
925
- const parent = node.parent;
926
- if (!parent || !this.isExpandable(parent)) {
927
- return false;
928
- }
929
- if (SelectableTreeNode.isSelected(parent)) {
930
- return true;
931
- }
932
- if (parent.expanded) {
933
- for (const sibling of parent.children) {
934
- if (SelectableTreeNode.isSelected(sibling) && !(this.isExpandable(sibling) && sibling.expanded)) {
935
- return true;
936
- }
937
- }
938
- }
939
- return false;
940
- }
941
-
942
- /**
943
- * Render the node given the tree node and node properties.
944
- * @param node the tree node.
945
- * @param props the node properties.
946
- */
947
- protected renderNode(node: TreeNode, props: NodeProps): React.ReactNode {
948
- if (!TreeNode.isVisible(node)) {
949
- return undefined;
950
- }
951
- const attributes = this.createNodeAttributes(node, props);
952
- const content = <div className={TREE_NODE_CONTENT_CLASS}>
953
- {this.renderExpansionToggle(node, props)}
954
- {this.renderCheckbox(node, props)}
955
- {this.decorateIcon(node, this.renderIcon(node, props))}
956
- {this.renderCaptionAffixes(node, props, 'captionPrefixes')}
957
- {this.renderCaption(node, props)}
958
- {this.renderCaptionAffixes(node, props, 'captionSuffixes')}
959
- {this.renderTailDecorations(node, props)}
960
- </div>;
961
- return React.createElement('div', attributes, content);
962
- }
963
-
964
- /**
965
- * Create node attributes for the tree node given the node properties.
966
- * @param node the tree node.
967
- * @param props the node properties.
968
- */
969
- protected createNodeAttributes(node: TreeNode, props: NodeProps): React.Attributes & React.HTMLAttributes<HTMLElement> {
970
- const className = this.createNodeClassNames(node, props).join(' ');
971
- const style = this.createNodeStyle(node, props);
972
- return {
973
- className,
974
- style,
975
- onClick: event => this.handleClickEvent(node, event),
976
- onDoubleClick: event => this.handleDblClickEvent(node, event),
977
- onAuxClick: event => this.handleAuxClickEvent(node, event),
978
- onContextMenu: event => this.handleContextMenuEvent(node, event),
979
- };
980
- }
981
-
982
- /**
983
- * Create the node class names.
984
- * @param node the tree node.
985
- * @param props the node properties.
986
- *
987
- * @returns the list of tree node class names.
988
- */
989
- protected createNodeClassNames(node: TreeNode, props: NodeProps): string[] {
990
- const classNames = [TREE_NODE_CLASS];
991
- if (CompositeTreeNode.is(node)) {
992
- classNames.push(COMPOSITE_TREE_NODE_CLASS);
993
- }
994
- if (this.isExpandable(node)) {
995
- classNames.push(EXPANDABLE_TREE_NODE_CLASS);
996
- }
997
- if (this.rowIsSelected(node, props)) {
998
- classNames.push(SELECTED_CLASS);
999
- }
1000
- if (this.focusService.hasFocus(node)) {
1001
- classNames.push(FOCUS_CLASS);
1002
- }
1003
- return classNames;
1004
- }
1005
-
1006
- protected rowIsSelected(node: TreeNode, props: NodeProps): boolean {
1007
- return SelectableTreeNode.isSelected(node);
1008
- }
1009
-
1010
- /**
1011
- * Get the default node style.
1012
- * @param node the tree node.
1013
- * @param props the node properties.
1014
- *
1015
- * @returns the CSS properties if available.
1016
- */
1017
- protected getDefaultNodeStyle(node: TreeNode, props: NodeProps): React.CSSProperties | undefined {
1018
- const paddingLeft = this.getPaddingLeft(node, props) + 'px';
1019
- return { paddingLeft };
1020
- }
1021
-
1022
- protected getPaddingLeft(node: TreeNode, props: NodeProps): number {
1023
- return this.getDepthPadding(props.depth) + (this.needsExpansionTogglePadding(node) ? this.props.expansionTogglePadding : 0);
1024
- }
1025
-
1026
- /**
1027
- * If the node is a composite, a toggle will be rendered.
1028
- * Otherwise we need to add the width and the left, right padding => 18px
1029
- */
1030
- protected needsExpansionTogglePadding(node: TreeNode): boolean {
1031
- return !this.isExpandable(node);
1032
- }
1033
-
1034
- /**
1035
- * Create the tree node style.
1036
- * @param node the tree node.
1037
- * @param props the node properties.
1038
- */
1039
- protected createNodeStyle(node: TreeNode, props: NodeProps): React.CSSProperties | undefined {
1040
- return this.decorateNodeStyle(node, this.getDefaultNodeStyle(node, props));
1041
- }
1042
-
1043
- /**
1044
- * Decorate the node style.
1045
- * @param node the tree node.
1046
- * @param style the optional CSS properties.
1047
- *
1048
- * @returns the CSS styles if available.
1049
- */
1050
- protected decorateNodeStyle(node: TreeNode, style: React.CSSProperties | undefined): React.CSSProperties | undefined {
1051
- const backgroundColor = this.getDecorationData(node, 'backgroundColor').filter(notEmpty).shift();
1052
- if (backgroundColor) {
1053
- style = {
1054
- ...(style || {}),
1055
- backgroundColor
1056
- };
1057
- }
1058
- return style;
1059
- }
1060
-
1061
- /**
1062
- * Determine if the tree node is expandable.
1063
- * @param node the tree node.
1064
- *
1065
- * @returns `true` if the tree node is expandable.
1066
- */
1067
- protected isExpandable(node: TreeNode): node is ExpandableTreeNode {
1068
- return ExpandableTreeNode.is(node);
1069
- }
1070
-
1071
- /**
1072
- * Get the tree node decorations.
1073
- * @param node the tree node.
1074
- *
1075
- * @returns the list of tree decoration data.
1076
- */
1077
- protected getDecorations(node: TreeNode): TreeDecoration.Data[] {
1078
- const decorations: TreeDecoration.Data[] = [];
1079
- if (DecoratedTreeNode.is(node)) {
1080
- decorations.push(node.decorationData);
1081
- }
1082
- if (this.decorations.has(node.id)) {
1083
- decorations.push(...this.decorations.get(node.id)!);
1084
- }
1085
- return decorations.sort(TreeDecoration.Data.comparePriority);
1086
- }
1087
-
1088
- /**
1089
- * Get the tree decoration data for the given key.
1090
- * @param node the tree node.
1091
- * @param key the tree decoration data key.
1092
- *
1093
- * @returns the tree decoration data at the given key.
1094
- */
1095
- protected getDecorationData<K extends keyof TreeDecoration.Data>(node: TreeNode, key: K): Required<Pick<TreeDecoration.Data, K>>[K][] {
1096
- return this.getDecorations(node).filter(data => data[key] !== undefined).map(data => data[key]);
1097
- }
1098
-
1099
- /**
1100
- * Store the last scroll state.
1101
- */
1102
- protected lastScrollState: {
1103
- /**
1104
- * The scroll top value.
1105
- */
1106
- scrollTop: number,
1107
- /**
1108
- * The scroll left value.
1109
- */
1110
- scrollLeft: number
1111
- } | undefined;
1112
-
1113
- /**
1114
- * Get the scroll container.
1115
- */
1116
- protected override getScrollContainer(): MaybePromise<HTMLElement> {
1117
- this.toDisposeOnDetach.push(Disposable.create(() => {
1118
- const { scrollTop, scrollLeft } = this.node;
1119
- this.lastScrollState = { scrollTop, scrollLeft };
1120
- }));
1121
- if (this.lastScrollState) {
1122
- const { scrollTop, scrollLeft } = this.lastScrollState;
1123
- this.node.scrollTop = scrollTop;
1124
- this.node.scrollLeft = scrollLeft;
1125
- }
1126
- return this.node;
1127
- }
1128
-
1129
- protected override onAfterAttach(msg: Message): void {
1130
- const up = [
1131
- Key.ARROW_UP,
1132
- KeyCode.createKeyCode({ first: Key.ARROW_UP, modifiers: [KeyModifier.Shift] })
1133
- ];
1134
- const down = [
1135
- Key.ARROW_DOWN,
1136
- KeyCode.createKeyCode({ first: Key.ARROW_DOWN, modifiers: [KeyModifier.Shift] })
1137
- ];
1138
- if (this.props.search) {
1139
- if (this.searchBox.isAttached) {
1140
- Widget.detach(this.searchBox);
1141
- }
1142
- UnsafeWidgetUtilities.attach(this.searchBox, this.node.parentElement!);
1143
- this.addKeyListener(this.node, this.searchBox.keyCodePredicate.bind(this.searchBox), this.searchBox.handle.bind(this.searchBox));
1144
- this.toDisposeOnDetach.push(Disposable.create(() => {
1145
- Widget.detach(this.searchBox);
1146
- }));
1147
- }
1148
- super.onAfterAttach(msg);
1149
- this.addKeyListener(this.node, Key.ARROW_LEFT, event => this.handleLeft(event));
1150
- this.addKeyListener(this.node, Key.ARROW_RIGHT, event => this.handleRight(event));
1151
- this.addKeyListener(this.node, up, event => this.handleUp(event));
1152
- this.addKeyListener(this.node, down, event => this.handleDown(event));
1153
- this.addKeyListener(this.node, Key.ENTER, event => this.handleEnter(event));
1154
- this.addKeyListener(this.node, Key.SPACE, event => this.handleSpace(event));
1155
- this.addKeyListener(this.node, Key.ESCAPE, event => this.handleEscape(event));
1156
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1157
- this.addEventListener<any>(this.node, 'ps-scroll-y', (e: Event & { target: { scrollTop: number } }) => {
1158
- if (this.view && this.view.list) {
1159
- const { scrollTop } = e.target;
1160
- this.view.list.scrollTo({
1161
- top: scrollTop
1162
- });
1163
- }
1164
- });
1165
- }
1166
-
1167
- /**
1168
- * Handle the `left arrow` keyboard event.
1169
- * @param event the `left arrow` keyboard event.
1170
- */
1171
- protected async handleLeft(event: KeyboardEvent): Promise<void> {
1172
- if (!!this.props.multiSelect && (this.hasCtrlCmdMask(event) || this.hasShiftMask(event))) {
1173
- return;
1174
- }
1175
- if (!await this.model.collapseNode()) {
1176
- this.model.selectParent();
1177
- }
1178
- }
1179
-
1180
- /**
1181
- * Handle the `right arrow` keyboard event.
1182
- * @param event the `right arrow` keyboard event.
1183
- */
1184
- protected async handleRight(event: KeyboardEvent): Promise<void> {
1185
- if (!!this.props.multiSelect && (this.hasCtrlCmdMask(event) || this.hasShiftMask(event))) {
1186
- return;
1187
- }
1188
- if (!await this.model.expandNode()) {
1189
- this.model.selectNextNode();
1190
- }
1191
- }
1192
-
1193
- /**
1194
- * Handle the `up arrow` keyboard event.
1195
- * @param event the `up arrow` keyboard event.
1196
- */
1197
- protected handleUp(event: KeyboardEvent): void {
1198
- if (!!this.props.multiSelect && this.hasShiftMask(event)) {
1199
- this.model.selectPrevNode(TreeSelection.SelectionType.RANGE);
1200
- } else {
1201
- this.model.selectPrevNode();
1202
- }
1203
- this.node.focus();
1204
- }
1205
-
1206
- /**
1207
- * Handle the `down arrow` keyboard event.
1208
- * @param event the `down arrow` keyboard event.
1209
- */
1210
- protected handleDown(event: KeyboardEvent): void {
1211
- if (!!this.props.multiSelect && this.hasShiftMask(event)) {
1212
- this.model.selectNextNode(TreeSelection.SelectionType.RANGE);
1213
- } else {
1214
- this.model.selectNextNode();
1215
- }
1216
- this.node.focus();
1217
- }
1218
-
1219
- /**
1220
- * Handle the `enter key` keyboard event.
1221
- * - `enter` opens the tree node.
1222
- * @param event the `enter key` keyboard event.
1223
- */
1224
- protected handleEnter(event: KeyboardEvent): void {
1225
- this.model.openNode();
1226
- }
1227
-
1228
- /**
1229
- * Handle the `space key` keyboard event.
1230
- * - By default should be similar to a single-click action.
1231
- * @param event the `space key` keyboard event.
1232
- */
1233
- protected handleSpace(event: KeyboardEvent): void {
1234
- const { focusedNode } = this.focusService;
1235
- if (!this.props.multiSelect || (!event.ctrlKey && !event.metaKey && !event.shiftKey)) {
1236
- this.tapNode(focusedNode);
1237
- }
1238
- }
1239
-
1240
- protected handleEscape(event: KeyboardEvent): void {
1241
- if (this.model.selectedNodes.length <= 1) {
1242
- this.focusService.setFocus(undefined);
1243
- this.node.focus();
1244
- }
1245
- this.model.clearSelection();
1246
- }
1247
-
1248
- /**
1249
- * Handle the single-click mouse event.
1250
- * @param node the tree node if available.
1251
- * @param event the mouse single-click event.
1252
- */
1253
- protected handleClickEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement>): void {
1254
- if (node) {
1255
- event.stopPropagation();
1256
- const shiftMask = this.hasShiftMask(event);
1257
- const ctrlCmdMask = this.hasCtrlCmdMask(event);
1258
- if (this.props.multiSelect && (shiftMask || ctrlCmdMask) && SelectableTreeNode.is(node)) {
1259
- if (shiftMask) {
1260
- this.model.selectRange(node);
1261
- } else if (ctrlCmdMask) {
1262
- this.model.toggleNode(node);
1263
- }
1264
- } else {
1265
- this.tapNode(node);
1266
- }
1267
- }
1268
- }
1269
-
1270
- /**
1271
- * The effective handler of an unmodified single-click event.
1272
- */
1273
- protected tapNode(node?: TreeNode): void {
1274
- if (SelectableTreeNode.is(node)) {
1275
- this.model.selectNode(node);
1276
- }
1277
- if (node && !this.props.expandOnlyOnExpansionToggleClick && this.isExpandable(node)) {
1278
- this.model.toggleNodeExpansion(node);
1279
- }
1280
- }
1281
-
1282
- /**
1283
- * Handle the double-click mouse event.
1284
- * @param node the tree node if available.
1285
- * @param event the double-click mouse event.
1286
- */
1287
- protected handleDblClickEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement>): void {
1288
- this.model.openNode(node);
1289
- event.stopPropagation();
1290
- }
1291
-
1292
- /**
1293
- * Handle the middle-click mouse event.
1294
- * @param node the tree node if available.
1295
- * @param event the middle-click mouse event.
1296
- */
1297
- protected handleAuxClickEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement>): void {
1298
- if (event.button === 1) {
1299
- this.model.openNode(node);
1300
- if (SelectableTreeNode.is(node)) {
1301
- this.model.selectNode(node);
1302
- }
1303
- }
1304
- event.stopPropagation();
1305
- }
1306
-
1307
- /**
1308
- * Handle the middle-click mouse event.
1309
- * @param event the middle-click mouse event.
1310
- */
1311
- protected handleMiddleClickEvent(event: MouseEvent): void {
1312
- // Prevents auto-scrolling behavior when middle-clicking.
1313
- if (event.button === 1) {
1314
- event.preventDefault();
1315
- }
1316
- }
1317
-
1318
- /**
1319
- * Handle the context menu click event.
1320
- * - The context menu click event is triggered by the right-click.
1321
- * @param node the tree node if available.
1322
- * @param event the right-click mouse event.
1323
- */
1324
- protected handleContextMenuEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement>): void {
1325
- if (SelectableTreeNode.is(node)) {
1326
- // Keep the selection for the context menu, if the widget support multi-selection and the right click happens on an already selected node.
1327
- if (!this.props.multiSelect || !node.selected) {
1328
- const type = !!this.props.multiSelect && this.hasCtrlCmdMask(event) ? TreeSelection.SelectionType.TOGGLE : TreeSelection.SelectionType.DEFAULT;
1329
- this.model.addSelection({ node, type });
1330
- }
1331
- this.focusService.setFocus(node);
1332
- const contextMenuPath = this.props.contextMenuPath;
1333
- if (contextMenuPath) {
1334
- const { x, y } = event.nativeEvent;
1335
- const args = this.toContextMenuArgs(node);
1336
- setTimeout(() => this.contextMenuRenderer.render({
1337
- menuPath: contextMenuPath,
1338
- anchor: { x, y },
1339
- args
1340
- }), 10);
1341
- }
1342
- }
1343
- event.stopPropagation();
1344
- event.preventDefault();
1345
- }
1346
-
1347
- /**
1348
- * Handle the double-click mouse event on the expansion toggle.
1349
- */
1350
- protected readonly handleExpansionToggleDblClickEvent = (event: React.MouseEvent<HTMLElement>) => this.doHandleExpansionToggleDblClickEvent(event);
1351
- /**
1352
- * Actually handle the double-click mouse event on the expansion toggle.
1353
- * @param event the double-click mouse event.
1354
- */
1355
- protected doHandleExpansionToggleDblClickEvent(event: React.MouseEvent<HTMLElement>): void {
1356
- if (this.props.expandOnlyOnExpansionToggleClick) {
1357
- // Ignore the double-click event.
1358
- event.stopPropagation();
1359
- }
1360
- }
1361
-
1362
- /**
1363
- * Convert the tree node to context menu arguments.
1364
- * @param node the selectable tree node.
1365
- */
1366
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1367
- protected toContextMenuArgs(node: SelectableTreeNode): any[] | undefined {
1368
- return undefined;
1369
- }
1370
-
1371
- /**
1372
- * Determine if the tree modifier aware event has a `ctrlcmd` mask.
1373
- * @param event the tree modifier aware event.
1374
- *
1375
- * @returns `true` if the tree modifier aware event contains the `ctrlcmd` mask.
1376
- */
1377
- protected hasCtrlCmdMask(event: TreeWidget.ModifierAwareEvent): boolean {
1378
- return isOSX ? event.metaKey : event.ctrlKey;
1379
- }
1380
-
1381
- /**
1382
- * Determine if the tree modifier aware event has a `shift` mask.
1383
- * @param event the tree modifier aware event.
1384
- *
1385
- * @returns `true` if the tree modifier aware event contains the `shift` mask.
1386
- */
1387
- protected hasShiftMask(event: TreeWidget.ModifierAwareEvent): boolean {
1388
- // Ctrl/Cmd mask overrules the Shift mask.
1389
- if (this.hasCtrlCmdMask(event)) {
1390
- return false;
1391
- }
1392
- return event.shiftKey;
1393
- }
1394
-
1395
- /**
1396
- * Deflate the tree node for storage.
1397
- * @param node the tree node.
1398
- */
1399
- protected deflateForStorage(node: TreeNode): object {
1400
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1401
- const copy = Object.assign({}, node) as any;
1402
- if (copy.parent) {
1403
- delete copy.parent;
1404
- }
1405
- if ('previousSibling' in copy) {
1406
- delete copy.previousSibling;
1407
- }
1408
- if ('nextSibling' in copy) {
1409
- delete copy.nextSibling;
1410
- }
1411
- if ('busy' in copy) {
1412
- delete copy.busy;
1413
- }
1414
- if (CompositeTreeNode.is(node)) {
1415
- copy.children = [];
1416
- for (const child of node.children) {
1417
- copy.children.push(this.deflateForStorage(child));
1418
- }
1419
- }
1420
- return copy;
1421
- }
1422
-
1423
- /**
1424
- * Inflate the tree node from storage.
1425
- * @param node the tree node.
1426
- * @param parent the optional tree node.
1427
- */
1428
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1429
- protected inflateFromStorage(node: any, parent?: TreeNode): TreeNode {
1430
- if (node.selected) {
1431
- node.selected = false;
1432
- }
1433
- if (parent) {
1434
- node.parent = parent;
1435
- }
1436
- if (Array.isArray(node.children)) {
1437
- for (const child of node.children as TreeNode[]) {
1438
- this.inflateFromStorage(child, node);
1439
- }
1440
- }
1441
- return node;
1442
- }
1443
-
1444
- /**
1445
- * Store the tree state.
1446
- */
1447
- storeState(): object {
1448
- const decorations = this.decoratorService.deflateDecorators(this.decorations);
1449
- let state: object = {
1450
- decorations
1451
- };
1452
- if (this.model.root) {
1453
- state = {
1454
- ...state,
1455
- root: this.deflateForStorage(this.model.root),
1456
- model: this.model.storeState(),
1457
- focusedNodeId: this.focusService.focusedNode?.id
1458
- };
1459
- }
1460
-
1461
- return state;
1462
- }
1463
-
1464
- /**
1465
- * Restore the state.
1466
- * @param oldState the old state object.
1467
- */
1468
- restoreState(oldState: object): void {
1469
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1470
- const { root, decorations, model, focusedNodeId } = (oldState as any);
1471
- if (root) {
1472
- this.model.root = this.inflateFromStorage(root);
1473
- }
1474
- if (decorations) {
1475
- this.decorations = this.decoratorService.inflateDecorators(decorations);
1476
- }
1477
- if (model) {
1478
- this.model.restoreState(model);
1479
- }
1480
- if (focusedNodeId) {
1481
- const candidate = this.model.getNode(focusedNodeId);
1482
- if (SelectableTreeNode.is(candidate)) {
1483
- this.focusService.setFocus(candidate);
1484
- }
1485
- }
1486
- }
1487
-
1488
- protected toNodeIcon(node: TreeNode): string {
1489
- return this.labelProvider.getIcon(node);
1490
- }
1491
-
1492
- protected toNodeName(node: TreeNode): string {
1493
- return this.labelProvider.getName(node);
1494
- }
1495
-
1496
- protected toNodeDescription(node: TreeNode): string {
1497
- return this.labelProvider.getLongName(node);
1498
- }
1499
- protected getDepthPadding(depth: number): number {
1500
- return depth * this.props.leftPadding;
1501
- }
1502
- }
1503
- export namespace TreeWidget {
1504
- /**
1505
- * Representation of a tree node row.
1506
- */
1507
- export interface NodeRow {
1508
- /**
1509
- * The node row index.
1510
- */
1511
- index: number
1512
- /**
1513
- * The actual node.
1514
- */
1515
- node: TreeNode
1516
- /**
1517
- * A root relative number representing the hierarchical depth of the actual node. Root is `0`, its children have `1` and so on.
1518
- */
1519
- depth: number
1520
- }
1521
- /**
1522
- * Representation of the tree view properties.
1523
- */
1524
- export interface ViewProps {
1525
- /**
1526
- * The width property.
1527
- */
1528
- width: number
1529
- /**
1530
- * The height property.
1531
- */
1532
- height: number
1533
- /**
1534
- * The scroll to row value.
1535
- */
1536
- scrollToRow?: number
1537
- /**
1538
- * The list of node rows.
1539
- */
1540
- rows: NodeRow[]
1541
- renderNodeRow: (row: NodeRow) => React.ReactNode
1542
- }
1543
- export class View extends React.Component<ViewProps> {
1544
- list: VirtuosoHandle | undefined;
1545
- override render(): React.ReactNode {
1546
- const { rows, width, height, scrollToRow } = this.props;
1547
- return <Virtuoso
1548
- ref={list => {
1549
- this.list = (list || undefined);
1550
- if (this.list && scrollToRow !== undefined) {
1551
- this.list.scrollIntoView({
1552
- index: scrollToRow,
1553
- align: 'center'
1554
- });
1555
- }
1556
- }}
1557
- totalCount={rows.length}
1558
- itemContent={index => this.props.renderNodeRow(rows[index])}
1559
- width={width}
1560
- height={height}
1561
- // This is a pixel value, it will scan 200px to the top and bottom of the current view
1562
- overscan={500}
1563
- />;
1564
- }
1565
- }
1566
- }
1
+ // *****************************************************************************
2
+ // Copyright (C) 2018 TypeFox and others.
3
+ //
4
+ // This program and the accompanying materials are made available under the
5
+ // terms of the Eclipse Public License v. 2.0 which is available at
6
+ // http://www.eclipse.org/legal/epl-2.0.
7
+ //
8
+ // This Source Code may also be made available under the following Secondary
9
+ // Licenses when the conditions for such availability set forth in the Eclipse
10
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
+ // with the GNU Classpath Exception which is available at
12
+ // https://www.gnu.org/software/classpath/license.html.
13
+ //
14
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
+ // *****************************************************************************
16
+
17
+ import { injectable, inject, postConstruct } from 'inversify';
18
+ import { Message } from '@phosphor/messaging';
19
+ import { Disposable, MenuPath, SelectionService } from '../../common';
20
+ import { Key, KeyCode, KeyModifier } from '../keyboard/keys';
21
+ import { ContextMenuRenderer } from '../context-menu-renderer';
22
+ import { StatefulWidget } from '../shell';
23
+ import {
24
+ EXPANSION_TOGGLE_CLASS, SELECTED_CLASS, COLLAPSED_CLASS, FOCUS_CLASS, BUSY_CLASS, CODICON_TREE_ITEM_CLASSES, CODICON_LOADING_CLASSES, Widget, UnsafeWidgetUtilities
25
+ } from '../widgets';
26
+ import { TreeNode, CompositeTreeNode } from './tree';
27
+ import { TreeModel } from './tree-model';
28
+ import { ExpandableTreeNode } from './tree-expansion';
29
+ import { SelectableTreeNode, TreeSelection } from './tree-selection';
30
+ import { TreeDecoratorService, TreeDecoration, DecoratedTreeNode } from './tree-decorator';
31
+ import { notEmpty } from '../../common/objects';
32
+ import { isOSX } from '../../common/os';
33
+ import { ReactWidget } from '../widgets/react-widget';
34
+ import * as React from 'react';
35
+ import { Virtuoso, VirtuosoHandle } from 'react-virtuoso';
36
+ import { TopDownTreeIterator } from './tree-iterator';
37
+ import { SearchBox, SearchBoxFactory, SearchBoxProps } from './search-box';
38
+ import { TreeSearch } from './tree-search';
39
+ import { ElementExt } from '@phosphor/domutils';
40
+ import { TreeWidgetSelection } from './tree-widget-selection';
41
+ import { MaybePromise } from '../../common/types';
42
+ import { LabelProvider } from '../label-provider';
43
+ import { CorePreferences } from '../core-preferences';
44
+ import { TreeFocusService } from './tree-focus-service';
45
+ import { useEffect } from 'react';
46
+ import { PreferenceService, PreferenceChange } from '../preferences';
47
+ import { PREFERENCE_NAME_TREE_INDENT } from './tree-preference';
48
+
49
+ const debounce = require('lodash.debounce');
50
+
51
+ export const TREE_CLASS = 'theia-Tree';
52
+ export const TREE_CONTAINER_CLASS = 'theia-TreeContainer';
53
+ export const TREE_NODE_CLASS = 'theia-TreeNode';
54
+ export const TREE_NODE_CONTENT_CLASS = 'theia-TreeNodeContent';
55
+ export const TREE_NODE_INFO_CLASS = 'theia-TreeNodeInfo';
56
+ export const TREE_NODE_TAIL_CLASS = 'theia-TreeNodeTail';
57
+ export const TREE_NODE_SEGMENT_CLASS = 'theia-TreeNodeSegment';
58
+ export const TREE_NODE_SEGMENT_GROW_CLASS = 'theia-TreeNodeSegmentGrow';
59
+
60
+ export const EXPANDABLE_TREE_NODE_CLASS = 'theia-ExpandableTreeNode';
61
+ export const COMPOSITE_TREE_NODE_CLASS = 'theia-CompositeTreeNode';
62
+ export const TREE_NODE_CAPTION_CLASS = 'theia-TreeNodeCaption';
63
+ export const TREE_NODE_INDENT_GUIDE_CLASS = 'theia-tree-node-indent';
64
+
65
+ export const TreeProps = Symbol('TreeProps');
66
+
67
+ /**
68
+ * Representation of tree properties.
69
+ */
70
+ export interface TreeProps {
71
+
72
+ /**
73
+ * The path of the context menu that one can use to contribute context menu items to the tree widget.
74
+ */
75
+ readonly contextMenuPath?: MenuPath;
76
+
77
+ /**
78
+ * The size of the padding (in pixels) for the root node of the tree.
79
+ */
80
+ readonly leftPadding: number;
81
+
82
+ readonly expansionTogglePadding: number;
83
+
84
+ /**
85
+ * `true` if the tree widget support multi-selection. Otherwise, `false`. Defaults to `false`.
86
+ */
87
+ readonly multiSelect?: boolean;
88
+
89
+ /**
90
+ * `true` if the tree widget support searching. Otherwise, `false`. Defaults to `false`.
91
+ */
92
+ readonly search?: boolean
93
+
94
+ /**
95
+ * `true` if the tree widget should be virtualized searching. Otherwise, `false`. Defaults to `true`.
96
+ */
97
+ readonly virtualized?: boolean
98
+
99
+ /**
100
+ * `true` if the selected node should be auto scrolled only if the widget is active. Otherwise, `false`. Defaults to `false`.
101
+ */
102
+ readonly scrollIfActive?: boolean
103
+
104
+ /**
105
+ * `true` if a tree widget contributes to the global selection. Defaults to `false`.
106
+ */
107
+ readonly globalSelection?: boolean;
108
+
109
+ /**
110
+ * `true` if the tree widget supports expansion only when clicking the expansion toggle. Defaults to `false`.
111
+ */
112
+ readonly expandOnlyOnExpansionToggleClick?: boolean;
113
+
114
+ }
115
+
116
+ /**
117
+ * Representation of node properties.
118
+ */
119
+ export interface NodeProps {
120
+
121
+ /**
122
+ * A root relative number representing the hierarchical depth of the actual node. Root is `0`, its children have `1` and so on.
123
+ */
124
+ readonly depth: number;
125
+
126
+ }
127
+
128
+ /**
129
+ * The default tree properties.
130
+ */
131
+ export const defaultTreeProps: TreeProps = {
132
+ leftPadding: 8,
133
+ expansionTogglePadding: 22
134
+ };
135
+
136
+ export namespace TreeWidget {
137
+
138
+ /**
139
+ * Bare minimum common interface of the keyboard and the mouse event with respect to the key maskings.
140
+ */
141
+ export interface ModifierAwareEvent {
142
+ /**
143
+ * Determines if the modifier aware event has the `meta` key masking.
144
+ */
145
+ readonly metaKey: boolean;
146
+ /**
147
+ * Determines if the modifier aware event has the `ctrl` key masking.
148
+ */
149
+ readonly ctrlKey: boolean;
150
+ /**
151
+ * Determines if the modifier aware event has the `shift` key masking.
152
+ */
153
+ readonly shiftKey: boolean;
154
+ }
155
+
156
+ }
157
+
158
+ @injectable()
159
+ export class TreeWidget extends ReactWidget implements StatefulWidget {
160
+
161
+ protected searchBox: SearchBox;
162
+ protected searchHighlights: Map<string, TreeDecoration.CaptionHighlight>;
163
+
164
+ @inject(TreeDecoratorService)
165
+ protected readonly decoratorService: TreeDecoratorService;
166
+ @inject(TreeSearch)
167
+ protected readonly treeSearch: TreeSearch;
168
+ @inject(SearchBoxFactory)
169
+ protected readonly searchBoxFactory: SearchBoxFactory;
170
+ @inject(TreeFocusService)
171
+ protected readonly focusService: TreeFocusService;
172
+
173
+ protected decorations: Map<string, TreeDecoration.Data[]> = new Map();
174
+
175
+ @inject(SelectionService)
176
+ protected readonly selectionService: SelectionService;
177
+
178
+ @inject(PreferenceService)
179
+ protected readonly preferenceService: PreferenceService;
180
+
181
+ @inject(LabelProvider)
182
+ protected readonly labelProvider: LabelProvider;
183
+
184
+ @inject(CorePreferences)
185
+ protected readonly corePreferences: CorePreferences;
186
+
187
+ protected shouldScrollToRow = true;
188
+
189
+ protected treeIndent: number = 8;
190
+
191
+ constructor(
192
+ @inject(TreeProps) readonly props: TreeProps,
193
+ @inject(TreeModel) readonly model: TreeModel,
194
+ @inject(ContextMenuRenderer) protected readonly contextMenuRenderer: ContextMenuRenderer,
195
+ ) {
196
+ super();
197
+ this.scrollOptions = {
198
+ suppressScrollX: true,
199
+ minScrollbarLength: 35
200
+ };
201
+ this.addClass(TREE_CLASS);
202
+ this.node.tabIndex = 0;
203
+ }
204
+
205
+ @postConstruct()
206
+ protected init(): void {
207
+ this.treeIndent = this.preferenceService.get(PREFERENCE_NAME_TREE_INDENT, this.treeIndent);
208
+ if (this.props.search) {
209
+ this.searchBox = this.searchBoxFactory({ ...SearchBoxProps.DEFAULT, showButtons: true, showFilter: true });
210
+ this.searchBox.node.addEventListener('focus', () => {
211
+ this.node.focus();
212
+ });
213
+ this.toDispose.pushAll([
214
+ this.searchBox,
215
+ this.searchBox.onTextChange(async data => {
216
+ await this.treeSearch.filter(data);
217
+ this.searchHighlights = this.treeSearch.getHighlights();
218
+ this.searchBox.updateHighlightInfo({
219
+ filterText: data,
220
+ total: this.rows.size,
221
+ matched: this.searchHighlights.size
222
+ });
223
+ this.update();
224
+ }),
225
+ this.searchBox.onClose(data => this.treeSearch.filter(undefined)),
226
+ this.searchBox.onNext(() => {
227
+ // Enable next selection if there are currently highlights.
228
+ if (this.searchHighlights.size > 1) {
229
+ this.model.selectNextNode();
230
+ }
231
+ }),
232
+ this.searchBox.onPrevious(() => {
233
+ // Enable previous selection if there are currently highlights.
234
+ if (this.searchHighlights.size > 1) {
235
+ this.model.selectPrevNode();
236
+ }
237
+ }),
238
+ this.searchBox.onFilterToggled(e => {
239
+ this.updateRows();
240
+ }),
241
+ this.treeSearch,
242
+ this.treeSearch.onFilteredNodesChanged(nodes => {
243
+ if (this.searchBox.isFiltering) {
244
+ this.updateRows();
245
+ }
246
+ const node = nodes.find(SelectableTreeNode.is);
247
+ if (node) {
248
+ this.model.selectNode(node);
249
+ }
250
+ }),
251
+ ]);
252
+ }
253
+ this.node.addEventListener('mousedown', this.handleMiddleClickEvent.bind(this));
254
+ this.node.addEventListener('mouseup', this.handleMiddleClickEvent.bind(this));
255
+ this.node.addEventListener('auxclick', this.handleMiddleClickEvent.bind(this));
256
+ this.toDispose.pushAll([
257
+ this.model,
258
+ this.model.onChanged(() => this.updateRows()),
259
+ this.model.onSelectionChanged(() => this.scheduleUpdateScrollToRow({ resize: false })),
260
+ this.focusService.onDidChangeFocus(() => this.scheduleUpdateScrollToRow({ resize: false })),
261
+ this.model.onDidChangeBusy(() => this.update()),
262
+ this.model.onDidUpdate(() => this.update()),
263
+ this.model.onNodeRefreshed(() => this.updateDecorations()),
264
+ this.model.onExpansionChanged(() => this.updateDecorations()),
265
+ this.decoratorService,
266
+ this.decoratorService.onDidChangeDecorations(() => this.updateDecorations()),
267
+ this.labelProvider.onDidChange(e => {
268
+ for (const row of this.rows.values()) {
269
+ if (e.affects(row)) {
270
+ this.update();
271
+ return;
272
+ }
273
+ }
274
+ }),
275
+ this.preferenceService.onPreferenceChanged((event: PreferenceChange) => {
276
+ if (event.preferenceName === PREFERENCE_NAME_TREE_INDENT) {
277
+ this.treeIndent = event.newValue;
278
+ this.update();
279
+ }
280
+ })
281
+ ]);
282
+ setTimeout(() => {
283
+ this.updateRows();
284
+ this.updateDecorations();
285
+ });
286
+ if (this.props.globalSelection) {
287
+ this.toDispose.pushAll([
288
+ this.model.onSelectionChanged(() => {
289
+ if (this.node.contains(document.activeElement)) {
290
+ this.updateGlobalSelection();
291
+ }
292
+ }),
293
+ this.focusService.onDidChangeFocus(focus => {
294
+ if (focus && this.node.contains(document.activeElement) && this.model.selectedNodes[0] !== focus && this.model.selectedNodes.includes(focus)) {
295
+ this.updateGlobalSelection();
296
+ }
297
+ }),
298
+ Disposable.create(() => {
299
+ const selection = this.selectionService.selection;
300
+ if (TreeWidgetSelection.isSource(selection, this)) {
301
+ this.selectionService.selection = undefined;
302
+ }
303
+ })
304
+ ]);
305
+ }
306
+ this.toDispose.push(this.corePreferences.onPreferenceChanged(preference => {
307
+ if (preference.preferenceName === 'workbench.tree.renderIndentGuides') {
308
+ this.update();
309
+ }
310
+ }));
311
+ }
312
+
313
+ /**
314
+ * Update the global selection for the tree.
315
+ */
316
+ protected updateGlobalSelection(): void {
317
+ this.selectionService.selection = TreeWidgetSelection.create(this);
318
+ }
319
+
320
+ protected rows = new Map<string, TreeWidget.NodeRow>();
321
+ protected updateRows = debounce(() => this.doUpdateRows(), 10);
322
+ protected doUpdateRows(): void {
323
+ const root = this.model.root;
324
+ const rowsToUpdate: Array<[string, TreeWidget.NodeRow]> = [];
325
+ if (root) {
326
+ const depths = new Map<CompositeTreeNode | undefined, number>();
327
+ let index = 0;
328
+ for (const node of new TopDownTreeIterator(root, {
329
+ pruneCollapsed: true,
330
+ pruneSiblings: true
331
+ })) {
332
+ if (this.shouldDisplayNode(node)) {
333
+ const depth = this.getDepthForNode(node, depths);
334
+ if (CompositeTreeNode.is(node)) {
335
+ depths.set(node, depth);
336
+ }
337
+ rowsToUpdate.push([node.id, this.toNodeRow(node, index++, depth)]);
338
+ }
339
+ }
340
+ }
341
+ this.rows = new Map(rowsToUpdate);
342
+ this.updateScrollToRow();
343
+ }
344
+
345
+ protected getDepthForNode(node: TreeNode, depths: Map<CompositeTreeNode | undefined, number>): number {
346
+ const parentDepth = depths.get(node.parent);
347
+ return parentDepth === undefined ? 0 : TreeNode.isVisible(node.parent) ? parentDepth + 1 : parentDepth;
348
+ }
349
+
350
+ protected toNodeRow(node: TreeNode, index: number, depth: number): TreeWidget.NodeRow {
351
+ return { node, index, depth };
352
+ }
353
+
354
+ protected shouldDisplayNode(node: TreeNode): boolean {
355
+ return TreeNode.isVisible(node) && (!this.searchBox?.isFiltering || this.treeSearch.passesFilters(node));
356
+ }
357
+
358
+ /**
359
+ * Row index to ensure visibility.
360
+ * - Used to forcefully scroll if necessary.
361
+ */
362
+ protected scrollToRow: number | undefined;
363
+ /**
364
+ * Update the `scrollToRow`.
365
+ * @param updateOptions the tree widget force update options.
366
+ */
367
+ protected updateScrollToRow(): void {
368
+ this.scrollToRow = this.getScrollToRow();
369
+ this.update();
370
+ }
371
+
372
+ protected scheduleUpdateScrollToRow = debounce(this.updateScrollToRow);
373
+
374
+ /**
375
+ * Get the `scrollToRow`.
376
+ *
377
+ * @returns the `scrollToRow` if available.
378
+ */
379
+ protected getScrollToRow(): number | undefined {
380
+ if (!this.shouldScrollToRow) {
381
+ return undefined;
382
+ }
383
+ const { focusedNode } = this.focusService;
384
+ return focusedNode && this.rows.get(focusedNode.id)?.index;
385
+ }
386
+
387
+ /**
388
+ * Update tree decorations.
389
+ * - Updating decorations are debounced in order to limit the number of expensive updates.
390
+ */
391
+ protected readonly updateDecorations = debounce(() => this.doUpdateDecorations(), 150);
392
+ protected async doUpdateDecorations(): Promise<void> {
393
+ this.decorations = await this.decoratorService.getDecorations(this.model);
394
+ this.update();
395
+ }
396
+
397
+ protected override onActivateRequest(msg: Message): void {
398
+ super.onActivateRequest(msg);
399
+ this.node.focus({ preventScroll: true });
400
+ }
401
+
402
+ /**
403
+ * Actually focus the tree node.
404
+ */
405
+ protected doFocus(): void {
406
+ if (!this.model.selectedNodes.length) {
407
+ const node = this.getNodeToFocus();
408
+ if (SelectableTreeNode.is(node)) {
409
+ this.model.selectNode(node);
410
+ }
411
+ }
412
+ }
413
+
414
+ /**
415
+ * Get the tree node to focus.
416
+ *
417
+ * @returns the node to focus if available.
418
+ */
419
+ protected getNodeToFocus(): SelectableTreeNode | undefined {
420
+ const { focusedNode } = this.focusService;
421
+ if (focusedNode) {
422
+ return focusedNode;
423
+ }
424
+ const { root } = this.model;
425
+ if (SelectableTreeNode.isVisible(root)) {
426
+ return root;
427
+ }
428
+ return this.model.getNextSelectableNode(root);
429
+ }
430
+
431
+ protected override onUpdateRequest(msg: Message): void {
432
+ if (!this.isAttached || !this.isVisible) {
433
+ return;
434
+ }
435
+ super.onUpdateRequest(msg);
436
+ }
437
+
438
+ protected override onResize(msg: Widget.ResizeMessage): void {
439
+ super.onResize(msg);
440
+ this.update();
441
+ }
442
+
443
+ protected render(): React.ReactNode {
444
+ return React.createElement('div', this.createContainerAttributes(), this.renderTree(this.model));
445
+ }
446
+
447
+ /**
448
+ * Create the container attributes for the widget.
449
+ */
450
+ protected createContainerAttributes(): React.HTMLAttributes<HTMLElement> {
451
+ const classNames = [TREE_CONTAINER_CLASS];
452
+ if (!this.rows.size) {
453
+ classNames.push('empty');
454
+ }
455
+ if (this.model.selectedNodes.length === 0 && !this.focusService.focusedNode) {
456
+ classNames.push('focused');
457
+ }
458
+ return {
459
+ className: classNames.join(' '),
460
+ onContextMenu: event => this.handleContextMenuEvent(this.getContainerTreeNode(), event)
461
+ };
462
+ }
463
+ /**
464
+ * Get the container tree node.
465
+ *
466
+ * @returns the tree node for the container if available.
467
+ */
468
+ protected getContainerTreeNode(): TreeNode | undefined {
469
+ return this.model.root;
470
+ }
471
+
472
+ protected ScrollingRowRenderer: React.FC<{ rows: TreeWidget.NodeRow[] }> = ({ rows }) => {
473
+ useEffect(() => this.scrollToSelected());
474
+ return <>{rows.map(row => <div key={row.index}>{this.renderNodeRow(row)}</div>)}</>;
475
+ };
476
+
477
+ protected view: TreeWidget.View | undefined;
478
+ /**
479
+ * Render the tree widget.
480
+ * @param model the tree model.
481
+ */
482
+ protected renderTree(model: TreeModel): React.ReactNode {
483
+ if (model.root) {
484
+ const rows = Array.from(this.rows.values());
485
+ if (this.props.virtualized === false) {
486
+ return <this.ScrollingRowRenderer rows={rows} />;
487
+ }
488
+ return <TreeWidget.View
489
+ ref={view => this.view = (view || undefined)}
490
+ width={this.node.offsetWidth}
491
+ height={this.node.offsetHeight}
492
+ rows={rows}
493
+ renderNodeRow={this.renderNodeRow}
494
+ scrollToRow={this.scrollToRow}
495
+ />;
496
+ }
497
+ // eslint-disable-next-line no-null/no-null
498
+ return null;
499
+ }
500
+
501
+ scrollArea: Element = this.node;
502
+ /**
503
+ * Scroll to the selected tree node.
504
+ */
505
+ protected scrollToSelected(): void {
506
+ if (this.props.scrollIfActive === true && !this.node.contains(document.activeElement)) {
507
+ return;
508
+ }
509
+ const focus = this.node.getElementsByClassName(FOCUS_CLASS)[0];
510
+ if (focus) {
511
+ ElementExt.scrollIntoViewIfNeeded(this.scrollArea, focus);
512
+ } else {
513
+ const selected = this.node.getElementsByClassName(SELECTED_CLASS)[0];
514
+ if (selected) {
515
+ ElementExt.scrollIntoViewIfNeeded(this.scrollArea, selected);
516
+ }
517
+ }
518
+ }
519
+
520
+ /**
521
+ * Render the node row.
522
+ */
523
+ protected readonly renderNodeRow = (row: TreeWidget.NodeRow) => this.doRenderNodeRow(row);
524
+ /**
525
+ * Actually render the node row.
526
+ */
527
+ protected doRenderNodeRow({ node, depth }: TreeWidget.NodeRow): React.ReactNode {
528
+ return <React.Fragment>
529
+ {this.renderIndent(node, { depth })}
530
+ {this.renderNode(node, { depth })}
531
+ </React.Fragment>;
532
+ }
533
+
534
+ /**
535
+ * Render the tree node given the node properties.
536
+ * @param node the tree node.
537
+ * @param props the node properties.
538
+ */
539
+ protected renderIcon(node: TreeNode, props: NodeProps): React.ReactNode {
540
+ // eslint-disable-next-line no-null/no-null
541
+ return null;
542
+ }
543
+
544
+ /**
545
+ * Toggle the node.
546
+ */
547
+ protected readonly toggle = (event: React.MouseEvent<HTMLElement>) => this.doToggle(event);
548
+ /**
549
+ * Actually toggle the tree node.
550
+ * @param event the mouse click event.
551
+ */
552
+ protected doToggle(event: React.MouseEvent<HTMLElement>): void {
553
+ const nodeId = event.currentTarget.getAttribute('data-node-id');
554
+ if (nodeId) {
555
+ const node = this.model.getNode(nodeId);
556
+ if (node && this.props.expandOnlyOnExpansionToggleClick) {
557
+ if (this.isExpandable(node) && !this.hasShiftMask(event) && !this.hasCtrlCmdMask(event)) {
558
+ this.model.toggleNodeExpansion(node);
559
+ }
560
+ } else {
561
+ this.handleClickEvent(node, event);
562
+ }
563
+ }
564
+ event.stopPropagation();
565
+ }
566
+
567
+ /**
568
+ * Render the node expansion toggle.
569
+ * @param node the tree node.
570
+ * @param props the node properties.
571
+ */
572
+ protected renderExpansionToggle(node: TreeNode, props: NodeProps): React.ReactNode {
573
+ if (!this.isExpandable(node)) {
574
+ // eslint-disable-next-line no-null/no-null
575
+ return null;
576
+ }
577
+ const classes = [TREE_NODE_SEGMENT_CLASS, EXPANSION_TOGGLE_CLASS];
578
+ if (!node.expanded) {
579
+ classes.push(COLLAPSED_CLASS);
580
+ }
581
+ if (node.busy) {
582
+ classes.push(BUSY_CLASS, ...CODICON_LOADING_CLASSES);
583
+ } else {
584
+ classes.push(...CODICON_TREE_ITEM_CLASSES);
585
+ }
586
+ const className = classes.join(' ');
587
+ return <div
588
+ data-node-id={node.id}
589
+ className={className}
590
+ onClick={this.toggle}
591
+ onDoubleClick={this.handleExpansionToggleDblClickEvent}>
592
+ </div>;
593
+ }
594
+
595
+ /**
596
+ * Render the node expansion toggle.
597
+ * @param node the tree node.
598
+ * @param props the node properties.
599
+ */
600
+ protected renderCheckbox(node: TreeNode, props: NodeProps): React.ReactNode {
601
+ if (node.checkboxInfo === undefined) {
602
+ // eslint-disable-next-line no-null/no-null
603
+ return null;
604
+ }
605
+ return <input data-node-id={node.id}
606
+ readOnly
607
+ type='checkbox'
608
+ checked={!!node.checkboxInfo.checked}
609
+ title={node.checkboxInfo.tooltip}
610
+ aria-label={node.checkboxInfo.accessibilityInformation?.label}
611
+ role={node.checkboxInfo.accessibilityInformation?.role}
612
+ className='theia-input'
613
+ onClick={event => this.toggleChecked(event)} />;
614
+ }
615
+
616
+ protected toggleChecked(event: React.MouseEvent<HTMLElement>): void {
617
+ const nodeId = event.currentTarget.getAttribute('data-node-id');
618
+ if (nodeId) {
619
+ const node = this.model.getNode(nodeId);
620
+ if (node) {
621
+ this.model.markAsChecked(node, !node.checkboxInfo!.checked);
622
+ } else {
623
+ this.handleClickEvent(node, event);
624
+ }
625
+ }
626
+ event.preventDefault();
627
+ event.stopPropagation();
628
+ }
629
+ /**
630
+ * Render the tree node caption given the node properties.
631
+ * @param node the tree node.
632
+ * @param props the node properties.
633
+ */
634
+ protected renderCaption(node: TreeNode, props: NodeProps): React.ReactNode {
635
+ const attrs = this.getCaptionAttributes(node, props);
636
+ const children = this.getCaptionChildren(node, props);
637
+ return React.createElement('div', attrs, children);
638
+ }
639
+
640
+ protected getCaptionAttributes(node: TreeNode, props: NodeProps): React.Attributes & React.HTMLAttributes<HTMLElement> {
641
+ const tooltip = this.getDecorationData(node, 'tooltip').filter(notEmpty).join(' • ');
642
+ const classes = [TREE_NODE_SEGMENT_CLASS];
643
+ if (!this.hasTrailingSuffixes(node)) {
644
+ classes.push(TREE_NODE_SEGMENT_GROW_CLASS);
645
+ }
646
+ const className = classes.join(' ');
647
+ let attrs = this.decorateCaption(node, {
648
+ className, id: node.id
649
+ });
650
+ if (tooltip.length > 0) {
651
+ attrs = {
652
+ ...attrs,
653
+ title: tooltip
654
+ };
655
+ }
656
+ return attrs;
657
+ }
658
+
659
+ protected getCaptionChildren(node: TreeNode, props: NodeProps): React.ReactNode {
660
+ const children = [];
661
+ const caption = this.toNodeName(node);
662
+ const highlight = this.getDecorationData(node, 'highlight')[0];
663
+ if (highlight) {
664
+ children.push(this.toReactNode(caption, highlight));
665
+ }
666
+ const searchHighlight = this.searchHighlights ? this.searchHighlights.get(node.id) : undefined;
667
+ if (searchHighlight) {
668
+ children.push(...this.toReactNode(caption, searchHighlight));
669
+ } else if (!highlight) {
670
+ children.push(caption);
671
+ }
672
+ return children;
673
+ }
674
+
675
+ /**
676
+ * Update the node given the caption and highlight.
677
+ * @param caption the caption.
678
+ * @param highlight the tree decoration caption highlight.
679
+ */
680
+ protected toReactNode(caption: string, highlight: TreeDecoration.CaptionHighlight): React.ReactNode[] {
681
+ let style: React.CSSProperties = {};
682
+ if (highlight.color) {
683
+ style = {
684
+ ...style,
685
+ color: highlight.color
686
+ };
687
+ }
688
+ if (highlight.backgroundColor) {
689
+ style = {
690
+ ...style,
691
+ backgroundColor: highlight.backgroundColor
692
+ };
693
+ }
694
+ const createChildren = (fragment: TreeDecoration.CaptionHighlight.Fragment, index: number) => {
695
+ const { data } = fragment;
696
+ if (fragment.highlight) {
697
+ return <mark className={TreeDecoration.Styles.CAPTION_HIGHLIGHT_CLASS} style={style} key={index}>{data}</mark>;
698
+ } else {
699
+ return data;
700
+ }
701
+ };
702
+ return TreeDecoration.CaptionHighlight.split(caption, highlight).map(createChildren);
703
+ }
704
+
705
+ /**
706
+ * Decorate the tree caption.
707
+ * @param node the tree node.
708
+ * @param attrs the additional attributes.
709
+ */
710
+ protected decorateCaption(node: TreeNode, attrs: React.HTMLAttributes<HTMLElement>): React.Attributes & React.HTMLAttributes<HTMLElement> {
711
+ const style = this.getDecorationData(node, 'fontData')
712
+ .filter(notEmpty)
713
+ .reverse()
714
+ .map(fontData => this.applyFontStyles({}, fontData))
715
+ .reduce((acc, current) => ({
716
+ ...acc,
717
+ ...current
718
+ }), {});
719
+ return {
720
+ ...attrs,
721
+ style
722
+ };
723
+ }
724
+
725
+ /**
726
+ * Determine if the tree node contains trailing suffixes.
727
+ * @param node the tree node.
728
+ *
729
+ * @returns `true` if the tree node contains trailing suffices.
730
+ */
731
+ protected hasTrailingSuffixes(node: TreeNode): boolean {
732
+ return this.getDecorationData(node, 'captionSuffixes').filter(notEmpty).reduce((acc, current) => acc.concat(current), []).length > 0;
733
+ }
734
+
735
+ /**
736
+ * Apply font styles to the tree.
737
+ * @param original the original css properties.
738
+ * @param fontData the optional `fontData`.
739
+ */
740
+ protected applyFontStyles(original: React.CSSProperties, fontData: TreeDecoration.FontData | undefined): React.CSSProperties {
741
+ if (fontData === undefined) {
742
+ return original;
743
+ }
744
+ const modified = { ...original }; // make a copy to mutate
745
+ const { color, style } = fontData;
746
+ if (color) {
747
+ modified.color = color;
748
+ }
749
+ if (style) {
750
+ (Array.isArray(style) ? style : [style]).forEach(s => {
751
+ switch (s) {
752
+ case 'bold':
753
+ modified.fontWeight = s;
754
+ break;
755
+ case 'normal':
756
+ case 'oblique':
757
+ case 'italic':
758
+ modified.fontStyle = s;
759
+ break;
760
+ case 'underline':
761
+ case 'line-through':
762
+ modified.textDecoration = s;
763
+ break;
764
+ default:
765
+ throw new Error(`Unexpected font style: "${s}".`);
766
+ }
767
+ });
768
+ }
769
+ return modified;
770
+ }
771
+
772
+ /**
773
+ * Render caption affixes for the given tree node.
774
+ * @param node the tree node.
775
+ * @param props the node properties.
776
+ * @param affixKey the affix key.
777
+ */
778
+ protected renderCaptionAffixes(node: TreeNode, props: NodeProps, affixKey: 'captionPrefixes' | 'captionSuffixes'): React.ReactNode {
779
+ const suffix = affixKey === 'captionSuffixes';
780
+ const affixClass = suffix ? TreeDecoration.Styles.CAPTION_SUFFIX_CLASS : TreeDecoration.Styles.CAPTION_PREFIX_CLASS;
781
+ const classes = [TREE_NODE_SEGMENT_CLASS, affixClass];
782
+ const affixes = this.getDecorationData(node, affixKey).filter(notEmpty).reduce((acc, current) => acc.concat(current), []);
783
+ const children: React.ReactNode[] = [];
784
+ for (let i = 0; i < affixes.length; i++) {
785
+ const affix = affixes[i];
786
+ if (suffix && i === affixes.length - 1) {
787
+ classes.push(TREE_NODE_SEGMENT_GROW_CLASS);
788
+ }
789
+ const style = this.applyFontStyles({}, affix.fontData);
790
+ const className = classes.join(' ');
791
+ const key = node.id + '_' + i;
792
+ const attrs = {
793
+ className,
794
+ style,
795
+ key
796
+ };
797
+ children.push(React.createElement('div', attrs, affix.data));
798
+ }
799
+ return <React.Fragment>{children}</React.Fragment>;
800
+ }
801
+
802
+ /**
803
+ * Decorate the tree node icon.
804
+ * @param node the tree node.
805
+ * @param icon the icon.
806
+ */
807
+ protected decorateIcon(node: TreeNode, icon: React.ReactNode): React.ReactNode {
808
+ if (!icon) {
809
+ return;
810
+ }
811
+ const overlayIcons: React.ReactNode[] = [];
812
+ // if multiple overlays have the same overlay.position attribute, we'll de-duplicate those and only process the first one from the decoration array
813
+ const seenPositions = new Set<TreeDecoration.IconOverlayPosition>();
814
+ const overlays = this.getDecorationData(node, 'iconOverlay').filter(notEmpty);
815
+
816
+ for (const overlay of overlays) {
817
+ if (!seenPositions.has(overlay.position)) {
818
+ seenPositions.add(overlay.position);
819
+ const iconClasses = [TreeDecoration.Styles.DECORATOR_SIZE_CLASS, TreeDecoration.IconOverlayPosition.getStyle(overlay.position)];
820
+ const style = (color?: string) => color === undefined ? {} : { color };
821
+
822
+ if (overlay.background) {
823
+ overlayIcons.push(<span key={node.id + 'bg'} className={this.getIconClass(overlay.background.shape, iconClasses)}
824
+ style={style(overlay.background.color)}></span>);
825
+ }
826
+
827
+ const overlayIcon = 'icon' in overlay ? overlay.icon : overlay.iconClass;
828
+ overlayIcons.push(<span key={node.id} className={this.getIconClass(overlayIcon, iconClasses)} style={style(overlay.color)}></span>);
829
+ }
830
+ }
831
+
832
+ if (overlayIcons.length > 0) {
833
+ return <div className={TreeDecoration.Styles.ICON_WRAPPER_CLASS}>{icon}{overlayIcons}</div>;
834
+ }
835
+
836
+ return icon;
837
+ }
838
+
839
+ /**
840
+ * Render the tree node tail decorations.
841
+ * @param node the tree node.
842
+ * @param props the node properties.
843
+ */
844
+ protected renderTailDecorations(node: TreeNode, props: NodeProps): React.ReactNode {
845
+ const tailDecorations = this.getDecorationData(node, 'tailDecorations').reduce((acc, current) => acc.concat(current), []);
846
+ if (tailDecorations.length === 0) {
847
+ return;
848
+ }
849
+ return this.renderTailDecorationsForNode(node, props, tailDecorations);
850
+ }
851
+
852
+ protected renderTailDecorationsForNode(node: TreeNode, props: NodeProps, tailDecorations: TreeDecoration.TailDecoration.AnyPartial[]): React.ReactNode {
853
+ let dotDecoration: TreeDecoration.TailDecoration.AnyPartial | undefined;
854
+ const otherDecorations: TreeDecoration.TailDecoration.AnyPartial[] = [];
855
+ tailDecorations.reverse().forEach(decoration => {
856
+ if (TreeDecoration.TailDecoration.isDotDecoration(decoration)) {
857
+ dotDecoration ||= decoration;
858
+ } else if (decoration.data || decoration.icon || decoration.iconClass) {
859
+ otherDecorations.push(decoration);
860
+ }
861
+ });
862
+ const decorationsToRender = dotDecoration ? [dotDecoration, ...otherDecorations] : otherDecorations;
863
+ return <React.Fragment>
864
+ {decorationsToRender.map((decoration, index) => {
865
+ const { tooltip, data, fontData, color, icon, iconClass } = decoration;
866
+ const iconToRender = icon ?? iconClass;
867
+ const className = [TREE_NODE_SEGMENT_CLASS, TREE_NODE_TAIL_CLASS, 'flex'].join(' ');
868
+ const style = fontData ? this.applyFontStyles({}, fontData) : color ? { color } : undefined;
869
+ const content = data ? data : iconToRender
870
+ ? <span
871
+ key={node.id + 'icon' + index}
872
+ className={this.getIconClass(iconToRender, iconToRender === 'circle' ? [TreeDecoration.Styles.DECORATOR_SIZE_CLASS] : [])}
873
+ ></span>
874
+ : '';
875
+ return <div key={node.id + className + index} className={className} style={style} title={tooltip}>
876
+ {content}{index !== decorationsToRender.length - 1 ? ',' : ''}
877
+ </div>;
878
+ })}
879
+ </React.Fragment>;
880
+ }
881
+
882
+ /**
883
+ * Determine the classes to use for an icon
884
+ * - Assumes a Font Awesome name when passed a single string, otherwise uses the passed string array
885
+ * @param iconName the icon name or list of icon names.
886
+ * @param additionalClasses additional CSS classes.
887
+ *
888
+ * @returns the icon class name.
889
+ */
890
+ protected getIconClass(iconName: string | string[], additionalClasses: string[] = []): string {
891
+ const iconClass = (typeof iconName === 'string') ? ['a', 'fa', `fa-${iconName}`] : ['a'].concat(iconName);
892
+ return iconClass.concat(additionalClasses).join(' ');
893
+ }
894
+
895
+ /**
896
+ * Render indent for the file tree based on the depth
897
+ * @param node the tree node.
898
+ * @param depth the depth of the tree node.
899
+ */
900
+ protected renderIndent(node: TreeNode, props: NodeProps): React.ReactNode {
901
+ const renderIndentGuides = this.corePreferences['workbench.tree.renderIndentGuides'];
902
+ if (renderIndentGuides === 'none') {
903
+ return undefined;
904
+ }
905
+
906
+ const indentDivs: React.ReactNode[] = [];
907
+ let current: TreeNode | undefined = node;
908
+ let depth = props.depth;
909
+ while (current && depth) {
910
+ if (this.shouldRenderIndent(current)) {
911
+ const classNames: string[] = [TREE_NODE_INDENT_GUIDE_CLASS];
912
+ if (this.needsActiveIndentGuideline(current)) {
913
+ classNames.push('active');
914
+ } else {
915
+ classNames.push(renderIndentGuides === 'onHover' ? 'hover' : 'always');
916
+ }
917
+ const paddingLeft = this.getDepthPadding(depth);
918
+ indentDivs.unshift(<div key={depth} className={classNames.join(' ')} style={{
919
+ paddingLeft: `${paddingLeft}px`
920
+ }} />);
921
+ depth--;
922
+ }
923
+ current = current.parent;
924
+ }
925
+ return indentDivs;
926
+ }
927
+
928
+ /**
929
+ * Determines whether an indentation div should be rendered for the specified tree node.
930
+ * If there are multiple tree nodes inside of a single rendered row,
931
+ * this method should only return true for the first node.
932
+ */
933
+ protected shouldRenderIndent(node: TreeNode): boolean {
934
+ return true;
935
+ }
936
+
937
+ protected needsActiveIndentGuideline(node: TreeNode): boolean {
938
+ const parent = node.parent;
939
+ if (!parent || !this.isExpandable(parent)) {
940
+ return false;
941
+ }
942
+ if (SelectableTreeNode.isSelected(parent)) {
943
+ return true;
944
+ }
945
+ if (parent.expanded) {
946
+ for (const sibling of parent.children) {
947
+ if (SelectableTreeNode.isSelected(sibling) && !(this.isExpandable(sibling) && sibling.expanded)) {
948
+ return true;
949
+ }
950
+ }
951
+ }
952
+ return false;
953
+ }
954
+
955
+ /**
956
+ * Render the node given the tree node and node properties.
957
+ * @param node the tree node.
958
+ * @param props the node properties.
959
+ */
960
+ protected renderNode(node: TreeNode, props: NodeProps): React.ReactNode {
961
+ if (!TreeNode.isVisible(node)) {
962
+ return undefined;
963
+ }
964
+ const attributes = this.createNodeAttributes(node, props);
965
+ const content = <div className={TREE_NODE_CONTENT_CLASS}>
966
+ {this.renderExpansionToggle(node, props)}
967
+ {this.renderCheckbox(node, props)}
968
+ {this.decorateIcon(node, this.renderIcon(node, props))}
969
+ {this.renderCaptionAffixes(node, props, 'captionPrefixes')}
970
+ {this.renderCaption(node, props)}
971
+ {this.renderCaptionAffixes(node, props, 'captionSuffixes')}
972
+ {this.renderTailDecorations(node, props)}
973
+ </div>;
974
+ return React.createElement('div', attributes, content);
975
+ }
976
+
977
+ /**
978
+ * Create node attributes for the tree node given the node properties.
979
+ * @param node the tree node.
980
+ * @param props the node properties.
981
+ */
982
+ protected createNodeAttributes(node: TreeNode, props: NodeProps): React.Attributes & React.HTMLAttributes<HTMLElement> {
983
+ const className = this.createNodeClassNames(node, props).join(' ');
984
+ const style = this.createNodeStyle(node, props);
985
+ return {
986
+ className,
987
+ style,
988
+ onClick: event => this.handleClickEvent(node, event),
989
+ onDoubleClick: event => this.handleDblClickEvent(node, event),
990
+ onAuxClick: event => this.handleAuxClickEvent(node, event),
991
+ onContextMenu: event => this.handleContextMenuEvent(node, event),
992
+ };
993
+ }
994
+
995
+ /**
996
+ * Create the node class names.
997
+ * @param node the tree node.
998
+ * @param props the node properties.
999
+ *
1000
+ * @returns the list of tree node class names.
1001
+ */
1002
+ protected createNodeClassNames(node: TreeNode, props: NodeProps): string[] {
1003
+ const classNames = [TREE_NODE_CLASS];
1004
+ if (CompositeTreeNode.is(node)) {
1005
+ classNames.push(COMPOSITE_TREE_NODE_CLASS);
1006
+ }
1007
+ if (this.isExpandable(node)) {
1008
+ classNames.push(EXPANDABLE_TREE_NODE_CLASS);
1009
+ }
1010
+ if (this.rowIsSelected(node, props)) {
1011
+ classNames.push(SELECTED_CLASS);
1012
+ }
1013
+ if (this.focusService.hasFocus(node)) {
1014
+ classNames.push(FOCUS_CLASS);
1015
+ }
1016
+ return classNames;
1017
+ }
1018
+
1019
+ protected rowIsSelected(node: TreeNode, props: NodeProps): boolean {
1020
+ return SelectableTreeNode.isSelected(node);
1021
+ }
1022
+
1023
+ /**
1024
+ * Get the default node style.
1025
+ * @param node the tree node.
1026
+ * @param props the node properties.
1027
+ *
1028
+ * @returns the CSS properties if available.
1029
+ */
1030
+ protected getDefaultNodeStyle(node: TreeNode, props: NodeProps): React.CSSProperties | undefined {
1031
+ const paddingLeft = this.getPaddingLeft(node, props) + 'px';
1032
+ return { paddingLeft };
1033
+ }
1034
+
1035
+ protected getPaddingLeft(node: TreeNode, props: NodeProps): number {
1036
+ return this.getDepthPadding(props.depth) + (this.needsExpansionTogglePadding(node) ? this.props.expansionTogglePadding : 0);
1037
+ }
1038
+
1039
+ /**
1040
+ * If the node is a composite, a toggle will be rendered.
1041
+ * Otherwise we need to add the width and the left, right padding => 18px
1042
+ */
1043
+ protected needsExpansionTogglePadding(node: TreeNode): boolean {
1044
+ return !this.isExpandable(node);
1045
+ }
1046
+
1047
+ /**
1048
+ * Create the tree node style.
1049
+ * @param node the tree node.
1050
+ * @param props the node properties.
1051
+ */
1052
+ protected createNodeStyle(node: TreeNode, props: NodeProps): React.CSSProperties | undefined {
1053
+ return this.decorateNodeStyle(node, this.getDefaultNodeStyle(node, props));
1054
+ }
1055
+
1056
+ /**
1057
+ * Decorate the node style.
1058
+ * @param node the tree node.
1059
+ * @param style the optional CSS properties.
1060
+ *
1061
+ * @returns the CSS styles if available.
1062
+ */
1063
+ protected decorateNodeStyle(node: TreeNode, style: React.CSSProperties | undefined): React.CSSProperties | undefined {
1064
+ const backgroundColor = this.getDecorationData(node, 'backgroundColor').filter(notEmpty).shift();
1065
+ if (backgroundColor) {
1066
+ style = {
1067
+ ...(style || {}),
1068
+ backgroundColor
1069
+ };
1070
+ }
1071
+ return style;
1072
+ }
1073
+
1074
+ /**
1075
+ * Determine if the tree node is expandable.
1076
+ * @param node the tree node.
1077
+ *
1078
+ * @returns `true` if the tree node is expandable.
1079
+ */
1080
+ protected isExpandable(node: TreeNode): node is ExpandableTreeNode {
1081
+ return ExpandableTreeNode.is(node);
1082
+ }
1083
+
1084
+ /**
1085
+ * Get the tree node decorations.
1086
+ * @param node the tree node.
1087
+ *
1088
+ * @returns the list of tree decoration data.
1089
+ */
1090
+ protected getDecorations(node: TreeNode): TreeDecoration.Data[] {
1091
+ const decorations: TreeDecoration.Data[] = [];
1092
+ if (DecoratedTreeNode.is(node)) {
1093
+ decorations.push(node.decorationData);
1094
+ }
1095
+ if (this.decorations.has(node.id)) {
1096
+ decorations.push(...this.decorations.get(node.id)!);
1097
+ }
1098
+ return decorations.sort(TreeDecoration.Data.comparePriority);
1099
+ }
1100
+
1101
+ /**
1102
+ * Get the tree decoration data for the given key.
1103
+ * @param node the tree node.
1104
+ * @param key the tree decoration data key.
1105
+ *
1106
+ * @returns the tree decoration data at the given key.
1107
+ */
1108
+ protected getDecorationData<K extends keyof TreeDecoration.Data>(node: TreeNode, key: K): Required<Pick<TreeDecoration.Data, K>>[K][] {
1109
+ return this.getDecorations(node).filter(data => data[key] !== undefined).map(data => data[key]);
1110
+ }
1111
+
1112
+ /**
1113
+ * Store the last scroll state.
1114
+ */
1115
+ protected lastScrollState: {
1116
+ /**
1117
+ * The scroll top value.
1118
+ */
1119
+ scrollTop: number,
1120
+ /**
1121
+ * The scroll left value.
1122
+ */
1123
+ scrollLeft: number
1124
+ } | undefined;
1125
+
1126
+ /**
1127
+ * Get the scroll container.
1128
+ */
1129
+ protected override getScrollContainer(): MaybePromise<HTMLElement> {
1130
+ this.toDisposeOnDetach.push(Disposable.create(() => {
1131
+ const { scrollTop, scrollLeft } = this.node;
1132
+ this.lastScrollState = { scrollTop, scrollLeft };
1133
+ }));
1134
+ if (this.lastScrollState) {
1135
+ const { scrollTop, scrollLeft } = this.lastScrollState;
1136
+ this.node.scrollTop = scrollTop;
1137
+ this.node.scrollLeft = scrollLeft;
1138
+ }
1139
+ return this.node;
1140
+ }
1141
+
1142
+ protected override onAfterAttach(msg: Message): void {
1143
+ const up = [
1144
+ Key.ARROW_UP,
1145
+ KeyCode.createKeyCode({ first: Key.ARROW_UP, modifiers: [KeyModifier.Shift] })
1146
+ ];
1147
+ const down = [
1148
+ Key.ARROW_DOWN,
1149
+ KeyCode.createKeyCode({ first: Key.ARROW_DOWN, modifiers: [KeyModifier.Shift] })
1150
+ ];
1151
+ if (this.props.search) {
1152
+ if (this.searchBox.isAttached) {
1153
+ Widget.detach(this.searchBox);
1154
+ }
1155
+ UnsafeWidgetUtilities.attach(this.searchBox, this.node.parentElement!);
1156
+ this.addKeyListener(this.node, this.searchBox.keyCodePredicate.bind(this.searchBox), this.searchBox.handle.bind(this.searchBox));
1157
+ this.toDisposeOnDetach.push(Disposable.create(() => {
1158
+ Widget.detach(this.searchBox);
1159
+ }));
1160
+ }
1161
+ super.onAfterAttach(msg);
1162
+ this.addKeyListener(this.node, Key.ARROW_LEFT, event => this.handleLeft(event));
1163
+ this.addKeyListener(this.node, Key.ARROW_RIGHT, event => this.handleRight(event));
1164
+ this.addKeyListener(this.node, up, event => this.handleUp(event));
1165
+ this.addKeyListener(this.node, down, event => this.handleDown(event));
1166
+ this.addKeyListener(this.node, Key.ENTER, event => this.handleEnter(event));
1167
+ this.addKeyListener(this.node, Key.SPACE, event => this.handleSpace(event));
1168
+ this.addKeyListener(this.node, Key.ESCAPE, event => this.handleEscape(event));
1169
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
1170
+ this.addEventListener<any>(this.node, 'ps-scroll-y', (e: Event & { target: { scrollTop: number } }) => {
1171
+ if (this.view && this.view.list) {
1172
+ const { scrollTop } = e.target;
1173
+ this.view.list.scrollTo({
1174
+ top: scrollTop
1175
+ });
1176
+ }
1177
+ });
1178
+ }
1179
+
1180
+ /**
1181
+ * Handle the `left arrow` keyboard event.
1182
+ * @param event the `left arrow` keyboard event.
1183
+ */
1184
+ protected async handleLeft(event: KeyboardEvent): Promise<void> {
1185
+ if (!!this.props.multiSelect && (this.hasCtrlCmdMask(event) || this.hasShiftMask(event))) {
1186
+ return;
1187
+ }
1188
+ if (!await this.model.collapseNode()) {
1189
+ this.model.selectParent();
1190
+ }
1191
+ }
1192
+
1193
+ /**
1194
+ * Handle the `right arrow` keyboard event.
1195
+ * @param event the `right arrow` keyboard event.
1196
+ */
1197
+ protected async handleRight(event: KeyboardEvent): Promise<void> {
1198
+ if (!!this.props.multiSelect && (this.hasCtrlCmdMask(event) || this.hasShiftMask(event))) {
1199
+ return;
1200
+ }
1201
+ if (!await this.model.expandNode()) {
1202
+ this.model.selectNextNode();
1203
+ }
1204
+ }
1205
+
1206
+ /**
1207
+ * Handle the `up arrow` keyboard event.
1208
+ * @param event the `up arrow` keyboard event.
1209
+ */
1210
+ protected handleUp(event: KeyboardEvent): void {
1211
+ if (!!this.props.multiSelect && this.hasShiftMask(event)) {
1212
+ this.model.selectPrevNode(TreeSelection.SelectionType.RANGE);
1213
+ } else {
1214
+ this.model.selectPrevNode();
1215
+ }
1216
+ this.node.focus();
1217
+ }
1218
+
1219
+ /**
1220
+ * Handle the `down arrow` keyboard event.
1221
+ * @param event the `down arrow` keyboard event.
1222
+ */
1223
+ protected handleDown(event: KeyboardEvent): void {
1224
+ if (!!this.props.multiSelect && this.hasShiftMask(event)) {
1225
+ this.model.selectNextNode(TreeSelection.SelectionType.RANGE);
1226
+ } else {
1227
+ this.model.selectNextNode();
1228
+ }
1229
+ this.node.focus();
1230
+ }
1231
+
1232
+ /**
1233
+ * Handle the `enter key` keyboard event.
1234
+ * - `enter` opens the tree node.
1235
+ * @param event the `enter key` keyboard event.
1236
+ */
1237
+ protected handleEnter(event: KeyboardEvent): void {
1238
+ this.model.openNode();
1239
+ }
1240
+
1241
+ /**
1242
+ * Handle the `space key` keyboard event.
1243
+ * - If the element has a checkbox, it will be toggled.
1244
+ * - Otherwise, it should be similar to a single-click action.
1245
+ * @param event the `space key` keyboard event.
1246
+ */
1247
+ protected handleSpace(event: KeyboardEvent): void {
1248
+ const { focusedNode } = this.focusService;
1249
+ if (focusedNode && focusedNode.checkboxInfo) {
1250
+ this.model.markAsChecked(focusedNode, !focusedNode.checkboxInfo.checked);
1251
+ } else if (!this.props.multiSelect || (!event.ctrlKey && !event.metaKey && !event.shiftKey)) {
1252
+ this.tapNode(focusedNode);
1253
+ }
1254
+ }
1255
+
1256
+ protected handleEscape(event: KeyboardEvent): void {
1257
+ if (this.model.selectedNodes.length <= 1) {
1258
+ this.focusService.setFocus(undefined);
1259
+ this.node.focus();
1260
+ }
1261
+ this.model.clearSelection();
1262
+ }
1263
+
1264
+ /**
1265
+ * Handle the single-click mouse event.
1266
+ * @param node the tree node if available.
1267
+ * @param event the mouse single-click event.
1268
+ */
1269
+ protected handleClickEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement>): void {
1270
+ if (node) {
1271
+ event.stopPropagation();
1272
+ const shiftMask = this.hasShiftMask(event);
1273
+ const ctrlCmdMask = this.hasCtrlCmdMask(event);
1274
+ if (this.props.multiSelect && (shiftMask || ctrlCmdMask) && SelectableTreeNode.is(node)) {
1275
+ if (shiftMask) {
1276
+ this.model.selectRange(node);
1277
+ } else if (ctrlCmdMask) {
1278
+ this.model.toggleNode(node);
1279
+ }
1280
+ } else {
1281
+ this.tapNode(node);
1282
+ }
1283
+ }
1284
+ }
1285
+
1286
+ /**
1287
+ * The effective handler of an unmodified single-click event.
1288
+ */
1289
+ protected tapNode(node?: TreeNode): void {
1290
+ if (SelectableTreeNode.is(node)) {
1291
+ this.model.selectNode(node);
1292
+ }
1293
+ if (node && !this.props.expandOnlyOnExpansionToggleClick && this.isExpandable(node)) {
1294
+ this.model.toggleNodeExpansion(node);
1295
+ }
1296
+ }
1297
+
1298
+ /**
1299
+ * Handle the double-click mouse event.
1300
+ * @param node the tree node if available.
1301
+ * @param event the double-click mouse event.
1302
+ */
1303
+ protected handleDblClickEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement>): void {
1304
+ this.model.openNode(node);
1305
+ event.stopPropagation();
1306
+ }
1307
+
1308
+ /**
1309
+ * Handle the middle-click mouse event.
1310
+ * @param node the tree node if available.
1311
+ * @param event the middle-click mouse event.
1312
+ */
1313
+ protected handleAuxClickEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement>): void {
1314
+ if (event.button === 1) {
1315
+ this.model.openNode(node);
1316
+ if (SelectableTreeNode.is(node)) {
1317
+ this.model.selectNode(node);
1318
+ }
1319
+ }
1320
+ event.stopPropagation();
1321
+ }
1322
+
1323
+ /**
1324
+ * Handle the middle-click mouse event.
1325
+ * @param event the middle-click mouse event.
1326
+ */
1327
+ protected handleMiddleClickEvent(event: MouseEvent): void {
1328
+ // Prevents auto-scrolling behavior when middle-clicking.
1329
+ if (event.button === 1) {
1330
+ event.preventDefault();
1331
+ }
1332
+ }
1333
+
1334
+ /**
1335
+ * Handle the context menu click event.
1336
+ * - The context menu click event is triggered by the right-click.
1337
+ * @param node the tree node if available.
1338
+ * @param event the right-click mouse event.
1339
+ */
1340
+ protected handleContextMenuEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement>): void {
1341
+ if (SelectableTreeNode.is(node)) {
1342
+ // Keep the selection for the context menu, if the widget support multi-selection and the right click happens on an already selected node.
1343
+ if (!this.props.multiSelect || !node.selected) {
1344
+ const type = !!this.props.multiSelect && this.hasCtrlCmdMask(event) ? TreeSelection.SelectionType.TOGGLE : TreeSelection.SelectionType.DEFAULT;
1345
+ this.model.addSelection({ node, type });
1346
+ }
1347
+ this.focusService.setFocus(node);
1348
+ const contextMenuPath = this.props.contextMenuPath;
1349
+ if (contextMenuPath) {
1350
+ const { x, y } = event.nativeEvent;
1351
+ const args = this.toContextMenuArgs(node);
1352
+ setTimeout(() => this.contextMenuRenderer.render({
1353
+ menuPath: contextMenuPath,
1354
+ anchor: { x, y },
1355
+ args
1356
+ }), 10);
1357
+ }
1358
+ }
1359
+ event.stopPropagation();
1360
+ event.preventDefault();
1361
+ }
1362
+
1363
+ /**
1364
+ * Handle the double-click mouse event on the expansion toggle.
1365
+ */
1366
+ protected readonly handleExpansionToggleDblClickEvent = (event: React.MouseEvent<HTMLElement>) => this.doHandleExpansionToggleDblClickEvent(event);
1367
+ /**
1368
+ * Actually handle the double-click mouse event on the expansion toggle.
1369
+ * @param event the double-click mouse event.
1370
+ */
1371
+ protected doHandleExpansionToggleDblClickEvent(event: React.MouseEvent<HTMLElement>): void {
1372
+ if (this.props.expandOnlyOnExpansionToggleClick) {
1373
+ // Ignore the double-click event.
1374
+ event.stopPropagation();
1375
+ }
1376
+ }
1377
+
1378
+ /**
1379
+ * Convert the tree node to context menu arguments.
1380
+ * @param node the selectable tree node.
1381
+ */
1382
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
1383
+ protected toContextMenuArgs(node: SelectableTreeNode): any[] | undefined {
1384
+ return undefined;
1385
+ }
1386
+
1387
+ /**
1388
+ * Determine if the tree modifier aware event has a `ctrlcmd` mask.
1389
+ * @param event the tree modifier aware event.
1390
+ *
1391
+ * @returns `true` if the tree modifier aware event contains the `ctrlcmd` mask.
1392
+ */
1393
+ protected hasCtrlCmdMask(event: TreeWidget.ModifierAwareEvent): boolean {
1394
+ return isOSX ? event.metaKey : event.ctrlKey;
1395
+ }
1396
+
1397
+ /**
1398
+ * Determine if the tree modifier aware event has a `shift` mask.
1399
+ * @param event the tree modifier aware event.
1400
+ *
1401
+ * @returns `true` if the tree modifier aware event contains the `shift` mask.
1402
+ */
1403
+ protected hasShiftMask(event: TreeWidget.ModifierAwareEvent): boolean {
1404
+ // Ctrl/Cmd mask overrules the Shift mask.
1405
+ if (this.hasCtrlCmdMask(event)) {
1406
+ return false;
1407
+ }
1408
+ return event.shiftKey;
1409
+ }
1410
+
1411
+ /**
1412
+ * Deflate the tree node for storage.
1413
+ * @param node the tree node.
1414
+ */
1415
+ protected deflateForStorage(node: TreeNode): object {
1416
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
1417
+ const copy = Object.assign({}, node) as any;
1418
+ if (copy.parent) {
1419
+ delete copy.parent;
1420
+ }
1421
+ if ('previousSibling' in copy) {
1422
+ delete copy.previousSibling;
1423
+ }
1424
+ if ('nextSibling' in copy) {
1425
+ delete copy.nextSibling;
1426
+ }
1427
+ if ('busy' in copy) {
1428
+ delete copy.busy;
1429
+ }
1430
+ if (CompositeTreeNode.is(node)) {
1431
+ copy.children = [];
1432
+ for (const child of node.children) {
1433
+ copy.children.push(this.deflateForStorage(child));
1434
+ }
1435
+ }
1436
+ return copy;
1437
+ }
1438
+
1439
+ /**
1440
+ * Inflate the tree node from storage.
1441
+ * @param node the tree node.
1442
+ * @param parent the optional tree node.
1443
+ */
1444
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
1445
+ protected inflateFromStorage(node: any, parent?: TreeNode): TreeNode {
1446
+ if (node.selected) {
1447
+ node.selected = false;
1448
+ }
1449
+ if (parent) {
1450
+ node.parent = parent;
1451
+ }
1452
+ if (Array.isArray(node.children)) {
1453
+ for (const child of node.children as TreeNode[]) {
1454
+ this.inflateFromStorage(child, node);
1455
+ }
1456
+ }
1457
+ return node;
1458
+ }
1459
+
1460
+ /**
1461
+ * Store the tree state.
1462
+ */
1463
+ storeState(): object {
1464
+ const decorations = this.decoratorService.deflateDecorators(this.decorations);
1465
+ let state: object = {
1466
+ decorations
1467
+ };
1468
+ if (this.model.root) {
1469
+ state = {
1470
+ ...state,
1471
+ root: this.deflateForStorage(this.model.root),
1472
+ model: this.model.storeState(),
1473
+ focusedNodeId: this.focusService.focusedNode?.id
1474
+ };
1475
+ }
1476
+
1477
+ return state;
1478
+ }
1479
+
1480
+ /**
1481
+ * Restore the state.
1482
+ * @param oldState the old state object.
1483
+ */
1484
+ restoreState(oldState: object): void {
1485
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
1486
+ const { root, decorations, model, focusedNodeId } = (oldState as any);
1487
+ if (root) {
1488
+ this.model.root = this.inflateFromStorage(root);
1489
+ }
1490
+ if (decorations) {
1491
+ this.decorations = this.decoratorService.inflateDecorators(decorations);
1492
+ }
1493
+ if (model) {
1494
+ this.model.restoreState(model);
1495
+ }
1496
+ if (focusedNodeId) {
1497
+ const candidate = this.model.getNode(focusedNodeId);
1498
+ if (SelectableTreeNode.is(candidate)) {
1499
+ this.focusService.setFocus(candidate);
1500
+ }
1501
+ }
1502
+ }
1503
+
1504
+ protected toNodeIcon(node: TreeNode): string {
1505
+ return this.labelProvider.getIcon(node);
1506
+ }
1507
+
1508
+ protected toNodeName(node: TreeNode): string {
1509
+ return this.labelProvider.getName(node);
1510
+ }
1511
+
1512
+ protected toNodeDescription(node: TreeNode): string {
1513
+ return this.labelProvider.getLongName(node);
1514
+ }
1515
+ protected getDepthPadding(depth: number): number {
1516
+ if (depth === 1) {
1517
+ return this.props.leftPadding;
1518
+ }
1519
+ return depth * this.treeIndent;
1520
+ }
1521
+ }
1522
+ export namespace TreeWidget {
1523
+ /**
1524
+ * Representation of a tree node row.
1525
+ */
1526
+ export interface NodeRow {
1527
+ /**
1528
+ * The node row index.
1529
+ */
1530
+ index: number
1531
+ /**
1532
+ * The actual node.
1533
+ */
1534
+ node: TreeNode
1535
+ /**
1536
+ * A root relative number representing the hierarchical depth of the actual node. Root is `0`, its children have `1` and so on.
1537
+ */
1538
+ depth: number
1539
+ }
1540
+ /**
1541
+ * Representation of the tree view properties.
1542
+ */
1543
+ export interface ViewProps {
1544
+ /**
1545
+ * The width property.
1546
+ */
1547
+ width: number
1548
+ /**
1549
+ * The height property.
1550
+ */
1551
+ height: number
1552
+ /**
1553
+ * The scroll to row value.
1554
+ */
1555
+ scrollToRow?: number
1556
+ /**
1557
+ * The list of node rows.
1558
+ */
1559
+ rows: NodeRow[]
1560
+ renderNodeRow: (row: NodeRow) => React.ReactNode
1561
+ }
1562
+ export class View extends React.Component<ViewProps> {
1563
+ list: VirtuosoHandle | undefined;
1564
+ override render(): React.ReactNode {
1565
+ const { rows, width, height, scrollToRow } = this.props;
1566
+ return <Virtuoso
1567
+ ref={list => {
1568
+ this.list = (list || undefined);
1569
+ if (this.list && scrollToRow !== undefined) {
1570
+ this.list.scrollIntoView({
1571
+ index: scrollToRow,
1572
+ align: 'center'
1573
+ });
1574
+ }
1575
+ }}
1576
+ totalCount={rows.length}
1577
+ itemContent={index => this.props.renderNodeRow(rows[index])}
1578
+ width={width}
1579
+ height={height}
1580
+ // This is a pixel value, it will scan 200px to the top and bottom of the current view
1581
+ overscan={500}
1582
+ />;
1583
+ }
1584
+ }
1585
+ }