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